Commit 54a45f52 authored by Kushal Pandya's avatar Kushal Pandya

Merge branch '345392-Remove-incident-header-dropdown-if-there-are-no-actions' into 'master'

Hide issue header dropdown button if there are no actions

See merge request gitlab-org/gitlab!76055
parents 7e866ccf e09446bb
...@@ -135,6 +135,14 @@ export default { ...@@ -135,6 +135,14 @@ export default {
const canReopen = this.isClosed && this.canReopenIssue; const canReopen = this.isClosed && this.canReopenIssue;
return canClose || canReopen; return canClose || canReopen;
}, },
hasDesktopDropdown() {
return (
this.canCreateIssue || this.canPromoteToEpic || !this.isIssueAuthor || this.canReportSpam
);
},
hasMobileDropdown() {
return this.hasDesktopDropdown || this.showToggleIssueStateButton;
},
}, },
created() { created() {
eventHub.$on('toggle.issuable.state', this.toggleIssueState); eventHub.$on('toggle.issuable.state', this.toggleIssueState);
...@@ -223,10 +231,12 @@ export default { ...@@ -223,10 +231,12 @@ export default {
<template> <template>
<div class="detail-page-header-actions gl-display-flex"> <div class="detail-page-header-actions gl-display-flex">
<gl-dropdown <gl-dropdown
v-if="hasMobileDropdown"
class="gl-sm-display-none! w-100" class="gl-sm-display-none! w-100"
block block
:text="dropdownText" :text="dropdownText"
data-qa-selector="issue_actions_dropdown" data-qa-selector="issue_actions_dropdown"
data-testid="mobile-dropdown"
:loading="isToggleStateButtonLoading" :loading="isToggleStateButtonLoading"
> >
<gl-dropdown-item <gl-dropdown-item
...@@ -276,11 +286,13 @@ export default { ...@@ -276,11 +286,13 @@ export default {
</gl-button> </gl-button>
<gl-dropdown <gl-dropdown
v-if="hasDesktopDropdown"
class="gl-display-none gl-sm-display-inline-flex! gl-ml-3" class="gl-display-none gl-sm-display-inline-flex! gl-ml-3"
icon="ellipsis_v" icon="ellipsis_v"
category="tertiary" category="tertiary"
:text="dropdownText" :text="dropdownText"
:text-sr-only="true" :text-sr-only="true"
data-testid="desktop-dropdown"
no-caret no-caret
right right
> >
......
...@@ -40,10 +40,8 @@ RSpec.describe "User views incident" do ...@@ -40,10 +40,8 @@ RSpec.describe "User views incident" do
visit(project_issues_incident_path(project, incident)) visit(project_issues_incident_path(project, incident))
end end
it 'does not show the incident action', :js, :aggregate_failures do it 'does not show the incident actions', :js, :aggregate_failures do
click_button 'Incident actions' expect(page).not_to have_button('Incident actions')
expect(page).not_to have_link('New incident')
end end
end end
end end
......
import { GlButton, GlDropdown, GlDropdownItem, GlLink, GlModal } from '@gitlab/ui';
import Vue, { nextTick } from 'vue'; import Vue, { nextTick } from 'vue';
import { GlButton, GlDropdownItem, GlLink, GlModal } from '@gitlab/ui';
import { shallowMount } from '@vue/test-utils'; import { shallowMount } from '@vue/test-utils';
import Vuex from 'vuex'; import Vuex from 'vuex';
import { mockTracking } from 'helpers/tracking_helper'; import { mockTracking } from 'helpers/tracking_helper';
...@@ -65,12 +65,17 @@ describe('HeaderActions component', () => { ...@@ -65,12 +65,17 @@ describe('HeaderActions component', () => {
}, },
}; };
const findToggleIssueStateButton = () => wrapper.findComponent(GlButton); const findToggleIssueStateButton = () => wrapper.find(GlButton);
const findDropdownAt = (index) => wrapper.findAllComponents(GlDropdown).at(index);
const findMobileDropdownItems = () => findDropdownAt(0).findAllComponents(GlDropdownItem); const findDropdownBy = (dataTestId) => wrapper.find(`[data-testid="${dataTestId}"]`);
const findDesktopDropdownItems = () => findDropdownAt(1).findAllComponents(GlDropdownItem); const findMobileDropdown = () => findDropdownBy('mobile-dropdown');
const findModal = () => wrapper.findComponent(GlModal); const findDesktopDropdown = () => findDropdownBy('desktop-dropdown');
const findModalLinkAt = (index) => findModal().findAllComponents(GlLink).at(index); const findMobileDropdownItems = () => findMobileDropdown().findAll(GlDropdownItem);
const findDesktopDropdownItems = () => findDesktopDropdown().findAll(GlDropdownItem);
const findModal = () => wrapper.find(GlModal);
const findModalLinkAt = (index) => findModal().findAll(GlLink).at(index);
const mountComponent = ({ const mountComponent = ({
props = {}, props = {},
...@@ -161,10 +166,10 @@ describe('HeaderActions component', () => { ...@@ -161,10 +166,10 @@ describe('HeaderActions component', () => {
}); });
describe.each` describe.each`
description | isCloseIssueItemVisible | findDropdownItems description | isCloseIssueItemVisible | findDropdownItems | findDropdown
${'mobile dropdown'} | ${true} | ${findMobileDropdownItems} ${'mobile dropdown'} | ${true} | ${findMobileDropdownItems} | ${findMobileDropdown}
${'desktop dropdown'} | ${false} | ${findDesktopDropdownItems} ${'desktop dropdown'} | ${false} | ${findDesktopDropdownItems} | ${findDesktopDropdown}
`('$description', ({ isCloseIssueItemVisible, findDropdownItems }) => { `('$description', ({ isCloseIssueItemVisible, findDropdownItems, findDropdown }) => {
describe.each` describe.each`
description | itemText | isItemVisible | canUpdateIssue | canCreateIssue | isIssueAuthor | canReportSpam | canPromoteToEpic | canDestroyIssue description | itemText | isItemVisible | canUpdateIssue | canCreateIssue | isIssueAuthor | canReportSpam | canPromoteToEpic | canDestroyIssue
${`when user can update ${issueType}`} | ${`Close ${issueType}`} | ${isCloseIssueItemVisible} | ${true} | ${true} | ${true} | ${true} | ${true} | ${true} ${`when user can update ${issueType}`} | ${`Close ${issueType}`} | ${isCloseIssueItemVisible} | ${true} | ${true} | ${true} | ${true} | ${true} | ${true}
...@@ -214,6 +219,24 @@ describe('HeaderActions component', () => { ...@@ -214,6 +219,24 @@ describe('HeaderActions component', () => {
}); });
}, },
); );
describe(`when user can update but not create ${issueType}`, () => {
beforeEach(() => {
wrapper = mountComponent({
props: {
canUpdateIssue: true,
canCreateIssue: false,
isIssueAuthor: true,
issueType,
canReportSpam: false,
canPromoteToEpic: false,
},
});
});
it(`${isCloseIssueItemVisible ? 'shows' : 'hides'} the dropdown button`, () => {
expect(findDropdown().exists()).toBe(isCloseIssueItemVisible);
});
});
}); });
}); });
......
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