FIX: Disable filter when loading tags in edit nav menu tags modal (#23789)
Why this change? When we're in the midst of loading more tags, the filter dropdown is still enabled and may result in us firing off multiple requests to the server to load more tags. This makes the loading hard to reason about in the tests environment and has led to flaky tests. What does this change do? This changes disables the filter dropdown when more tags are being loading.
This commit is contained in:
parent
f2a90afa4c
commit
8c07bbe084
|
@ -40,7 +40,7 @@
|
||||||
@value={{this.filterDropdownValue}}
|
@value={{this.filterDropdownValue}}
|
||||||
@content={{this.filterDropdownContent}}
|
@content={{this.filterDropdownContent}}
|
||||||
@onChange={{this.onFilterDropdownChange}}
|
@onChange={{this.onFilterDropdownChange}}
|
||||||
@options={{hash showCaret=true}}
|
@options={{hash showCaret=true disabled=@loading}}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
@filterSelected={{this.filterSelected}}
|
@filterSelected={{this.filterSelected}}
|
||||||
@filterUnselected={{this.filterUnselected}}
|
@filterUnselected={{this.filterUnselected}}
|
||||||
@closeModal={{@closeModal}}
|
@closeModal={{@closeModal}}
|
||||||
|
@loading={{this.tagsLoading}}
|
||||||
>
|
>
|
||||||
{{#if this.tagsLoading}}
|
{{#if this.tagsLoading}}
|
||||||
{{loading-spinner size="large"}}
|
{{loading-spinner size="large"}}
|
||||||
|
|
|
@ -15,7 +15,7 @@ export default class extends Component {
|
||||||
@tracked onlySelected = false;
|
@tracked onlySelected = false;
|
||||||
@tracked onlyUnSelected = false;
|
@tracked onlyUnSelected = false;
|
||||||
@tracked tags = [];
|
@tracked tags = [];
|
||||||
@tracked tagsLoading = true;
|
@tracked tagsLoading;
|
||||||
@tracked selectedTags = [...this.currentUser.sidebarTagNames];
|
@tracked selectedTags = [...this.currentUser.sidebarTagNames];
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
|
@ -43,11 +43,13 @@ export default class extends Component {
|
||||||
await this.store
|
await this.store
|
||||||
.findAll("listTag", findArgs)
|
.findAll("listTag", findArgs)
|
||||||
.then((tags) => {
|
.then((tags) => {
|
||||||
this.tagsLoading = false;
|
|
||||||
this.tags = tags;
|
this.tags = tags;
|
||||||
})
|
})
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
popupAjaxError(error);
|
popupAjaxError(error);
|
||||||
|
})
|
||||||
|
.finally(() => {
|
||||||
|
this.tagsLoading = false;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -157,6 +157,9 @@ RSpec.describe "Editing sidebar tags navigation", type: :system do
|
||||||
expect(sidebar).to have_tags_section
|
expect(sidebar).to have_tags_section
|
||||||
|
|
||||||
modal = sidebar.click_edit_tags_button
|
modal = sidebar.click_edit_tags_button
|
||||||
|
|
||||||
|
expect(modal).to have_tag_checkboxes([tag1, tag2, tag3, tag4])
|
||||||
|
|
||||||
modal.filter_by_selected
|
modal.filter_by_selected
|
||||||
|
|
||||||
expect(modal).to have_tag_checkboxes([tag1, tag2])
|
expect(modal).to have_tag_checkboxes([tag1, tag2])
|
||||||
|
|
|
@ -38,6 +38,10 @@ module PageObjects
|
||||||
has_css?(context + ":not(.is-expanded)", wait: 0)
|
has_css?(context + ":not(.is-expanded)", wait: 0)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def is_not_disabled?
|
||||||
|
has_css?(@context + ":not(.disabled)", wait: 0)
|
||||||
|
end
|
||||||
|
|
||||||
def has_selected_value?(value)
|
def has_selected_value?(value)
|
||||||
component.find(".select-kit-header[data-value='#{value}']")
|
component.find(".select-kit-header[data-value='#{value}']")
|
||||||
end
|
end
|
||||||
|
|
|
@ -67,7 +67,9 @@ module PageObjects
|
||||||
private
|
private
|
||||||
|
|
||||||
def dropdown_filter
|
def dropdown_filter
|
||||||
PageObjects::Components::SelectKit.new(".sidebar__edit-navigation-menu__filter-dropdown")
|
PageObjects::Components::SelectKit.new(
|
||||||
|
".sidebar__edit-navigation-menu__filter-dropdown",
|
||||||
|
).tap(&:is_not_disabled?)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue