Commit c7f01b80 authored by David O'Regan's avatar David O'Regan

Merge branch 'gitlab-ui-integration-renovate/bootstrap-vue' into 'master'

Upgrade @gitlab/ui to v29.18.0

See merge request gitlab-org/gitlab!60926
parents fe8c4d53 1a3f200a
...@@ -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,
}, },
...@@ -72,7 +73,7 @@ export default { ...@@ -72,7 +73,7 @@ export default {
thClass: `gl-text-right gl-w-eighth`, thClass: `gl-text-right gl-w-eighth`,
tdClass: `${tdClass} gl-text-right`, tdClass: `${tdClass} gl-text-right`,
thAttr: TH_INCIDENT_SLA_TEST_ID, thAttr: TH_INCIDENT_SLA_TEST_ID,
sortKey: 'SLA_DUE_AT', actualSortKey: 'SLA_DUE_AT',
sortable: true, sortable: true,
sortDirection: 'asc', sortDirection: 'asc',
}, },
...@@ -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,
}, },
...@@ -174,8 +176,7 @@ export default { ...@@ -174,8 +176,7 @@ export default {
redirecting: false, redirecting: false,
incidents: {}, incidents: {},
incidentsCount: {}, incidentsCount: {},
sort: 'created_desc', sort: 'CREATED_DESC',
sortBy: 'createdAt',
sortDesc: true, sortDesc: true,
statusFilter: '', statusFilter: '',
filteredByStatus: '', filteredByStatus: '',
...@@ -256,20 +257,17 @@ export default { ...@@ -256,20 +257,17 @@ 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?.sortKey) {
sortKey = field.sortKey;
} else {
sortKey = convertToSnakeCase(sortBy).replace(/_.*/, '').toUpperCase();
}
this.pagination = initialPaginationState; this.pagination = initialPaginationState;
this.sort = `${sortKey}_${sortingDirection}`;
// BootstapVue natively supports a `sortKey` parameter, but using it results in the sorting
// icons not being updated properly in the header. We decided to fallback on `actualSortKey`
// to bypass BootstrapVue's behavior until the bug is addressed upstream.
// Related discussion: https://gitlab.com/gitlab-org/gitlab/-/merge_requests/60926/diffs#note_568020482
// Upstream issue: https://github.com/bootstrap-vue/bootstrap-vue/issues/6602
this.sort = `${field.actualSortKey}_${sortingDirection}`;
}, },
getSeverity(severity) { getSeverity(severity) {
return INCIDENT_SEVERITY[severity]; return INCIDENT_SEVERITY[severity];
...@@ -334,14 +332,14 @@ export default { ...@@ -334,14 +332,14 @@ export default {
<gl-table <gl-table
:items="incidents.list || []" :items="incidents.list || []"
:fields="availableFields" :fields="availableFields"
:show-empty="true"
:busy="loading" :busy="loading"
stacked="md" stacked="md"
:tbody-tr-class="tbodyTrClass" :tbody-tr-class="tbodyTrClass"
:no-local-sorting="true" sort-direction="desc"
:sort-direction="'desc'"
:sort-desc.sync="sortDesc" :sort-desc.sync="sortDesc"
:sort-by.sync="sortBy" sort-by="createdAt"
show-empty
no-local-sorting
sort-icon-left sort-icon-left
fixed fixed
@row-clicked="navigateToIncidentDetails" @row-clicked="navigateToIncidentDetails"
......
import { mount, shallowMount } from '@vue/test-utils'; import { mount, shallowMount } from '@vue/test-utils';
import ExpandableSection from 'ee/security_configuration/components/expandable_section.vue'; import ExpandableSection from 'ee/security_configuration/components/expandable_section.vue';
import { stubTransition } from 'helpers/stub_transition'; import { stubTransition } from 'helpers/stub_transition';
import waitForPromises from 'helpers/wait_for_promises';
describe('ExpandableSection component', () => { describe('ExpandableSection component', () => {
let wrapper; let wrapper;
...@@ -90,7 +91,8 @@ describe('ExpandableSection component', () => { ...@@ -90,7 +91,8 @@ describe('ExpandableSection component', () => {
}); });
describe('clicking the expand button', () => { describe('clicking the expand button', () => {
beforeEach(() => { beforeEach(async () => {
await waitForPromises();
const button = findButton(); const button = findButton();
button.trigger('click'); button.trigger('click');
return wrapper.vm.$nextTick(); return wrapper.vm.$nextTick();
......
...@@ -270,22 +270,25 @@ describe('Incidents List', () => { ...@@ -270,22 +270,25 @@ describe('Incidents List', () => {
const noneSort = 'none'; const noneSort = 'none';
it.each` it.each`
selector | initialSort | firstSort | nextSort description | selector | initialSort | firstSort | nextSort
${TH_CREATED_AT_TEST_ID} | ${descSort} | ${ascSort} | ${descSort} ${'creation date'} | ${TH_CREATED_AT_TEST_ID} | ${descSort} | ${ascSort} | ${descSort}
${TH_SEVERITY_TEST_ID} | ${noneSort} | ${descSort} | ${ascSort} ${'severity'} | ${TH_SEVERITY_TEST_ID} | ${noneSort} | ${descSort} | ${ascSort}
${TH_PUBLISHED_TEST_ID} | ${noneSort} | ${descSort} | ${ascSort} ${'publish date'} | ${TH_PUBLISHED_TEST_ID} | ${noneSort} | ${descSort} | ${ascSort}
${TH_INCIDENT_SLA_TEST_ID} | ${noneSort} | ${ascSort} | ${descSort} ${'due date'} | ${TH_INCIDENT_SLA_TEST_ID} | ${noneSort} | ${ascSort} | ${descSort}
`('updates sort with new direction', async ({ selector, initialSort, firstSort, nextSort }) => { `(
const [[attr, value]] = Object.entries(selector); 'updates sort with new direction when sorting by $description',
const columnHeader = () => wrapper.find(`[${attr}="${value}"]`); async ({ selector, initialSort, firstSort, nextSort }) => {
expect(columnHeader().attributes('aria-sort')).toBe(initialSort); const [[attr, value]] = Object.entries(selector);
columnHeader().trigger('click'); const columnHeader = () => wrapper.find(`[${attr}="${value}"]`);
await wrapper.vm.$nextTick(); expect(columnHeader().attributes('aria-sort')).toBe(initialSort);
expect(columnHeader().attributes('aria-sort')).toBe(firstSort); columnHeader().trigger('click');
columnHeader().trigger('click'); await wrapper.vm.$nextTick();
await wrapper.vm.$nextTick(); expect(columnHeader().attributes('aria-sort')).toBe(firstSort);
expect(columnHeader().attributes('aria-sort')).toBe(nextSort); columnHeader().trigger('click');
}); await wrapper.vm.$nextTick();
expect(columnHeader().attributes('aria-sort')).toBe(nextSort);
},
);
}); });
describe('Snowplow tracking', () => { describe('Snowplow tracking', () => {
......
...@@ -44,9 +44,7 @@ exports[`Learn GitLab Design A renders correctly 1`] = ` ...@@ -44,9 +44,7 @@ exports[`Learn GitLab Design A renders correctly 1`] = `
class="progress-bar" class="progress-bar"
role="progressbar" role="progressbar"
style="width: 22.22222222222222%;" style="width: 22.22222222222222%;"
> />
<!---->
</div>
</div> </div>
</div> </div>
......
...@@ -44,9 +44,7 @@ exports[`Learn GitLab Design B renders correctly 1`] = ` ...@@ -44,9 +44,7 @@ exports[`Learn GitLab Design B renders correctly 1`] = `
class="progress-bar" class="progress-bar"
role="progressbar" role="progressbar"
style="width: 22.22222222222222%;" style="width: 22.22222222222222%;"
> />
<!---->
</div>
</div> </div>
</div> </div>
......
...@@ -907,14 +907,14 @@ ...@@ -907,14 +907,14 @@
resolved "https://registry.yarnpkg.com/@gitlab/tributejs/-/tributejs-1.0.0.tgz#672befa222aeffc83e7d799b0500a7a4418e59b8" resolved "https://registry.yarnpkg.com/@gitlab/tributejs/-/tributejs-1.0.0.tgz#672befa222aeffc83e7d799b0500a7a4418e59b8"
integrity sha512-nmKw1+hB6MHvlmPz63yPwVs1qQkycHwsKgxpEbzmky16Y6mL4EJMk3w1b8QlOAF/AIAzjCERPhe/R4MJiohbZw== integrity sha512-nmKw1+hB6MHvlmPz63yPwVs1qQkycHwsKgxpEbzmky16Y6mL4EJMk3w1b8QlOAF/AIAzjCERPhe/R4MJiohbZw==
"@gitlab/ui@29.17.0": "@gitlab/ui@29.18.0":
version "29.17.0" version "29.18.0"
resolved "https://registry.yarnpkg.com/@gitlab/ui/-/ui-29.17.0.tgz#405eb5448741f1b7ea17afd913d6e918d783cbce" resolved "https://registry.yarnpkg.com/@gitlab/ui/-/ui-29.18.0.tgz#c6ca04d9ef0b2e96ab0cd1e0570441e0d2accda7"
integrity sha512-BsHPEBD9wIq0LnewxgTmPYKDn0rE3b3aluN3hn9A7zVgnofifmA9c0Cn25u0ha3sOV13K1NNtDKlEgcwgOWgQQ== integrity sha512-CNa7eZn+8/j4/NzDBG5cdiIfyRZEb9J84WkEFTk7ZafZKdP2jtbdzys9eotQcS11kS1rf95rSVpQy0P6vebt1A==
dependencies: dependencies:
"@babel/standalone" "^7.0.0" "@babel/standalone" "^7.0.0"
"@gitlab/vue-toasted" "^1.3.0" "@gitlab/vue-toasted" "^1.3.0"
bootstrap-vue "2.16.0" bootstrap-vue "2.17.3"
copy-to-clipboard "^3.0.8" copy-to-clipboard "^3.0.8"
dompurify "^2.2.8" dompurify "^2.2.8"
echarts "^4.9.0" echarts "^4.9.0"
...@@ -2740,22 +2740,27 @@ bonjour@^3.5.0: ...@@ -2740,22 +2740,27 @@ bonjour@^3.5.0:
multicast-dns "^6.0.1" multicast-dns "^6.0.1"
multicast-dns-service-types "^1.1.0" multicast-dns-service-types "^1.1.0"
bootstrap-vue@2.16.0: bootstrap-vue@2.17.3:
version "2.16.0" version "2.17.3"
resolved "https://registry.yarnpkg.com/bootstrap-vue/-/bootstrap-vue-2.16.0.tgz#07e7032ec9ffdd576470dc437da54f398ec16ba5" resolved "https://registry.yarnpkg.com/bootstrap-vue/-/bootstrap-vue-2.17.3.tgz#3d78b7b4ff992a8ad69d2ed1c7413fcfdcefaec7"
integrity sha512-gLETwPmeRHCe5WHmhGxzb5PtTEuKqQPGl0TFvZ2Odbkg/7UuIHdqIexrJRerpnomP4ZzDQ+qYGL91Ls9lcQsJQ== integrity sha512-upX5LktvsecbBsLnjwaSQoDCsYfneToOweOaERt+Cc/cT6P44zODzpxZa54HZEAbE5gSE5mJmDacUrs02qAR8g==
dependencies: dependencies:
"@nuxt/opencollective" "^0.3.0" "@nuxt/opencollective" "^0.3.0"
bootstrap ">=4.5.0 <5.0.0" bootstrap ">=4.5.2 <5.0.0"
popper.js "^1.16.1" popper.js "^1.16.1"
portal-vue "^2.1.7" portal-vue "^2.1.7"
vue-functional-data-merge "^3.1.0" vue-functional-data-merge "^3.1.0"
bootstrap@4.5.3, "bootstrap@>=4.5.0 <5.0.0": bootstrap@4.5.3:
version "4.5.3" version "4.5.3"
resolved "https://registry.yarnpkg.com/bootstrap/-/bootstrap-4.5.3.tgz#c6a72b355aaf323920be800246a6e4ef30997fe6" resolved "https://registry.yarnpkg.com/bootstrap/-/bootstrap-4.5.3.tgz#c6a72b355aaf323920be800246a6e4ef30997fe6"
integrity sha512-o9ppKQioXGqhw8Z7mah6KdTYpNQY//tipnkxppWhPbiSWdD+1raYsnhwEZjkTHYbGee4cVQ0Rx65EhOY/HNLcQ== integrity sha512-o9ppKQioXGqhw8Z7mah6KdTYpNQY//tipnkxppWhPbiSWdD+1raYsnhwEZjkTHYbGee4cVQ0Rx65EhOY/HNLcQ==
"bootstrap@>=4.5.2 <5.0.0":
version "4.6.0"
resolved "https://registry.yarnpkg.com/bootstrap/-/bootstrap-4.6.0.tgz#97b9f29ac98f98dfa43bf7468262d84392552fd7"
integrity sha512-Io55IuQY3kydzHtbGvQya3H+KorS/M9rSNyfCGCg9WZ4pyT/lCxIlpJgG1GXW/PswzC84Tr2fBYi+7+jFVQQBw==
boxen@^4.2.0: boxen@^4.2.0:
version "4.2.0" version "4.2.0"
resolved "https://registry.yarnpkg.com/boxen/-/boxen-4.2.0.tgz#e411b62357d6d6d36587c8ac3d5d974daa070e64" resolved "https://registry.yarnpkg.com/boxen/-/boxen-4.2.0.tgz#e411b62357d6d6d36587c8ac3d5d974daa070e64"
......
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