Skip to content

Commit

Permalink
resolve #6754 Dropdown with Lazy Loading - The search query with the …
Browse files Browse the repository at this point in the history
…ê symbol doesn't produce any results when the the choicesLazyLoadEnabled option is set from code
  • Loading branch information
OlgaLarina committed Aug 28, 2023
1 parent f68b610 commit 8b4183e
Show file tree
Hide file tree
Showing 3 changed files with 47 additions and 0 deletions.
3 changes: 3 additions & 0 deletions src/dropdownListModel.ts
Original file line number Diff line number Diff line change
Expand Up @@ -373,6 +373,9 @@ export class DropdownListModel extends Base {
if (options.name == "value") {
this.showInputFieldComponent = this.question.showInputFieldComponent;
}
if(options.name == "choicesLazyLoadEnabled" && options.newValue) {
this.listModel.setOnFilterStringChangedCallback(this.listModelFilterStringChanged);
}
}
protected focusItemOnClickAndPopup() {
if (this._popupModel.isVisible && this.question.value)
Expand Down
3 changes: 3 additions & 0 deletions src/list.ts
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,9 @@ export class ListModel<T extends BaseAction = Action> extends ActionContainer<T>
this.selectedItem = selectedItem;
}

public setOnFilterStringChangedCallback(callback: (text: string) => void) {
this.onFilterStringChangedCallback = callback;
}
public setItems(items: Array<IAction>, sortByVisibleIndex = true): void {
super.setItems(items, sortByVisibleIndex);
if(this.elementId) {
Expand Down
41 changes: 41 additions & 0 deletions tests/questionDropdownTests.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1655,4 +1655,45 @@ QUnit.test("isReady flag + onGetChoiceDisplayValue + choicesRestfull", assert =>
assert.ok(question["waitingAcyncOperations"]);
assert.notOk(question["waitingChoicesByURL"]);
assert.ok(question["waitingGetChoiceDisplayValueResponse"]);
});

QUnit.test("lazy loading: change choicesLazyLoadEnabled on runtime", assert => {
const json = {
questions: [{
"type": "dropdown",
"name": "q1",
}]
};
const survey = new SurveyModel(json);
survey.onChoicesLazyLoad.add((_, opt) => {
const total = 55;
const result: Array<any> = [];
for (let index = 0; index < total; index++) {
result.push({ value: "item" + index, text: "item" + index });
}
if(opt.filter === "des") {
opt.setItems(result.slice(10, 15), total);
} else {
opt.setItems(result.slice(0, 15), total);
}
});

const question = <QuestionDropdownModel>survey.getAllQuestions()[0];
assert.equal(question.choicesLazyLoadEnabled, false);
assert.equal(question.choices.length, 0);

question.choicesLazyLoadEnabled = true;
assert.equal(question.choicesLazyLoadEnabled, true);
assert.equal(question.choices.length, 0);
assert.equal(question.dropdownListModel["listModel"].visibleItems.length, 0, "#1");

question.dropdownListModel.popupModel.isVisible = true;
assert.equal(question.choices.length, 15);
assert.equal(question.dropdownListModel["listModel"].visibleItems.length, 16, "#2");
assert.equal(question.dropdownListModel["listModel"].visibleItems[15].id, "loadingIndicator");

question.dropdownListModel.filterString = "des";
assert.equal(question.choices.length, 5);
assert.equal(question.dropdownListModel["listModel"].visibleItems.length, 6, "#3");
assert.equal(question.dropdownListModel["listModel"].visibleItems[5].id, "loadingIndicator");
});

0 comments on commit 8b4183e

Please sign in to comment.