From 857e4fe11437c3902b527794d2272eb7c0c2dbff Mon Sep 17 00:00:00 2001 From: pietervdvn Date: Sun, 14 Mar 2021 03:14:45 +0100 Subject: [PATCH] MultiAnswer option with rendering only shows up once --- UI/Popup/TagRenderingAnswer.ts | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/UI/Popup/TagRenderingAnswer.ts b/UI/Popup/TagRenderingAnswer.ts index a08698f5c..1cfc5f0b2 100644 --- a/UI/Popup/TagRenderingAnswer.ts +++ b/UI/Popup/TagRenderingAnswer.ts @@ -44,17 +44,25 @@ export default class TagRenderingAnswer extends UIElement { // The render value doesn't work well with multi-answers (checkboxes), so we have to check for them manually if (this._configuration.multiAnswer) { + + let freeformKeyUsed = this._configuration.freeform?.key === undefined; // If it is undefined, it is "used" already, or at least we don't have to check for it anymore const applicableThens: Translation[] = Utils.NoNull(this._configuration.mappings.map(mapping => { if (mapping.if === undefined) { return mapping.then; } if (TagUtils.MatchesMultiAnswer(mapping.if, tags)) { + if(!freeformKeyUsed){ + if(mapping.if.usedKeys().indexOf(this._configuration.freeform.key) >= 0){ + freeformKeyUsed = true; + } + } return mapping.then; } return undefined; })) - if (this._configuration.freeform !== undefined && tags[this._configuration.freeform.key] !== undefined) { + if (!freeformKeyUsed + && tags[this._configuration.freeform.key] !== undefined) { applicableThens.push(this._configuration.render) }