Commit bf80a0e4 authored by Ezekiel Kigbo's avatar Ezekiel Kigbo

Merge branch 'eread/migrate-vsa-stage-dropdown-to-new-dropdown' into 'master'

Migrate vsa stage dropdown to new dropdown

See merge request gitlab-org/gitlab!43505
parents 4f1a0b56 99657890
<script> <script>
import { GlButton, GlTooltipDirective } from '@gitlab/ui'; import { GlIcon, GlTooltipDirective, GlDropdown, GlDropdownItem } from '@gitlab/ui';
import { __ } from '~/locale'; import { __ } from '~/locale';
import { approximateDuration } from '~/lib/utils/datetime_utility'; import { approximateDuration } from '~/lib/utils/datetime_utility';
import StageCardListItem from './stage_card_list_item.vue'; import StageCardListItem from './stage_card_list_item.vue';
...@@ -17,7 +17,9 @@ export default { ...@@ -17,7 +17,9 @@ export default {
name: 'StageNavItem', name: 'StageNavItem',
components: { components: {
StageCardListItem, StageCardListItem,
GlButton, GlIcon,
GlDropdown,
GlDropdownItem,
}, },
directives: { directives: {
GlTooltip: GlTooltipDirective, GlTooltip: GlTooltipDirective,
...@@ -68,7 +70,7 @@ export default { ...@@ -68,7 +70,7 @@ export default {
return approximateDuration(this.value); return approximateDuration(this.value);
}, },
openMenuClasses() { openMenuClasses() {
return this.isHover ? 'd-flex justify-content-end' : ''; return this.isHover ? 'gl-display-flex gl-justify-content-end' : '';
}, },
error() { error() {
return ERROR_NAV_ITEM_CONTENT[this.errorMessage] || ERROR_NAV_ITEM_CONTENT.fallback; return ERROR_NAV_ITEM_CONTENT[this.errorMessage] || ERROR_NAV_ITEM_CONTENT.fallback;
...@@ -114,7 +116,7 @@ export default { ...@@ -114,7 +116,7 @@ export default {
@mouseover="handleHover(true)" @mouseover="handleHover(true)"
@mouseleave="handleHover()" @mouseleave="handleHover()"
> >
<stage-card-list-item :is-active="isActive" class="d-flex justify-space-between"> <stage-card-list-item :is-active="isActive" class="gl-display-flex gl-justify-space-between">
<div <div
ref="title" ref="title"
class="stage-nav-item-cell stage-name text-truncate w-50 pr-2" class="stage-nav-item-cell stage-name text-truncate w-50 pr-2"
...@@ -124,53 +126,52 @@ export default { ...@@ -124,53 +126,52 @@ export default {
title title
}}</span> }}</span>
</div> </div>
<div class="stage-nav-item-cell w-50 d-flex justify-content-between"> <div class="stage-nav-item-cell w-50 gl-display-flex gl-justify-content-between">
<div ref="median" class="stage-median w-75 align-items-start"> <div ref="median" class="stage-median w-75 align-items-start">
<span v-if="hasValue">{{ median }}</span> <span v-if="hasValue">{{ median }}</span>
<span v-else v-gl-tooltip="{ title: errorMessage }" class="stage-empty">{{ error }}</span> <span v-else v-gl-tooltip="{ title: errorMessage }" class="stage-empty">{{ error }}</span>
</div> </div>
<div v-show="isHover" ref="dropdown" :class="[openMenuClasses]" class="dropdown w-25"> <div v-show="isHover" ref="dropdown" :class="[openMenuClasses]" class="dropdown w-25">
<gl-button <gl-dropdown
toggle-class="gl-p-0! gl-bg-transparent! gl-shadow-none!"
data-testid="more-actions-toggle"
>
<template #button-content>
<span
v-gl-tooltip v-gl-tooltip
category="tertiary" category="tertiary"
icon="ellipsis_v"
:title="__('More actions')" :title="__('More actions')"
class="more-actions-toggle btn btn-transparent p-0"
data-toggle="dropdown" data-toggle="dropdown"
/> >
<ul class="more-actions-dropdown dropdown-menu dropdown-open-left"> <gl-icon name="ellipsis_v" />
</span>
</template>
<template v-if="isDefaultStage"> <template v-if="isDefaultStage">
<li> <gl-dropdown-item
<gl-button
category="tertiary" category="tertiary"
data-testid="hide-btn" data-testid="hide-btn"
@click="handleDropdownAction('hide', $event)" @click="handleDropdownAction('hide', $event)"
> >
{{ __('Hide stage') }} {{ __('Hide stage') }}
</gl-button> </gl-dropdown-item>
</li>
</template> </template>
<template v-else> <template v-else>
<li> <gl-dropdown-item
<gl-button
category="tertiary" category="tertiary"
data-testid="edit-btn" data-testid="edit-btn"
@click="handleDropdownAction('edit', $event)" @click="handleDropdownAction('edit', $event)"
> >
{{ __('Edit stage') }} {{ __('Edit stage') }}
</gl-button> </gl-dropdown-item>
</li> <gl-dropdown-item
<li>
<gl-button
category="tertiary" category="tertiary"
data-testid="remove-btn" data-testid="remove-btn"
@click="handleDropdownAction('remove', $event)" @click="handleDropdownAction('remove', $event)"
> >
{{ __('Remove stage') }} {{ __('Remove stage') }}
</gl-button> </gl-dropdown-item>
</li>
</template> </template>
</ul> </gl-dropdown>
</div> </div>
</div> </div>
</stage-card-list-item> </stage-card-list-item>
......
...@@ -27,7 +27,7 @@ RSpec.describe 'Value stream analytics charts', :js do ...@@ -27,7 +27,7 @@ RSpec.describe 'Value stream analytics charts', :js do
def toggle_more_options(stage) def toggle_more_options(stage)
stage.hover stage.hover
stage.find('.more-actions-toggle').click stage.find('[data-testid="more-actions-toggle"]').click
end end
before do before do
......
...@@ -53,7 +53,7 @@ RSpec.describe 'Customizable Group Value Stream Analytics', :js do ...@@ -53,7 +53,7 @@ RSpec.describe 'Customizable Group Value Stream Analytics', :js do
def toggle_more_options(stage) def toggle_more_options(stage)
stage.hover stage.hover
stage.find('.more-actions-toggle').click find_stage_actions_btn(stage).click
end end
def select_dropdown_option(name, value = start_event_identifier) def select_dropdown_option(name, value = start_event_identifier)
...@@ -84,6 +84,10 @@ RSpec.describe 'Customizable Group Value Stream Analytics', :js do ...@@ -84,6 +84,10 @@ RSpec.describe 'Customizable Group Value Stream Analytics', :js do
to_index: to) to_index: to)
end end
def find_stage_actions_btn(stage)
stage.find('[data-testid="more-actions-toggle"]')
end
before do before do
stub_licensed_features(cycle_analytics_for_groups: true, type_of_work_analytics: true) stub_licensed_features(cycle_analytics_for_groups: true, type_of_work_analytics: true)
...@@ -391,9 +395,9 @@ RSpec.describe 'Customizable Group Value Stream Analytics', :js do ...@@ -391,9 +395,9 @@ RSpec.describe 'Customizable Group Value Stream Analytics', :js do
end end
it "can be hidden, can't be edited or removed" do it "can be hidden, can't be edited or removed" do
expect(first_default_stage.find('.more-actions-dropdown')).to have_text(_('Hide stage')) expect(find_stage_actions_btn(first_default_stage)).to have_text(_('Hide stage'))
expect(first_default_stage.find('.more-actions-dropdown')).not_to have_text(_('Edit stage')) expect(find_stage_actions_btn(first_default_stage)).not_to have_text(_('Edit stage'))
expect(first_default_stage.find('.more-actions-dropdown')).not_to have_text(_('Remove stage')) expect(find_stage_actions_btn(first_default_stage)).not_to have_text(_('Remove stage'))
end end
context 'Hide stage' do context 'Hide stage' do
...@@ -445,9 +449,9 @@ RSpec.describe 'Customizable Group Value Stream Analytics', :js do ...@@ -445,9 +449,9 @@ RSpec.describe 'Customizable Group Value Stream Analytics', :js do
end end
it 'can not be hidden, can be edited or removed' do it 'can not be hidden, can be edited or removed' do
expect(first_custom_stage.find('.more-actions-dropdown')).not_to have_text(_('Hide stage')) expect(find_stage_actions_btn(first_custom_stage)).not_to have_text(_('Hide stage'))
expect(first_custom_stage.find('.more-actions-dropdown')).to have_text(_('Edit stage')) expect(find_stage_actions_btn(first_custom_stage)).to have_text(_('Edit stage'))
expect(first_custom_stage.find('.more-actions-dropdown')).to have_text(_('Remove stage')) expect(find_stage_actions_btn(first_custom_stage)).to have_text(_('Remove stage'))
end end
it 'disappears from the stage table after being removed' do it 'disappears from the stage table after being removed' do
......
...@@ -118,7 +118,7 @@ describe('StageNavItem', () => { ...@@ -118,7 +118,7 @@ describe('StageNavItem', () => {
expect(wrapper.find('.stage-median').text()).toBe('Not available'); expect(wrapper.find('.stage-median').text()).toBe('Not available');
}); });
it('does not render options menu', () => { it('does not render options menu', () => {
expect(wrapper.find('.more-actions-toggle').exists()).toBe(false); expect(wrapper.find('[data-testid="more-actions-toggle"]').exists()).toBe(false);
}); });
}); });
...@@ -135,7 +135,7 @@ describe('StageNavItem', () => { ...@@ -135,7 +135,7 @@ describe('StageNavItem', () => {
}); });
it('does not render options menu', () => { it('does not render options menu', () => {
expect(wrapper.find('.more-actions-toggle').exists()).toBe(false); expect(wrapper.find('[data-testid="more-actions-toggle"]').exists()).toBe(false);
}); });
it('can not edit the stage', () => { it('can not edit the stage', () => {
......
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