Commit 8734a62d authored by Brandon Labuschagne's avatar Brandon Labuschagne Committed by Martin Wortschack

Add DA add segment tooltip

We introduce the limit of 30 segments in this MR
and display a tooltip on the disabled button when
this happens.
parent c0b25778
<script>
import dateformat from 'dateformat';
import { GlLoadingIcon, GlButton, GlSprintf, GlAlert, GlModalDirective } from '@gitlab/ui';
import {
GlLoadingIcon,
GlButton,
GlSprintf,
GlAlert,
GlModalDirective,
GlTooltipDirective,
} from '@gitlab/ui';
import * as Sentry from '~/sentry/wrapper';
import getGroupsQuery from '../graphql/queries/get_groups.query.graphql';
import devopsAdoptionSegmentsQuery from '../graphql/queries/devops_adoption_segments.query.graphql';
......@@ -11,6 +18,7 @@ import {
DEVOPS_ADOPTION_STRINGS,
DEVOPS_ADOPTION_ERROR_KEYS,
MAX_REQUEST_COUNT,
MAX_SEGMENTS,
DATE_TIME_FORMAT,
DEVOPS_ADOPTION_SEGMENT_MODAL_ID,
} from '../constants';
......@@ -28,10 +36,12 @@ export default {
},
directives: {
GlModal: GlModalDirective,
GlTooltip: GlTooltipDirective,
},
i18n: {
...DEVOPS_ADOPTION_STRINGS.app,
},
maxSegments: MAX_SEGMENTS,
devopsSegmentModalId: DEVOPS_ADOPTION_SEGMENT_MODAL_ID,
data() {
return {
......@@ -78,6 +88,12 @@ export default {
modalKey() {
return this.selectedSegment?.id;
},
segmentLimitReached() {
return this.devopsAdoptionSegments.nodes?.length > this.$options.maxSegments;
},
addSegmentButtonTooltipText() {
return this.segmentLimitReached ? this.$options.i18n.tableHeader.buttonTooltip : false;
},
},
created() {
this.fetchGroups();
......@@ -149,9 +165,14 @@ export default {
<template #timestamp>{{ timestamp }}</template>
</gl-sprintf>
</span>
<gl-button v-gl-modal="$options.devopsSegmentModalId" @click="clearSelectedSegment">{{
$options.i18n.tableHeader.button
}}</gl-button>
<span v-gl-tooltip.hover="addSegmentButtonTooltipText" data-testid="segmentButtonWrapper">
<gl-button
v-gl-modal="$options.devopsSegmentModalId"
:disabled="segmentLimitReached"
@click="clearSelectedSegment"
>{{ $options.i18n.tableHeader.button }}</gl-button
></span
>
</div>
<devops-adoption-table
:segments="devopsAdoptionSegments.nodes"
......
import { s__, __ } from '~/locale';
import { s__, __, sprintf } from '~/locale';
export const MAX_SEGMENTS = 30;
export const MAX_REQUEST_COUNT = 10;
......@@ -26,6 +28,9 @@ export const DEVOPS_ADOPTION_STRINGS = {
'DevopsAdoption|Feature adoption is based on usage in the last calendar month. Last updated: %{timestamp}.',
),
button: s__('DevopsAdoption|Add new segment'),
buttonTooltip: sprintf(s__('DevopsAdoption|Maximum %{maxSegments} segments allowed'), {
maxSegments: MAX_SEGMENTS,
}),
},
},
emptyState: {
......
import Vue from 'vue';
import VueApollo from 'vue-apollo';
import { createMockDirective, getBinding } from 'helpers/vue_mock_directive';
import { createLocalVue, shallowMount } from '@vue/test-utils';
import { GlAlert, GlButton, GlLoadingIcon, GlSprintf } from '@gitlab/ui';
import { getByText } from '@testing-library/dom';
......@@ -14,6 +15,7 @@ import DevopsAdoptionSegmentModal from 'ee/admin/dev_ops_report/components/devop
import {
DEVOPS_ADOPTION_STRINGS,
DEVOPS_ADOPTION_SEGMENT_MODAL_ID,
MAX_SEGMENTS,
} from 'ee/admin/dev_ops_report/constants';
import * as Sentry from '~/sentry/wrapper';
import {
......@@ -68,6 +70,9 @@ describe('DevopsAdoptionApp', () => {
stubs: {
GlSprintf,
},
directives: {
GlTooltip: createMockDirective(),
},
data() {
return data;
},
......@@ -354,9 +359,11 @@ describe('DevopsAdoptionApp', () => {
describe('segment modal button', () => {
let segmentButton;
let segmentButtonWrapper;
beforeEach(() => {
segmentButton = tableHeader.find(GlButton);
segmentButtonWrapper = wrapper.find("[data-testid='segmentButtonWrapper']");
});
afterEach(() => {
......@@ -375,6 +382,33 @@ describe('DevopsAdoptionApp', () => {
expect(rootEmit.mock.calls[0][0]).toContain('show');
expect(rootEmit.mock.calls[0][1]).toBe(DEVOPS_ADOPTION_SEGMENT_MODAL_ID);
});
it('does not have a tooltip', () => {
const tooltip = getBinding(segmentButtonWrapper.element, 'gl-tooltip');
// Setting a directive's value to false tells it not to render
expect(tooltip.value).toBe(false);
});
describe('when there are more than the max number of segments', () => {
beforeEach(() => {
const data = {
nodes: Array(MAX_SEGMENTS + 1).fill(devopsAdoptionSegmentsData.nodes[0]),
};
wrapper.setData({ devopsAdoptionSegments: data });
});
it('disables the button', () => {
expect(segmentButton.props('disabled')).toBe(true);
});
it('has a tooltip', () => {
const tooltip = getBinding(segmentButtonWrapper.element, 'gl-tooltip');
expect(tooltip).toBeDefined();
expect(tooltip.value).toBe('Maximum 30 segments allowed');
});
});
});
});
});
......
......@@ -9676,6 +9676,9 @@ msgstr ""
msgid "DevopsAdoption|MRs"
msgstr ""
msgid "DevopsAdoption|Maximum %{maxSegments} segments allowed"
msgstr ""
msgid "DevopsAdoption|My segment"
msgstr ""
......
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