Commit 4eb4de9c authored by Marcin Majkowski's avatar Marcin Majkowski

Hide "Resolve conflicts" button when source branch is protected

parent 38186b3c
<script> <script>
import { GlButton, GlModalDirective, GlSkeletonLoader, GlPopover, GlLink } from '@gitlab/ui'; import { GlButton, GlModalDirective, GlSkeletonLoader } from '@gitlab/ui';
import { s__ } from '~/locale';
import glFeatureFlagMixin from '~/vue_shared/mixins/gl_feature_flags_mixin'; import glFeatureFlagMixin from '~/vue_shared/mixins/gl_feature_flags_mixin';
import mergeRequestQueryVariablesMixin from '../../mixins/merge_request_query_variables'; import mergeRequestQueryVariablesMixin from '../../mixins/merge_request_query_variables';
import userPermissionsQuery from '../../queries/permissions.query.graphql'; import userPermissionsQuery from '../../queries/permissions.query.graphql';
...@@ -13,8 +12,6 @@ export default { ...@@ -13,8 +12,6 @@ export default {
GlSkeletonLoader, GlSkeletonLoader,
StatusIcon, StatusIcon,
GlButton, GlButton,
GlPopover,
GlLink,
}, },
directives: { directives: {
GlModalDirective, GlModalDirective,
...@@ -93,24 +90,12 @@ export default { ...@@ -93,24 +90,12 @@ export default {
return this.mr.sourceBranchProtected; return this.mr.sourceBranchProtected;
}, },
popoverTitle() {
return s__(
'mrWidget|This feature merges changes from the target branch to the source branch. You cannot use this feature since the source branch is protected.',
);
},
showResolveButton() { showResolveButton() {
return this.mr.conflictResolutionPath && this.canPushToSourceBranch; return (
}, this.mr.conflictResolutionPath && this.canPushToSourceBranch && !this.sourceBranchProtected
showPopover() { );
return this.showResolveButton && this.sourceBranchProtected;
}, },
}, },
i18n: {
title: s__(
'mrWidget|This feature merges changes from the target branch to the source branch. You cannot use this feature since the source branch is protected.',
),
linkText: s__('mrWidget|Learn more about resolving conflicts'),
},
}; };
</script> </script>
<template> <template>
...@@ -141,28 +126,13 @@ export default { ...@@ -141,28 +126,13 @@ export default {
}} }}
</span> </span>
</span> </span>
<span v-if="showResolveButton" ref="popover"> <gl-button
<gl-button v-if="showResolveButton"
:href="mr.conflictResolutionPath" :href="mr.conflictResolutionPath"
:disabled="sourceBranchProtected" data-testid="resolve-conflicts-button"
data-testid="resolve-conflicts-button" >
> {{ s__('mrWidget|Resolve conflicts') }}
{{ s__('mrWidget|Resolve conflicts') }} </gl-button>
</gl-button>
<gl-popover v-if="showPopover" :target="() => $refs.popover" placement="top">
<template #title>
<div class="gl-font-weight-normal gl-font-base">
{{ $options.i18n.title }}
</div>
</template>
<div class="gl-text-center">
<gl-link :href="mr.conflictsDocsPath" target="_blank" rel="noopener noreferrer">
{{ $options.i18n.linkText }}
</gl-link>
</div>
</gl-popover>
</span>
<gl-button <gl-button
v-if="canMerge" v-if="canMerge"
v-gl-modal-directive="'modal-merge-info'" v-gl-modal-directive="'modal-merge-info'"
......
---
title: Hide "Resolve conflicts" button when source branch is protected.
merge_request: 51121
author: Marcin Majkowski @marcinmajkowski
type: added
...@@ -36756,9 +36756,6 @@ msgstr "" ...@@ -36756,9 +36756,6 @@ msgstr ""
msgid "mrWidget|Jump to first unresolved thread" msgid "mrWidget|Jump to first unresolved thread"
msgstr "" msgstr ""
msgid "mrWidget|Learn more about resolving conflicts"
msgstr ""
msgid "mrWidget|Loading deployment statistics" msgid "mrWidget|Loading deployment statistics"
msgstr "" msgstr ""
...@@ -36873,9 +36870,6 @@ msgstr "" ...@@ -36873,9 +36870,6 @@ msgstr ""
msgid "mrWidget|This action will start a merge train when pipeline %{pipelineLink} succeeds." msgid "mrWidget|This action will start a merge train when pipeline %{pipelineLink} succeeds."
msgstr "" msgstr ""
msgid "mrWidget|This feature merges changes from the target branch to the source branch. You cannot use this feature since the source branch is protected."
msgstr ""
msgid "mrWidget|This merge request failed to be merged automatically" msgid "mrWidget|This merge request failed to be merged automatically"
msgstr "" msgstr ""
......
import { GlPopover } from '@gitlab/ui';
import { shallowMount } from '@vue/test-utils'; import { shallowMount } from '@vue/test-utils';
import { TEST_HOST } from 'helpers/test_constants'; import { TEST_HOST } from 'helpers/test_constants';
import { removeBreakLine } from 'helpers/text_helper'; import { removeBreakLine } from 'helpers/text_helper';
...@@ -10,7 +9,6 @@ describe('MRWidgetConflicts', () => { ...@@ -10,7 +9,6 @@ describe('MRWidgetConflicts', () => {
let mergeRequestWidgetGraphql = null; let mergeRequestWidgetGraphql = null;
const path = '/conflicts'; const path = '/conflicts';
const findPopover = () => wrapper.find(GlPopover);
const findResolveButton = () => wrapper.findByTestId('resolve-conflicts-button'); const findResolveButton = () => wrapper.findByTestId('resolve-conflicts-button');
const findMergeLocalButton = () => wrapper.findByTestId('merge-locally-button'); const findMergeLocalButton = () => wrapper.findByTestId('merge-locally-button');
...@@ -219,12 +217,8 @@ describe('MRWidgetConflicts', () => { ...@@ -219,12 +217,8 @@ describe('MRWidgetConflicts', () => {
}); });
}); });
it('sets resolve button as disabled', () => { it('should not allow you to resolve the conflicts', () => {
expect(findResolveButton().attributes('disabled')).toBe('true'); expect(findResolveButton().exists()).toBe(false);
});
it('shows the popover', () => {
expect(findPopover().exists()).toBe(true);
}); });
}); });
...@@ -241,12 +235,9 @@ describe('MRWidgetConflicts', () => { ...@@ -241,12 +235,9 @@ describe('MRWidgetConflicts', () => {
}); });
}); });
it('sets resolve button as disabled', () => { it('should allow you to resolve the conflicts', () => {
expect(findResolveButton().attributes('disabled')).toBe(undefined); expect(findResolveButton().text()).toContain('Resolve conflicts');
}); expect(findResolveButton().attributes('href')).toEqual(TEST_HOST);
it('does not show the popover', () => {
expect(findPopover().exists()).toBe(false);
}); });
}); });
}); });
......
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