Commit 427826b0 authored by Frédéric Caplette's avatar Frédéric Caplette Committed by Andrew Fontaine

Improve cancel button experience in Pipeline editor

parent 0665ed13
...@@ -73,7 +73,7 @@ export default { ...@@ -73,7 +73,7 @@ export default {
}); });
}, },
onReset() { onReset() {
this.$emit('cancel'); this.$emit('resetContent');
}, },
scrollIntoView() { scrollIntoView() {
this.$el.scrollIntoView({ behavior: 'smooth' }); this.$el.scrollIntoView({ behavior: 'smooth' });
...@@ -86,7 +86,7 @@ export default { ...@@ -86,7 +86,7 @@ export default {
startMergeRequest: __('Start a %{new_merge_request} with these changes'), startMergeRequest: __('Start a %{new_merge_request} with these changes'),
newMergeRequest: __('new merge request'), newMergeRequest: __('new merge request'),
commitChanges: __('Commit changes'), commitChanges: __('Commit changes'),
cancel: __('Cancel'), resetContent: __('Reset'),
}, },
}; };
</script> </script>
...@@ -148,7 +148,7 @@ export default { ...@@ -148,7 +148,7 @@ export default {
{{ $options.i18n.commitChanges }} {{ $options.i18n.commitChanges }}
</gl-button> </gl-button>
<gl-button type="reset" category="secondary" class="gl-mr-3"> <gl-button type="reset" category="secondary" class="gl-mr-3">
{{ $options.i18n.cancel }} {{ $options.i18n.resetContent }}
</gl-button> </gl-button>
</div> </div>
</gl-form> </gl-form>
......
...@@ -127,9 +127,6 @@ export default { ...@@ -127,9 +127,6 @@ export default {
this.isSaving = false; this.isSaving = false;
} }
}, },
onCommitCancel() {
this.$emit('resetContent');
},
updateCurrentBranch(currentBranch) { updateCurrentBranch(currentBranch) {
this.$apollo.mutate({ this.$apollo.mutate({
mutation: updateCurrentBranchMutation, mutation: updateCurrentBranchMutation,
...@@ -153,7 +150,6 @@ export default { ...@@ -153,7 +150,6 @@ export default {
:is-saving="isSaving" :is-saving="isSaving"
:scroll-to-commit-form="scrollToCommitForm" :scroll-to-commit-form="scrollToCommitForm"
v-on="$listeners" v-on="$listeners"
@cancel="onCommitCancel"
@submit="onCommitSubmit" @submit="onCommitSubmit"
/> />
</template> </template>
<script> <script>
import { GlLoadingIcon } from '@gitlab/ui'; import { GlLoadingIcon, GlModal } from '@gitlab/ui';
import { fetchPolicies } from '~/lib/graphql'; import { fetchPolicies } from '~/lib/graphql';
import { queryToObject } from '~/lib/utils/url_utility'; import { queryToObject } from '~/lib/utils/url_utility';
import { s__ } from '~/locale'; import { __, s__ } from '~/locale';
import { unwrapStagesWithNeeds } from '~/pipelines/components/unwrapping_utils'; import { unwrapStagesWithNeeds } from '~/pipelines/components/unwrapping_utils';
...@@ -30,6 +30,7 @@ export default { ...@@ -30,6 +30,7 @@ export default {
components: { components: {
ConfirmUnsavedChangesDialog, ConfirmUnsavedChangesDialog,
GlLoadingIcon, GlLoadingIcon,
GlModal,
PipelineEditorEmptyState, PipelineEditorEmptyState,
PipelineEditorHome, PipelineEditorHome,
PipelineEditorMessages, PipelineEditorMessages,
...@@ -54,6 +55,7 @@ export default { ...@@ -54,6 +55,7 @@ export default {
lastCommittedContent: '', lastCommittedContent: '',
shouldSkipStartScreen: false, shouldSkipStartScreen: false,
showFailure: false, showFailure: false,
showResetComfirmationModal: false,
showStartScreen: false, showStartScreen: false,
showSuccess: false, showSuccess: false,
starterTemplate: '', starterTemplate: '',
...@@ -224,6 +226,18 @@ export default { ...@@ -224,6 +226,18 @@ export default {
tabGraph: s__('Pipelines|Visualize'), tabGraph: s__('Pipelines|Visualize'),
tabLint: s__('Pipelines|Lint'), tabLint: s__('Pipelines|Lint'),
}, },
resetModal: {
actionPrimary: {
text: __('Reset file'),
},
actionCancel: {
text: __('Cancel'),
},
body: s__(
'Pipeline Editor|Are you sure you want to reset the file to its last committed version?',
),
title: __('Discard changes'),
},
watch: { watch: {
isEmpty(flag) { isEmpty(flag) {
if (flag) { if (flag) {
...@@ -242,6 +256,11 @@ export default { ...@@ -242,6 +256,11 @@ export default {
hideSuccess() { hideSuccess() {
this.showSuccess = false; this.showSuccess = false;
}, },
confirmReset() {
if (this.hasUnsavedChanges) {
this.showResetComfirmationModal = true;
}
},
async refetchContent() { async refetchContent() {
this.$apollo.queries.initialCiFileContent.skip = false; this.$apollo.queries.initialCiFileContent.skip = false;
await this.$apollo.queries.initialCiFileContent.refetch(); await this.$apollo.queries.initialCiFileContent.refetch();
...@@ -262,6 +281,7 @@ export default { ...@@ -262,6 +281,7 @@ export default {
this.successType = type; this.successType = type;
}, },
resetContent() { resetContent() {
this.showResetComfirmationModal = false;
this.currentCiFileContent = this.lastCommittedContent; this.currentCiFileContent = this.lastCommittedContent;
}, },
setAppStatus(appStatus) { setAppStatus(appStatus) {
...@@ -335,12 +355,22 @@ export default { ...@@ -335,12 +355,22 @@ export default {
:has-unsaved-changes="hasUnsavedChanges" :has-unsaved-changes="hasUnsavedChanges"
:is-new-ci-config-file="isNewCiConfigFile" :is-new-ci-config-file="isNewCiConfigFile"
@commit="updateOnCommit" @commit="updateOnCommit"
@resetContent="resetContent" @resetContent="confirmReset"
@showError="showErrorAlert" @showError="showErrorAlert"
@refetchContent="refetchContent" @refetchContent="refetchContent"
@updateCiConfig="updateCiConfig" @updateCiConfig="updateCiConfig"
@updateCommitSha="updateCommitSha" @updateCommitSha="updateCommitSha"
/> />
<gl-modal
v-model="showResetComfirmationModal"
modal-id="reset-content"
:title="$options.resetModal.title"
:action-cancel="$options.resetModal.actionCancel"
:action-primary="$options.resetModal.actionPrimary"
@primary="resetContent"
>
{{ $options.resetModal.body }}
</gl-modal>
<confirm-unsaved-changes-dialog :has-unsaved-changes="hasUnsavedChanges" /> <confirm-unsaved-changes-dialog :has-unsaved-changes="hasUnsavedChanges" />
</div> </div>
</div> </div>
......
...@@ -25292,6 +25292,9 @@ msgstr "" ...@@ -25292,6 +25292,9 @@ msgstr ""
msgid "Pipeline Editor" msgid "Pipeline Editor"
msgstr "" msgstr ""
msgid "Pipeline Editor|Are you sure you want to reset the file to its last committed version?"
msgstr ""
msgid "Pipeline ID" msgid "Pipeline ID"
msgstr "" msgstr ""
...@@ -29523,6 +29526,9 @@ msgstr "" ...@@ -29523,6 +29526,9 @@ msgstr ""
msgid "Reset authorization key?" msgid "Reset authorization key?"
msgstr "" msgstr ""
msgid "Reset file"
msgstr ""
msgid "Reset filters" msgid "Reset filters"
msgstr "" msgstr ""
......
...@@ -52,4 +52,53 @@ RSpec.describe 'Pipeline Editor', :js do ...@@ -52,4 +52,53 @@ RSpec.describe 'Pipeline Editor', :js do
end end
end end
end end
context 'Editor content' do
it 'user can reset their CI configuration' do
click_button 'Collapse'
page.within('#source-editor-') do
find('textarea').send_keys '123'
end
# It takes some time after sending keys for the reset
# btn to register the changes inside the editor
sleep 1
click_button 'Reset'
expect(page).to have_css('#reset-content')
page.within('#reset-content') do
click_button 'Reset file'
end
page.within('#source-editor-') do
expect(page).to have_content('Default Content')
expect(page).not_to have_content('Default Content123')
end
end
it 'user can cancel reseting their CI configuration' do
click_button 'Collapse'
page.within('#source-editor-') do
find('textarea').send_keys '123'
end
# It takes some time after sending keys for the reset
# btn to register the changes inside the editor
sleep 1
click_button 'Reset'
expect(page).to have_css('#reset-content')
page.within('#reset-content') do
click_button 'Cancel'
end
page.within('#source-editor-') do
expect(page).to have_content('Default Content123')
end
end
end
end end
...@@ -78,7 +78,7 @@ describe('Pipeline Editor | Commit Form', () => { ...@@ -78,7 +78,7 @@ describe('Pipeline Editor | Commit Form', () => {
it('emits an event when the form resets', () => { it('emits an event when the form resets', () => {
findCancelBtn().trigger('click'); findCancelBtn().trigger('click');
expect(wrapper.emitted('cancel')).toHaveLength(1); expect(wrapper.emitted('resetContent')).toHaveLength(1);
}); });
}); });
......
...@@ -103,11 +103,6 @@ describe('Pipeline Editor | Commit section', () => { ...@@ -103,11 +103,6 @@ describe('Pipeline Editor | Commit section', () => {
await waitForPromises(); await waitForPromises();
}; };
const cancelCommitForm = async () => {
const findCancelBtn = () => wrapper.find('[type="reset"]');
await findCancelBtn().trigger('click');
};
afterEach(() => { afterEach(() => {
mockMutate.mockReset(); mockMutate.mockReset();
wrapper.destroy(); wrapper.destroy();
...@@ -266,18 +261,6 @@ describe('Pipeline Editor | Commit section', () => { ...@@ -266,18 +261,6 @@ describe('Pipeline Editor | Commit section', () => {
}); });
}); });
describe('when the commit form is cancelled', () => {
beforeEach(async () => {
createComponent();
});
it('emits an event so that it cab be reseted', async () => {
await cancelCommitForm();
expect(wrapper.emitted('resetContent')).toHaveLength(1);
});
});
it('sets listeners on commit form', () => { it('sets listeners on commit form', () => {
const handler = jest.fn(); const handler = jest.fn();
createComponent({ options: { listeners: { event: handler } } }); createComponent({ options: { listeners: { event: handler } } });
......
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