From c6c8b1968cfe4e4ac771576eb75a56263ec5c0d0 Mon Sep 17 00:00:00 2001 From: Andrew Date: Thu, 4 Jul 2024 10:08:16 +0300 Subject: [PATCH] Bug/paneldynamic tabactions templatevisibleif (#8507) * Dynamic Panel (Tab) wrongly switch panel when some panels are hidden fix #8430 * Improve the unit test better #8430 --- src/question_paneldynamic.ts | 11 ++++++----- src/survey-element.ts | 1 - tests/question_paneldynamic_tests.ts | 23 +++++++++++++++++++++++ 3 files changed, 29 insertions(+), 6 deletions(-) diff --git a/src/question_paneldynamic.ts b/src/question_paneldynamic.ts index de82e981c7..6b93553b30 100644 --- a/src/question_paneldynamic.ts +++ b/src/question_paneldynamic.ts @@ -1541,9 +1541,10 @@ export class QuestionPanelDynamicModel extends Question } return -1; } - private getPanelIndexById(id: string): number { - for (var i = 0; i < this.panelsCore.length; i++) { - if (this.panelsCore[i].id === id) return i; + private getPanelVisibleIndexById(id: string): number { + const visPanels = this.visiblePanelsCore; + for (var i = 0; i < visPanels.length; i++) { + if (visPanels[i].id === id) return i; } return -1; } @@ -2423,14 +2424,14 @@ export class QuestionPanelDynamicModel extends Question return options.title; }; locTitle.sharedData = this.locTemplateTabTitle; - const isActive = this.getPanelIndexById(panel.id) === this.currentIndex; + const isActive = this.getPanelVisibleIndexById(panel.id) === this.currentIndex; const newItem = new Action({ id: panel.id, pressed: isActive, locTitle: locTitle, disableHide: isActive, action: () => { - this.currentIndex = this.getPanelIndexById(newItem.id); + this.currentIndex = this.getPanelVisibleIndexById(newItem.id); } }); return newItem; diff --git a/src/survey-element.ts b/src/survey-element.ts index 7ad1ab8bbc..1b6022b55c 100644 --- a/src/survey-element.ts +++ b/src/survey-element.ts @@ -24,7 +24,6 @@ import { SurveyModel } from "./survey"; import { IAnimationConsumer, AnimationBoolean } from "./utils/animation"; import { classesToSelector } from "./utils/utils"; import { DomDocumentHelper, DomWindowHelper } from "./global_variables_utils"; -import { Panel } from "./knockout/kopage"; import { PanelModel } from "./panel"; /** * A base class for the [`SurveyElement`](https://surveyjs.io/form-library/documentation/surveyelement) and [`SurveyModel`](https://surveyjs.io/form-library/documentation/surveymodel) classes. diff --git a/tests/question_paneldynamic_tests.ts b/tests/question_paneldynamic_tests.ts index 0ea3515795..1188e048fb 100644 --- a/tests/question_paneldynamic_tests.ts +++ b/tests/question_paneldynamic_tests.ts @@ -6273,6 +6273,29 @@ QUnit.test("templateVisibleIf & additionalTitleToolbar", function (assert) { assert.equal(getNextBtn().visible, true, "nextButton #6"); survey.css = oldCss; }); +QUnit.test("templateVisibleIf & tabs action click, bug#8430", function (assert) { + const survey = new SurveyModel({ + elements: [ + { type: "paneldynamic", + name: "panel", + templateElements: [ + { type: "text", name: "q1" } + ], + panelCount: 4, + templateVisibleIf: "{panel.q1}!='a'", + renderMode: "tab" + }], + }); + const panel = survey.getQuestionByName("panel"); + assert.equal(panel.additionalTitleToolbar.visibleActions.length, 4, "There are 4 visible tabs"); + panel.panels[1].getQuestionByName("q1").value = "a"; + assert.equal(panel.currentIndex, 0, "Current Index 0"); + const panelId = panel.panels[2].id; + assert.equal(panel.additionalTitleToolbar.visibleActions.length, 3, "There are 3 visible tabs"); + panel.additionalTitleToolbar.visibleActions[1].action(); + assert.equal(panel.currentIndex, 1, "Current Index 1"); + assert.equal(panel.currentPanel.id, panelId, "Select the correct panel"); +}); QUnit.test("question.enableIf & add panel button visibility, Bug#6292", function (assert) { const survey = new SurveyModel({ elements: [