From 96aa83d4548d57a076830a7ad031862ed264af85 Mon Sep 17 00:00:00 2001 From: Andrew Kingston Date: Wed, 22 May 2024 10:15:09 +0100 Subject: [PATCH] Change how empty JS values are handled to avoid weird lockup --- .../src/components/common/bindings/BindingPanel.svelte | 10 ++++++++-- .../common/bindings/DrawerBindableInput.svelte | 9 ++------- 2 files changed, 10 insertions(+), 9 deletions(-) diff --git a/packages/builder/src/components/common/bindings/BindingPanel.svelte b/packages/builder/src/components/common/bindings/BindingPanel.svelte index 8c94455c58..0046725a72 100644 --- a/packages/builder/src/components/common/bindings/BindingPanel.svelte +++ b/packages/builder/src/components/common/bindings/BindingPanel.svelte @@ -186,6 +186,8 @@ } const updateValue = val => { + console.log("val", val) + const runtimeExpression = readableToRuntimeBinding(enrichedBindings, val) dispatch("change", val) requestEval(runtimeExpression, context, snippets) @@ -236,8 +238,12 @@ } const onChangeJSValue = e => { - jsValue = encodeJSBinding(e.detail) - updateValue(jsValue) + if (!e.detail?.trim()) { + // Don't bother saving empty values as JS + updateValue("") + } else { + updateValue(encodeJSBinding(e.detail)) + } } onMount(() => { diff --git a/packages/builder/src/components/common/bindings/DrawerBindableInput.svelte b/packages/builder/src/components/common/bindings/DrawerBindableInput.svelte index 0792866581..0cb10d1aa5 100644 --- a/packages/builder/src/components/common/bindings/DrawerBindableInput.svelte +++ b/packages/builder/src/components/common/bindings/DrawerBindableInput.svelte @@ -6,7 +6,7 @@ } from "dataBinding" import ClientBindingPanel from "components/common/bindings/ClientBindingPanel.svelte" import { createEventDispatcher, setContext } from "svelte" - import { isJSBinding, decodeJSBinding } from "@budibase/string-templates" + import { isJSBinding } from "@budibase/string-templates" import { builderStore } from "stores/builder" export let panel = ClientBindingPanel @@ -34,12 +34,7 @@ $: isJS = isJSBinding(value) const saveBinding = () => { - // Don't bother saving empty JS expressions as JS - let val = tempValue - if (decodeJSBinding(tempValue)?.trim() === "") { - val = null - } - onChange(val) + onChange(tempValue) onBlur() builderStore.propertyFocus() bindingDrawer.hide()