Commit bbb108e6 authored by Ezekiel Kigbo's avatar Ezekiel Kigbo

Ensure selected projects are always visible

When displaying selected / unselected projects in the vsa
project selector, we were checking the `availableProjects`
computed property, this would return the items that match the
current search string, instead we should always use the
`selectedProjects` computed property for selected items.

This ensures that selected items that do not match the
current search term are still visible.

Adds a related spec test
parent e905f975
...@@ -101,9 +101,7 @@ export default { ...@@ -101,9 +101,7 @@ export default {
return !loading && !availableProjects.length; return !loading && !availableProjects.length;
}, },
selectedItems() { selectedItems() {
return sortByProjectName( return sortByProjectName(this.selectedProjects);
this.availableProjects.filter(({ id }) => this.selectedProjectIds.includes(id)),
);
}, },
unselectedItems() { unselectedItems() {
return this.availableProjects.filter(({ id }) => !this.selectedProjectIds.includes(id)); return this.availableProjects.filter(({ id }) => !this.selectedProjectIds.includes(id));
......
...@@ -2,6 +2,7 @@ import { GlDropdown, GlDropdownItem } from '@gitlab/ui'; ...@@ -2,6 +2,7 @@ import { GlDropdown, GlDropdownItem } from '@gitlab/ui';
import { mountExtended } from 'helpers/vue_test_utils_helper'; import { mountExtended } from 'helpers/vue_test_utils_helper';
import { stubComponent } from 'helpers/stub_component'; import { stubComponent } from 'helpers/stub_component';
import { TEST_HOST } from 'helpers/test_constants'; import { TEST_HOST } from 'helpers/test_constants';
import waitForPromises from 'helpers/wait_for_promises';
import ProjectsDropdownFilter from '~/analytics/shared/components/projects_dropdown_filter.vue'; import ProjectsDropdownFilter from '~/analytics/shared/components/projects_dropdown_filter.vue';
import getProjects from '~/analytics/shared/graphql/projects.query.graphql'; import getProjects from '~/analytics/shared/graphql/projects.query.graphql';
...@@ -65,7 +66,7 @@ describe('ProjectsDropdownFilter component', () => { ...@@ -65,7 +66,7 @@ describe('ProjectsDropdownFilter component', () => {
const createWithMockDropdown = (props) => { const createWithMockDropdown = (props) => {
createComponent(props, { GlDropdown: MockGlDropdown }); createComponent(props, { GlDropdown: MockGlDropdown });
return wrapper.vm.$nextTick(); return waitForPromises();
}; };
afterEach(() => { afterEach(() => {
...@@ -73,6 +74,7 @@ describe('ProjectsDropdownFilter component', () => { ...@@ -73,6 +74,7 @@ describe('ProjectsDropdownFilter component', () => {
}); });
const findHighlightedItems = () => wrapper.findByTestId('vsa-highlighted-items'); const findHighlightedItems = () => wrapper.findByTestId('vsa-highlighted-items');
const findUnhighlightedItems = () => wrapper.findByTestId('vsa-default-items');
const findHighlightedItemsTitle = () => wrapper.findByText('Selected'); const findHighlightedItemsTitle = () => wrapper.findByText('Selected');
const findClearAllButton = () => wrapper.findByText('Clear all'); const findClearAllButton = () => wrapper.findByText('Clear all');
...@@ -197,6 +199,24 @@ describe('ProjectsDropdownFilter component', () => { ...@@ -197,6 +199,24 @@ describe('ProjectsDropdownFilter component', () => {
}); });
}); });
describe('with a selected project and search term', () => {
beforeEach(async () => {
await createWithMockDropdown({ multiSelect: true });
selectDropdownItemAtIndex(0);
wrapper.setData({ searchTerm: 'this is a very long search string' });
});
it('renders the highlighted items', async () => {
expect(findUnhighlightedItems().findAll('li').length).toBe(1);
});
it('hides the unhighlighted items that do not match the string', async () => {
expect(findUnhighlightedItems().findAll('li').length).toBe(1);
expect(findUnhighlightedItems().text()).toContain('No matching results');
});
});
describe('when passed an array of defaultProject as prop', () => { describe('when passed an array of defaultProject as prop', () => {
beforeEach(() => { beforeEach(() => {
createComponent({ createComponent({
......
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