Merge pull request #12969 from Budibase/monolith-cheeks-tweaks
Monolith cheeks tweaks
This commit is contained in:
commit
f35230d46e
|
@ -23,7 +23,6 @@
|
||||||
"\\.(jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$": "<rootDir>/internals/mocks/fileMock.js",
|
"\\.(jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$": "<rootDir>/internals/mocks/fileMock.js",
|
||||||
"\\.(css|less|sass|scss)$": "identity-obj-proxy",
|
"\\.(css|less|sass|scss)$": "identity-obj-proxy",
|
||||||
"components(.*)$": "<rootDir>/src/components$1",
|
"components(.*)$": "<rootDir>/src/components$1",
|
||||||
"builder(.*)$": "<rootDir>/src/builder$1",
|
|
||||||
"stores(.*)$": "<rootDir>/src/stores$1",
|
"stores(.*)$": "<rootDir>/src/stores$1",
|
||||||
"analytics(.*)$": "<rootDir>/src/analytics$1",
|
"analytics(.*)$": "<rootDir>/src/analytics$1",
|
||||||
"constants/backend": "<rootDir>/src/constants/backend/index.js"
|
"constants/backend": "<rootDir>/src/constants/backend/index.js"
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
import { admin, licensing } from "stores/portal"
|
import { admin, licensing } from "stores/portal"
|
||||||
import { externalActions } from "./ExternalActions"
|
import { externalActions } from "./ExternalActions"
|
||||||
import { TriggerStepID, ActionStepID } from "constants/backend/automations"
|
import { TriggerStepID, ActionStepID } from "constants/backend/automations"
|
||||||
import { checkForCollectStep } from "builder/utils"
|
import { checkForCollectStep } from "helpers/utils"
|
||||||
|
|
||||||
export let blockIdx
|
export let blockIdx
|
||||||
export let lastStep
|
export let lastStep
|
||||||
|
|
|
@ -42,7 +42,7 @@
|
||||||
import {
|
import {
|
||||||
getSchemaForDatasourcePlus,
|
getSchemaForDatasourcePlus,
|
||||||
getEnvironmentBindings,
|
getEnvironmentBindings,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
import { TriggerStepID, ActionStepID } from "constants/backend/automations"
|
import { TriggerStepID, ActionStepID } from "constants/backend/automations"
|
||||||
import { onMount } from "svelte"
|
import { onMount } from "svelte"
|
||||||
import { cloneDeep } from "lodash/fp"
|
import { cloneDeep } from "lodash/fp"
|
||||||
|
|
|
@ -28,7 +28,7 @@
|
||||||
PrettyRelationshipDefinitions,
|
PrettyRelationshipDefinitions,
|
||||||
DB_TYPE_EXTERNAL,
|
DB_TYPE_EXTERNAL,
|
||||||
} from "constants/backend"
|
} from "constants/backend"
|
||||||
import { getAutoColumnInformation, buildAutoColumn } from "builder/utils"
|
import { getAutoColumnInformation, buildAutoColumn } from "helpers/utils"
|
||||||
import ConfirmDialog from "components/common/ConfirmDialog.svelte"
|
import ConfirmDialog from "components/common/ConfirmDialog.svelte"
|
||||||
import ModalBindableInput from "components/common/bindings/ModalBindableInput.svelte"
|
import ModalBindableInput from "components/common/bindings/ModalBindableInput.svelte"
|
||||||
import { getBindings } from "components/backend/DataTable/formula"
|
import { getBindings } from "components/backend/DataTable/formula"
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
} from "@budibase/bbui"
|
} from "@budibase/bbui"
|
||||||
import { onMount, createEventDispatcher } from "svelte"
|
import { onMount, createEventDispatcher } from "svelte"
|
||||||
import { FIELDS } from "constants/backend"
|
import { FIELDS } from "constants/backend"
|
||||||
import { generate } from "builder/schemaGenerator"
|
import { generate } from "helpers/schemaGenerator"
|
||||||
|
|
||||||
export let schema = {}
|
export let schema = {}
|
||||||
export let json
|
export let json
|
||||||
|
|
|
@ -9,7 +9,6 @@
|
||||||
views,
|
views,
|
||||||
viewsV2,
|
viewsV2,
|
||||||
userSelectedResourceMap,
|
userSelectedResourceMap,
|
||||||
database,
|
|
||||||
} from "stores/builder"
|
} from "stores/builder"
|
||||||
import EditDatasourcePopover from "./popovers/EditDatasourcePopover.svelte"
|
import EditDatasourcePopover from "./popovers/EditDatasourcePopover.svelte"
|
||||||
import EditQueryPopover from "./popovers/EditQueryPopover.svelte"
|
import EditQueryPopover from "./popovers/EditQueryPopover.svelte"
|
||||||
|
@ -75,7 +74,6 @@
|
||||||
searchTerm && !showAppUsersTable && !enrichedDataSources.find(ds => ds.show)
|
searchTerm && !showAppUsersTable && !enrichedDataSources.find(ds => ds.show)
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
{#if $database?._id}
|
|
||||||
<div class="hierarchy-items-container">
|
<div class="hierarchy-items-container">
|
||||||
{#if showAppUsersTable}
|
{#if showAppUsersTable}
|
||||||
<NavItem
|
<NavItem
|
||||||
|
@ -137,7 +135,6 @@
|
||||||
</Layout>
|
</Layout>
|
||||||
{/if}
|
{/if}
|
||||||
</div>
|
</div>
|
||||||
{/if}
|
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
.hierarchy-items-container {
|
.hierarchy-items-container {
|
||||||
|
|
|
@ -4,7 +4,6 @@
|
||||||
views,
|
views,
|
||||||
viewsV2,
|
viewsV2,
|
||||||
userSelectedResourceMap,
|
userSelectedResourceMap,
|
||||||
database,
|
|
||||||
} from "stores/builder"
|
} from "stores/builder"
|
||||||
import { TableNames } from "constants"
|
import { TableNames } from "constants"
|
||||||
import EditTablePopover from "./popovers/EditTablePopover.svelte"
|
import EditTablePopover from "./popovers/EditTablePopover.svelte"
|
||||||
|
@ -29,7 +28,6 @@
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
{#if $database?._id}
|
|
||||||
<div class="hierarchy-items-container">
|
<div class="hierarchy-items-container">
|
||||||
{#each sortedTables as table, idx}
|
{#each sortedTables as table, idx}
|
||||||
<NavItem
|
<NavItem
|
||||||
|
@ -67,4 +65,3 @@
|
||||||
{/each}
|
{/each}
|
||||||
{/each}
|
{/each}
|
||||||
</div>
|
</div>
|
||||||
{/if}
|
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
import { tables } from "stores/builder"
|
import { tables } from "stores/builder"
|
||||||
import { API } from "api"
|
import { API } from "api"
|
||||||
import { Select, Label, Multiselect } from "@budibase/bbui"
|
import { Select, Label, Multiselect } from "@budibase/bbui"
|
||||||
import { capitalise } from "../../helpers"
|
import { capitalise } from "helpers"
|
||||||
import { createEventDispatcher } from "svelte"
|
import { createEventDispatcher } from "svelte"
|
||||||
|
|
||||||
export let schema
|
export let schema
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
import {
|
import {
|
||||||
readableToRuntimeBinding,
|
readableToRuntimeBinding,
|
||||||
runtimeToReadableBinding,
|
runtimeToReadableBinding,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
import { createEventDispatcher } from "svelte"
|
import { createEventDispatcher } from "svelte"
|
||||||
import { isJSBinding } from "@budibase/string-templates"
|
import { isJSBinding } from "@budibase/string-templates"
|
||||||
|
|
||||||
|
|
|
@ -19,7 +19,7 @@
|
||||||
import {
|
import {
|
||||||
readableToRuntimeBinding,
|
readableToRuntimeBinding,
|
||||||
runtimeToReadableBinding,
|
runtimeToReadableBinding,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
|
|
||||||
import { admin } from "stores/portal"
|
import { admin } from "stores/portal"
|
||||||
import CodeEditor from "../CodeEditor/CodeEditor.svelte"
|
import CodeEditor from "../CodeEditor/CodeEditor.svelte"
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
import {
|
import {
|
||||||
readableToRuntimeBinding,
|
readableToRuntimeBinding,
|
||||||
runtimeToReadableBinding,
|
runtimeToReadableBinding,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
import ClientBindingPanel from "components/common/bindings/ClientBindingPanel.svelte"
|
import ClientBindingPanel from "components/common/bindings/ClientBindingPanel.svelte"
|
||||||
import { createEventDispatcher, setContext } from "svelte"
|
import { createEventDispatcher, setContext } from "svelte"
|
||||||
import { isJSBinding } from "@budibase/string-templates"
|
import { isJSBinding } from "@budibase/string-templates"
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
import {
|
import {
|
||||||
readableToRuntimeBinding,
|
readableToRuntimeBinding,
|
||||||
runtimeToReadableBinding,
|
runtimeToReadableBinding,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
|
|
||||||
import ClientBindingPanel from "components/common/bindings/ClientBindingPanel.svelte"
|
import ClientBindingPanel from "components/common/bindings/ClientBindingPanel.svelte"
|
||||||
import { createEventDispatcher, setContext } from "svelte"
|
import { createEventDispatcher, setContext } from "svelte"
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
import {
|
import {
|
||||||
readableToRuntimeBinding,
|
readableToRuntimeBinding,
|
||||||
runtimeToReadableBinding,
|
runtimeToReadableBinding,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
|
|
||||||
import ClientBindingPanel from "components/common/bindings/ClientBindingPanel.svelte"
|
import ClientBindingPanel from "components/common/bindings/ClientBindingPanel.svelte"
|
||||||
import { createEventDispatcher, setContext } from "svelte"
|
import { createEventDispatcher, setContext } from "svelte"
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
import {
|
import {
|
||||||
readableToRuntimeBinding,
|
readableToRuntimeBinding,
|
||||||
runtimeToReadableBinding,
|
runtimeToReadableBinding,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
import ServerBindingPanel from "components/common/bindings/ServerBindingPanel.svelte"
|
import ServerBindingPanel from "components/common/bindings/ServerBindingPanel.svelte"
|
||||||
import { createEventDispatcher } from "svelte"
|
import { createEventDispatcher } from "svelte"
|
||||||
import { isJSBinding } from "@budibase/string-templates"
|
import { isJSBinding } from "@budibase/string-templates"
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
<script>
|
<script>
|
||||||
import { Layout, Input } from "@budibase/bbui"
|
import { Layout, Input } from "@budibase/bbui"
|
||||||
import {
|
import { createValidationStore, requiredValidator } from "helpers/validation"
|
||||||
createValidationStore,
|
|
||||||
requiredValidator,
|
|
||||||
} from "../../../helpers/validation"
|
|
||||||
|
|
||||||
export let password
|
export let password
|
||||||
export let error
|
export let error
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<script>
|
<script>
|
||||||
import { ModalContent, Input } from "@budibase/bbui"
|
import { ModalContent, Input } from "@budibase/bbui"
|
||||||
import sanitizeUrl from "builder/store/screenTemplates/utils/sanitizeUrl"
|
import sanitizeUrl from "helpers/sanitizeUrl"
|
||||||
import { get } from "svelte/store"
|
import { get } from "svelte/store"
|
||||||
import { screenStore } from "stores/builder"
|
import { screenStore } from "stores/builder"
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
getActionBindings,
|
getActionBindings,
|
||||||
makeStateBinding,
|
makeStateBinding,
|
||||||
updateReferencesInObject,
|
updateReferencesInObject,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
import { cloneDeep } from "lodash/fp"
|
import { cloneDeep } from "lodash/fp"
|
||||||
|
|
||||||
const flipDurationMs = 150
|
const flipDurationMs = 150
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<script>
|
<script>
|
||||||
import { Select, Label } from "@budibase/bbui"
|
import { Select, Label } from "@budibase/bbui"
|
||||||
import { currentAsset, componentStore } from "stores/builder"
|
import { selectedScreen, componentStore } from "stores/builder"
|
||||||
import { getActionProviders } from "builder/dataBinding"
|
import { getActionProviders } from "dataBinding"
|
||||||
import { onMount } from "svelte"
|
import { onMount } from "svelte"
|
||||||
import DrawerBindableInput from "components/common/bindings/DrawerBindableInput.svelte"
|
import DrawerBindableInput from "components/common/bindings/DrawerBindableInput.svelte"
|
||||||
|
|
||||||
|
@ -10,7 +10,7 @@
|
||||||
export let nested
|
export let nested
|
||||||
|
|
||||||
$: actionProviders = getActionProviders(
|
$: actionProviders = getActionProviders(
|
||||||
$currentAsset,
|
$selectedScreen,
|
||||||
$componentStore.selectedComponentId,
|
$componentStore.selectedComponentId,
|
||||||
"ChangeFormStep",
|
"ChangeFormStep",
|
||||||
{ includeSelf: nested }
|
{ includeSelf: nested }
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
<script>
|
<script>
|
||||||
import { Select, Label } from "@budibase/bbui"
|
import { Select, Label } from "@budibase/bbui"
|
||||||
import { currentAsset, componentStore } from "stores/builder"
|
import { selectedScreen, componentStore } from "stores/builder"
|
||||||
import { getActionProviders } from "builder/dataBinding"
|
import { getActionProviders } from "dataBinding"
|
||||||
|
|
||||||
export let parameters
|
export let parameters
|
||||||
export let nested
|
export let nested
|
||||||
|
|
||||||
$: actionProviders = getActionProviders(
|
$: actionProviders = getActionProviders(
|
||||||
$currentAsset,
|
$selectedScreen,
|
||||||
$componentStore.selectedComponentId,
|
$componentStore.selectedComponentId,
|
||||||
"ClearForm",
|
"ClearForm",
|
||||||
{ includeSelf: nested }
|
{ includeSelf: nested }
|
||||||
|
|
|
@ -1,7 +1,12 @@
|
||||||
<script>
|
<script>
|
||||||
import { Select, Label, Body, Checkbox, Input } from "@budibase/bbui"
|
import { Select, Label, Body, Checkbox, Input } from "@budibase/bbui"
|
||||||
import { currentAsset, componentStore, tables, viewsV2 } from "stores/builder"
|
import {
|
||||||
import { getSchemaForDatasourcePlus } from "builder/dataBinding"
|
selectedScreen,
|
||||||
|
componentStore,
|
||||||
|
tables,
|
||||||
|
viewsV2,
|
||||||
|
} from "stores/builder"
|
||||||
|
import { getSchemaForDatasourcePlus } from "dataBinding"
|
||||||
import SaveFields from "./SaveFields.svelte"
|
import SaveFields from "./SaveFields.svelte"
|
||||||
import { getDatasourceLikeProviders } from "components/design/settings/controls/ButtonActionEditor/actions/utils"
|
import { getDatasourceLikeProviders } from "components/design/settings/controls/ButtonActionEditor/actions/utils"
|
||||||
|
|
||||||
|
@ -10,7 +15,7 @@
|
||||||
export let nested
|
export let nested
|
||||||
|
|
||||||
$: providerOptions = getDatasourceLikeProviders({
|
$: providerOptions = getDatasourceLikeProviders({
|
||||||
asset: $currentAsset,
|
asset: $selectedScreen,
|
||||||
componentId: $componentStore.selectedComponentId,
|
componentId: $componentStore.selectedComponentId,
|
||||||
nested,
|
nested,
|
||||||
})
|
})
|
||||||
|
|
|
@ -1,15 +1,9 @@
|
||||||
<script>
|
<script>
|
||||||
import { Label, Select, Body, Multiselect } from "@budibase/bbui"
|
import { Label, Select, Body, Multiselect } from "@budibase/bbui"
|
||||||
import {
|
import { findAllMatchingComponents, findComponent } from "helpers/components"
|
||||||
findAllMatchingComponents,
|
import { selectedScreen } from "stores/builder"
|
||||||
findComponent,
|
|
||||||
} from "stores/builder/components/utils"
|
|
||||||
import { currentAsset } from "stores/builder"
|
|
||||||
import { onMount } from "svelte"
|
import { onMount } from "svelte"
|
||||||
import {
|
import { getDatasourceForProvider, getSchemaForDatasource } from "dataBinding"
|
||||||
getDatasourceForProvider,
|
|
||||||
getSchemaForDatasource,
|
|
||||||
} from "builder/dataBinding"
|
|
||||||
|
|
||||||
export let parameters
|
export let parameters
|
||||||
|
|
||||||
|
@ -24,14 +18,15 @@
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
|
|
||||||
$: tables = findAllMatchingComponents($currentAsset?.props, component =>
|
$: tables = findAllMatchingComponents($selectedScreen?.props, component =>
|
||||||
component._component.endsWith("table")
|
component._component.endsWith("table")
|
||||||
).map(table => ({
|
).map(table => ({
|
||||||
label: table._instanceName,
|
label: table._instanceName,
|
||||||
value: table._id,
|
value: table._id,
|
||||||
}))
|
}))
|
||||||
$: tableBlocks = findAllMatchingComponents($currentAsset?.props, component =>
|
$: tableBlocks = findAllMatchingComponents(
|
||||||
component._component.endsWith("tableblock")
|
$selectedScreen?.props,
|
||||||
|
component => component._component.endsWith("tableblock")
|
||||||
).map(block => ({
|
).map(block => ({
|
||||||
label: block._instanceName,
|
label: block._instanceName,
|
||||||
value: `${block._id}-table`,
|
value: `${block._id}-table`,
|
||||||
|
@ -44,9 +39,9 @@
|
||||||
if (tableId?.includes("-")) {
|
if (tableId?.includes("-")) {
|
||||||
tableId = tableId.split("-")[0]
|
tableId = tableId.split("-")[0]
|
||||||
}
|
}
|
||||||
const selectedTable = findComponent($currentAsset?.props, tableId)
|
const selectedTable = findComponent($selectedScreen?.props, tableId)
|
||||||
const datasource = getDatasourceForProvider($currentAsset, selectedTable)
|
const datasource = getDatasourceForProvider($selectedScreen, selectedTable)
|
||||||
const { schema } = getSchemaForDatasource($currentAsset, datasource)
|
const { schema } = getSchemaForDatasource($selectedScreen, datasource)
|
||||||
return Object.keys(schema || {})
|
return Object.keys(schema || {})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<script>
|
<script>
|
||||||
import { Select, Label } from "@budibase/bbui"
|
import { Select, Label } from "@budibase/bbui"
|
||||||
import { selectedScreen } from "stores/builder"
|
import { selectedScreen } from "stores/builder"
|
||||||
import { findAllMatchingComponents } from "stores/builder/components/utils"
|
import { findAllMatchingComponents } from "helpers/components"
|
||||||
|
|
||||||
export let parameters
|
export let parameters
|
||||||
|
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
<script>
|
<script>
|
||||||
import { Select, Label } from "@budibase/bbui"
|
import { Select, Label } from "@budibase/bbui"
|
||||||
import { currentAsset, componentStore } from "stores/builder"
|
import { selectedScreen, componentStore } from "stores/builder"
|
||||||
import { getActionProviders } from "builder/dataBinding"
|
import { getActionProviders } from "dataBinding"
|
||||||
|
|
||||||
export let parameters
|
export let parameters
|
||||||
export let nested
|
export let nested
|
||||||
|
|
||||||
$: actionProviders = getActionProviders(
|
$: actionProviders = getActionProviders(
|
||||||
$currentAsset,
|
$selectedScreen,
|
||||||
$componentStore.selectedComponentId,
|
$componentStore.selectedComponentId,
|
||||||
"RefreshDatasource",
|
"RefreshDatasource",
|
||||||
{ includeSelf: nested }
|
{ includeSelf: nested }
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
<script>
|
<script>
|
||||||
import { Select, Label } from "@budibase/bbui"
|
import { Select, Label } from "@budibase/bbui"
|
||||||
import { currentAsset } from "stores/builder"
|
import { selectedScreen } from "stores/builder"
|
||||||
import { findAllMatchingComponents } from "stores/builder/components/utils"
|
import { findAllMatchingComponents } from "helpers/components"
|
||||||
|
|
||||||
export let parameters
|
export let parameters
|
||||||
|
|
||||||
$: components = findAllMatchingComponents($currentAsset?.props, component =>
|
$: components = findAllMatchingComponents($selectedScreen?.props, component =>
|
||||||
component._component.endsWith("s3upload")
|
component._component.endsWith("s3upload")
|
||||||
)
|
)
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -1,7 +1,12 @@
|
||||||
<script>
|
<script>
|
||||||
import { Select, Label, Body, Checkbox, Input } from "@budibase/bbui"
|
import { Select, Label, Body, Checkbox, Input } from "@budibase/bbui"
|
||||||
import { currentAsset, componentStore, tables, viewsV2 } from "stores/builder"
|
import {
|
||||||
import { getSchemaForDatasourcePlus } from "builder/dataBinding"
|
selectedScreen,
|
||||||
|
componentStore,
|
||||||
|
tables,
|
||||||
|
viewsV2,
|
||||||
|
} from "stores/builder"
|
||||||
|
import { getSchemaForDatasourcePlus } from "dataBinding"
|
||||||
import SaveFields from "./SaveFields.svelte"
|
import SaveFields from "./SaveFields.svelte"
|
||||||
import { getDatasourceLikeProviders } from "components/design/settings/controls/ButtonActionEditor/actions/utils"
|
import { getDatasourceLikeProviders } from "components/design/settings/controls/ButtonActionEditor/actions/utils"
|
||||||
|
|
||||||
|
@ -10,7 +15,7 @@
|
||||||
export let nested
|
export let nested
|
||||||
|
|
||||||
$: providerOptions = getDatasourceLikeProviders({
|
$: providerOptions = getDatasourceLikeProviders({
|
||||||
asset: $currentAsset,
|
asset: $selectedScreen,
|
||||||
componentId: $componentStore.selectedComponentId,
|
componentId: $componentStore.selectedComponentId,
|
||||||
nested,
|
nested,
|
||||||
})
|
})
|
||||||
|
|
|
@ -1,20 +1,20 @@
|
||||||
<script>
|
<script>
|
||||||
import { currentAsset, componentStore } from "stores/builder"
|
import { selectedScreen, componentStore } from "stores/builder"
|
||||||
import { Label, Combobox, Select } from "@budibase/bbui"
|
import { Label, Combobox, Select } from "@budibase/bbui"
|
||||||
import { getActionProviders, buildFormSchema } from "builder/dataBinding"
|
import { getActionProviders, buildFormSchema } from "dataBinding"
|
||||||
import { findComponent } from "stores/builder/components/utils"
|
import { findComponent } from "helpers/components"
|
||||||
|
|
||||||
export let parameters
|
export let parameters
|
||||||
export let nested
|
export let nested
|
||||||
|
|
||||||
$: formComponent = getFormComponent(
|
$: formComponent = getFormComponent(
|
||||||
$currentAsset.props,
|
$selectedScreen.props,
|
||||||
parameters.componentId
|
parameters.componentId
|
||||||
)
|
)
|
||||||
$: formSchema = buildFormSchema(formComponent)
|
$: formSchema = buildFormSchema(formComponent)
|
||||||
$: fieldOptions = Object.keys(formSchema || {})
|
$: fieldOptions = Object.keys(formSchema || {})
|
||||||
$: actionProviders = getActionProviders(
|
$: actionProviders = getActionProviders(
|
||||||
$currentAsset,
|
$selectedScreen,
|
||||||
$componentStore.selectedComponentId,
|
$componentStore.selectedComponentId,
|
||||||
"ScrollTo",
|
"ScrollTo",
|
||||||
{ includeSelf: nested }
|
{ includeSelf: nested }
|
||||||
|
|
|
@ -2,9 +2,9 @@
|
||||||
import { Select, Label, Combobox } from "@budibase/bbui"
|
import { Select, Label, Combobox } from "@budibase/bbui"
|
||||||
import { onMount } from "svelte"
|
import { onMount } from "svelte"
|
||||||
import DrawerBindableInput from "components/common/bindings/DrawerBindableInput.svelte"
|
import DrawerBindableInput from "components/common/bindings/DrawerBindableInput.svelte"
|
||||||
import { currentAsset, componentStore } from "stores/builder"
|
import { selectedScreen, componentStore } from "stores/builder"
|
||||||
import { getActionProviders, buildFormSchema } from "builder/dataBinding"
|
import { getActionProviders, buildFormSchema } from "dataBinding"
|
||||||
import { findComponent } from "stores/builder/components/utils"
|
import { findComponent } from "helpers/components"
|
||||||
|
|
||||||
export let parameters
|
export let parameters
|
||||||
export let bindings = []
|
export let bindings = []
|
||||||
|
@ -22,13 +22,13 @@
|
||||||
]
|
]
|
||||||
|
|
||||||
$: formComponent = getFormComponent(
|
$: formComponent = getFormComponent(
|
||||||
$currentAsset.props,
|
$selectedScreen.props,
|
||||||
parameters.componentId
|
parameters.componentId
|
||||||
)
|
)
|
||||||
$: formSchema = buildFormSchema(formComponent)
|
$: formSchema = buildFormSchema(formComponent)
|
||||||
$: fieldOptions = Object.keys(formSchema || {})
|
$: fieldOptions = Object.keys(formSchema || {})
|
||||||
$: actionProviders = getActionProviders(
|
$: actionProviders = getActionProviders(
|
||||||
$currentAsset,
|
$selectedScreen,
|
||||||
$componentStore.selectedComponentId,
|
$componentStore.selectedComponentId,
|
||||||
"ValidateForm",
|
"ValidateForm",
|
||||||
{ includeSelf: nested }
|
{ includeSelf: nested }
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
import { Select, Label, Combobox, Checkbox, Body } from "@budibase/bbui"
|
import { Select, Label, Combobox, Checkbox, Body } from "@budibase/bbui"
|
||||||
import { onMount } from "svelte"
|
import { onMount } from "svelte"
|
||||||
import DrawerBindableInput from "components/common/bindings/DrawerBindableInput.svelte"
|
import DrawerBindableInput from "components/common/bindings/DrawerBindableInput.svelte"
|
||||||
import { getAllStateVariables } from "builder/dataBinding"
|
import { getAllStateVariables } from "dataBinding"
|
||||||
|
|
||||||
export let parameters
|
export let parameters
|
||||||
export let bindings = []
|
export let bindings = []
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
<script>
|
<script>
|
||||||
import { Select, Label } from "@budibase/bbui"
|
import { Select, Label } from "@budibase/bbui"
|
||||||
import { currentAsset, componentStore } from "stores/builder"
|
import { selectedScreen, componentStore } from "stores/builder"
|
||||||
import { getActionProviders } from "builder/dataBinding"
|
import { getActionProviders } from "dataBinding"
|
||||||
|
|
||||||
export let parameters
|
export let parameters
|
||||||
export let nested
|
export let nested
|
||||||
|
|
||||||
$: actionProviders = getActionProviders(
|
$: actionProviders = getActionProviders(
|
||||||
$currentAsset,
|
$selectedScreen,
|
||||||
$componentStore.selectedComponentId,
|
$componentStore.selectedComponentId,
|
||||||
"ValidateForm",
|
"ValidateForm",
|
||||||
{ includeSelf: nested }
|
{ includeSelf: nested }
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import { getComponentContexts } from "builder/dataBinding"
|
import { getComponentContexts } from "dataBinding"
|
||||||
import { capitalise } from "helpers"
|
import { capitalise } from "helpers"
|
||||||
|
|
||||||
// Generates bindings for all components that provider "datasource like"
|
// Generates bindings for all components that provider "datasource like"
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
import { createEventDispatcher } from "svelte"
|
import { createEventDispatcher } from "svelte"
|
||||||
import { Helpers } from "@budibase/bbui"
|
import { Helpers } from "@budibase/bbui"
|
||||||
import { componentStore } from "stores/builder"
|
import { componentStore } from "stores/builder"
|
||||||
import { getEventContextBindings } from "builder/dataBinding"
|
import { getEventContextBindings } from "dataBinding"
|
||||||
import { cloneDeep, isEqual } from "lodash/fp"
|
import { cloneDeep, isEqual } from "lodash/fp"
|
||||||
|
|
||||||
export let componentInstance
|
export let componentInstance
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<script>
|
<script>
|
||||||
import EditComponentPopover from "../EditComponentPopover.svelte"
|
import EditComponentPopover from "../EditComponentPopover.svelte"
|
||||||
import { Icon } from "@budibase/bbui"
|
import { Icon } from "@budibase/bbui"
|
||||||
import { runtimeToReadableBinding } from "builder/dataBinding"
|
import { runtimeToReadableBinding } from "dataBinding"
|
||||||
import { isJSBinding } from "@budibase/string-templates"
|
import { isJSBinding } from "@budibase/string-templates"
|
||||||
|
|
||||||
export let item
|
export let item
|
||||||
|
|
|
@ -3,11 +3,8 @@
|
||||||
import { createEventDispatcher } from "svelte"
|
import { createEventDispatcher } from "svelte"
|
||||||
import ColumnDrawer from "./ColumnDrawer.svelte"
|
import ColumnDrawer from "./ColumnDrawer.svelte"
|
||||||
import { cloneDeep } from "lodash/fp"
|
import { cloneDeep } from "lodash/fp"
|
||||||
import {
|
import { getDatasourceForProvider, getSchemaForDatasource } from "dataBinding"
|
||||||
getDatasourceForProvider,
|
import { selectedScreen } from "stores/builder"
|
||||||
getSchemaForDatasource,
|
|
||||||
} from "builder/dataBinding"
|
|
||||||
import { currentAsset } from "stores/builder"
|
|
||||||
import { getFields } from "helpers/searchFields"
|
import { getFields } from "helpers/searchFields"
|
||||||
|
|
||||||
export let componentInstance
|
export let componentInstance
|
||||||
|
@ -21,8 +18,8 @@
|
||||||
let boundValue
|
let boundValue
|
||||||
|
|
||||||
$: text = getText(value)
|
$: text = getText(value)
|
||||||
$: datasource = getDatasourceForProvider($currentAsset, componentInstance)
|
$: datasource = getDatasourceForProvider($selectedScreen, componentInstance)
|
||||||
$: schema = getSchema($currentAsset, datasource)
|
$: schema = getSchema($selectedScreen, datasource)
|
||||||
$: options = allowCellEditing
|
$: options = allowCellEditing
|
||||||
? Object.keys(schema || {})
|
? Object.keys(schema || {})
|
||||||
: enrichedSchemaFields?.map(field => field.name)
|
: enrichedSchemaFields?.map(field => field.name)
|
||||||
|
|
|
@ -1,14 +1,14 @@
|
||||||
<script>
|
<script>
|
||||||
import { Select } from "@budibase/bbui"
|
import { Select } from "@budibase/bbui"
|
||||||
import { makePropSafe } from "@budibase/string-templates"
|
import { makePropSafe } from "@budibase/string-templates"
|
||||||
import { currentAsset } from "stores/builder"
|
import { selectedScreen } from "stores/builder"
|
||||||
import { findAllMatchingComponents } from "stores/builder/components/utils"
|
import { findAllMatchingComponents } from "helpers/components"
|
||||||
|
|
||||||
export let value
|
export let value
|
||||||
|
|
||||||
const getValue = component => `{{ literal ${makePropSafe(component._id)} }}`
|
const getValue = component => `{{ literal ${makePropSafe(component._id)} }}`
|
||||||
|
|
||||||
$: providers = findAllMatchingComponents($currentAsset?.props, c =>
|
$: providers = findAllMatchingComponents($selectedScreen?.props, c =>
|
||||||
c._component?.endsWith("/dataprovider")
|
c._component?.endsWith("/dataprovider")
|
||||||
)
|
)
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
import {
|
import {
|
||||||
readableToRuntimeBinding,
|
readableToRuntimeBinding,
|
||||||
runtimeToReadableBinding,
|
runtimeToReadableBinding,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
import {
|
import {
|
||||||
Button,
|
Button,
|
||||||
Popover,
|
Popover,
|
||||||
|
@ -22,7 +22,7 @@
|
||||||
queries as queriesStore,
|
queries as queriesStore,
|
||||||
viewsV2 as viewsV2Store,
|
viewsV2 as viewsV2Store,
|
||||||
views as viewsStore,
|
views as viewsStore,
|
||||||
currentAsset,
|
selectedScreen,
|
||||||
componentStore,
|
componentStore,
|
||||||
datasources,
|
datasources,
|
||||||
integrations,
|
integrations,
|
||||||
|
@ -30,7 +30,7 @@
|
||||||
import BindingBuilder from "components/integration/QueryBindingBuilder.svelte"
|
import BindingBuilder from "components/integration/QueryBindingBuilder.svelte"
|
||||||
import IntegrationQueryEditor from "components/integration/index.svelte"
|
import IntegrationQueryEditor from "components/integration/index.svelte"
|
||||||
import { makePropSafe as safe } from "@budibase/string-templates"
|
import { makePropSafe as safe } from "@budibase/string-templates"
|
||||||
import { findAllComponents } from "stores/builder/components/utils"
|
import { findAllComponents } from "helpers/components"
|
||||||
import ClientBindingPanel from "components/common/bindings/ClientBindingPanel.svelte"
|
import ClientBindingPanel from "components/common/bindings/ClientBindingPanel.svelte"
|
||||||
import DataSourceCategory from "components/design/settings/controls/DataSourceSelect/DataSourceCategory.svelte"
|
import DataSourceCategory from "components/design/settings/controls/DataSourceSelect/DataSourceCategory.svelte"
|
||||||
import { API } from "api"
|
import { API } from "api"
|
||||||
|
@ -76,7 +76,7 @@
|
||||||
...query,
|
...query,
|
||||||
type: "query",
|
type: "query",
|
||||||
}))
|
}))
|
||||||
$: dataProviders = findAllComponents($currentAsset.props)
|
$: dataProviders = findAllComponents($selectedScreen.props)
|
||||||
.filter(component => {
|
.filter(component => {
|
||||||
return (
|
return (
|
||||||
component._component?.endsWith("/dataprovider") &&
|
component._component?.endsWith("/dataprovider") &&
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
import { componentStore } from "stores/builder"
|
import { componentStore } from "stores/builder"
|
||||||
import { cloneDeep } from "lodash/fp"
|
import { cloneDeep } from "lodash/fp"
|
||||||
import { createEventDispatcher, getContext } from "svelte"
|
import { createEventDispatcher, getContext } from "svelte"
|
||||||
import ComponentSettingsSection from "../../../../pages/builder/app/[application]/design/[screenId]/[componentId]/_components/Component/ComponentSettingsSection.svelte"
|
import ComponentSettingsSection from "pages/builder/app/[application]/design/[screenId]/[componentId]/_components/Component/ComponentSettingsSection.svelte"
|
||||||
|
|
||||||
export let anchor
|
export let anchor
|
||||||
export let componentInstance
|
export let componentInstance
|
||||||
|
|
|
@ -6,8 +6,8 @@
|
||||||
getSchemaForDatasource,
|
getSchemaForDatasource,
|
||||||
getBindableProperties,
|
getBindableProperties,
|
||||||
getComponentBindableProperties,
|
getComponentBindableProperties,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
import { selectedScreen, currentAsset, componentStore } from "stores/builder"
|
import { selectedScreen, componentStore } from "stores/builder"
|
||||||
import DraggableList from "../DraggableList/DraggableList.svelte"
|
import DraggableList from "../DraggableList/DraggableList.svelte"
|
||||||
import { createEventDispatcher } from "svelte"
|
import { createEventDispatcher } from "svelte"
|
||||||
import FieldSetting from "./FieldSetting.svelte"
|
import FieldSetting from "./FieldSetting.svelte"
|
||||||
|
@ -44,7 +44,7 @@
|
||||||
|
|
||||||
$: datasource =
|
$: datasource =
|
||||||
componentInstance.dataSource ||
|
componentInstance.dataSource ||
|
||||||
getDatasourceForProvider($currentAsset, componentInstance)
|
getDatasourceForProvider($selectedScreen, componentInstance)
|
||||||
|
|
||||||
$: resourceId = datasource?.resourceId || datasource?.tableId
|
$: resourceId = datasource?.resourceId || datasource?.tableId
|
||||||
|
|
||||||
|
@ -53,7 +53,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
const updateState = value => {
|
const updateState = value => {
|
||||||
schema = getSchema($currentAsset, datasource)
|
schema = getSchema($selectedScreen, datasource)
|
||||||
options = Object.keys(schema || {})
|
options = Object.keys(schema || {})
|
||||||
sanitisedValue = getValidColumns(convertOldFieldFormat(value), options)
|
sanitisedValue = getValidColumns(convertOldFieldFormat(value), options)
|
||||||
updateSanitsedFields(sanitisedValue)
|
updateSanitsedFields(sanitisedValue)
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
import { Toggle, Icon } from "@budibase/bbui"
|
import { Toggle, Icon } from "@budibase/bbui"
|
||||||
import { createEventDispatcher } from "svelte"
|
import { createEventDispatcher } from "svelte"
|
||||||
import { cloneDeep } from "lodash/fp"
|
import { cloneDeep } from "lodash/fp"
|
||||||
import { runtimeToReadableBinding } from "builder/dataBinding"
|
import { runtimeToReadableBinding } from "dataBinding"
|
||||||
import { isJSBinding } from "@budibase/string-templates"
|
import { isJSBinding } from "@budibase/string-templates"
|
||||||
import { componentStore } from "stores/builder"
|
import { componentStore } from "stores/builder"
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,7 @@
|
||||||
<script>
|
<script>
|
||||||
import { Select } from "@budibase/bbui"
|
import { Select } from "@budibase/bbui"
|
||||||
import {
|
import { getDatasourceForProvider, getSchemaForDatasource } from "dataBinding"
|
||||||
getDatasourceForProvider,
|
import { selectedScreen } from "stores/builder"
|
||||||
getSchemaForDatasource,
|
|
||||||
} from "builder/dataBinding"
|
|
||||||
import { currentAsset } from "stores/builder"
|
|
||||||
import { createEventDispatcher } from "svelte"
|
import { createEventDispatcher } from "svelte"
|
||||||
|
|
||||||
export let componentInstance = {}
|
export let componentInstance = {}
|
||||||
|
@ -12,8 +9,8 @@
|
||||||
export let placeholder
|
export let placeholder
|
||||||
|
|
||||||
const dispatch = createEventDispatcher()
|
const dispatch = createEventDispatcher()
|
||||||
$: datasource = getDatasourceForProvider($currentAsset, componentInstance)
|
$: datasource = getDatasourceForProvider($selectedScreen, componentInstance)
|
||||||
$: schema = getSchemaForDatasource($currentAsset, datasource).schema
|
$: schema = getSchemaForDatasource($selectedScreen, datasource).schema
|
||||||
$: options = Object.keys(schema || {})
|
$: options = Object.keys(schema || {})
|
||||||
$: boundValue = getValidValue(value, options)
|
$: boundValue = getValidValue(value, options)
|
||||||
|
|
||||||
|
|
|
@ -1,12 +1,9 @@
|
||||||
<script>
|
<script>
|
||||||
import { notifications, ActionButton, Button, Drawer } from "@budibase/bbui"
|
import { notifications, ActionButton, Button, Drawer } from "@budibase/bbui"
|
||||||
import { createEventDispatcher } from "svelte"
|
import { createEventDispatcher } from "svelte"
|
||||||
import {
|
import { getDatasourceForProvider, getSchemaForDatasource } from "dataBinding"
|
||||||
getDatasourceForProvider,
|
|
||||||
getSchemaForDatasource,
|
|
||||||
} from "builder/dataBinding"
|
|
||||||
import FilterDrawer from "./FilterDrawer.svelte"
|
import FilterDrawer from "./FilterDrawer.svelte"
|
||||||
import { currentAsset } from "stores/builder"
|
import { selectedScreen } from "stores/builder"
|
||||||
|
|
||||||
const dispatch = createEventDispatcher()
|
const dispatch = createEventDispatcher()
|
||||||
|
|
||||||
|
@ -18,8 +15,8 @@
|
||||||
let drawer
|
let drawer
|
||||||
|
|
||||||
$: tempValue = value
|
$: tempValue = value
|
||||||
$: datasource = getDatasourceForProvider($currentAsset, componentInstance)
|
$: datasource = getDatasourceForProvider($selectedScreen, componentInstance)
|
||||||
$: dsSchema = getSchemaForDatasource($currentAsset, datasource)?.schema
|
$: dsSchema = getSchemaForDatasource($selectedScreen, datasource)?.schema
|
||||||
$: schemaFields = Object.values(schema || dsSchema || {})
|
$: schemaFields = Object.values(schema || dsSchema || {})
|
||||||
$: text = getText(value?.filter(filter => filter.field))
|
$: text = getText(value?.filter(filter => filter.field))
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<script>
|
<script>
|
||||||
import { Combobox } from "@budibase/bbui"
|
import { Combobox } from "@budibase/bbui"
|
||||||
import { currentAsset } from "stores/builder"
|
import { selectedScreen } from "stores/builder"
|
||||||
import { getComponentFieldOptions } from "helpers/formFields"
|
import { getComponentFieldOptions } from "helpers/formFields"
|
||||||
|
|
||||||
export let componentInstance
|
export let componentInstance
|
||||||
|
@ -8,7 +8,7 @@
|
||||||
export let type
|
export let type
|
||||||
|
|
||||||
$: options = getComponentFieldOptions(
|
$: options = getComponentFieldOptions(
|
||||||
$currentAsset?.props,
|
$selectedScreen?.props,
|
||||||
componentInstance?._id,
|
componentInstance?._id,
|
||||||
type
|
type
|
||||||
)
|
)
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
<script>
|
<script>
|
||||||
import { createEventDispatcher, setContext } from "svelte"
|
import { createEventDispatcher, setContext } from "svelte"
|
||||||
import ComponentSettingsSection from "../../../../pages/builder/app/[application]/design/[screenId]/[componentId]/_components/Component/ComponentSettingsSection.svelte"
|
import ComponentSettingsSection from "pages/builder/app/[application]/design/[screenId]/[componentId]/_components/Component/ComponentSettingsSection.svelte"
|
||||||
import { getDatasourceForProvider } from "builder/dataBinding"
|
import { getDatasourceForProvider } from "dataBinding"
|
||||||
import { currentAsset, componentStore, previewStore } from "stores/builder"
|
import { selectedScreen, componentStore, previewStore } from "stores/builder"
|
||||||
import { Helpers } from "@budibase/bbui"
|
import { Helpers } from "@budibase/bbui"
|
||||||
import { derived, writable } from "svelte/store"
|
import { derived, writable } from "svelte/store"
|
||||||
import { Utils } from "@budibase/frontend-core"
|
import { Utils } from "@budibase/frontend-core"
|
||||||
|
@ -36,7 +36,7 @@
|
||||||
|
|
||||||
$: stepCount = cachedValue?.length || 0
|
$: stepCount = cachedValue?.length || 0
|
||||||
$: updateStore(stepCount)
|
$: updateStore(stepCount)
|
||||||
$: dataSource = getDatasourceForProvider($currentAsset, cachedInstance)
|
$: dataSource = getDatasourceForProvider($selectedScreen, cachedInstance)
|
||||||
$: emitCurrentStep($currentStep)
|
$: emitCurrentStep($currentStep)
|
||||||
$: stepLabel = getStepLabel($multiStepStore)
|
$: stepLabel = getStepLabel($multiStepStore)
|
||||||
$: stepDef = getDefinition(stepLabel)
|
$: stepDef = getDefinition(stepLabel)
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
<script>
|
<script>
|
||||||
import {
|
import { getDatasourceForProvider, getSchemaForDatasource } from "dataBinding"
|
||||||
getDatasourceForProvider,
|
import { selectedScreen, componentStore } from "stores/builder"
|
||||||
getSchemaForDatasource,
|
|
||||||
} from "builder/dataBinding"
|
|
||||||
import { currentAsset, componentStore } from "stores/builder"
|
|
||||||
import DraggableList from "../DraggableList/DraggableList.svelte"
|
import DraggableList from "../DraggableList/DraggableList.svelte"
|
||||||
import { createEventDispatcher } from "svelte"
|
import { createEventDispatcher } from "svelte"
|
||||||
import FieldSetting from "./FieldSetting.svelte"
|
import FieldSetting from "./FieldSetting.svelte"
|
||||||
|
@ -32,12 +29,12 @@
|
||||||
return schema
|
return schema
|
||||||
}
|
}
|
||||||
|
|
||||||
$: datasource = getDatasourceForProvider($currentAsset, componentInstance)
|
$: datasource = getDatasourceForProvider($selectedScreen, componentInstance)
|
||||||
$: primaryDisplayColumnName = getSchemaForDatasource(
|
$: primaryDisplayColumnName = getSchemaForDatasource(
|
||||||
$currentAsset,
|
$selectedScreen,
|
||||||
datasource
|
datasource
|
||||||
)?.table?.primaryDisplay
|
)?.table?.primaryDisplay
|
||||||
$: schema = getSchema(currentAsset, datasource)
|
$: schema = getSchema(selectedScreen, datasource)
|
||||||
$: columns = getColumns({
|
$: columns = getColumns({
|
||||||
columns: value,
|
columns: value,
|
||||||
schema,
|
schema,
|
||||||
|
|
|
@ -1,10 +1,7 @@
|
||||||
<script>
|
<script>
|
||||||
import { Multiselect } from "@budibase/bbui"
|
import { Multiselect } from "@budibase/bbui"
|
||||||
import {
|
import { getDatasourceForProvider, getSchemaForDatasource } from "dataBinding"
|
||||||
getDatasourceForProvider,
|
import { selectedScreen } from "stores/builder"
|
||||||
getSchemaForDatasource,
|
|
||||||
} from "builder/dataBinding"
|
|
||||||
import { currentAsset } from "stores/builder"
|
|
||||||
import { createEventDispatcher } from "svelte"
|
import { createEventDispatcher } from "svelte"
|
||||||
|
|
||||||
export let componentInstance = {}
|
export let componentInstance = {}
|
||||||
|
@ -12,8 +9,8 @@
|
||||||
export let placeholder
|
export let placeholder
|
||||||
|
|
||||||
const dispatch = createEventDispatcher()
|
const dispatch = createEventDispatcher()
|
||||||
$: datasource = getDatasourceForProvider($currentAsset, componentInstance)
|
$: datasource = getDatasourceForProvider($selectedScreen, componentInstance)
|
||||||
$: schema = getSchemaForDatasource($currentAsset, datasource).schema
|
$: schema = getSchemaForDatasource($selectedScreen, datasource).schema
|
||||||
$: options = Object.keys(schema || {})
|
$: options = Object.keys(schema || {})
|
||||||
$: boundValue = getValidOptions(value, options)
|
$: boundValue = getValidOptions(value, options)
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
import {
|
import {
|
||||||
readableToRuntimeBinding,
|
readableToRuntimeBinding,
|
||||||
runtimeToReadableBinding,
|
runtimeToReadableBinding,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
import { builderStore } from "stores/builder"
|
import { builderStore } from "stores/builder"
|
||||||
import { onDestroy } from "svelte"
|
import { onDestroy } from "svelte"
|
||||||
|
|
||||||
|
|
|
@ -2,12 +2,9 @@
|
||||||
import {
|
import {
|
||||||
findClosestMatchingComponent,
|
findClosestMatchingComponent,
|
||||||
findComponent,
|
findComponent,
|
||||||
} from "stores/builder/components/utils"
|
} from "helpers/components"
|
||||||
import {
|
import { getDatasourceForProvider, getSchemaForDatasource } from "dataBinding"
|
||||||
getDatasourceForProvider,
|
import { tables, selectedScreen, componentStore } from "stores/builder"
|
||||||
getSchemaForDatasource,
|
|
||||||
} from "builder/dataBinding"
|
|
||||||
import { tables, currentAsset, componentStore } from "stores/builder"
|
|
||||||
import FilterEditor from "./FilterEditor/FilterEditor.svelte"
|
import FilterEditor from "./FilterEditor/FilterEditor.svelte"
|
||||||
|
|
||||||
export let componentInstance
|
export let componentInstance
|
||||||
|
@ -17,29 +14,29 @@
|
||||||
|
|
||||||
// Find the closest parent form
|
// Find the closest parent form
|
||||||
$: form = findClosestMatchingComponent(
|
$: form = findClosestMatchingComponent(
|
||||||
$currentAsset.props,
|
$selectedScreen.props,
|
||||||
componentInstance._id,
|
componentInstance._id,
|
||||||
component => component._component.endsWith("/form")
|
component => component._component.endsWith("/form")
|
||||||
)
|
)
|
||||||
|
|
||||||
const resolveDatasource = (currentAsset, componentInstance, form) => {
|
const resolveDatasource = (selectedScreen, componentInstance, form) => {
|
||||||
if (!form && componentInstance._id != $componentStore.selectedComponentId) {
|
if (!form && componentInstance._id != $componentStore.selectedComponentId) {
|
||||||
const block = findComponent(
|
const block = findComponent(
|
||||||
currentAsset.props,
|
selectedScreen.props,
|
||||||
$componentStore.selectedComponentId
|
$componentStore.selectedComponentId
|
||||||
)
|
)
|
||||||
const def = componentStore.getDefinition(block._component)
|
const def = componentStore.getDefinition(block._component)
|
||||||
return def?.block === true
|
return def?.block === true
|
||||||
? getDatasourceForProvider(currentAsset, block)
|
? getDatasourceForProvider(selectedScreen, block)
|
||||||
: {}
|
: {}
|
||||||
} else {
|
} else {
|
||||||
return getDatasourceForProvider(currentAsset, form)
|
return getDatasourceForProvider(selectedScreen, form)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get that form's schema
|
// Get that form's schema
|
||||||
$: datasource = resolveDatasource($currentAsset, componentInstance, form)
|
$: datasource = resolveDatasource($selectedScreen, componentInstance, form)
|
||||||
$: formSchema = getSchemaForDatasource($currentAsset, datasource)?.schema
|
$: formSchema = getSchemaForDatasource($selectedScreen, datasource)?.schema
|
||||||
|
|
||||||
// Get the schema for the relationship field that this picker is using
|
// Get the schema for the relationship field that this picker is using
|
||||||
$: columnSchema = formSchema?.[column]
|
$: columnSchema = formSchema?.[column]
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
<script>
|
<script>
|
||||||
import { ActionButton, notifications } from "@budibase/bbui"
|
import { ActionButton, notifications } from "@budibase/bbui"
|
||||||
import { currentAsset, componentStore } from "stores/builder"
|
import { selectedScreen, componentStore } from "stores/builder"
|
||||||
import { findClosestMatchingComponent } from "stores/builder/components/utils"
|
import { findClosestMatchingComponent } from "helpers/components"
|
||||||
import { makeDatasourceFormComponents } from "builder/store/screenTemplates/utils/commonComponents"
|
import { makeDatasourceFormComponents } from "templates/commonComponents"
|
||||||
import ConfirmDialog from "components/common/ConfirmDialog.svelte"
|
import ConfirmDialog from "components/common/ConfirmDialog.svelte"
|
||||||
|
|
||||||
export let componentInstance
|
export let componentInstance
|
||||||
|
@ -11,7 +11,7 @@
|
||||||
|
|
||||||
const resetFormFields = async () => {
|
const resetFormFields = async () => {
|
||||||
const form = findClosestMatchingComponent(
|
const form = findClosestMatchingComponent(
|
||||||
$currentAsset?.props,
|
$selectedScreen?.props,
|
||||||
componentInstance._id,
|
componentInstance._id,
|
||||||
component => component._component.endsWith("/form")
|
component => component._component.endsWith("/form")
|
||||||
)
|
)
|
||||||
|
|
|
@ -1,10 +1,7 @@
|
||||||
<script>
|
<script>
|
||||||
import { Multiselect } from "@budibase/bbui"
|
import { Multiselect } from "@budibase/bbui"
|
||||||
import {
|
import { getDatasourceForProvider, getSchemaForDatasource } from "dataBinding"
|
||||||
getDatasourceForProvider,
|
import { selectedScreen, tables } from "stores/builder"
|
||||||
getSchemaForDatasource,
|
|
||||||
} from "builder/dataBinding"
|
|
||||||
import { currentAsset, tables } from "stores/builder"
|
|
||||||
import { createEventDispatcher } from "svelte"
|
import { createEventDispatcher } from "svelte"
|
||||||
import { getFields } from "helpers/searchFields"
|
import { getFields } from "helpers/searchFields"
|
||||||
|
|
||||||
|
@ -13,8 +10,8 @@
|
||||||
export let placeholder
|
export let placeholder
|
||||||
|
|
||||||
const dispatch = createEventDispatcher()
|
const dispatch = createEventDispatcher()
|
||||||
$: datasource = getDatasourceForProvider($currentAsset, componentInstance)
|
$: datasource = getDatasourceForProvider($selectedScreen, componentInstance)
|
||||||
$: schema = getSchemaForDatasource($currentAsset, datasource).schema
|
$: schema = getSchemaForDatasource($selectedScreen, datasource).schema
|
||||||
$: options = getOptions(datasource, schema || {})
|
$: options = getOptions(datasource, schema || {})
|
||||||
$: boundValue = getSelectedOption(value, options)
|
$: boundValue = getSelectedOption(value, options)
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,7 @@
|
||||||
<script>
|
<script>
|
||||||
import { Select } from "@budibase/bbui"
|
import { Select } from "@budibase/bbui"
|
||||||
import {
|
import { getDatasourceForProvider, getSchemaForDatasource } from "dataBinding"
|
||||||
getDatasourceForProvider,
|
import { selectedScreen } from "stores/builder"
|
||||||
getSchemaForDatasource,
|
|
||||||
} from "builder/dataBinding"
|
|
||||||
import { currentAsset } from "stores/builder"
|
|
||||||
import { createEventDispatcher } from "svelte"
|
import { createEventDispatcher } from "svelte"
|
||||||
import { canBeSortColumn } from "@budibase/shared-core"
|
import { canBeSortColumn } from "@budibase/shared-core"
|
||||||
|
|
||||||
|
@ -13,8 +10,8 @@
|
||||||
export let placeholder
|
export let placeholder
|
||||||
|
|
||||||
const dispatch = createEventDispatcher()
|
const dispatch = createEventDispatcher()
|
||||||
$: datasource = getDatasourceForProvider($currentAsset, componentInstance)
|
$: datasource = getDatasourceForProvider($selectedScreen, componentInstance)
|
||||||
$: schema = getSchemaForDatasource($currentAsset, datasource).schema
|
$: schema = getSchemaForDatasource($selectedScreen, datasource).schema
|
||||||
$: options = getSortableFields(schema)
|
$: options = getSortableFields(schema)
|
||||||
$: boundValue = getValidValue(value, options)
|
$: boundValue = getValidValue(value, options)
|
||||||
|
|
||||||
|
|
|
@ -10,12 +10,9 @@
|
||||||
Input,
|
Input,
|
||||||
DatePicker,
|
DatePicker,
|
||||||
} from "@budibase/bbui"
|
} from "@budibase/bbui"
|
||||||
import { currentAsset, selectedComponent } from "stores/builder"
|
import { selectedScreen, selectedComponent } from "stores/builder"
|
||||||
import { findClosestMatchingComponent } from "stores/builder/components/utils"
|
import { findClosestMatchingComponent } from "helpers/components"
|
||||||
import {
|
import { getSchemaForDatasource, getDatasourceForProvider } from "dataBinding"
|
||||||
getSchemaForDatasource,
|
|
||||||
getDatasourceForProvider,
|
|
||||||
} from "builder/dataBinding"
|
|
||||||
import DrawerBindableInput from "components/common/bindings/DrawerBindableInput.svelte"
|
import DrawerBindableInput from "components/common/bindings/DrawerBindableInput.svelte"
|
||||||
import { generate } from "shortid"
|
import { generate } from "shortid"
|
||||||
|
|
||||||
|
@ -127,13 +124,14 @@
|
||||||
],
|
],
|
||||||
}
|
}
|
||||||
|
|
||||||
const resolveDatasource = (currentAsset, componentInstance, parent) => {
|
const resolveDatasource = (selectedScreen, componentInstance, parent) => {
|
||||||
return (
|
return (
|
||||||
getDatasourceForProvider(currentAsset, parent || componentInstance) || {}
|
getDatasourceForProvider(selectedScreen, parent || componentInstance) ||
|
||||||
|
{}
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
$: dataSourceSchema = getDataSourceSchema($currentAsset, $selectedComponent)
|
$: dataSourceSchema = getDataSourceSchema($selectedScreen, $selectedComponent)
|
||||||
$: field = fieldName || $selectedComponent?.field
|
$: field = fieldName || $selectedComponent?.field
|
||||||
$: schemaRules = parseRulesFromSchema(field, dataSourceSchema || {})
|
$: schemaRules = parseRulesFromSchema(field, dataSourceSchema || {})
|
||||||
$: fieldType = type?.split("/")[1] || "string"
|
$: fieldType = type?.split("/")[1] || "string"
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
import {
|
import {
|
||||||
readableToRuntimeBinding,
|
readableToRuntimeBinding,
|
||||||
runtimeToReadableBinding,
|
runtimeToReadableBinding,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
import DrawerBindableInput from "components/common/bindings/DrawerBindableInput.svelte"
|
import DrawerBindableInput from "components/common/bindings/DrawerBindableInput.svelte"
|
||||||
import { createEventDispatcher } from "svelte"
|
import { createEventDispatcher } from "svelte"
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<script>
|
<script>
|
||||||
import KeyValueBuilder from "components/integration/KeyValueBuilder.svelte"
|
import KeyValueBuilder from "components/integration/KeyValueBuilder.svelte"
|
||||||
import { getUserBindings } from "builder/dataBinding"
|
import { getUserBindings } from "dataBinding"
|
||||||
|
|
||||||
export let queryBindings = []
|
export let queryBindings = []
|
||||||
|
|
||||||
|
|
|
@ -48,7 +48,7 @@
|
||||||
runtimeToReadableBinding,
|
runtimeToReadableBinding,
|
||||||
runtimeToReadableMap,
|
runtimeToReadableMap,
|
||||||
toBindingsArray,
|
toBindingsArray,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
|
|
||||||
export let queryId
|
export let queryId
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<script>
|
<script>
|
||||||
import { Body, ProgressBar, Heading, Icon, Link } from "@budibase/bbui"
|
import { Body, ProgressBar, Heading, Icon, Link } from "@budibase/bbui"
|
||||||
import { admin, auth } from "../../stores/portal"
|
import { admin, auth } from "stores/portal"
|
||||||
import { onMount } from "svelte"
|
import { onMount } from "svelte"
|
||||||
|
|
||||||
export let usage
|
export let usage
|
||||||
|
|
|
@ -5,9 +5,8 @@ import {
|
||||||
findAllMatchingComponents,
|
findAllMatchingComponents,
|
||||||
findComponent,
|
findComponent,
|
||||||
findComponentPath,
|
findComponentPath,
|
||||||
} from "stores/builder/components/utils"
|
} from "helpers/components"
|
||||||
import {
|
import {
|
||||||
currentAsset,
|
|
||||||
componentStore,
|
componentStore,
|
||||||
screenStore,
|
screenStore,
|
||||||
appStore,
|
appStore,
|
||||||
|
@ -15,6 +14,7 @@ import {
|
||||||
queries as queriesStores,
|
queries as queriesStores,
|
||||||
tables as tablesStore,
|
tables as tablesStore,
|
||||||
roles as rolesStore,
|
roles as rolesStore,
|
||||||
|
selectedScreen,
|
||||||
} from "stores/builder"
|
} from "stores/builder"
|
||||||
import {
|
import {
|
||||||
makePropSafe,
|
makePropSafe,
|
||||||
|
@ -22,7 +22,7 @@ import {
|
||||||
decodeJSBinding,
|
decodeJSBinding,
|
||||||
encodeJSBinding,
|
encodeJSBinding,
|
||||||
} from "@budibase/string-templates"
|
} from "@budibase/string-templates"
|
||||||
import { TableNames } from "../constants"
|
import { TableNames } from "constants"
|
||||||
import { JSONUtils } from "@budibase/frontend-core"
|
import { JSONUtils } from "@budibase/frontend-core"
|
||||||
import ActionDefinitions from "components/design/settings/controls/ButtonActionEditor/manifest.json"
|
import ActionDefinitions from "components/design/settings/controls/ButtonActionEditor/manifest.json"
|
||||||
import { environment, licensing } from "stores/portal"
|
import { environment, licensing } from "stores/portal"
|
||||||
|
@ -731,13 +731,11 @@ export const getEventContextBindings = ({
|
||||||
asset,
|
asset,
|
||||||
}) => {
|
}) => {
|
||||||
let bindings = []
|
let bindings = []
|
||||||
|
asset = asset ?? get(selectedScreen)
|
||||||
const selectedAsset = asset ?? get(currentAsset)
|
|
||||||
|
|
||||||
// Check if any context bindings are provided by the component for this
|
// Check if any context bindings are provided by the component for this
|
||||||
// setting
|
// setting
|
||||||
const component =
|
const component = componentInstance ?? findComponent(asset.props, componentId)
|
||||||
componentInstance ?? findComponent(selectedAsset.props, componentId)
|
|
||||||
|
|
||||||
if (!component) {
|
if (!component) {
|
||||||
return bindings
|
return bindings
|
|
@ -3,7 +3,7 @@ import {
|
||||||
runtimeToReadableBinding,
|
runtimeToReadableBinding,
|
||||||
readableToRuntimeBinding,
|
readableToRuntimeBinding,
|
||||||
updateReferencesInObject,
|
updateReferencesInObject,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
|
|
||||||
describe("Builder dataBinding", () => {
|
describe("Builder dataBinding", () => {
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
|
@ -6,7 +6,7 @@ import {
|
||||||
encodeJSBinding,
|
encodeJSBinding,
|
||||||
findHBSBlocks,
|
findHBSBlocks,
|
||||||
} from "@budibase/string-templates"
|
} from "@budibase/string-templates"
|
||||||
import { capitalise } from "helpers"
|
import { capitalise } from "./index"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Recursively searches for a specific component ID
|
* Recursively searches for a specific component ID
|
|
@ -1,8 +1,5 @@
|
||||||
import { findClosestMatchingComponent } from "stores/builder/components/utils"
|
import { findClosestMatchingComponent } from "helpers/components"
|
||||||
import {
|
import { getDatasourceForProvider, getSchemaForDatasource } from "dataBinding"
|
||||||
getDatasourceForProvider,
|
|
||||||
getSchemaForDatasource,
|
|
||||||
} from "builder/dataBinding"
|
|
||||||
|
|
||||||
export const getComponentFieldOptions = (asset, id, type, loose = true) => {
|
export const getComponentFieldOptions = (asset, id, type, loose = true) => {
|
||||||
const form = findClosestMatchingComponent(
|
const form = findClosestMatchingComponent(
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
import { ActionStepID } from "constants/backend/automations"
|
import { ActionStepID } from "constants/backend/automations"
|
||||||
import { TableNames } from "../constants"
|
import { TableNames } from "constants"
|
||||||
import {
|
import {
|
||||||
AUTO_COLUMN_DISPLAY_NAMES,
|
AUTO_COLUMN_DISPLAY_NAMES,
|
||||||
AUTO_COLUMN_SUB_TYPES,
|
AUTO_COLUMN_SUB_TYPES,
|
||||||
FIELDS,
|
FIELDS,
|
||||||
isAutoColumnUserRelationship,
|
isAutoColumnUserRelationship,
|
||||||
} from "../constants/backend"
|
} from "constants/backend"
|
||||||
|
|
||||||
export function getAutoColumnInformation(enabled = true) {
|
export function getAutoColumnInformation(enabled = true) {
|
||||||
let info = {}
|
let info = {}
|
|
@ -12,7 +12,7 @@
|
||||||
} from "@budibase/bbui"
|
} from "@budibase/bbui"
|
||||||
import { AUTH_TYPE_LABELS, AUTH_TYPES } from "./authTypes"
|
import { AUTH_TYPE_LABELS, AUTH_TYPES } from "./authTypes"
|
||||||
import BindableCombobox from "components/common/bindings/BindableCombobox.svelte"
|
import BindableCombobox from "components/common/bindings/BindableCombobox.svelte"
|
||||||
import { getAuthBindings, getEnvironmentBindings } from "builder/dataBinding"
|
import { getAuthBindings, getEnvironmentBindings } from "dataBinding"
|
||||||
import { environment, licensing, auth } from "stores/portal"
|
import { environment, licensing, auth } from "stores/portal"
|
||||||
import CreateEditVariableModal from "components/portal/environment/CreateEditVariableModal.svelte"
|
import CreateEditVariableModal from "components/portal/environment/CreateEditVariableModal.svelte"
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
getRestBindings,
|
getRestBindings,
|
||||||
readableToRuntimeBinding,
|
readableToRuntimeBinding,
|
||||||
runtimeToReadableMap,
|
runtimeToReadableMap,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
import { cloneDeep } from "lodash/fp"
|
import { cloneDeep } from "lodash/fp"
|
||||||
import SaveDatasourceButton from "./SaveDatasourceButton.svelte"
|
import SaveDatasourceButton from "./SaveDatasourceButton.svelte"
|
||||||
import Panel from "./Panel.svelte"
|
import Panel from "./Panel.svelte"
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
import { Heading, Layout } from "@budibase/bbui"
|
import { Heading, Layout } from "@budibase/bbui"
|
||||||
import KeyValueBuilder from "components/integration/KeyValueBuilder.svelte"
|
import KeyValueBuilder from "components/integration/KeyValueBuilder.svelte"
|
||||||
import ViewDynamicVariables from "./ViewDynamicVariables.svelte"
|
import ViewDynamicVariables from "./ViewDynamicVariables.svelte"
|
||||||
import { getEnvironmentBindings } from "builder/dataBinding"
|
import { getEnvironmentBindings } from "dataBinding"
|
||||||
import { licensing } from "stores/portal"
|
import { licensing } from "stores/portal"
|
||||||
import { queries } from "stores/builder"
|
import { queries } from "stores/builder"
|
||||||
import { cloneDeep } from "lodash/fp"
|
import { cloneDeep } from "lodash/fp"
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<script>
|
<script>
|
||||||
import { queries, datasources, database } from "stores/builder"
|
import { queries, datasources } from "stores/builder"
|
||||||
import QueryViewer from "components/integration/QueryViewer.svelte"
|
import QueryViewer from "components/integration/QueryViewer.svelte"
|
||||||
import RestQueryViewer from "components/integration/RestQueryViewer.svelte"
|
import RestQueryViewer from "components/integration/RestQueryViewer.svelte"
|
||||||
import { IntegrationTypes } from "constants/backend"
|
import { IntegrationTypes } from "constants/backend"
|
||||||
|
@ -11,7 +11,7 @@
|
||||||
$: isRestQuery = datasource?.source === IntegrationTypes.REST
|
$: isRestQuery = datasource?.source === IntegrationTypes.REST
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
{#if $database._id && query}
|
{#if query}
|
||||||
{#if isRestQuery}
|
{#if isRestQuery}
|
||||||
<RestQueryViewer queryId={$queries.selectedQueryId} />
|
<RestQueryViewer queryId={$queries.selectedQueryId} />
|
||||||
{:else}
|
{:else}
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
import QueryViewer from "components/integration/QueryViewer.svelte"
|
import QueryViewer from "components/integration/QueryViewer.svelte"
|
||||||
import RestQueryViewer from "components/integration/RestQueryViewer.svelte"
|
import RestQueryViewer from "components/integration/RestQueryViewer.svelte"
|
||||||
import { IntegrationTypes } from "constants/backend"
|
import { IntegrationTypes } from "constants/backend"
|
||||||
import { database, datasources } from "stores/builder"
|
import { datasources } from "stores/builder"
|
||||||
|
|
||||||
$: datasource = $datasources.list.find(ds => ds._id === $params.datasourceId)
|
$: datasource = $datasources.list.find(ds => ds._id === $params.datasourceId)
|
||||||
$: {
|
$: {
|
||||||
|
@ -32,7 +32,7 @@
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
{#if $database._id && datasource && query}
|
{#if datasource && query}
|
||||||
{#if isRestQuery}
|
{#if isRestQuery}
|
||||||
<RestQueryViewer />
|
<RestQueryViewer />
|
||||||
{:else}
|
{:else}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<script>
|
<script>
|
||||||
import TableDataTable from "components/backend/DataTable/TableDataTable.svelte"
|
import TableDataTable from "components/backend/DataTable/TableDataTable.svelte"
|
||||||
import { tables, database } from "stores/builder"
|
import { tables } from "stores/builder"
|
||||||
import { Banner } from "@budibase/bbui"
|
import { Banner } from "@budibase/bbui"
|
||||||
|
|
||||||
const verifyAutocolumns = table => {
|
const verifyAutocolumns = table => {
|
||||||
|
@ -30,7 +30,7 @@
|
||||||
})
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
{#if $database?._id && $tables?.selected?.name}
|
{#if $tables?.selected?.name}
|
||||||
{#if duplicates?.length}
|
{#if duplicates?.length}
|
||||||
<div class="alert-wrap">
|
<div class="alert-wrap">
|
||||||
<Banner type="warning" showCloseButton={false}>
|
<Banner type="warning" showCloseButton={false}>
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
<script>
|
<script>
|
||||||
import ViewDataTable from "components/backend/DataTable/ViewDataTable.svelte"
|
import ViewDataTable from "components/backend/DataTable/ViewDataTable.svelte"
|
||||||
import { views, database } from "stores/builder"
|
import { views } from "stores/builder"
|
||||||
|
|
||||||
$: selectedView = $views.selected
|
$: selectedView = $views.selected
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
{#if $database._id && selectedView}
|
{#if selectedView}
|
||||||
<ViewDataTable view={selectedView} />
|
<ViewDataTable view={selectedView} />
|
||||||
{:else}<i>Create your first table to start building</i>{/if}
|
{:else}<i>Create your first table to start building</i>{/if}
|
||||||
|
|
||||||
|
|
|
@ -9,11 +9,11 @@
|
||||||
import DesignSection from "./DesignSection.svelte"
|
import DesignSection from "./DesignSection.svelte"
|
||||||
import CustomStylesSection from "./CustomStylesSection.svelte"
|
import CustomStylesSection from "./CustomStylesSection.svelte"
|
||||||
import ConditionalUISection from "./ConditionalUISection.svelte"
|
import ConditionalUISection from "./ConditionalUISection.svelte"
|
||||||
import { getComponentName } from "stores/builder/components/utils"
|
import { getComponentName } from "helpers/components"
|
||||||
import {
|
import {
|
||||||
getBindableProperties,
|
getBindableProperties,
|
||||||
getComponentBindableProperties,
|
getComponentBindableProperties,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
import { ActionButton, notifications } from "@budibase/bbui"
|
import { ActionButton, notifications } from "@budibase/bbui"
|
||||||
import { capitalise } from "helpers"
|
import { capitalise } from "helpers"
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
getBindableProperties,
|
getBindableProperties,
|
||||||
readableToRuntimeBinding,
|
readableToRuntimeBinding,
|
||||||
runtimeToReadableBinding,
|
runtimeToReadableBinding,
|
||||||
} from "builder/dataBinding"
|
} from "dataBinding"
|
||||||
|
|
||||||
export let componentInstance
|
export let componentInstance
|
||||||
export let componentDefinition
|
export let componentDefinition
|
||||||
|
|
|
@ -11,9 +11,9 @@
|
||||||
import PropertyControl from "components/design/settings/controls/PropertyControl.svelte"
|
import PropertyControl from "components/design/settings/controls/PropertyControl.svelte"
|
||||||
import RoleSelect from "components/design/settings/controls/RoleSelect.svelte"
|
import RoleSelect from "components/design/settings/controls/RoleSelect.svelte"
|
||||||
import { selectedScreen, screenStore } from "stores/builder"
|
import { selectedScreen, screenStore } from "stores/builder"
|
||||||
import sanitizeUrl from "builder/store/screenTemplates/utils/sanitizeUrl"
|
import sanitizeUrl from "helpers/sanitizeUrl"
|
||||||
import ButtonActionEditor from "components/design/settings/controls/ButtonActionEditor/ButtonActionEditor.svelte"
|
import ButtonActionEditor from "components/design/settings/controls/ButtonActionEditor/ButtonActionEditor.svelte"
|
||||||
import { getBindableProperties } from "builder/dataBinding"
|
import { getBindableProperties } from "dataBinding"
|
||||||
|
|
||||||
$: bindings = getBindableProperties($selectedScreen, null)
|
$: bindings = getBindableProperties($selectedScreen, null)
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
} from "stores/builder"
|
} from "stores/builder"
|
||||||
import * as routify from "@roxi/routify"
|
import * as routify from "@roxi/routify"
|
||||||
import { onDestroy } from "svelte"
|
import { onDestroy } from "svelte"
|
||||||
import { findComponent } from "stores/builder/components/utils"
|
import { findComponent } from "helpers/components"
|
||||||
import ComponentSettingsPanel from "./_components/Component/ComponentSettingsPanel.svelte"
|
import ComponentSettingsPanel from "./_components/Component/ComponentSettingsPanel.svelte"
|
||||||
import NavigationPanel from "./_components/Navigation/index.svelte"
|
import NavigationPanel from "./_components/Navigation/index.svelte"
|
||||||
import ScreenSettingsPanel from "./_components/Screen/index.svelte"
|
import ScreenSettingsPanel from "./_components/Screen/index.svelte"
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
} from "stores/builder"
|
} from "stores/builder"
|
||||||
import { onMount } from "svelte"
|
import { onMount } from "svelte"
|
||||||
import { fly } from "svelte/transition"
|
import { fly } from "svelte/transition"
|
||||||
import { findComponentPath } from "stores/builder/components/utils"
|
import { findComponentPath } from "helpers/components"
|
||||||
|
|
||||||
let searchString
|
let searchString
|
||||||
let searchRef
|
let searchRef
|
||||||
|
|
|
@ -9,7 +9,6 @@
|
||||||
appStore,
|
appStore,
|
||||||
navigationStore,
|
navigationStore,
|
||||||
selectedScreen,
|
selectedScreen,
|
||||||
currentAsset,
|
|
||||||
hoverStore,
|
hoverStore,
|
||||||
} from "stores/builder"
|
} from "stores/builder"
|
||||||
import ConfirmDialog from "components/common/ConfirmDialog.svelte"
|
import ConfirmDialog from "components/common/ConfirmDialog.svelte"
|
||||||
|
@ -22,10 +21,7 @@
|
||||||
notifications,
|
notifications,
|
||||||
} from "@budibase/bbui"
|
} from "@budibase/bbui"
|
||||||
import ErrorSVG from "@budibase/frontend-core/assets/error.svg?raw"
|
import ErrorSVG from "@budibase/frontend-core/assets/error.svg?raw"
|
||||||
import {
|
import { findComponent, findComponentPath } from "helpers/components"
|
||||||
findComponent,
|
|
||||||
findComponentPath,
|
|
||||||
} from "stores/builder/components/utils"
|
|
||||||
import { isActive, goto } from "@roxi/routify"
|
import { isActive, goto } from "@roxi/routify"
|
||||||
|
|
||||||
let iframe
|
let iframe
|
||||||
|
@ -147,7 +143,7 @@
|
||||||
const { key, ctrlKey } = data
|
const { key, ctrlKey } = data
|
||||||
document.dispatchEvent(new KeyboardEvent("keydown", { key, ctrlKey }))
|
document.dispatchEvent(new KeyboardEvent("keydown", { key, ctrlKey }))
|
||||||
} else if (type === "duplicate-component" && data.id) {
|
} else if (type === "duplicate-component" && data.id) {
|
||||||
const rootComponent = get(currentAsset).props
|
const rootComponent = get(selectedScreen).props
|
||||||
const component = findComponent(rootComponent, data.id)
|
const component = findComponent(rootComponent, data.id)
|
||||||
componentStore.copy(component)
|
componentStore.copy(component)
|
||||||
await componentStore.paste(component)
|
await componentStore.paste(component)
|
||||||
|
@ -157,7 +153,7 @@
|
||||||
loading = false
|
loading = false
|
||||||
} else if (type === "move-component") {
|
} else if (type === "move-component") {
|
||||||
const { componentId, destinationComponentId } = data
|
const { componentId, destinationComponentId } = data
|
||||||
const rootComponent = get(currentAsset).props
|
const rootComponent = get(selectedScreen).props
|
||||||
|
|
||||||
// Get source and destination components
|
// Get source and destination components
|
||||||
const source = findComponent(rootComponent, componentId)
|
const source = findComponent(rootComponent, componentId)
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
componentStore,
|
componentStore,
|
||||||
selectedComponent,
|
selectedComponent,
|
||||||
} from "stores/builder"
|
} from "stores/builder"
|
||||||
import { findComponent } from "stores/builder/components/utils"
|
import { findComponent } from "helpers/components"
|
||||||
import { goto, isActive } from "@roxi/routify"
|
import { goto, isActive } from "@roxi/routify"
|
||||||
import { notifications } from "@budibase/bbui"
|
import { notifications } from "@budibase/bbui"
|
||||||
import ConfirmDialog from "components/common/ConfirmDialog.svelte"
|
import ConfirmDialog from "components/common/ConfirmDialog.svelte"
|
||||||
|
|
|
@ -14,7 +14,7 @@
|
||||||
findComponentPath,
|
findComponentPath,
|
||||||
getComponentText,
|
getComponentText,
|
||||||
getComponentName,
|
getComponentName,
|
||||||
} from "stores/builder/components/utils"
|
} from "helpers/components"
|
||||||
import { get } from "svelte/store"
|
import { get } from "svelte/store"
|
||||||
import { dndStore } from "./dndStore"
|
import { dndStore } from "./dndStore"
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,5 @@
|
||||||
import { writable, get } from "svelte/store"
|
import { writable, get } from "svelte/store"
|
||||||
import {
|
import { findComponentParent, findComponentPath } from "helpers/components"
|
||||||
findComponentParent,
|
|
||||||
findComponentPath,
|
|
||||||
} from "stores/builder/components/utils"
|
|
||||||
import { selectedScreen, componentStore } from "stores/builder"
|
import { selectedScreen, componentStore } from "stores/builder"
|
||||||
|
|
||||||
export const DropPosition = {
|
export const DropPosition = {
|
||||||
|
|
|
@ -10,8 +10,8 @@
|
||||||
notifications,
|
notifications,
|
||||||
} from "@budibase/bbui"
|
} from "@budibase/bbui"
|
||||||
import ScreenDetailsModal from "components/design/ScreenDetailsModal.svelte"
|
import ScreenDetailsModal from "components/design/ScreenDetailsModal.svelte"
|
||||||
import sanitizeUrl from "builder/store/screenTemplates/utils/sanitizeUrl"
|
import sanitizeUrl from "helpers/sanitizeUrl"
|
||||||
import { makeComponentUnique } from "stores/builder/components/utils"
|
import { makeComponentUnique } from "helpers/components"
|
||||||
|
|
||||||
export let screenId
|
export let screenId
|
||||||
|
|
||||||
|
|
|
@ -2,11 +2,11 @@
|
||||||
import ScreenDetailsModal from "components/design/ScreenDetailsModal.svelte"
|
import ScreenDetailsModal from "components/design/ScreenDetailsModal.svelte"
|
||||||
import DatasourceModal from "./DatasourceModal.svelte"
|
import DatasourceModal from "./DatasourceModal.svelte"
|
||||||
import ScreenRoleModal from "./ScreenRoleModal.svelte"
|
import ScreenRoleModal from "./ScreenRoleModal.svelte"
|
||||||
import sanitizeUrl from "builder/store/screenTemplates/utils/sanitizeUrl"
|
import sanitizeUrl from "helpers/sanitizeUrl"
|
||||||
import { Modal, notifications } from "@budibase/bbui"
|
import { Modal, notifications } from "@budibase/bbui"
|
||||||
import { screenStore, navigationStore, tables } from "stores/builder"
|
import { screenStore, navigationStore, tables } from "stores/builder"
|
||||||
import { get } from "svelte/store"
|
import { get } from "svelte/store"
|
||||||
import getTemplates from "builder/store/screenTemplates"
|
import getTemplates from "templates"
|
||||||
import { Roles } from "constants/backend"
|
import { Roles } from "constants/backend"
|
||||||
import { capitalise } from "helpers"
|
import { capitalise } from "helpers"
|
||||||
import { goto } from "@roxi/routify"
|
import { goto } from "@roxi/routify"
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
import ICONS from "components/backend/DatasourceNavigator/icons"
|
import ICONS from "components/backend/DatasourceNavigator/icons"
|
||||||
import { IntegrationNames } from "constants"
|
import { IntegrationNames } from "constants"
|
||||||
import { onMount } from "svelte"
|
import { onMount } from "svelte"
|
||||||
import rowListScreen from "builder/store/screenTemplates/rowListScreen"
|
import rowListScreen from "templates/rowListScreen"
|
||||||
import DatasourceTemplateRow from "./DatasourceTemplateRow.svelte"
|
import DatasourceTemplateRow from "./DatasourceTemplateRow.svelte"
|
||||||
|
|
||||||
export let mode
|
export let mode
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
import { auth, admin } from "stores/portal"
|
import { auth, admin } from "stores/portal"
|
||||||
import { redirect } from "@roxi/routify"
|
import { redirect } from "@roxi/routify"
|
||||||
import { processStringSync } from "@budibase/string-templates"
|
import { processStringSync } from "@budibase/string-templates"
|
||||||
import DeleteLicenseKeyModal from "../../../../components/portal/licensing/DeleteLicenseKeyModal.svelte"
|
import DeleteLicenseKeyModal from "components/portal/licensing/DeleteLicenseKeyModal.svelte"
|
||||||
import { API } from "api"
|
import { API } from "api"
|
||||||
import { onMount } from "svelte"
|
import { onMount } from "svelte"
|
||||||
import { sdk } from "@budibase/shared-core"
|
import { sdk } from "@budibase/shared-core"
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
import { notifications } from "@budibase/bbui"
|
import { notifications } from "@budibase/bbui"
|
||||||
import { SplitPage } from "@budibase/frontend-core"
|
import { SplitPage } from "@budibase/frontend-core"
|
||||||
import { API } from "api"
|
import { API } from "api"
|
||||||
import { database } from "stores/builder"
|
|
||||||
import { auth, admin } from "stores/portal"
|
import { auth, admin } from "stores/portal"
|
||||||
|
|
||||||
let name = "My first app"
|
let name = "My first app"
|
||||||
|
@ -26,9 +25,6 @@
|
||||||
|
|
||||||
const createdApp = await API.createApp(data)
|
const createdApp = await API.createApp(data)
|
||||||
|
|
||||||
// Select Correct Application/DB in prep for creating user
|
|
||||||
database.syncAppDatabase(createdApp)
|
|
||||||
|
|
||||||
// Update checklist - in case first app
|
// Update checklist - in case first app
|
||||||
await admin.init()
|
await admin.init()
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<script>
|
<script>
|
||||||
import { ModalContent, Body, Layout, Icon } from "@budibase/bbui"
|
import { ModalContent, Body, Layout, Icon } from "@budibase/bbui"
|
||||||
import { OnboardingType } from "../../../../../../constants"
|
import { OnboardingType } from "constants"
|
||||||
|
|
||||||
export let chooseCreationType
|
export let chooseCreationType
|
||||||
|
|
||||||
|
|
|
@ -36,7 +36,7 @@
|
||||||
import { get } from "svelte/store"
|
import { get } from "svelte/store"
|
||||||
import { Constants, Utils, fetchData } from "@budibase/frontend-core"
|
import { Constants, Utils, fetchData } from "@budibase/frontend-core"
|
||||||
import { API } from "api"
|
import { API } from "api"
|
||||||
import { OnboardingType } from "../../../../../constants"
|
import { OnboardingType } from "constants"
|
||||||
import ScimBanner from "../_components/SCIMBanner.svelte"
|
import ScimBanner from "../_components/SCIMBanner.svelte"
|
||||||
import { sdk } from "@budibase/shared-core"
|
import { sdk } from "@budibase/shared-core"
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<script>
|
<script>
|
||||||
import { redirect } from "@roxi/routify"
|
import { redirect } from "@roxi/routify"
|
||||||
import { auth } from "../stores/portal"
|
import { auth } from "stores/portal"
|
||||||
import { onMount } from "svelte"
|
import { onMount } from "svelte"
|
||||||
import { notifications } from "@budibase/bbui"
|
import { notifications } from "@budibase/bbui"
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,7 @@ import { cloneDeep } from "lodash/fp"
|
||||||
import { generate } from "shortid"
|
import { generate } from "shortid"
|
||||||
import { createHistoryStore } from "stores/builder/history"
|
import { createHistoryStore } from "stores/builder/history"
|
||||||
import { notifications } from "@budibase/bbui"
|
import { notifications } from "@budibase/bbui"
|
||||||
import { updateReferencesInObject } from "builder/dataBinding"
|
import { updateReferencesInObject } from "dataBinding"
|
||||||
|
|
||||||
const initialAutomationState = {
|
const initialAutomationState = {
|
||||||
automations: [],
|
automations: [],
|
||||||
|
|
|
@ -11,18 +11,23 @@ import {
|
||||||
findComponentParent,
|
findComponentParent,
|
||||||
findAllMatchingComponents,
|
findAllMatchingComponents,
|
||||||
makeComponentUnique,
|
makeComponentUnique,
|
||||||
} from "stores/builder/components/utils"
|
} from "helpers/components"
|
||||||
import { getComponentFieldOptions } from "helpers/formFields"
|
import { getComponentFieldOptions } from "helpers/formFields"
|
||||||
import { selectedScreen } from "../screens"
|
import { selectedScreen } from "./screens"
|
||||||
import { screenStore, appStore, previewStore, tables } from "stores/builder"
|
import {
|
||||||
import { buildFormSchema, getSchemaForDatasource } from "builder/dataBinding"
|
screenStore,
|
||||||
|
appStore,
|
||||||
|
previewStore,
|
||||||
|
tables,
|
||||||
|
} from "stores/builder/index"
|
||||||
|
import { buildFormSchema, getSchemaForDatasource } from "dataBinding"
|
||||||
import {
|
import {
|
||||||
BUDIBASE_INTERNAL_DB_ID,
|
BUDIBASE_INTERNAL_DB_ID,
|
||||||
DEFAULT_BB_DATASOURCE_ID,
|
DEFAULT_BB_DATASOURCE_ID,
|
||||||
DB_TYPE_INTERNAL,
|
DB_TYPE_INTERNAL,
|
||||||
DB_TYPE_EXTERNAL,
|
DB_TYPE_EXTERNAL,
|
||||||
} from "constants/backend"
|
} from "constants/backend"
|
||||||
import BudiStore from "../BudiStore"
|
import BudiStore from "./BudiStore"
|
||||||
import { Utils } from "@budibase/frontend-core"
|
import { Utils } from "@budibase/frontend-core"
|
||||||
|
|
||||||
export const INITIAL_COMPONENTS_STATE = {
|
export const INITIAL_COMPONENTS_STATE = {
|
||||||
|
@ -67,39 +72,6 @@ export class ComponentStore extends BudiStore {
|
||||||
this.isCached = this.isCached.bind(this)
|
this.isCached = this.isCached.bind(this)
|
||||||
this.cacheSettings = this.cacheSettings.bind(this)
|
this.cacheSettings = this.cacheSettings.bind(this)
|
||||||
this.getComponentSettings = this.getComponentSettings.bind(this)
|
this.getComponentSettings = this.getComponentSettings.bind(this)
|
||||||
|
|
||||||
this.selected = derived(
|
|
||||||
[this.store, selectedScreen],
|
|
||||||
([$store, $selectedScreen]) => {
|
|
||||||
if (
|
|
||||||
$selectedScreen &&
|
|
||||||
$store.selectedComponentId?.startsWith(`${$selectedScreen._id}-`)
|
|
||||||
) {
|
|
||||||
return $selectedScreen?.props
|
|
||||||
}
|
|
||||||
if (!$selectedScreen || !$store.selectedComponentId) {
|
|
||||||
return null
|
|
||||||
}
|
|
||||||
const selected = findComponent(
|
|
||||||
$selectedScreen?.props,
|
|
||||||
$store.selectedComponentId
|
|
||||||
)
|
|
||||||
|
|
||||||
const clone = selected ? cloneDeep(selected) : selected
|
|
||||||
this.migrateSettings(clone)
|
|
||||||
return clone
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
this.selectedComponentPath = derived(
|
|
||||||
[this.store, selectedScreen],
|
|
||||||
([$store, $selectedScreen]) => {
|
|
||||||
return findComponentPath(
|
|
||||||
$selectedScreen?.props,
|
|
||||||
$store.selectedComponentId
|
|
||||||
).map(component => component._id)
|
|
||||||
}
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -197,7 +169,7 @@ export class ComponentStore extends BudiStore {
|
||||||
const componentPrefix = "@budibase/standard-components"
|
const componentPrefix = "@budibase/standard-components"
|
||||||
let migrated = false
|
let migrated = false
|
||||||
|
|
||||||
if (enrichedComponent?._component == `${componentPrefix}/formblock`) {
|
if (enrichedComponent?._component === `${componentPrefix}/formblock`) {
|
||||||
// Use default config if the 'buttons' prop has never been initialised
|
// Use default config if the 'buttons' prop has never been initialised
|
||||||
if (!("buttons" in enrichedComponent)) {
|
if (!("buttons" in enrichedComponent)) {
|
||||||
enrichedComponent["buttons"] =
|
enrichedComponent["buttons"] =
|
||||||
|
@ -1080,11 +1052,11 @@ export class ComponentStore extends BudiStore {
|
||||||
* @param {object} definition
|
* @param {object} definition
|
||||||
* @example
|
* @example
|
||||||
* '@budibase/standard-components/container'
|
* '@budibase/standard-components/container'
|
||||||
* @returns {boolean}
|
* @returns {array} the settings
|
||||||
*/
|
*/
|
||||||
cacheSettings(componentType, definition) {
|
cacheSettings(componentType, definition) {
|
||||||
let settings = []
|
let settings = []
|
||||||
if (definition && componentType) {
|
if (definition) {
|
||||||
settings = definition.settings?.filter(setting => !setting.section) ?? []
|
settings = definition.settings?.filter(setting => !setting.section) ?? []
|
||||||
definition.settings
|
definition.settings
|
||||||
?.filter(setting => setting.section)
|
?.filter(setting => setting.section)
|
||||||
|
@ -1096,6 +1068,7 @@ export class ComponentStore extends BudiStore {
|
||||||
}))
|
}))
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
|
}
|
||||||
this.update(state => ({
|
this.update(state => ({
|
||||||
...state,
|
...state,
|
||||||
settingsCache: {
|
settingsCache: {
|
||||||
|
@ -1103,7 +1076,7 @@ export class ComponentStore extends BudiStore {
|
||||||
[componentType]: settings,
|
[componentType]: settings,
|
||||||
},
|
},
|
||||||
}))
|
}))
|
||||||
}
|
return settings
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1129,18 +1102,49 @@ export class ComponentStore extends BudiStore {
|
||||||
componentType = `@budibase/standard-components/${componentType}`
|
componentType = `@budibase/standard-components/${componentType}`
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.isCached(componentType)) {
|
// Use cached value if possible
|
||||||
return get(this.store).settingsCache[componentType]
|
const cachedValue = get(this.store).settingsCache[componentType]
|
||||||
} else {
|
if (cachedValue) {
|
||||||
const def = this.getDefinition(componentType)
|
return cachedValue
|
||||||
this.cacheSettings(componentType, def)
|
|
||||||
return get(this.store).settingsCache[componentType]
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Otherwise cache and return new value
|
||||||
|
const def = this.getDefinition(componentType)
|
||||||
|
return this.cacheSettings(componentType, def)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export const componentStore = new ComponentStore()
|
export const componentStore = new ComponentStore()
|
||||||
|
|
||||||
export const selectedComponent = componentStore.selected
|
export const selectedComponent = derived(
|
||||||
|
[componentStore, selectedScreen],
|
||||||
|
([$store, $selectedScreen]) => {
|
||||||
|
if (
|
||||||
|
$selectedScreen &&
|
||||||
|
$store.selectedComponentId?.startsWith(`${$selectedScreen._id}-`)
|
||||||
|
) {
|
||||||
|
return $selectedScreen?.props
|
||||||
|
}
|
||||||
|
if (!$selectedScreen || !$store.selectedComponentId) {
|
||||||
|
return null
|
||||||
|
}
|
||||||
|
const selected = findComponent(
|
||||||
|
$selectedScreen?.props,
|
||||||
|
$store.selectedComponentId
|
||||||
|
)
|
||||||
|
|
||||||
export const selectedComponentPath = componentStore.selectedComponentPath
|
const clone = selected ? cloneDeep(selected) : selected
|
||||||
|
componentStore.migrateSettings(clone)
|
||||||
|
return clone
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
export const selectedComponentPath = derived(
|
||||||
|
[componentStore, selectedScreen],
|
||||||
|
([$store, $selectedScreen]) => {
|
||||||
|
return findComponentPath(
|
||||||
|
$selectedScreen?.props,
|
||||||
|
$store.selectedComponentId
|
||||||
|
).map(component => component._id)
|
||||||
|
}
|
||||||
|
)
|
|
@ -1,16 +0,0 @@
|
||||||
import { writable } from "svelte/store"
|
|
||||||
|
|
||||||
export const createDatabaseStore = () => {
|
|
||||||
const store = writable({})
|
|
||||||
|
|
||||||
const syncAppDatabase = application => {
|
|
||||||
store.set({ ...application.instance })
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
|
||||||
subscribe: store.subscribe,
|
|
||||||
syncAppDatabase,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export const database = createDatabaseStore()
|
|
|
@ -7,12 +7,7 @@ import {
|
||||||
} from "./components"
|
} from "./components"
|
||||||
import { navigationStore } from "./navigation.js"
|
import { navigationStore } from "./navigation.js"
|
||||||
import { themeStore } from "./theme.js"
|
import { themeStore } from "./theme.js"
|
||||||
import {
|
import { screenStore, selectedScreen, sortedScreens } from "./screens.js"
|
||||||
screenStore,
|
|
||||||
selectedScreen,
|
|
||||||
currentAsset,
|
|
||||||
sortedScreens,
|
|
||||||
} from "./screens.js"
|
|
||||||
import { builderStore } from "./builder.js"
|
import { builderStore } from "./builder.js"
|
||||||
import { hoverStore } from "./hover.js"
|
import { hoverStore } from "./hover.js"
|
||||||
import { previewStore } from "./preview.js"
|
import { previewStore } from "./preview.js"
|
||||||
|
@ -23,7 +18,6 @@ import {
|
||||||
} from "./automations.js"
|
} from "./automations.js"
|
||||||
import { userStore, userSelectedResourceMap, isOnlyUser } from "./users.js"
|
import { userStore, userSelectedResourceMap, isOnlyUser } from "./users.js"
|
||||||
import { deploymentStore } from "./deployments.js"
|
import { deploymentStore } from "./deployments.js"
|
||||||
import { database } from "./database.js"
|
|
||||||
|
|
||||||
// Backend
|
// Backend
|
||||||
import { tables } from "./tables"
|
import { tables } from "./tables"
|
||||||
|
@ -39,7 +33,6 @@ import { flags } from "./flags"
|
||||||
|
|
||||||
export {
|
export {
|
||||||
layoutStore,
|
layoutStore,
|
||||||
database,
|
|
||||||
appStore,
|
appStore,
|
||||||
componentStore,
|
componentStore,
|
||||||
navigationStore,
|
navigationStore,
|
||||||
|
@ -52,7 +45,6 @@ export {
|
||||||
automationStore,
|
automationStore,
|
||||||
selectedAutomation,
|
selectedAutomation,
|
||||||
automationHistoryStore,
|
automationHistoryStore,
|
||||||
currentAsset,
|
|
||||||
sortedScreens,
|
sortedScreens,
|
||||||
userStore,
|
userStore,
|
||||||
isOnlyUser,
|
isOnlyUser,
|
||||||
|
@ -82,13 +74,15 @@ export const reset = () => {
|
||||||
}
|
}
|
||||||
|
|
||||||
const refreshBuilderData = async () => {
|
const refreshBuilderData = async () => {
|
||||||
await automationStore.actions.fetch()
|
await Promise.all([
|
||||||
await datasources.init()
|
automationStore.actions.fetch(),
|
||||||
await integrations.init()
|
datasources.init(),
|
||||||
await queries.init()
|
integrations.init(),
|
||||||
await tables.init()
|
queries.init(),
|
||||||
await roles.fetch()
|
tables.init(),
|
||||||
await flags.fetch()
|
roles.fetch(),
|
||||||
|
flags.fetch(),
|
||||||
|
])
|
||||||
}
|
}
|
||||||
|
|
||||||
const resetBuilderHistory = () => {
|
const resetBuilderHistory = () => {
|
||||||
|
@ -98,27 +92,16 @@ const resetBuilderHistory = () => {
|
||||||
|
|
||||||
export const initialise = async pkg => {
|
export const initialise = async pkg => {
|
||||||
const { application } = pkg
|
const { application } = pkg
|
||||||
|
await Promise.all([
|
||||||
appStore.syncAppPackage(pkg)
|
appStore.syncAppRoutes(),
|
||||||
|
componentStore.refreshDefinitions(application?.appId),
|
||||||
appStore.syncAppRoutes()
|
])
|
||||||
|
|
||||||
builderStore.init(application)
|
builderStore.init(application)
|
||||||
|
appStore.syncAppPackage(pkg)
|
||||||
navigationStore.syncAppNavigation(application?.navigation)
|
navigationStore.syncAppNavigation(application?.navigation)
|
||||||
|
|
||||||
await componentStore.refreshDefinitions(application?.appId)
|
|
||||||
|
|
||||||
themeStore.syncAppTheme(application)
|
themeStore.syncAppTheme(application)
|
||||||
|
|
||||||
screenStore.syncAppScreens(pkg)
|
screenStore.syncAppScreens(pkg)
|
||||||
|
|
||||||
layoutStore.syncAppLayouts(pkg)
|
layoutStore.syncAppLayouts(pkg)
|
||||||
|
|
||||||
// required for api comms
|
|
||||||
database.syncAppDatabase(application)
|
|
||||||
|
|
||||||
resetBuilderHistory()
|
resetBuilderHistory()
|
||||||
|
|
||||||
await refreshBuilderData()
|
await refreshBuilderData()
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,12 +16,6 @@ export class LayoutStore extends BudiStore {
|
||||||
this.syncAppLayouts = this.syncAppLayouts.bind(this)
|
this.syncAppLayouts = this.syncAppLayouts.bind(this)
|
||||||
this.select = this.select.bind(this)
|
this.select = this.select.bind(this)
|
||||||
this.deleteLayout = this.deleteLayout.bind(this)
|
this.deleteLayout = this.deleteLayout.bind(this)
|
||||||
|
|
||||||
this.selectedLayout = derived(this.store, $store => {
|
|
||||||
return $store.layouts?.find(
|
|
||||||
layout => layout._id === $store.selectedLayoutId
|
|
||||||
)
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
reset() {
|
reset() {
|
||||||
|
@ -78,4 +72,6 @@ export class LayoutStore extends BudiStore {
|
||||||
|
|
||||||
export const layoutStore = new LayoutStore()
|
export const layoutStore = new LayoutStore()
|
||||||
|
|
||||||
export const selectedLayout = layoutStore.selectedLayout
|
export const selectedLayout = derived(layoutStore, $store => {
|
||||||
|
return $store.layouts?.find(layout => layout._id === $store.selectedLayoutId)
|
||||||
|
})
|
||||||
|
|
|
@ -2,7 +2,7 @@ import { derived, get } from "svelte/store"
|
||||||
import { cloneDeep } from "lodash/fp"
|
import { cloneDeep } from "lodash/fp"
|
||||||
import { Helpers } from "@budibase/bbui"
|
import { Helpers } from "@budibase/bbui"
|
||||||
import { RoleUtils, Utils } from "@budibase/frontend-core"
|
import { RoleUtils, Utils } from "@budibase/frontend-core"
|
||||||
import { findAllMatchingComponents } from "stores/builder/components/utils"
|
import { findAllMatchingComponents } from "helpers/components"
|
||||||
import {
|
import {
|
||||||
layoutStore,
|
layoutStore,
|
||||||
appStore,
|
appStore,
|
||||||
|
@ -39,12 +39,6 @@ export class ScreenStore extends BudiStore {
|
||||||
this.sequentialScreenPatch = this.sequentialScreenPatch.bind(this)
|
this.sequentialScreenPatch = this.sequentialScreenPatch.bind(this)
|
||||||
this.removeCustomLayout = this.removeCustomLayout.bind(this)
|
this.removeCustomLayout = this.removeCustomLayout.bind(this)
|
||||||
|
|
||||||
this.selected = derived(this.store, $store => {
|
|
||||||
return get(this.store).screens.find(
|
|
||||||
screen => screen._id === $store.selectedScreenId
|
|
||||||
)
|
|
||||||
})
|
|
||||||
|
|
||||||
this.history = createHistoryStore({
|
this.history = createHistoryStore({
|
||||||
getDoc: id => get(this.store).screens?.find(screen => screen._id === id),
|
getDoc: id => get(this.store).screens?.find(screen => screen._id === id),
|
||||||
selectDoc: this.select,
|
selectDoc: this.select,
|
||||||
|
@ -485,9 +479,9 @@ export class ScreenStore extends BudiStore {
|
||||||
|
|
||||||
export const screenStore = new ScreenStore()
|
export const screenStore = new ScreenStore()
|
||||||
|
|
||||||
export const selectedScreen = screenStore.selected
|
export const selectedScreen = derived(screenStore, $store => {
|
||||||
|
return $store.screens.find(screen => screen._id === $store.selectedScreenId)
|
||||||
export const currentAsset = selectedScreen
|
})
|
||||||
|
|
||||||
export const sortedScreens = derived(screenStore, $screenStore => {
|
export const sortedScreens = derived(screenStore, $screenStore => {
|
||||||
return $screenStore.screens.slice().sort((a, b) => {
|
return $screenStore.screens.slice().sort((a, b) => {
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import { v4 } from "uuid"
|
import { v4 } from "uuid"
|
||||||
import { Component } from "builder/store/screenTemplates/utils/Component"
|
import { Component } from "templates/Component"
|
||||||
import { Screen } from "builder/store/screenTemplates/utils/Screen"
|
import { Screen } from "templates/Screen"
|
||||||
import { get } from "svelte/store"
|
import { get } from "svelte/store"
|
||||||
import {
|
import {
|
||||||
BUDIBASE_INTERNAL_DB_ID,
|
BUDIBASE_INTERNAL_DB_ID,
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import { writable } from "svelte/store"
|
import { writable } from "svelte/store"
|
||||||
import { AppStatus } from "../../constants"
|
import { AppStatus } from "constants"
|
||||||
import { API } from "api"
|
import { API } from "api"
|
||||||
|
|
||||||
// properties that should always come from the dev app, not the deployed
|
// properties that should always come from the dev app, not the deployed
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import { Component } from "./Component"
|
import { Component } from "./Component"
|
||||||
import { getSchemaForDatasource } from "../../../dataBinding"
|
import { getSchemaForDatasource } from "dataBinding"
|
||||||
|
|
||||||
const fieldTypeToComponentMap = {
|
const fieldTypeToComponentMap = {
|
||||||
string: "stringfield",
|
string: "stringfield",
|
|
@ -1,4 +1,4 @@
|
||||||
import { Screen } from "./utils/Screen"
|
import { Screen } from "./Screen"
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: `Create from scratch`,
|
name: `Create from scratch`,
|
|
@ -1,6 +1,6 @@
|
||||||
import sanitizeUrl from "./utils/sanitizeUrl"
|
import sanitizeUrl from "helpers/sanitizeUrl"
|
||||||
import { Screen } from "./utils/Screen"
|
import { Screen } from "./Screen"
|
||||||
import { Component } from "./utils/Component"
|
import { Component } from "./Component"
|
||||||
|
|
||||||
export default function (datasources, mode = "table") {
|
export default function (datasources, mode = "table") {
|
||||||
if (!Array.isArray(datasources)) {
|
if (!Array.isArray(datasources)) {
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue