From b4c77f27b66275ddb58138e8d2fe1509265e9652 Mon Sep 17 00:00:00 2001 From: Charlie Kolb Date: Mon, 23 Dec 2024 13:03:24 +0100 Subject: [PATCH] fix: Set correct default for added Resource Mapper boolean fields (#12344) --- .../src/components/ResourceMapper/ResourceMapper.vue | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/packages/editor-ui/src/components/ResourceMapper/ResourceMapper.vue b/packages/editor-ui/src/components/ResourceMapper/ResourceMapper.vue index 7487f1d8d4e47..835e4a87a3c12 100644 --- a/packages/editor-ui/src/components/ResourceMapper/ResourceMapper.vue +++ b/packages/editor-ui/src/components/ResourceMapper/ResourceMapper.vue @@ -493,14 +493,20 @@ function addField(name: string): void { if (name === 'removeAllFields') { return removeAllFields(); } + const schema = state.paramValue.schema; + const field = schema.find((f) => f.id === name); + state.paramValue.value = { ...state.paramValue.value, - [name]: null, + // We only supply boolean defaults since it's a switch that cannot be null in `Fixed` mode + // Other defaults may break backwards compatibility as we'd remove the implicit passthrough + // mode you get when the field exists, but is empty in `Fixed` mode. + [name]: field?.type === 'boolean' ? false : null, }; - const field = state.paramValue.schema.find((f) => f.id === name); + if (field) { field.removed = false; - state.paramValue.schema.splice(state.paramValue.schema.indexOf(field), 1, field); + schema.splice(schema.indexOf(field), 1, field); } emitValueChanged(); }