Commit 73faac08 authored by Nicolò Maria Mezzopera's avatar Nicolò Maria Mezzopera

Merge branch '327198-Hide-search-bar-when-registry-is-empty' into 'master'

Hide search bar when registry is empty

See merge request gitlab-org/gitlab!75915
parents 12eaece6 8203c487
...@@ -21,13 +21,17 @@ export default { ...@@ -21,13 +21,17 @@ export default {
}, },
}, },
computed: { computed: {
showModuleCount() { hasModules() {
return Number.isInteger(this.count); return Number.isInteger(this.count) && this.count > 0;
}, },
moduleAmountText() { moduleAmountText() {
return n__(`%d Module`, `%d Modules`, this.count); return n__(`%d Module`, `%d Modules`, this.count);
}, },
infoMessages() { infoMessages() {
if (!this.hasModules) {
return [];
}
return [{ text: this.$options.i18n.LIST_INTRO_TEXT, link: this.helpUrl }]; return [{ text: this.$options.i18n.LIST_INTRO_TEXT, link: this.helpUrl }];
}, },
}, },
...@@ -43,11 +47,7 @@ export default { ...@@ -43,11 +47,7 @@ export default {
<template> <template>
<title-area :title="$options.i18n.LIST_TITLE_TEXT" :info-messages="infoMessages"> <title-area :title="$options.i18n.LIST_TITLE_TEXT" :info-messages="infoMessages">
<template #metadata-amount> <template #metadata-amount>
<metadata-item <metadata-item v-if="hasModules" icon="infrastructure-registry" :text="moduleAmountText" />
v-if="showModuleCount"
icon="infrastructure-registry"
:text="moduleAmountText"
/>
</template> </template>
</title-area> </title-area>
</template> </template>
...@@ -99,7 +99,7 @@ export default { ...@@ -99,7 +99,7 @@ export default {
<template> <template>
<div> <div>
<infrastructure-title :help-url="packageHelpUrl" :count="packagesCount" /> <infrastructure-title :help-url="packageHelpUrl" :count="packagesCount" />
<infrastructure-search @update="requestPackagesList" /> <infrastructure-search v-if="packagesCount > 0" @update="requestPackagesList" />
<package-list @page:changed="onPageChanged" @package:delete="onPackageDeleteRequest"> <package-list @page:changed="onPageChanged" @package:delete="onPackageDeleteRequest">
<template #empty-state> <template #empty-state>
......
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
exports[`packages_list_app renders 1`] = ` exports[`packages_list_app renders 1`] = `
<div> <div>
<infrastructure-title-stub <infrastructure-title-stub
count="1"
helpurl="foo" helpurl="foo"
/> />
......
...@@ -10,7 +10,9 @@ describe('Infrastructure Title', () => { ...@@ -10,7 +10,9 @@ describe('Infrastructure Title', () => {
const findTitleArea = () => wrapper.find(TitleArea); const findTitleArea = () => wrapper.find(TitleArea);
const findMetadataItem = () => wrapper.find(MetadataItem); const findMetadataItem = () => wrapper.find(MetadataItem);
const mountComponent = (propsData = { helpUrl: 'foo' }) => { const exampleProps = { helpUrl: 'http://example.gitlab.com/help' };
const mountComponent = (propsData = exampleProps) => {
wrapper = shallowMount(component, { wrapper = shallowMount(component, {
store, store,
propsData, propsData,
...@@ -26,23 +28,36 @@ describe('Infrastructure Title', () => { ...@@ -26,23 +28,36 @@ describe('Infrastructure Title', () => {
}); });
describe('title area', () => { describe('title area', () => {
it('exists', () => { beforeEach(() => {
mountComponent(); mountComponent();
});
it('exists', () => {
expect(findTitleArea().exists()).toBe(true); expect(findTitleArea().exists()).toBe(true);
}); });
it('has the correct props', () => { it('has the correct title', () => {
mountComponent(); expect(findTitleArea().props('title')).toBe('Infrastructure Registry');
});
describe('with no modules', () => {
it('has no info message', () => {
expect(findTitleArea().props('infoMessages')).toStrictEqual([]);
});
});
describe('with at least one module', () => {
beforeEach(() => {
mountComponent({ ...exampleProps, count: 1 });
});
expect(findTitleArea().props()).toMatchObject({ it('has an info message', () => {
title: 'Infrastructure Registry', expect(findTitleArea().props('infoMessages')).toStrictEqual([
infoMessages: [
{ {
text: 'Publish and share your modules. %{docLinkStart}More information%{docLinkEnd}', text: 'Publish and share your modules. %{docLinkStart}More information%{docLinkEnd}',
link: 'foo', link: exampleProps.helpUrl,
}, },
], ]);
}); });
}); });
}); });
...@@ -51,15 +66,15 @@ describe('Infrastructure Title', () => { ...@@ -51,15 +66,15 @@ describe('Infrastructure Title', () => {
count | exist | text count | exist | text
${null} | ${false} | ${''} ${null} | ${false} | ${''}
${undefined} | ${false} | ${''} ${undefined} | ${false} | ${''}
${0} | ${true} | ${'0 Modules'} ${0} | ${false} | ${''}
${1} | ${true} | ${'1 Module'} ${1} | ${true} | ${'1 Module'}
${2} | ${true} | ${'2 Modules'} ${2} | ${true} | ${'2 Modules'}
`('when count is $count metadata item', ({ count, exist, text }) => { `('when count is $count metadata item', ({ count, exist, text }) => {
beforeEach(() => { beforeEach(() => {
mountComponent({ count, helpUrl: 'foo' }); mountComponent({ ...exampleProps, count });
}); });
it(`is ${exist} that it exists`, () => { it(exist ? 'exists' : 'does not exist', () => {
expect(findMetadataItem().exists()).toBe(exist); expect(findMetadataItem().exists()).toBe(exist);
}); });
......
...@@ -35,7 +35,7 @@ describe('packages_list_app', () => { ...@@ -35,7 +35,7 @@ describe('packages_list_app', () => {
const findListComponent = () => wrapper.find(PackageList); const findListComponent = () => wrapper.find(PackageList);
const findInfrastructureSearch = () => wrapper.find(InfrastructureSearch); const findInfrastructureSearch = () => wrapper.find(InfrastructureSearch);
const createStore = (filter = []) => { const createStore = ({ filter = [], packageCount = 0 } = {}) => {
store = new Vuex.Store({ store = new Vuex.Store({
state: { state: {
isLoading: false, isLoading: false,
...@@ -46,6 +46,9 @@ describe('packages_list_app', () => { ...@@ -46,6 +46,9 @@ describe('packages_list_app', () => {
packageHelpUrl: 'foo', packageHelpUrl: 'foo',
}, },
filter, filter,
pagination: {
total: packageCount,
},
}, },
}); });
store.dispatch = jest.fn(); store.dispatch = jest.fn();
...@@ -68,6 +71,7 @@ describe('packages_list_app', () => { ...@@ -68,6 +71,7 @@ describe('packages_list_app', () => {
beforeEach(() => { beforeEach(() => {
createStore(); createStore();
jest.spyOn(packageUtils, 'getQueryParams').mockReturnValue({}); jest.spyOn(packageUtils, 'getQueryParams').mockReturnValue({});
mountComponent();
}); });
afterEach(() => { afterEach(() => {
...@@ -75,30 +79,26 @@ describe('packages_list_app', () => { ...@@ -75,30 +79,26 @@ describe('packages_list_app', () => {
}); });
it('renders', () => { it('renders', () => {
createStore({ packageCount: 1 });
mountComponent(); mountComponent();
expect(wrapper.element).toMatchSnapshot(); expect(wrapper.element).toMatchSnapshot();
}); });
it('call requestPackagesList on page:changed', () => { it('calls requestPackagesList on page:changed', () => {
mountComponent();
store.dispatch.mockClear();
const list = findListComponent(); const list = findListComponent();
list.vm.$emit('page:changed', 1); list.vm.$emit('page:changed', 1);
expect(store.dispatch).toHaveBeenCalledWith('requestPackagesList', { page: 1 }); expect(store.dispatch).toHaveBeenCalledWith('requestPackagesList', { page: 1 });
}); });
it('call requestDeletePackage on package:delete', () => { it('calls requestDeletePackage on package:delete', () => {
mountComponent();
const list = findListComponent(); const list = findListComponent();
list.vm.$emit('package:delete', 'foo'); list.vm.$emit('package:delete', 'foo');
expect(store.dispatch).toHaveBeenCalledWith('requestDeletePackage', 'foo'); expect(store.dispatch).toHaveBeenCalledWith('requestDeletePackage', 'foo');
}); });
it('does call requestPackagesList only one time on render', () => { it('calls requestPackagesList only once on render', () => {
mountComponent();
expect(store.dispatch).toHaveBeenCalledTimes(3); expect(store.dispatch).toHaveBeenCalledTimes(3);
expect(store.dispatch).toHaveBeenNthCalledWith(1, 'setSorting', expect.any(Object)); expect(store.dispatch).toHaveBeenNthCalledWith(1, 'setSorting', expect.any(Object));
expect(store.dispatch).toHaveBeenNthCalledWith(2, 'setFilter', expect.any(Array)); expect(store.dispatch).toHaveBeenNthCalledWith(2, 'setFilter', expect.any(Array));
...@@ -113,9 +113,12 @@ describe('packages_list_app', () => { ...@@ -113,9 +113,12 @@ describe('packages_list_app', () => {
orderBy: 'created', orderBy: 'created',
}; };
it('calls setSorting with the query string based sorting', () => { beforeEach(() => {
createStore();
jest.spyOn(packageUtils, 'getQueryParams').mockReturnValue(defaultQueryParamsMock); jest.spyOn(packageUtils, 'getQueryParams').mockReturnValue(defaultQueryParamsMock);
});
it('calls setSorting with the query string based sorting', () => {
mountComponent(); mountComponent();
expect(store.dispatch).toHaveBeenNthCalledWith(1, 'setSorting', { expect(store.dispatch).toHaveBeenNthCalledWith(1, 'setSorting', {
...@@ -125,8 +128,6 @@ describe('packages_list_app', () => { ...@@ -125,8 +128,6 @@ describe('packages_list_app', () => {
}); });
it('calls setFilter with the query string based filters', () => { it('calls setFilter with the query string based filters', () => {
jest.spyOn(packageUtils, 'getQueryParams').mockReturnValue(defaultQueryParamsMock);
mountComponent(); mountComponent();
expect(store.dispatch).toHaveBeenNthCalledWith(2, 'setFilter', [ expect(store.dispatch).toHaveBeenNthCalledWith(2, 'setFilter', [
...@@ -150,8 +151,6 @@ describe('packages_list_app', () => { ...@@ -150,8 +151,6 @@ describe('packages_list_app', () => {
describe('empty state', () => { describe('empty state', () => {
it('generate the correct empty list link', () => { it('generate the correct empty list link', () => {
mountComponent();
const link = findListComponent().find(GlLink); const link = findListComponent().find(GlLink);
expect(link.attributes('href')).toBe(emptyListHelpUrl); expect(link.attributes('href')).toBe(emptyListHelpUrl);
...@@ -159,8 +158,6 @@ describe('packages_list_app', () => { ...@@ -159,8 +158,6 @@ describe('packages_list_app', () => {
}); });
it('includes the right content on the default tab', () => { it('includes the right content on the default tab', () => {
mountComponent();
const heading = findEmptyState().find('h1'); const heading = findEmptyState().find('h1');
expect(heading.text()).toBe('There are no packages yet'); expect(heading.text()).toBe('There are no packages yet');
...@@ -169,7 +166,7 @@ describe('packages_list_app', () => { ...@@ -169,7 +166,7 @@ describe('packages_list_app', () => {
describe('filter without results', () => { describe('filter without results', () => {
beforeEach(() => { beforeEach(() => {
createStore([{ type: 'something' }]); createStore({ filter: [{ type: 'something' }] });
mountComponent(); mountComponent();
}); });
...@@ -181,15 +178,24 @@ describe('packages_list_app', () => { ...@@ -181,15 +178,24 @@ describe('packages_list_app', () => {
}); });
}); });
describe('Search', () => { describe('search', () => {
it('exists', () => { describe('with no packages', () => {
it('does not exist', () => {
expect(findInfrastructureSearch().exists()).toBe(false);
});
});
describe('with packages', () => {
beforeEach(() => {
createStore({ packageCount: 1 });
mountComponent(); mountComponent();
});
it('exists', () => {
expect(findInfrastructureSearch().exists()).toBe(true); expect(findInfrastructureSearch().exists()).toBe(true);
}); });
it('on update fetches data from the store', () => { it('on update fetches data from the store', () => {
mountComponent();
store.dispatch.mockClear(); store.dispatch.mockClear();
findInfrastructureSearch().vm.$emit('update'); findInfrastructureSearch().vm.$emit('update');
...@@ -197,6 +203,7 @@ describe('packages_list_app', () => { ...@@ -197,6 +203,7 @@ describe('packages_list_app', () => {
expect(store.dispatch).toHaveBeenCalledWith('requestPackagesList'); expect(store.dispatch).toHaveBeenCalledWith('requestPackagesList');
}); });
}); });
});
describe('delete alert handling', () => { describe('delete alert handling', () => {
const originalLocation = window.location.href; const originalLocation = window.location.href;
......
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