Commit 52c76470 authored by Mark Florian's avatar Mark Florian

Sort according to the field in Dependency List

This makes the Dependency List use a more sensible sort order for the
chosen sort field. Specifically, sorting by "Component name" or
"Packager" should be alphabetical by default (ascending), while sorting
by "Severity" should be descending (most severe to least).

Addresses https://gitlab.com/gitlab-org/gitlab/-/issues/335066.

Changelog: changed
EE: true
parent 62c8c506
...@@ -9,6 +9,12 @@ export const SORT_FIELDS = { ...@@ -9,6 +9,12 @@ export const SORT_FIELDS = {
export const SORT_ASCENDING = 'asc'; export const SORT_ASCENDING = 'asc';
export const SORT_DESCENDING = 'desc'; export const SORT_DESCENDING = 'desc';
export const SORT_FIELD_ORDER = {
name: SORT_ASCENDING,
packager: SORT_ASCENDING,
severity: SORT_DESCENDING,
};
export const REPORT_STATUS = { export const REPORT_STATUS = {
ok: 'ok', ok: 'ok',
jobNotSetUp: 'job_not_set_up', jobNotSetUp: 'job_not_set_up',
......
import { REPORT_STATUS, SORT_ASCENDING, SORT_DESCENDING } from './constants'; import { REPORT_STATUS, SORT_FIELD_ORDER, SORT_ASCENDING, SORT_DESCENDING } from './constants';
import * as types from './mutation_types'; import * as types from './mutation_types';
export default { export default {
...@@ -36,6 +36,7 @@ export default { ...@@ -36,6 +36,7 @@ export default {
}, },
[types.SET_SORT_FIELD](state, payload) { [types.SET_SORT_FIELD](state, payload) {
state.sortField = payload; state.sortField = payload;
state.sortOrder = SORT_FIELD_ORDER[payload];
}, },
[types.TOGGLE_SORT_ORDER](state) { [types.TOGGLE_SORT_ORDER](state) {
state.sortOrder = state.sortOrder === SORT_ASCENDING ? SORT_DESCENDING : SORT_ASCENDING; state.sortOrder = state.sortOrder === SORT_ASCENDING ? SORT_DESCENDING : SORT_ASCENDING;
......
import { FILTER, REPORT_STATUS, SORT_DESCENDING } from './constants'; import { FILTER, REPORT_STATUS, SORT_FIELD_ORDER } from './constants';
export default () => ({ export default () => {
endpoint: '', const sortField = 'severity';
initialized: false,
isLoading: false, return {
errorLoading: false, endpoint: '',
dependencies: [], initialized: false,
pageInfo: { isLoading: false,
total: 0, errorLoading: false,
}, dependencies: [],
reportInfo: { pageInfo: {
status: REPORT_STATUS.ok, total: 0,
jobPath: '', },
generatedAt: '', reportInfo: {
}, status: REPORT_STATUS.ok,
filter: FILTER.all, jobPath: '',
sortField: 'severity', generatedAt: '',
sortOrder: SORT_DESCENDING, },
}); filter: FILTER.all,
sortField,
sortOrder: SORT_FIELD_ORDER[sortField],
};
};
...@@ -90,11 +90,17 @@ describe('Dependencies mutations', () => { ...@@ -90,11 +90,17 @@ describe('Dependencies mutations', () => {
}); });
describe(types.SET_SORT_FIELD, () => { describe(types.SET_SORT_FIELD, () => {
it('sets the sort field', () => { it.each`
const field = 'foo'; field | order
${'name'} | ${SORT_ASCENDING}
${'packager'} | ${SORT_ASCENDING}
${'severity'} | ${SORT_DESCENDING}
${'foo'} | ${undefined}
`('sets the sort field to $field and sort order to $order', ({ field, order }) => {
mutations[types.SET_SORT_FIELD](state, field); mutations[types.SET_SORT_FIELD](state, field);
expect(state.sortField).toBe(field); expect(state.sortField).toBe(field);
expect(state.sortOrder).toBe(order);
}); });
}); });
......
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