diff --git a/lerna.json b/lerna.json index 349c24622c..bdf32d27ba 100644 --- a/lerna.json +++ b/lerna.json @@ -1,5 +1,5 @@ { - "version": "2.4.27-alpha.5", + "version": "2.4.27-alpha.6", "npmClient": "yarn", "packages": [ "packages/*" diff --git a/packages/backend-core/package.json b/packages/backend-core/package.json index b1d17562c2..7d4bc7e033 100644 --- a/packages/backend-core/package.json +++ b/packages/backend-core/package.json @@ -1,6 +1,6 @@ { "name": "@budibase/backend-core", - "version": "2.4.27-alpha.5", + "version": "2.4.27-alpha.6", "description": "Budibase backend core libraries used in server and worker", "main": "dist/src/index.js", "types": "dist/src/index.d.ts", @@ -24,7 +24,7 @@ "dependencies": { "@budibase/nano": "10.1.2", "@budibase/pouchdb-replication-stream": "1.2.10", - "@budibase/types": "2.4.27-alpha.5", + "@budibase/types": "2.4.27-alpha.6", "@shopify/jest-koa-mocks": "5.0.1", "@techpass/passport-openidconnect": "0.3.2", "aws-cloudfront-sign": "2.2.0", diff --git a/packages/bbui/package.json b/packages/bbui/package.json index 3d79dd0a54..56bb1fd9f3 100644 --- a/packages/bbui/package.json +++ b/packages/bbui/package.json @@ -1,7 +1,7 @@ { "name": "@budibase/bbui", "description": "A UI solution used in the different Budibase projects.", - "version": "2.4.27-alpha.5", + "version": "2.4.27-alpha.6", "license": "MPL-2.0", "svelte": "src/index.js", "module": "dist/bbui.es.js", @@ -38,8 +38,8 @@ ], "dependencies": { "@adobe/spectrum-css-workflow-icons": "1.2.1", - "@budibase/shared-core": "2.4.27-alpha.5", - "@budibase/string-templates": "2.4.27-alpha.5", + "@budibase/shared-core": "2.4.27-alpha.6", + "@budibase/string-templates": "2.4.27-alpha.6", "@spectrum-css/accordion": "3.0.24", "@spectrum-css/actionbutton": "1.0.1", "@spectrum-css/actiongroup": "1.0.1", diff --git a/packages/bbui/src/Skeleton/Skeleton.svelte b/packages/bbui/src/Skeleton/Skeleton.svelte deleted file mode 100644 index 92357a8c75..0000000000 --- a/packages/bbui/src/Skeleton/Skeleton.svelte +++ /dev/null @@ -1,56 +0,0 @@ -
-
- -
-
- - diff --git a/packages/bbui/src/index.js b/packages/bbui/src/index.js index 9aa377b147..d26b938dd5 100644 --- a/packages/bbui/src/index.js +++ b/packages/bbui/src/index.js @@ -4,7 +4,6 @@ import "./bbui.css" import "@spectrum-css/icon/dist/index-vars.css" // Components -export { default as Skeleton } from "./Skeleton/Skeleton.svelte" export { default as Input } from "./Form/Input.svelte" export { default as Stepper } from "./Form/Stepper.svelte" export { default as TextArea } from "./Form/TextArea.svelte" diff --git a/packages/builder/package.json b/packages/builder/package.json index f988643fd3..cfd91b366c 100644 --- a/packages/builder/package.json +++ b/packages/builder/package.json @@ -1,6 +1,6 @@ { "name": "@budibase/builder", - "version": "2.4.27-alpha.5", + "version": "2.4.27-alpha.6", "license": "GPL-3.0", "private": true, "scripts": { @@ -58,11 +58,11 @@ } }, "dependencies": { - "@budibase/bbui": "2.4.27-alpha.5", - "@budibase/client": "2.4.27-alpha.5", - "@budibase/frontend-core": "2.4.27-alpha.5", - "@budibase/shared-core": "2.4.27-alpha.5", - "@budibase/string-templates": "2.4.27-alpha.5", + "@budibase/bbui": "2.4.27-alpha.6", + "@budibase/client": "2.4.27-alpha.6", + "@budibase/frontend-core": "2.4.27-alpha.6", + "@budibase/shared-core": "2.4.27-alpha.6", + "@budibase/string-templates": "2.4.27-alpha.6", "@fortawesome/fontawesome-svg-core": "^6.2.1", "@fortawesome/free-brands-svg-icons": "^6.2.1", "@fortawesome/free-solid-svg-icons": "^6.2.1", diff --git a/packages/cli/package.json b/packages/cli/package.json index 265a56591b..e66e0d0268 100644 --- a/packages/cli/package.json +++ b/packages/cli/package.json @@ -1,6 +1,6 @@ { "name": "@budibase/cli", - "version": "2.4.27-alpha.5", + "version": "2.4.27-alpha.6", "description": "Budibase CLI, for developers, self hosting and migrations.", "main": "dist/index.js", "bin": { @@ -29,9 +29,9 @@ "outputPath": "build" }, "dependencies": { - "@budibase/backend-core": "2.4.27-alpha.5", - "@budibase/string-templates": "2.4.27-alpha.5", - "@budibase/types": "2.4.27-alpha.5", + "@budibase/backend-core": "2.4.27-alpha.6", + "@budibase/string-templates": "2.4.27-alpha.6", + "@budibase/types": "2.4.27-alpha.6", "axios": "0.21.2", "chalk": "4.1.0", "cli-progress": "3.11.2", diff --git a/packages/client/manifest.json b/packages/client/manifest.json index 2579cdedaa..0ac7f6808f 100644 --- a/packages/client/manifest.json +++ b/packages/client/manifest.json @@ -2346,7 +2346,6 @@ ] }, "stringfield": { - "skeleton": false, "name": "Text Field", "icon": "Text", "styles": ["size"], @@ -2436,7 +2435,6 @@ ] }, "numberfield": { - "skeleton": false, "name": "Number Field", "icon": "123", "styles": ["size"], @@ -2492,7 +2490,6 @@ ] }, "passwordfield": { - "skeleton": false, "name": "Password Field", "icon": "LockClosed", "styles": ["size"], @@ -2548,7 +2545,6 @@ ] }, "optionsfield": { - "skeleton": false, "name": "Options Picker", "icon": "Menu", "styles": ["size"], @@ -2715,7 +2711,6 @@ ] }, "multifieldselect": { - "skeleton": false, "name": "Multi-select Picker", "icon": "ViewList", "styles": ["size"], @@ -2876,7 +2871,6 @@ ] }, "booleanfield": { - "skeleton": false, "name": "Checkbox", "icon": "SelectBox", "editable": true, @@ -2955,7 +2949,6 @@ ] }, "longformfield": { - "skeleton": false, "name": "Long Form Field", "icon": "TextAlignLeft", "styles": ["size"], @@ -3033,7 +3026,6 @@ ] }, "datetimefield": { - "skeleton": false, "name": "Date Picker", "icon": "Date", "styles": ["size"], @@ -3113,7 +3105,6 @@ ] }, "codescanner": { - "skeleton": false, "name": "Barcode/QR Scanner", "icon": "Camera", "styles": ["size"], @@ -3275,7 +3266,6 @@ ] }, "attachmentfield": { - "skeleton": false, "name": "Attachment", "icon": "Attach", "styles": ["size"], @@ -3338,7 +3328,6 @@ ] }, "relationshipfield": { - "skeleton": false, "name": "Relationship Picker", "icon": "TaskList", "styles": ["size"], @@ -3400,7 +3389,6 @@ ] }, "jsonfield": { - "skeleton": false, "name": "JSON Field", "icon": "Brackets", "styles": ["size"], @@ -3591,7 +3579,6 @@ } }, "table": { - "skeleton": false, "name": "Table", "icon": "Table", "illegalChildren": ["section"], diff --git a/packages/client/package.json b/packages/client/package.json index 4cf4ad7c59..99d97f7143 100644 --- a/packages/client/package.json +++ b/packages/client/package.json @@ -1,6 +1,6 @@ { "name": "@budibase/client", - "version": "2.4.27-alpha.5", + "version": "2.4.27-alpha.6", "license": "MPL-2.0", "module": "dist/budibase-client.js", "main": "dist/budibase-client.js", @@ -19,11 +19,11 @@ "dev:builder": "rollup -cw" }, "dependencies": { - "@budibase/bbui": "2.4.27-alpha.5", - "@budibase/frontend-core": "2.4.27-alpha.5", - "@budibase/shared-core": "2.4.27-alpha.5", - "@budibase/string-templates": "2.4.27-alpha.5", - "@budibase/types": "2.4.27-alpha.5", + "@budibase/bbui": "2.4.27-alpha.6", + "@budibase/frontend-core": "2.4.27-alpha.6", + "@budibase/shared-core": "2.4.27-alpha.6", + "@budibase/string-templates": "2.4.27-alpha.6", + "@budibase/types": "2.4.27-alpha.6", "@spectrum-css/button": "^3.0.3", "@spectrum-css/card": "^3.0.3", "@spectrum-css/divider": "^1.0.3", diff --git a/packages/client/src/components/BlockComponent.svelte b/packages/client/src/components/BlockComponent.svelte index 841aeb219a..4f720e2931 100644 --- a/packages/client/src/components/BlockComponent.svelte +++ b/packages/client/src/components/BlockComponent.svelte @@ -24,7 +24,6 @@ // to render this part of the block, taking advantage of binding enrichment $: id = `${block.id}-${context ?? rand}` $: instance = { - _blockElementHasChildren: $$slots?.default ?? false, _component: `@budibase/standard-components/${type}`, _id: id, _instanceName: name || type[0].toUpperCase() + type.slice(1), diff --git a/packages/client/src/components/Component.svelte b/packages/client/src/components/Component.svelte index d94199bc49..c0b8febd96 100644 --- a/packages/client/src/components/Component.svelte +++ b/packages/client/src/components/Component.svelte @@ -29,7 +29,6 @@ import Placeholder from "components/app/Placeholder.svelte" import ScreenPlaceholder from "components/app/ScreenPlaceholder.svelte" import ComponentPlaceholder from "components/app/ComponentPlaceholder.svelte" - import Skeleton from "components/app/Skeleton.svelte" export let instance = {} export let isLayout = false @@ -39,7 +38,6 @@ // Get parent contexts const context = getContext("context") - const loading = getContext("loading") const insideScreenslot = !!getContext("screenslot") // Create component context @@ -172,15 +170,6 @@ $: pad = pad || (interactive && hasChildren && inDndPath) $: $dndIsDragging, (pad = false) - // Determine whether we should render a skeleton loader for this component - $: showSkeleton = - $loading && - definition?.name !== "Screenslot" && - children.length === 0 && - !instance._blockElementHasChildren && - !definition?.block && - definition?.skeleton !== false - // Update component context $: store.set({ id, @@ -507,12 +496,7 @@ }) -{#if showSkeleton} - -{:else if constructor && initialSettings && (visible || inSelectedPath) && !builderHidden} +{#if constructor && initialSettings && (visible || inSelectedPath) && !builderHidden}
- - {#if hasMissingRequiredSettings} - - {:else if children.length} - {#each children as child (child._id)} - - {/each} - {:else if emptyState} - {#if isScreen} - - {:else} - + {#if hasMissingRequiredSettings} + + {:else} + + {#if children.length} + {#each children as child (child._id)} + + {/each} + {:else if emptyState} + {#if isScreen} + + {:else} + + {/if} + {:else if isBlock} + {/if} - {:else if isBlock} - - {/if} - + + {/if}
{/if} diff --git a/packages/client/src/components/Router.svelte b/packages/client/src/components/Router.svelte index e81bb20de5..551a564094 100644 --- a/packages/client/src/components/Router.svelte +++ b/packages/client/src/components/Router.svelte @@ -1,5 +1,4 @@ {#if $builderStore.inBuilder && requiredSetting} -
+
Add the {requiredSetting.label} setting to start using your component - @@ -32,7 +33,7 @@ } .component-placeholder mark { background-color: var(--spectrum-global-color-gray-400); - padding: 0 2px; + padding: 0 4px; border-radius: 2px; } .component-placeholder .spectrum-Link { diff --git a/packages/client/src/components/app/DataProvider.svelte b/packages/client/src/components/app/DataProvider.svelte index 1b4504e689..62a0588172 100644 --- a/packages/client/src/components/app/DataProvider.svelte +++ b/packages/client/src/components/app/DataProvider.svelte @@ -1,7 +1,6 @@ {#if $component.empty} - {:else if !$loading && rows.length === 0} -
{noRowsMessage}
- {:else} + {:else if rows.length > 0} {#each rows as row, index} {/each} + {:else if loaded && noRowsMessage} +
{noRowsMessage}
{/if}
diff --git a/packages/client/src/components/app/Skeleton.svelte b/packages/client/src/components/app/Skeleton.svelte deleted file mode 100644 index 5c247bf3e4..0000000000 --- a/packages/client/src/components/app/Skeleton.svelte +++ /dev/null @@ -1,31 +0,0 @@ - - -
- - - -
diff --git a/packages/client/src/components/app/blocks/CardsBlock.svelte b/packages/client/src/components/app/blocks/CardsBlock.svelte index 795e62eb31..3f42375f0b 100644 --- a/packages/client/src/components/app/blocks/CardsBlock.svelte +++ b/packages/client/src/components/app/blocks/CardsBlock.svelte @@ -37,6 +37,7 @@ let repeaterId let schema let enrichedSearchColumns + let schemaLoaded = false $: fetchSchema(dataSource) $: enrichSearchColumns(searchColumns, schema).then( @@ -77,135 +78,138 @@ enrichRelationships: true, }) } + schemaLoaded = true } - - - {#if title || enrichedSearchColumns?.length || showTitleButton} - - +{#if schemaLoaded} + + + {#if title || enrichedSearchColumns?.length || showTitleButton} - {#if enrichedSearchColumns?.length} - {#each enrichedSearchColumns as column, idx} - - {/each} - {/if} - {#if showTitleButton} - - {/if} - - - {/if} - - - + > + + + {#if enrichedSearchColumns?.length} + {#each enrichedSearchColumns as column, idx} + + {/each} + {/if} + {#if showTitleButton} + + {/if} + + + {/if} + + + + - - + +{/if} diff --git a/packages/client/src/components/app/blocks/TableBlock.svelte b/packages/client/src/components/app/blocks/TableBlock.svelte index 91c266b434..509ad49663 100644 --- a/packages/client/src/components/app/blocks/TableBlock.svelte +++ b/packages/client/src/components/app/blocks/TableBlock.svelte @@ -37,6 +37,7 @@ let schema let primaryDisplay let enrichedSearchColumns + let schemaLoaded = false $: fetchSchema(dataSource) $: enrichSearchColumns(searchColumns, schema).then( @@ -91,6 +92,7 @@ enrichRelationships: true, }) } + schemaLoaded = true } const getNormalFields = schema => { @@ -114,160 +116,162 @@ } - - - {#if title || enrichedSearchColumns?.length || showTitleButton} - - +{#if schemaLoaded} + + + {#if title || enrichedSearchColumns?.length || showTitleButton} - {#if enrichedSearchColumns?.length} - {#each enrichedSearchColumns as column, idx} + + + {#if enrichedSearchColumns?.length} + {#each enrichedSearchColumns as column, idx} + + {/each} + {/if} + {#if showTitleButton} - {/each} - {/if} - {#if showTitleButton} - - {/if} + {/if} + - - {/if} - + {/if} + order={1} + > + + + {#if clickBehaviour === "details"} + + + + {/if} + {#if showTitleButton && titleButtonClickBehaviour === "new"} + + + + {/if} - {#if clickBehaviour === "details"} - - - - {/if} - {#if showTitleButton && titleButtonClickBehaviour === "new"} - - - - {/if} - - + +{/if} diff --git a/packages/client/src/components/app/forms/Field.svelte b/packages/client/src/components/app/forms/Field.svelte index 435805cee8..5f11757c9c 100644 --- a/packages/client/src/components/app/forms/Field.svelte +++ b/packages/client/src/components/app/forms/Field.svelte @@ -1,7 +1,6 @@ -{#key resetKey} - - - -{/key} +{#if loaded} + {#key resetKey} + + + + {/key} +{/if} diff --git a/packages/client/src/components/app/table/Table.svelte b/packages/client/src/components/app/table/Table.svelte index 6e5cd6c5cf..07b64b4107 100644 --- a/packages/client/src/components/app/table/Table.svelte +++ b/packages/client/src/components/app/table/Table.svelte @@ -1,6 +1,6 @@