From 41953e049dc0267051f467ebed52060c3fbd7fb4 Mon Sep 17 00:00:00 2001 From: Andrew Kingston Date: Mon, 26 Jul 2021 12:52:55 +0100 Subject: [PATCH] Add full type support to conditional UI --- .../ConditionalUISection.svelte | 2 - .../ConditionalUIDrawer.svelte | 92 +++++++++++++++++-- packages/client/src/utils/conditions.js | 29 +++++- 3 files changed, 107 insertions(+), 16 deletions(-) diff --git a/packages/builder/src/components/design/PropertiesPanel/ConditionalUISection.svelte b/packages/builder/src/components/design/PropertiesPanel/ConditionalUISection.svelte index 448c21e9ad..b1f65f3593 100644 --- a/packages/builder/src/components/design/PropertiesPanel/ConditionalUISection.svelte +++ b/packages/builder/src/components/design/PropertiesPanel/ConditionalUISection.svelte @@ -17,8 +17,6 @@ store.actions.components.updateConditions(tempValue) drawer.hide() } - - $: console.log(componentInstance?._id) { conditions = e.detail.items } + + const getOperatorOptions = condition => { + return getValidOperatorsForType(condition.valueType) + } + + const onOperatorChange = (condition, newOperator) => { + const noValueOptions = [ + OperatorOptions.Empty.value, + OperatorOptions.NotEmpty.value, + ] + condition.noValue = noValueOptions.includes(newOperator) + if (condition.noValue) { + condition.referenceValue = null + condition.valueType = "string" + } + } + + const onValueTypeChange = (condition, newType) => { + condition.referenceValue = null + + // Ensure a valid operator is set + const validOperators = getValidOperatorsForType(newType) + if (!validOperators.includes(condition.operator)) { + condition.operator = + validOperators[0]?.value ?? OperatorOptions.Equals.value + onOperatorChange(condition, condition.operator) + } + } @@ -143,15 +191,39 @@ /> onValueTypeChange(condition, e.detail)} /> + {#if ["string", "number"].includes(condition.valueType)} + (condition.referenceValue = e.detail)} + /> + {:else if condition.valueType === "datetime"} + + {:else if condition.valueType === "boolean"} +