Commit e0538e3e authored by Micael Bergeron's avatar Micael Bergeron

Reset the pagination cursor upon search filter changes

This commit ensure the pagination cursor, known as the `page=` query
parameter, will be reset whenever a search filter changes.

This will ensure the new results are seen in the proper order.
parent d802e948
...@@ -43,7 +43,15 @@ export default { ...@@ -43,7 +43,15 @@ export default {
return this.filterData.filters.ANY.value; return this.filterData.filters.ANY.value;
}, },
set(filter) { set(filter) {
visitUrl(setUrlParams({ [this.filterData.filterParam]: filter })); // we need to remove the pagination cursor to ensure the
// relevancy of the new results
visitUrl(
setUrlParams({
page: null,
[this.filterData.filterParam]: filter,
}),
);
}, },
}, },
selectedFilterText() { selectedFilterText() {
......
...@@ -62,7 +62,9 @@ class SearchService ...@@ -62,7 +62,9 @@ class SearchService
end end
def search_objects(preload_method = nil) def search_objects(preload_method = nil)
@search_objects ||= redact_unauthorized_results(search_results.objects(scope, page: params[:page], per_page: per_page, preload_method: preload_method)) @search_objects ||= redact_unauthorized_results(
search_results.objects(scope, page: page, per_page: per_page, preload_method: preload_method)
)
end end
def search_highlight def search_highlight
...@@ -71,6 +73,10 @@ class SearchService ...@@ -71,6 +73,10 @@ class SearchService
private private
def page
[1, params[:page].to_i].max
end
def per_page def per_page
per_page_param = params[:per_page].to_i per_page_param = params[:per_page].to_i
......
---
title: Reset the pagination cursor when a search result filter changes.
merge_request: 45708
author:
type: fixed
...@@ -106,6 +106,7 @@ describe('DropdownFilter', () => { ...@@ -106,6 +106,7 @@ describe('DropdownFilter', () => {
firstDropDownItem().vm.$emit('click'); firstDropDownItem().vm.$emit('click');
expect(urlUtils.setUrlParams).toHaveBeenCalledWith({ expect(urlUtils.setUrlParams).toHaveBeenCalledWith({
page: null,
[stateFilterData.filterParam]: filter, [stateFilterData.filterParam]: filter,
}); });
}); });
...@@ -183,6 +184,7 @@ describe('DropdownFilter', () => { ...@@ -183,6 +184,7 @@ describe('DropdownFilter', () => {
firstDropDownItem().vm.$emit('click'); firstDropDownItem().vm.$emit('click');
expect(urlUtils.setUrlParams).toHaveBeenCalledWith({ expect(urlUtils.setUrlParams).toHaveBeenCalledWith({
page: null,
[confidentialFilterData.filterParam]: filter, [confidentialFilterData.filterParam]: filter,
}); });
}); });
......
...@@ -18,9 +18,10 @@ RSpec.describe SearchService do ...@@ -18,9 +18,10 @@ RSpec.describe SearchService do
let(:group_project) { create(:project, group: accessible_group, name: 'group_project') } let(:group_project) { create(:project, group: accessible_group, name: 'group_project') }
let(:public_project) { create(:project, :public, name: 'public_project') } let(:public_project) { create(:project, :public, name: 'public_project') }
let(:page) { 1 }
let(:per_page) { described_class::DEFAULT_PER_PAGE } let(:per_page) { described_class::DEFAULT_PER_PAGE }
subject(:search_service) { described_class.new(user, search: search, scope: scope, page: 1, per_page: per_page) } subject(:search_service) { described_class.new(user, search: search, scope: scope, page: page, per_page: per_page) }
before do before do
accessible_project.add_maintainer(user) accessible_project.add_maintainer(user)
...@@ -242,10 +243,10 @@ RSpec.describe SearchService do ...@@ -242,10 +243,10 @@ RSpec.describe SearchService do
end end
describe '#search_objects' do describe '#search_objects' do
context 'handling per_page param' do
let(:search) { '' } let(:search) { '' }
let(:scope) { nil } let(:scope) { nil }
describe 'per_page: parameter' do
context 'when nil' do context 'when nil' do
let(:per_page) { nil } let(:per_page) { nil }
...@@ -312,6 +313,34 @@ RSpec.describe SearchService do ...@@ -312,6 +313,34 @@ RSpec.describe SearchService do
end end
end end
describe 'page: parameter' do
context 'when < 1' do
let(:page) { 0 }
it "defaults to 1" do
expect_any_instance_of(Gitlab::SearchResults)
.to receive(:objects)
.with(anything, hash_including(page: 1))
.and_call_original
subject.search_objects
end
end
context 'when nil' do
let(:page) { nil }
it "defaults to 1" do
expect_any_instance_of(Gitlab::SearchResults)
.to receive(:objects)
.with(anything, hash_including(page: 1))
.and_call_original
subject.search_objects
end
end
end
context 'with accessible project_id' do context 'with accessible project_id' do
it 'returns objects in the project' do it 'returns objects in the project' do
search_objects = described_class.new( search_objects = described_class.new(
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment