From dc903a43f279c50e682ef315c2788977d7060e50 Mon Sep 17 00:00:00 2001 From: Gerard Burns Date: Mon, 8 Apr 2024 13:05:15 +0100 Subject: [PATCH] refactor validation --- .../controls/FieldContext/Chart.svelte | 42 +++-- .../settings/controls/MultiFieldSelect.svelte | 149 +----------------- .../design/settings/fieldValidator.js | 54 ++++--- 3 files changed, 58 insertions(+), 187 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 27355b2811..01454081af 100644 --- a/packages/builder/src/components/design/settings/controls/FieldContext/Chart.svelte +++ b/packages/builder/src/components/design/settings/controls/FieldContext/Chart.svelte @@ -7,20 +7,15 @@ import InfoWord from './InfoWord.svelte' import DocumentationLink from './DocumentationLink.svelte' import ExplanationModal from './ExplanationModal/index.svelte' + import { warnings, errors } from "../../fieldValidator"; - export let supportLevelClass = '' - export let supportLevelIconColor = "" - export let supportLevelIcon = "" - export let supportLevelIconTooltip = "" - export let supportLevelText = "" + export let support = {} export let columnIcon export let columnType export let columnName export let explanationModal = false - export let errors = [] - export let warnings = [] export let tableHref = () => {} export let schema @@ -57,12 +52,12 @@ let explanationModalSubject = null - const handleMouseenter = (option, idx) => { + const handleMouseenter = (option) => { explanationModalSubject = option; root = root } - const handleMouseleave = (option) => { + const handleMouseleave = () => { explanationModalSubject = null; } @@ -70,7 +65,7 @@
@@ -91,14 +86,14 @@ /> .
-
+
handleMouseenter("support")} on:mouseleave={() => handleMouseleave("support")} - icon={supportLevelIcon} - color={supportLevelIconColor} - text={supportLevelText} + icon={support.icon} + color={support.iconColor} + text={support.text} /> with @@ -110,7 +105,7 @@ /> .
- {#if warnings.includes("string number warning")} + {#if support?.warnings?.includes(warnings.stringAsNumber)}
Any @@ -118,7 +113,7 @@ handleMouseenter("stringsAndNumbers")} on:mouseleave={() => handleMouseleave("stringsAndNumbers")} - text="non-number-values" + text="non-number values" /> @@ -127,7 +122,7 @@ .
{/if} - {#if warnings.includes("optional warning")} + {#if support?.warnings?.includes(warnings.notRequired)}
No @@ -152,11 +147,14 @@ {/if}
- + +{#if explanationModal} + +{/if} diff --git a/packages/builder/src/components/design/settings/fieldValidator.js b/packages/builder/src/components/design/settings/fieldValidator.js index 5ecda9b1f8..4580c41911 100644 --- a/packages/builder/src/components/design/settings/fieldValidator.js +++ b/packages/builder/src/components/design/settings/fieldValidator.js @@ -1,8 +1,18 @@ import { capitalize } from 'lodash'; +export const errors = { + // fail without explanation + general: Symbol("values-validator-general"), + jsonPrimitivesOnly: Symbol("values-validator-json-primitives-only"), +} + +export const warnings = { + stringAsNumber: Symbol("values-validator-string-as-number"), + chartDatetime: Symbol("values-validator-chart-datetime"), + notRequired: Symbol("values-validator-not-required"), +} + export const constants = { - warning: Symbol("values-validator-warning"), - error: Symbol("values-validator-error"), unsupported: Symbol("values-validator-unsupported"), partialSupport: Symbol("values-validator-partialSupport"), supported: Symbol("values-validator-supported") @@ -13,54 +23,60 @@ export const validators = { try { const response = { level: null, - message: null, warnings: [], - errors: [] + errors: [], + text: "", + icon: "", + iconColor: "" } const generalUnsupportedFields = ["array", "attachment", "barcodeqr", "link", "bb_reference"] if (generalUnsupportedFields.includes(fieldSchema.type)) { - response.errors.push('This column can not be used a chart input.') + response.errors.push(errors.general) } if (fieldSchema.type === "json") { - 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.`) + response.errors.push(errors.jsonPrimitivesOnly) } if (fieldSchema.type === "string") { - - response.warnings.push( - "string number warning") + response.warnings.push(warnings.stringAsNumber) } if (fieldSchema.type === "datetime") { - response.warnings.push( - "This column can be used as an input for a chart, but it may be parsed differently depending on which is used.") + response.warnings.push(warnings.chartDatetime); + //"This column can be used as an input for a chart, but it may be parsed differently depending on which is used. } const isRequired = fieldSchema?.constraints?.presence?.allowEmpty === false if (!isRequired) { - response.warnings.push( - "optional warning") + response.warnings.push(warnings.notRequired); } if (response.errors.length > 0) { response.level = constants.unsupported - response.message = "This column can not be used as a chart input." + response.text = "Not compatible" + response.icon = "Alert" + response.iconColor = "var(--red)" } else if (response.warnings.length > 0) { response.level = constants.partialSupport - response.message = "This column can be used as a chart input, but certain values may cause issues." + response.text = "Partially compatible" + response.icon = "AlertCheck" + response.iconColor = "var(--yellow)" } else { response.level = constants.supported - response.message = "This column can be used as a chart input." + response.text = "Compatible" + response.icon = "CheckmarkCircle" + response.iconColor = "var(--green)" } return response } catch (e) { - console.log(e) return { level: constants.partialSupport, - message: "There was an issue validating this field, it may not be fully supported for use with charts.", warnings: [], - errors: [] + errors: [], + text: "Partially compatible", + icon: "AlertCheck", + iconColor: "var(--yellow)" } } }