From d5bccdfe2c2ae420680a3d9304f197a5efe6a1a5 Mon Sep 17 00:00:00 2001 From: Andrew Telnov Date: Wed, 21 Feb 2024 11:48:43 +0200 Subject: [PATCH] Composite Component - The setValueIf and setValueExpression do not work for inner questions fix #7888 --- src/question_custom.ts | 8 ++++++++ tests/question_customtests.ts | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 40 insertions(+) diff --git a/src/question_custom.ts b/src/question_custom.ts index 8cac5ccb19..025e0b64b0 100644 --- a/src/question_custom.ts +++ b/src/question_custom.ts @@ -1120,6 +1120,14 @@ export class QuestionCompositeModel extends QuestionCustomModelBase { this.setNewValueIntoQuestion(name, newValue); super.setValue(name, newValue, locNotification, allowNotifyValueChanged); this.settingNewValue = false; + this.runPanelTriggers(QuestionCompositeModel.ItemVariableName + "." + name, newValue); + } + private runPanelTriggers(name: string, value: any): void { + if(!!this.contentPanel) { + this.contentPanel.questions.forEach(q => { + q.runTriggers(name, value); + }); + } } getFilteredValues(): any { const values = !!this.data ? this.data.getFilteredValues() : {}; diff --git a/tests/question_customtests.ts b/tests/question_customtests.ts index 6ae457256e..768fa1ad79 100644 --- a/tests/question_customtests.ts +++ b/tests/question_customtests.ts @@ -2265,6 +2265,38 @@ QUnit.test("Composite: with expression", function (assert) { ComponentCollection.Instance.clear(); }); +QUnit.test("Composite: with setValueIf & setValueExpression, bug#7888", function (assert) { + const json = { + name: "comp1", + elementsJSON: [ + { + "type": "text", + "name": "q1" + }, + { + "type": "text", + "name": "q2", + "enableIf": "{composite.q1} notempty", + "setValueIf": "{composite.q1} notempty", + "setValueExpression": "{composite.q1} + {composite.q1}" + } + ], + }; + ComponentCollection.Instance.add(json); + const survey = new SurveyModel({ elements: [{ type: "comp1", name: "question1" }] }); + const q = survey.getAllQuestions()[0]; + const q1 = q.contentPanel.getQuestionByName("q1"); + const q2 = q.contentPanel.getQuestionByName("q2"); + assert.equal(q2.isEmpty(), true, "#1"); + q1.value = 1; + assert.equal(q2.value, 2, "#2"); + q1.value = 3; + assert.equal(q2.value, 6, "#3"); + q1.clearValue(); + assert.equal(q2.value, 6, "#4"); + + ComponentCollection.Instance.clear(); +}); QUnit.test("Composite: check valueToData and valueFromData callbacks", function (assert) { const json = { name: "test",