From 911fa31fe3a54cc028c4e92b3607b2b6b3f7ae05 Mon Sep 17 00:00:00 2001 From: Andrew Kingston Date: Fri, 20 Nov 2020 10:49:39 +0000 Subject: [PATCH 1/3] Tidy up data binding --- .../builderStore/fetchBindableProperties.js | 43 ++++--------------- .../src/builderStore/replaceBindings.js | 5 +-- .../AppPreview/iframeTemplate.js | 2 +- .../client/src/components/Component.svelte | 5 +-- .../client/src/components/DataProvider.svelte | 3 +- packages/client/src/store/dataContext.js | 12 ++---- 6 files changed, 19 insertions(+), 51 deletions(-) diff --git a/packages/builder/src/builderStore/fetchBindableProperties.js b/packages/builder/src/builderStore/fetchBindableProperties.js index 9a193112fb..962fb80ebf 100644 --- a/packages/builder/src/builderStore/fetchBindableProperties.js +++ b/packages/builder/src/builderStore/fetchBindableProperties.js @@ -24,7 +24,7 @@ import { cloneDeep, difference } from "lodash/fp" * @returns {Array.} */ export default function({ componentInstanceId, screen, components, tables }) { - const walkResult = walk({ + const result = walk({ // cloning so we are free to mutate props (e.g. by adding _contexts) instance: cloneDeep(screen.props), targetId: componentInstanceId, @@ -33,13 +33,10 @@ export default function({ componentInstanceId, screen, components, tables }) { }) return [ - ...walkResult.bindableInstances - .filter(isInstanceInSharedContext(walkResult)) - .map(componentInstanceToBindable(walkResult)), - - ...(walkResult.target?._contexts - .map(contextToBindables(tables, walkResult)) - .flat() ?? []), + ...result.bindableInstances + .filter(isInstanceInSharedContext(result)) + .map(componentInstanceToBindable), + ...(result.target?._contexts.map(contextToBindables(tables)).flat() ?? []), ] } @@ -53,26 +50,18 @@ const isInstanceInSharedContext = walkResult => i => // turns a component instance prop into binding expressions // used by the UI -const componentInstanceToBindable = walkResult => i => { - const lastContext = - i.instance._contexts.length && - i.instance._contexts[i.instance._contexts.length - 1] - const contextParentPath = lastContext - ? getParentPath(walkResult, lastContext) - : "" - +const componentInstanceToBindable = i => { return { type: "instance", instance: i.instance, // how the binding expression persists, and is used in the app at runtime - runtimeBinding: `${contextParentPath}${i.instance._id}.${i.prop}`, + runtimeBinding: `${i.instance._id}`, // how the binding exressions looks to the user of the builder readableBinding: `${i.instance._instanceName}`, } } -const contextToBindables = (tables, walkResult) => context => { - const contextParentPath = getParentPath(walkResult, context) +const contextToBindables = tables => context => { const tableId = context.table?.tableId ?? context.table const table = tables.find(table => table._id === tableId) let schema = @@ -98,7 +87,7 @@ const contextToBindables = (tables, walkResult) => context => { fieldSchema, instance: context.instance, // how the binding expression persists, and is used in the app at runtime - runtimeBinding: `${contextParentPath}data.${runtimeBoundKey}`, + runtimeBinding: `${context.instance._id}.${runtimeBoundKey}`, // how the binding expressions looks to the user of the builder readableBinding: `${context.instance._instanceName}.${table.name}.${key}`, // table / view info @@ -118,20 +107,6 @@ const contextToBindables = (tables, walkResult) => context => { ) } -const getParentPath = (walkResult, context) => { - // describes the number of "parent" in the path - // clone array first so original array is not mtated - const contextParentNumber = [...walkResult.target._contexts] - .reverse() - .indexOf(context) - - return ( - new Array(contextParentNumber).fill("parent").join(".") + - // trailing . if has parents - (contextParentNumber ? "." : "") - ) -} - const walk = ({ instance, targetId, components, tables, result }) => { if (!result) { result = { diff --git a/packages/builder/src/builderStore/replaceBindings.js b/packages/builder/src/builderStore/replaceBindings.js index aa57301261..0bf9f485c9 100644 --- a/packages/builder/src/builderStore/replaceBindings.js +++ b/packages/builder/src/builderStore/replaceBindings.js @@ -12,10 +12,7 @@ export function readableToRuntimeBinding(bindableProperties, textWithBindings) { return boundValue === `{{ ${readableBinding} }}` }) if (binding) { - result = textWithBindings.replace( - boundValue, - `{{ ${binding.runtimeBinding} }}` - ) + result = result.replace(boundValue, `{{ ${binding.runtimeBinding} }}`) } }) return result diff --git a/packages/builder/src/components/userInterface/AppPreview/iframeTemplate.js b/packages/builder/src/components/userInterface/AppPreview/iframeTemplate.js index 745ae7c89b..a2e7d1ee8b 100644 --- a/packages/builder/src/components/userInterface/AppPreview/iframeTemplate.js +++ b/packages/builder/src/components/userInterface/AppPreview/iframeTemplate.js @@ -46,7 +46,7 @@ export default ` selectedComponentStyle = document.createElement('style'); document.head.appendChild(selectedComponentStyle) - var selectedCss = '[data-bb-id="' + data.selectedComponentType + '-' + data.selectedComponentId + '"]' + '{border:2px solid #0055ff !important;}' + var selectedCss = '[data-bb-id="' + data.selectedComponentId + '"]' + '{border:2px solid #0055ff !important;}' selectedComponentStyle.appendChild(document.createTextNode(selectedCss)) styles = document.createElement('style') diff --git a/packages/client/src/components/Component.svelte b/packages/client/src/components/Component.svelte index 273d217df3..62d9f5ef94 100644 --- a/packages/client/src/components/Component.svelte +++ b/packages/client/src/components/Component.svelte @@ -30,14 +30,13 @@ // Extract component definition info const componentName = extractComponentName(definition._component) const constructor = getComponentConstructor(componentName) - const id = `${componentName}-${definition._id}` const componentProps = extractValidProps(definition) const dataContext = getContext("data") const enrichedProps = dataContext.actions.enrichDataBindings(componentProps) const children = definition._children - // Set style context to be consumed by component - setContext("style", { ...definition._styles, id }) + // Set contexts to be consumed by component + setContext("style", { ...definition._styles, id: definition._id }) $: console.log("Rendering: " + componentName) diff --git a/packages/client/src/components/DataProvider.svelte b/packages/client/src/components/DataProvider.svelte index 30c1b4aec6..48465599f2 100644 --- a/packages/client/src/components/DataProvider.svelte +++ b/packages/client/src/components/DataProvider.svelte @@ -6,6 +6,7 @@ // Get current contexts const dataContext = getContext("data") + const { id } = getContext("style") // Clone current context to this context const newDataContext = createDataContextStore($dataContext) @@ -14,7 +15,7 @@ // Add additional layer to context let loaded = false onMount(() => { - newDataContext.actions.addContext(row) + newDataContext.actions.addContext(row, id) loaded = true }) diff --git a/packages/client/src/store/dataContext.js b/packages/client/src/store/dataContext.js index 959731d207..90acc42664 100644 --- a/packages/client/src/store/dataContext.js +++ b/packages/client/src/store/dataContext.js @@ -3,7 +3,6 @@ import { enrichDataBinding } from "../utils" import { cloneDeep } from "lodash/fp" const initialValue = { - parent: null, data: null, } @@ -12,15 +11,12 @@ export const createDataContextStore = existingContext => { const store = writable(initial) // Adds a context layer to the data context tree - const addContext = row => { + const addContext = (row, componentId) => { store.update(state => { - if (state.data) { - state.parent = { - parent: state.parent, - data: state.data, - } + if (row && componentId) { + state[componentId] = row + state.data = row } - state.data = row return state }) } From 192959c8651ecdce7784ba7c8158f7b5f9db21c6 Mon Sep 17 00:00:00 2001 From: Andrew Kingston Date: Mon, 23 Nov 2020 11:29:24 +0000 Subject: [PATCH 2/3] Fix builder preview --- .../AppPreview/CurrentItemPreview.svelte | 102 +++++------------- .../AppPreview/iframeTemplate.js | 59 +++++----- .../client/src/components/Component.svelte | 1 - packages/client/src/components/Screen.svelte | 2 +- packages/client/src/store/screens.js | 19 +++- .../client/src/utils/enrichDataBinding.js | 3 - packages/standard-components/components.json | 34 +----- .../standard-components/src/RowDetail.svelte | 1 - .../src/charts/LineChart.svelte | 2 +- 9 files changed, 75 insertions(+), 148 deletions(-) diff --git a/packages/builder/src/components/userInterface/AppPreview/CurrentItemPreview.svelte b/packages/builder/src/components/userInterface/AppPreview/CurrentItemPreview.svelte index 45a25bd71f..c9fe02e786 100644 --- a/packages/builder/src/components/userInterface/AppPreview/CurrentItemPreview.svelte +++ b/packages/builder/src/components/userInterface/AppPreview/CurrentItemPreview.svelte @@ -1,28 +1,13 @@
- {#if hasComponent && $store.currentPreviewItem} + {#if $store.currentPreviewItem}