106 lines
3.4 KiB
Vue
106 lines
3.4 KiB
Vue
<script>
|
|
import { GlButton, GlEmptyState, GlLoadingIcon } from '@gitlab/ui';
|
|
import { s__, __, sprintf } from '~/locale';
|
|
|
|
import appDataQuery from '../graphql/queries/app_data.query.graphql';
|
|
import savedContentMetaQuery from '../graphql/queries/saved_content_meta.query.graphql';
|
|
import { HOME_ROUTE } from '../router/constants';
|
|
|
|
export default {
|
|
components: {
|
|
GlButton,
|
|
GlEmptyState,
|
|
GlLoadingIcon,
|
|
},
|
|
props: {
|
|
mergeRequestsIllustrationPath: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
},
|
|
apollo: {
|
|
savedContentMeta: {
|
|
query: savedContentMetaQuery,
|
|
},
|
|
appData: {
|
|
query: appDataQuery,
|
|
},
|
|
},
|
|
computed: {
|
|
updatedFileDescription() {
|
|
const { sourcePath } = this.appData;
|
|
|
|
return sprintf(s__('Update %{sourcePath} file'), { sourcePath });
|
|
},
|
|
},
|
|
created() {
|
|
if (!this.appData.hasSubmittedChanges) {
|
|
this.$router.push(HOME_ROUTE);
|
|
}
|
|
},
|
|
title: s__('StaticSiteEditor|Your merge request has been created'),
|
|
primaryButtonText: __('View merge request'),
|
|
returnToSiteBtnText: s__('StaticSiteEditor|Return to site'),
|
|
mergeRequestInstructionsHeading: s__(
|
|
'StaticSiteEditor|To see your changes live you will need to do the following things:',
|
|
),
|
|
addTitleInstruction: s__('StaticSiteEditor|1. Add a clear title to describe the change.'),
|
|
addDescriptionInstruction: s__(
|
|
'StaticSiteEditor|2. Add a description to explain why the change is being made.',
|
|
),
|
|
assignMergeRequestInstruction: s__(
|
|
'StaticSiteEditor|3. Assign a person to review and accept the merge request.',
|
|
),
|
|
submittingTitle: s__('StaticSiteEditor|Creating your merge request'),
|
|
submittingNotePrimary: s__(
|
|
'StaticSiteEditor|You can set an assignee to get your changes reviewed and deployed once your merge request is created.',
|
|
),
|
|
submittingNoteSecondary: s__(
|
|
'StaticSiteEditor|A link to view the merge request will appear once ready.',
|
|
),
|
|
};
|
|
</script>
|
|
<template>
|
|
<div>
|
|
<div class="gl-border-b-solid gl-border-b-1 gl-border-b-gray-100">
|
|
<div class="container gl-py-4">
|
|
<div class="gl-display-flex">
|
|
<gl-button
|
|
v-if="appData.returnUrl"
|
|
ref="returnToSiteButton"
|
|
class="gl-mr-5 gl-align-self-start"
|
|
:href="appData.returnUrl"
|
|
>{{ $options.returnToSiteBtnText }}</gl-button
|
|
>
|
|
<strong class="gl-mt-2">
|
|
{{ updatedFileDescription }}
|
|
</strong>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="container">
|
|
<gl-empty-state
|
|
class="gl-my-7"
|
|
:title="savedContentMeta ? $options.title : $options.submittingTitle"
|
|
:primary-button-text="savedContentMeta && $options.primaryButtonText"
|
|
:primary-button-link="savedContentMeta && savedContentMeta.mergeRequest.url"
|
|
:svg-path="mergeRequestsIllustrationPath"
|
|
:svg-height="146"
|
|
>
|
|
<template #description>
|
|
<div v-if="savedContentMeta">
|
|
<p>{{ $options.mergeRequestInstructionsHeading }}</p>
|
|
<p>{{ $options.addTitleInstruction }}</p>
|
|
<p>{{ $options.addDescriptionInstruction }}</p>
|
|
<p>{{ $options.assignMergeRequestInstruction }}</p>
|
|
</div>
|
|
<div v-else>
|
|
<p>{{ $options.submittingNotePrimary }}</p>
|
|
<p>{{ $options.submittingNoteSecondary }}</p>
|
|
<gl-loading-icon size="xl" />
|
|
</div>
|
|
</template>
|
|
</gl-empty-state>
|
|
</div>
|
|
</div>
|
|
</template>
|