From 27e44821e233d4c779b4183650ef1b4b303bbcc5 Mon Sep 17 00:00:00 2001 From: Andrew Kingston Date: Wed, 24 Aug 2022 09:05:08 +0100 Subject: [PATCH] Allow block ejection to properly apply all styles from blocks --- packages/client/src/components/Block.svelte | 20 +- .../src/components/BlockComponent.svelte | 8 +- .../components/app/blocks/CardsBlock.svelte | 221 +++++++++--------- .../app/blocks/RepeaterBlock.svelte | 73 +++--- .../components/app/blocks/TableBlock.svelte | 188 +++++++-------- 5 files changed, 263 insertions(+), 247 deletions(-) diff --git a/packages/client/src/components/Block.svelte b/packages/client/src/components/Block.svelte index b382062787..05d92f208c 100644 --- a/packages/client/src/components/Block.svelte +++ b/packages/client/src/components/Block.svelte @@ -4,6 +4,7 @@ import { blockStore } from "stores/blocks.js" const component = getContext("component") + const { styleable } = getContext("sdk") let structureLookupMap = {} @@ -18,8 +19,21 @@ } const eject = () => { - // Start the new structure with the first top level component + // Start the new structure with the root component let definition = structureLookupMap[$component.id][0] + + // Copy styles from block to root component + definition._styles = { + ...definition._styles, + normal: { + ...definition._styles?.normal, + ...$component.styles?.normal, + }, + custom: + definition._styles?.custom || "" + $component.styles?.custom || "", + } + + // Create component tree attachChildren(definition, structureLookupMap) builderStore.actions.ejectBlock($component.id, definition) } @@ -73,4 +87,6 @@ }) - +
+ +
diff --git a/packages/client/src/components/BlockComponent.svelte b/packages/client/src/components/BlockComponent.svelte index fe2eb0bd02..95016c4847 100644 --- a/packages/client/src/components/BlockComponent.svelte +++ b/packages/client/src/components/BlockComponent.svelte @@ -7,7 +7,6 @@ export let type export let props export let styles - export let css export let context export let order = 0 export let containsSlot = false @@ -27,12 +26,7 @@ _component: `@budibase/standard-components/${type}`, _id: id, _instanceName: type[0].toUpperCase() + type.slice(1), - _styles: { - normal: { - ...styles, - }, - custom: css, - }, + _styles: styles, _containsSlot: containsSlot, ...props, } diff --git a/packages/client/src/components/app/blocks/CardsBlock.svelte b/packages/client/src/components/app/blocks/CardsBlock.svelte index 789aa76c1b..9c110d7097 100644 --- a/packages/client/src/components/app/blocks/CardsBlock.svelte +++ b/packages/client/src/components/app/blocks/CardsBlock.svelte @@ -2,7 +2,6 @@ import { getContext } from "svelte" import Block from "components/Block.svelte" import BlockComponent from "components/BlockComponent.svelte" - import { Heading } from "@budibase/bbui" import { makePropSafe as safe } from "@budibase/string-templates" import { enrichSearchColumns, enrichFilter } from "utils/blocks.js" @@ -31,9 +30,7 @@ export let cardButtonOnClick export let linkColumn - const { fetchDatasourceSchema, styleable } = getContext("sdk") - const context = getContext("context") - const component = getContext("component") + const { fetchDatasourceSchema } = getContext("sdk") let formId let dataProviderId @@ -84,126 +81,132 @@ {#if schemaLoaded} -
- - {#if title || enrichedSearchColumns?.length || showTitleButton} + + {#if title || enrichedSearchColumns?.length || showTitleButton} + + - - - {#if enrichedSearchColumns?.length} - {#each enrichedSearchColumns as column, idx} - - {/each} - {/if} - {#if showTitleButton} + {#if enrichedSearchColumns?.length} + {#each enrichedSearchColumns as column, idx} - {/if} - - - {/if} - - - + {/each} + {/if} + {#if showTitleButton} + + {/if} + {/if} + + + + -
+
{/if} diff --git a/packages/client/src/components/app/blocks/RepeaterBlock.svelte b/packages/client/src/components/app/blocks/RepeaterBlock.svelte index c7e8f28dd7..30fbdddcdc 100644 --- a/packages/client/src/components/app/blocks/RepeaterBlock.svelte +++ b/packages/client/src/components/app/blocks/RepeaterBlock.svelte @@ -17,46 +17,43 @@ export let vAlign export let gap - let providerId - const component = getContext("component") - const { styleable } = getContext("sdk") + + let providerId -
- - {#if $component.empty} - - {:else} - - - - {/if} - -
+ + {#if $component.empty} + + {:else} + + + + {/if} +
diff --git a/packages/client/src/components/app/blocks/TableBlock.svelte b/packages/client/src/components/app/blocks/TableBlock.svelte index 25a8fb2b30..f75a71a3ee 100644 --- a/packages/client/src/components/app/blocks/TableBlock.svelte +++ b/packages/client/src/components/app/blocks/TableBlock.svelte @@ -28,8 +28,7 @@ export let titleButtonURL export let titleButtonPeek - const { fetchDatasourceSchema, styleable } = getContext("sdk") - const component = getContext("component") + const { fetchDatasourceSchema } = getContext("sdk") let formId let dataProviderId @@ -62,109 +61,116 @@ {#if schemaLoaded} -
- - {#if title || enrichedSearchColumns?.length || showTitleButton} + + {#if title || enrichedSearchColumns?.length || showTitleButton} + + - - - {#if enrichedSearchColumns?.length} - {#each enrichedSearchColumns as column, idx} - - {/each} - {/if} - {#if showTitleButton} + {#if enrichedSearchColumns?.length} + {#each enrichedSearchColumns as column, idx} - {/if} - + {/each} + {/if} + {#if showTitleButton} + + {/if} - {/if} - - + {/if} + + -
+
{/if}