budibase/packages/client/src/index.js

60 lines
1.6 KiB
JavaScript
Raw Normal View History

import { createApp } from "./createApp"
import { builtins, builtinLibName } from "./render/builtinComponents"
2020-11-12 10:31:04 +01:00
import { getAppId } from "../../component-sdk/src/utils"
2019-09-07 07:50:35 +02:00
2020-02-20 21:19:24 +01:00
/**
* create a web application from static budibase definition files.
* @param {object} opts - configuration options for budibase client libary
*/
2020-02-25 16:21:23 +01:00
export const loadBudibase = async opts => {
const _window = (opts && opts.window) || window
2020-05-07 11:53:34 +02:00
// const _localStorage = (opts && opts.localStorage) || localStorage
const appId = getAppId(window.document.cookie)
const frontendDefinition = _window["##BUDIBASE_FRONTEND_DEFINITION##"]
2020-02-25 16:21:23 +01:00
2020-05-07 11:53:34 +02:00
const user = {}
2020-05-18 12:01:09 +02:00
const componentLibraryModules = (opts && opts.componentLibraries) || {}
2020-05-07 23:25:27 +02:00
const libraries = frontendDefinition.libraries || []
2020-05-07 11:53:34 +02:00
2020-05-06 13:17:15 +02:00
for (let library of libraries) {
2020-05-07 11:53:34 +02:00
// fetch the JavaScript for the component libraries from the server
2020-07-06 20:43:40 +02:00
componentLibraryModules[library] = await import(
`/componentlibrary?library=${encodeURI(library)}&appId=${appId}`
2020-07-06 20:43:40 +02:00
)
2020-05-07 11:53:34 +02:00
}
2020-05-06 13:17:15 +02:00
componentLibraryModules[builtinLibName] = builtins(_window)
2020-02-25 17:23:45 +01:00
const {
initialisePage,
screenStore,
pageStore,
routeTo,
rootNode,
2020-05-29 15:06:10 +02:00
} = createApp({
componentLibraries: componentLibraryModules,
frontendDefinition,
user,
2020-06-14 21:30:23 +02:00
window: _window,
2020-05-29 15:06:10 +02:00
})
2020-02-25 16:21:23 +01:00
const route = _window.location
? _window.location.pathname.replace(`${appId}/`, "").replace(appId, "")
2020-02-25 16:21:23 +01:00
: ""
2020-02-25 17:23:45 +01:00
initialisePage(frontendDefinition.page, _window.document.body, route)
return {
screenStore,
pageStore,
routeTo,
2020-02-25 17:23:45 +01:00
rootNode,
}
}
if (window) {
window.loadBudibase = loadBudibase
}