/** * Fetches the definitions for component library components. This includes * their props and other metadata from components.json. * @param {string} clientId - ID of the current client * @param {string} appId - ID of the currently running app */ export const fetchComponentLibDefinitions = async (clientId, appId) => { const LIB_DEFINITION_URL = `/${clientId}/${appId}/components/definitions` try { const libDefinitionResponse = await fetch(LIB_DEFINITION_URL) return await libDefinitionResponse.json() } catch (err) { console.error(`Error fetching component definitions for ${appId}`, err) } } /** * Loads the JavaScript files for app component libraries and returns a map of their modules. * @param {object} application - package definition */ export const fetchComponentLibModules = async application => { const allLibraries = {} for (let libraryName of application.componentLibraries) { const LIBRARY_URL = `/${application._id}/componentlibrary?library=${libraryName}` const libraryModule = await import(LIBRARY_URL) allLibraries[libraryName] = libraryModule } return allLibraries }