Commit 06c868c3 authored by Tristan Read's avatar Tristan Read Committed by Paul Gascou-Vaillancourt

Use a sort key for all sortable columns

parent 71861c69
...@@ -10,7 +10,6 @@ import { ...@@ -10,7 +10,6 @@ import {
GlIcon, GlIcon,
GlEmptyState, GlEmptyState,
} from '@gitlab/ui'; } from '@gitlab/ui';
import { convertToSnakeCase } from '~/lib/utils/text_utility';
import { visitUrl, mergeUrlParams, joinPaths } from '~/lib/utils/url_utility'; import { visitUrl, mergeUrlParams, joinPaths } from '~/lib/utils/url_utility';
import { s__ } from '~/locale'; import { s__ } from '~/locale';
import { INCIDENT_SEVERITY } from '~/sidebar/components/severity/constants'; import { INCIDENT_SEVERITY } from '~/sidebar/components/severity/constants';
...@@ -49,6 +48,7 @@ export default { ...@@ -49,6 +48,7 @@ export default {
label: s__('IncidentManagement|Severity'), label: s__('IncidentManagement|Severity'),
thClass: `${thClass} w-15p`, thClass: `${thClass} w-15p`,
tdClass: `${tdClass} sortable-cell`, tdClass: `${tdClass} sortable-cell`,
actualSortKey: 'SEVERITY',
sortable: true, sortable: true,
thAttr: TH_SEVERITY_TEST_ID, thAttr: TH_SEVERITY_TEST_ID,
}, },
...@@ -63,6 +63,7 @@ export default { ...@@ -63,6 +63,7 @@ export default {
label: s__('IncidentManagement|Date created'), label: s__('IncidentManagement|Date created'),
thClass: `${thClass} gl-w-eighth`, thClass: `${thClass} gl-w-eighth`,
tdClass: `${tdClass} sortable-cell`, tdClass: `${tdClass} sortable-cell`,
actualSortKey: 'CREATED',
sortable: true, sortable: true,
thAttr: TH_CREATED_AT_TEST_ID, thAttr: TH_CREATED_AT_TEST_ID,
}, },
...@@ -87,6 +88,7 @@ export default { ...@@ -87,6 +88,7 @@ export default {
label: s__('IncidentManagement|Published'), label: s__('IncidentManagement|Published'),
thClass: `${thClass} w-15p`, thClass: `${thClass} w-15p`,
tdClass: `${tdClass} sortable-cell`, tdClass: `${tdClass} sortable-cell`,
actualSortKey: 'PUBLISHED',
sortable: true, sortable: true,
thAttr: TH_PUBLISHED_TEST_ID, thAttr: TH_PUBLISHED_TEST_ID,
}, },
...@@ -175,7 +177,6 @@ export default { ...@@ -175,7 +177,6 @@ export default {
incidents: {}, incidents: {},
incidentsCount: {}, incidentsCount: {},
sort: 'CREATED_DESC', sort: 'CREATED_DESC',
sortBy: 'createdAt',
sortDesc: true, sortDesc: true,
statusFilter: '', statusFilter: '',
filteredByStatus: '', filteredByStatus: '',
...@@ -256,20 +257,11 @@ export default { ...@@ -256,20 +257,11 @@ export default {
this.redirecting = true; this.redirecting = true;
}, },
fetchSortedData({ sortBy, sortDesc }) { fetchSortedData({ sortBy, sortDesc }) {
let sortKey;
// In bootstrap-vue v2.17.0, sortKey becomes natively supported and we can eliminate this function
const field = this.availableFields.find(({ key }) => key === sortBy); const field = this.availableFields.find(({ key }) => key === sortBy);
const sortingDirection = sortDesc ? 'DESC' : 'ASC'; const sortingDirection = sortDesc ? 'DESC' : 'ASC';
// Use `sortKey` if provided, otherwise fall back to existing algorithm
if (field?.actualSortKey) {
sortKey = field.actualSortKey;
} else {
sortKey = convertToSnakeCase(sortBy).replace(/_.*/, '').toUpperCase();
}
this.pagination = initialPaginationState; this.pagination = initialPaginationState;
this.sort = `${sortKey}_${sortingDirection}`; this.sort = `${field.actualSortKey}_${sortingDirection}`;
}, },
getSeverity(severity) { getSeverity(severity) {
return INCIDENT_SEVERITY[severity]; return INCIDENT_SEVERITY[severity];
...@@ -339,7 +331,7 @@ export default { ...@@ -339,7 +331,7 @@ export default {
:tbody-tr-class="tbodyTrClass" :tbody-tr-class="tbodyTrClass"
sort-direction="desc" sort-direction="desc"
:sort-desc.sync="sortDesc" :sort-desc.sync="sortDesc"
:sort-by.sync="sortBy" sort-by="createdAt"
show-empty show-empty
no-local-sorting no-local-sorting
sort-icon-left sort-icon-left
......
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