From ad5fc0e7802faa88bf37684020159c4fd30c0bd3 Mon Sep 17 00:00:00 2001 From: Andrew Kingston Date: Tue, 24 Nov 2020 11:28:31 +0000 Subject: [PATCH] Simplify data contexts --- packages/client/src/api/datasources.js | 4 ++-- packages/client/src/components/Component.svelte | 12 ++++++------ packages/standard-components/src/Form.svelte | 7 +++---- packages/standard-components/src/List.svelte | 3 +-- .../standard-components/src/charts/BarChart.svelte | 4 ++-- .../src/charts/CandleStickChart.svelte | 4 ++-- .../standard-components/src/charts/LineChart.svelte | 4 ++-- .../standard-components/src/charts/PieChart.svelte | 4 ++-- .../standard-components/src/grid/Component.svelte | 3 +-- 9 files changed, 21 insertions(+), 24 deletions(-) diff --git a/packages/client/src/api/datasources.js b/packages/client/src/api/datasources.js index f97618b4a9..e422d34983 100644 --- a/packages/client/src/api/datasources.js +++ b/packages/client/src/api/datasources.js @@ -20,8 +20,8 @@ export const fetchDatasource = async (datasource, dataContext) => { rows = await fetchViewData(datasource) } else if (type === "link") { rows = await fetchRelationshipData({ - rowId: dataContext?.data?._id, - tableId: dataContext?.data?.tableId, + rowId: dataContext?._id, + tableId: dataContext?.tableId, fieldName, }) } diff --git a/packages/client/src/components/Component.svelte b/packages/client/src/components/Component.svelte index f003033f08..ebda18a2ab 100644 --- a/packages/client/src/components/Component.svelte +++ b/packages/client/src/components/Component.svelte @@ -26,10 +26,10 @@ } // Enriches data bindings to real values based on data context - const enrichDataBindings = (data, bindings, props) => { + const enrichDataBindings = (dataContexts, dataBindings, props) => { const state = { - ...data, - ...bindings, + ...dataContexts, + ...dataBindings, } let enrichedProps = {} Object.entries(props).forEach(([key, value]) => { @@ -49,9 +49,9 @@ $: componentProps = extractValidProps(definition) $: children = definition._children $: id = definition._id - $: dataStore = getContext("data") + $: dataContext = getContext("data") $: enrichedProps = enrichDataBindings( - $dataStore, + $dataContext, $bindingStore, componentProps ) @@ -64,7 +64,7 @@ $: componentStore.set({ id, styles: { ...definition._styles, id }, - dataContext: $dataStore.data, + dataContext: $dataContext.data, }) diff --git a/packages/standard-components/src/Form.svelte b/packages/standard-components/src/Form.svelte index 9da1232434..8639fbde1a 100644 --- a/packages/standard-components/src/Form.svelte +++ b/packages/standard-components/src/Form.svelte @@ -6,7 +6,6 @@ import { capitalise } from "./helpers" const { styleable, screenStore, API } = getContext("sdk") - const dataContextStore = getContext("data") const component = getContext("component") export let wide = false @@ -15,11 +14,11 @@ let schema let fields = [] - $: getContextDetails($dataContextStore) + $: getContextDetails($component.dataContext) const getContextDetails = async dataContext => { - row = dataContext?.data - if (row) { + if (dataContext) { + row = dataContext const tableDefinition = await API.fetchTableDefinition(row.tableId) schema = tableDefinition.schema fields = Object.keys(schema) diff --git a/packages/standard-components/src/List.svelte b/packages/standard-components/src/List.svelte index 4ee1f23df3..a305bff04d 100644 --- a/packages/standard-components/src/List.svelte +++ b/packages/standard-components/src/List.svelte @@ -3,7 +3,6 @@ import { isEmpty } from "lodash/fp" const { API, styleable, DataProvider } = getContext("sdk") - const dataContextStore = getContext("data") const component = getContext("component") export let datasource = [] @@ -12,7 +11,7 @@ onMount(async () => { if (!isEmpty(datasource)) { - rows = await API.fetchDatasource(datasource, $dataContextStore) + rows = await API.fetchDatasource(datasource, $component.dataContext) } }) diff --git a/packages/standard-components/src/charts/BarChart.svelte b/packages/standard-components/src/charts/BarChart.svelte index 4bf01b9a21..a4937d70df 100644 --- a/packages/standard-components/src/charts/BarChart.svelte +++ b/packages/standard-components/src/charts/BarChart.svelte @@ -5,7 +5,7 @@ import { isEmpty } from "lodash/fp" const { API } = getContext("sdk") - const dataContext = getContext("data") + const component = getContext("component") export let title export let datasource @@ -35,7 +35,7 @@ // Fetch, filter and sort data const schema = (await API.fetchTableDefinition(datasource.tableId)).schema - const result = await API.fetchDatasource(datasource, $dataContext) + const result = await API.fetchDatasource(datasource, $component.dataContext) const reducer = row => (valid, column) => valid && row[column] != null const hasAllColumns = row => allCols.reduce(reducer(row), true) const data = result diff --git a/packages/standard-components/src/charts/CandleStickChart.svelte b/packages/standard-components/src/charts/CandleStickChart.svelte index 341b1d714f..cb5b6d2607 100644 --- a/packages/standard-components/src/charts/CandleStickChart.svelte +++ b/packages/standard-components/src/charts/CandleStickChart.svelte @@ -5,7 +5,7 @@ import { isEmpty } from "lodash/fp" const { API } = getContext("sdk") - const dataContext = getContext("data") + const component = getContext("component") export let title export let datasource @@ -33,7 +33,7 @@ // Fetch, filter and sort data const schema = (await API.fetchTableDefinition(datasource.tableId)).schema - const result = await API.fetchDatasource(datasource, $dataContext) + const result = await API.fetchDatasource(datasource, $component.dataContext) const reducer = row => (valid, column) => valid && row[column] != null const hasAllColumns = row => allCols.reduce(reducer(row), true) const data = result diff --git a/packages/standard-components/src/charts/LineChart.svelte b/packages/standard-components/src/charts/LineChart.svelte index 6e7f7f65f0..5eff91a324 100644 --- a/packages/standard-components/src/charts/LineChart.svelte +++ b/packages/standard-components/src/charts/LineChart.svelte @@ -5,7 +5,7 @@ import { isEmpty } from "lodash/fp" const { API } = getContext("sdk") - const dataContext = getContext("data") + const component = getContext("component") // Common props export let title @@ -41,7 +41,7 @@ // Fetch, filter and sort data const schema = (await API.fetchTableDefinition(datasource.tableId)).schema - const result = await API.fetchDatasource(datasource, $dataContext) + const result = await API.fetchDatasource(datasource, $component.dataContext) const reducer = row => (valid, column) => valid && row[column] != null const hasAllColumns = row => allCols.reduce(reducer(row), true) const data = result diff --git a/packages/standard-components/src/charts/PieChart.svelte b/packages/standard-components/src/charts/PieChart.svelte index 9a8db6b17a..584b88bbec 100644 --- a/packages/standard-components/src/charts/PieChart.svelte +++ b/packages/standard-components/src/charts/PieChart.svelte @@ -5,7 +5,7 @@ import { isEmpty } from "lodash/fp" const { API } = getContext("sdk") - const dataContext = getContext("data") + const component = getContext("component") export let title export let datasource @@ -31,7 +31,7 @@ // Fetch, filter and sort data const schema = (await API.fetchTableDefinition(datasource.tableId)).schema - const result = await API.fetchDatasource(datasource, $dataContext) + const result = await API.fetchDatasource(datasource, $component.dataContext) const data = result .filter(row => row[labelColumn] != null && row[valueColumn] != null) .slice(0, 20) diff --git a/packages/standard-components/src/grid/Component.svelte b/packages/standard-components/src/grid/Component.svelte index 5cef467607..3911501735 100644 --- a/packages/standard-components/src/grid/Component.svelte +++ b/packages/standard-components/src/grid/Component.svelte @@ -15,7 +15,6 @@ // These maps need to be set up to handle whatever types that are used in the tables. const setters = new Map([["number", number]]) const SDK = getContext("sdk") - const dataContext = getContext("data") const component = getContext("component") const { API, styleable } = SDK @@ -59,7 +58,7 @@ onMount(async () => { if (!isEmpty(datasource)) { - data = await API.fetchDatasource(datasource, $dataContext) + data = await API.fetchDatasource(datasource, $component.dataContext) let schema // Get schema for datasource