From 2e68d8b7d6c51bb2c138584c065eb0d60e46a036 Mon Sep 17 00:00:00 2001 From: Gerard Burns Date: Thu, 4 Apr 2024 09:53:15 +0100 Subject: [PATCH] vibing --- .../controls/FieldContext/Chart.svelte | 37 +++++++++++++++---- .../settings/controls/MultiFieldSelect.svelte | 14 ++++--- .../design/settings/fieldValidator.js | 8 ++-- 3 files changed, 43 insertions(+), 16 deletions(-) diff --git a/packages/builder/src/components/design/settings/controls/FieldContext/Chart.svelte b/packages/builder/src/components/design/settings/controls/FieldContext/Chart.svelte index 921c7a8871..52e5de4416 100644 --- a/packages/builder/src/components/design/settings/controls/FieldContext/Chart.svelte +++ b/packages/builder/src/components/design/settings/controls/FieldContext/Chart.svelte @@ -16,6 +16,22 @@ export let errors = [] export let warnings = [] + const getDocLink = (columnType) => { + if (columnType === "number") { + return "https://docs.budibase.com/docs/number" + } + if (columnType === "string") { + return "https://docs.budibase.com/docs/text" + } + if (columnType === "attachment") { + return "https://docs.budibase.com/docs/attachments" + } + + return "" + } + + $: docLink = getDocLink(columnType); +
- {columnName} + {columnName} is a - + column.
@@ -45,6 +61,8 @@ {#each warnings as datum}

{datum}

{/each} + {:else} +

{supportLevelIconTooltip}

{/if}
@@ -75,13 +93,14 @@ } .contextTooltipHeader { - row-gap: 4px; + row-gap: 6px; + column-gap: 5px; background-color: var(--background-alt); color: var(--ink); display: flex; flex-wrap: wrap; align-items: center; - padding: 4px 4px; + padding: 6px 8px; border-width: var(--spectrum-actionbutton-border-size); border-radius: var(--spectrum-alias-border-radius-regular); border: 1px solid @@ -107,7 +126,6 @@ white-space: nowrap; overflow: hidden; text-overflow: ellipsis; - margin-right: 5px; } .link { @@ -116,7 +134,12 @@ border-radius: 5px; background-color: var(--spectrum-global-color-blue-500); color: white; - margin: 0 8px; + transition: background-color 300ms + } + + .link:hover { + background-color: var(--spectrum-global-color-blue-700); + cursor: pointer; } .link :global(svg) { diff --git a/packages/builder/src/components/design/settings/controls/MultiFieldSelect.svelte b/packages/builder/src/components/design/settings/controls/MultiFieldSelect.svelte index ee450eada1..ccf3fe4948 100644 --- a/packages/builder/src/components/design/settings/controls/MultiFieldSelect.svelte +++ b/packages/builder/src/components/design/settings/controls/MultiFieldSelect.svelte @@ -5,6 +5,7 @@ import { createEventDispatcher } from "svelte" import { validators, constants as validatorConstants } from "../fieldValidator"; import ChartFieldContext from './FieldContext/Chart.svelte' + import { FIELDS } from 'constants/backend' export let componentInstance = {} export let value = "" @@ -63,9 +64,6 @@ $: fieldSupport = getFieldSupport(schema, fieldValidator); $: boundValue = getValidOptions(value, options) - $: { - console.log(schema) - } const getValidOptions = (selectedOptions, allOptions) => { // Fix the hardcoded default string value @@ -100,7 +98,14 @@ const getOptionIconTooltip = optionKey => { const option = schema[optionKey] - return option?.type; + const type = option?.type; + const field = Object.values(FIELDS).find(f => f.type === type) + + if (field) { + return field.name + } + + return "" } const isOptionEnabled = optionKey => { @@ -157,7 +162,6 @@ $: previousOptionSupport = getSupportLevel(previousOption) const onOptionMouseenter = (e, option, idx) => { - console.log(option) contextTooltipId += 1; const invokedContextTooltipId = contextTooltipId diff --git a/packages/builder/src/components/design/settings/fieldValidator.js b/packages/builder/src/components/design/settings/fieldValidator.js index 86412462b3..0e6537ba60 100644 --- a/packages/builder/src/components/design/settings/fieldValidator.js +++ b/packages/builder/src/components/design/settings/fieldValidator.js @@ -20,20 +20,20 @@ export const validators = { } const generalUnsupportedFields = ["array", "attachment", "barcodeqr", "link", "bb_reference"] if (generalUnsupportedFields.includes(fieldSchema.type)) { - response.errors.push(`${capitalize(fieldSchema.type)} columns are unsupported.`) + response.errors.push('This column can not be used a chart input.') } if (fieldSchema.type === "json") { - response.errors.push(`JSON columns can not be used as chart inputs, but individual properties of this JSON field can be be used if supported.`) + response.errors.push(`This column can not be used as a chart input, but individual properties of a JSON object can be be used if supported.`) } if (fieldSchema.type === "string") { response.warnings.push( - "String columns can be used as input for a chart, but non-numeric values may cause unexpected behavior.") + "This column can be used as input for a chart, but non-numeric values may cause unexpected behavior.") } if (fieldSchema.type === "datetime") { response.warnings.push( - "This column can be used as input for a chart, but it is parsed differently for various charts.") + "This column can be used as input for a chart, but it may be parsed differently depending on the which is used.") } const isRequired = fieldSchema?.constraints?.presence?.allowEmpty === false