budibase/packages/client/src/createApp.js

67 lines
1.5 KiB
JavaScript

import {
split,
last
} from "lodash/fp";
import {writable} from "svelte/store";
import { $ } from "./core/common";
import {
setupBinding
} from "./state/stateBinding";
import { createCoreApi } from "./core";
import { getStateOrValue } from "./state/getState";
export const createApp = (componentLibraries, appDefinition, user) => {
const initialiseComponent = (props, htmlElement) => {
const {componentName, libName} = splitName(props._component);
if(!componentName || !libName) return;
const {initialProps, bind} = setupBinding(store, props, coreApi);
const component = new (componentLibraries[libName][componentName])({
target: htmlElement,
props: {...initialProps, _bb},
hydrate:true
});
bind(component);
}
const coreApi = createCoreApi(appDefinition, user);
const store = writable({
_bbuser: user
});
let globalState = null;
store.subscribe(s => {
globalState = s;
});
const _bb = {
initialiseComponent,
store,
getStateOrValue: (prop, currentContext) =>
getStateOrValue(globalState, prop, currentContext)
};
return _bb;
}
const splitName = fullname => {
const componentName = $(fullname, [
split("/"),
last
]);
const libName =fullname.substring(
0, fullname.length - componentName.length - 1);
return {libName, componentName};
}