Commit 0fe02c5d authored by Vitaly Slobodin's avatar Vitaly Slobodin

Merge branch '268017-suggest-pipeline-celebration-emoji-broken' into 'master'

Fix broken suggest pipeline emoji

See merge request gitlab-org/gitlab!45326
parents bc2e560c eb6f3bda
<script> <script>
import { GlModal, GlSprintf, GlLink, GlButton } from '@gitlab/ui'; import { GlModal, GlSprintf, GlLink, GlButton } from '@gitlab/ui';
import Cookies from 'js-cookie'; import Cookies from 'js-cookie';
import { sprintf, s__, __ } from '~/locale'; import { s__ } from '~/locale';
import { glEmojiTag } from '~/emoji';
import Tracking from '~/tracking'; import Tracking from '~/tracking';
const trackingMixin = Tracking.mixin(); const trackingMixin = Tracking.mixin();
...@@ -12,21 +11,6 @@ export default { ...@@ -12,21 +11,6 @@ export default {
'https://about.gitlab.com/blog/2018/01/22/a-beginners-guide-to-continuous-integration/', 'https://about.gitlab.com/blog/2018/01/22/a-beginners-guide-to-continuous-integration/',
exampleLink: 'https://docs.gitlab.com/ee/ci/examples/', exampleLink: 'https://docs.gitlab.com/ee/ci/examples/',
codeQualityLink: 'https://docs.gitlab.com/ee/user/project/merge_requests/code_quality.html', codeQualityLink: 'https://docs.gitlab.com/ee/user/project/merge_requests/code_quality.html',
bodyMessage: s__(
`MR widget|The pipeline will test your code on every commit. A %{codeQualityLinkStart}code quality report%{codeQualityLinkEnd} will appear in your merge requests to warn you about potential code degradations.`,
),
helpMessage: s__(
`MR widget|Take a look at our %{beginnerLinkStart}Beginner's Guide to Continuous Integration%{beginnerLinkEnd} and our %{exampleLinkStart}examples of GitLab CI/CD%{exampleLinkEnd} to learn more.`,
),
pipelinesButton: s__('MR widget|See your pipeline in action'),
mergeRequestButton: s__('MR widget|Back to the Merge request'),
modalTitle: sprintf(
__("That's it, well done!%{celebrate}"),
{
celebrate: glEmojiTag('tada'),
},
false,
),
goToTrackValuePipelines: 10, goToTrackValuePipelines: 10,
goToTrackValueMergeRequest: 20, goToTrackValueMergeRequest: 20,
trackEvent: 'click_button', trackEvent: 'click_button',
...@@ -78,6 +62,17 @@ export default { ...@@ -78,6 +62,17 @@ export default {
return ''; return '';
}, },
}, },
i18n: {
modalTitle: s__("That's it, well done!"),
pipelinesButton: s__('MR widget|See your pipeline in action'),
mergeRequestButton: s__('MR widget|Back to the Merge request'),
bodyMessage: s__(
`MR widget|The pipeline will test your code on every commit. A %{codeQualityLinkStart}code quality report%{codeQualityLinkEnd} will appear in your merge requests to warn you about potential code degradations.`,
),
helpMessage: s__(
`MR widget|Take a look at our %{beginnerLinkStart}Beginner's Guide to Continuous Integration%{beginnerLinkEnd} and our %{exampleLinkStart}examples of GitLab CI/CD%{exampleLinkEnd} to learn more.`,
),
},
mounted() { mounted() {
this.track(); this.track();
this.disableModalFromRenderingAgain(); this.disableModalFromRenderingAgain();
...@@ -90,14 +85,13 @@ export default { ...@@ -90,14 +85,13 @@ export default {
}; };
</script> </script>
<template> <template>
<gl-modal <gl-modal visible size="sm" modal-id="success-pipeline-modal-id-not-used">
visible <template #modal-title>
size="sm" {{ $options.i18n.modalTitle }}
:title="$options.modalTitle" <gl-emoji class="gl-vertical-align-baseline font-size-inherit gl-mr-1" data-name="tada" />
modal-id="success-pipeline-modal-id-not-used" </template>
>
<p> <p>
<gl-sprintf :message="$options.bodyMessage"> <gl-sprintf :message="$options.i18n.bodyMessage">
<template #codeQualityLink="{content}"> <template #codeQualityLink="{content}">
<gl-link :href="$options.codeQualityLink" target="_blank" class="font-size-inherit">{{ <gl-link :href="$options.codeQualityLink" target="_blank" class="font-size-inherit">{{
content content
...@@ -105,7 +99,7 @@ export default { ...@@ -105,7 +99,7 @@ export default {
</template> </template>
</gl-sprintf> </gl-sprintf>
</p> </p>
<gl-sprintf :message="$options.helpMessage"> <gl-sprintf :message="$options.i18n.helpMessage">
<template #beginnerLink="{content}"> <template #beginnerLink="{content}">
<gl-link :href="$options.beginnerLink" target="_blank"> <gl-link :href="$options.beginnerLink" target="_blank">
{{ content }} {{ content }}
...@@ -127,7 +121,7 @@ export default { ...@@ -127,7 +121,7 @@ export default {
:data-track-event="$options.trackEvent" :data-track-event="$options.trackEvent"
:data-track-label="trackLabel" :data-track-label="trackLabel"
> >
{{ $options.mergeRequestButton }} {{ $options.i18n.mergeRequestButton }}
</gl-button> </gl-button>
<gl-button <gl-button
ref="goToPipelines" ref="goToPipelines"
...@@ -138,7 +132,7 @@ export default { ...@@ -138,7 +132,7 @@ export default {
:data-track-event="$options.trackEvent" :data-track-event="$options.trackEvent"
:data-track-label="trackLabel" :data-track-label="trackLabel"
> >
{{ $options.pipelinesButton }} {{ $options.i18n.pipelinesButton }}
</gl-button> </gl-button>
</template> </template>
</gl-modal> </gl-modal>
......
...@@ -25990,7 +25990,7 @@ msgstr "" ...@@ -25990,7 +25990,7 @@ msgstr ""
msgid "Thanks! Don't show me this again" msgid "Thanks! Don't show me this again"
msgstr "" msgstr ""
msgid "That's it, well done!%{celebrate}" msgid "That's it, well done!"
msgstr "" msgstr ""
msgid "The \"%{group_path}\" group allows you to sign in with your Single Sign-On Account" msgid "The \"%{group_path}\" group allows you to sign in with your Single Sign-On Account"
......
...@@ -16,6 +16,7 @@ describe('PipelineTourSuccessModal', () => { ...@@ -16,6 +16,7 @@ describe('PipelineTourSuccessModal', () => {
stubs: { stubs: {
GlModal, GlModal,
GlSprintf, GlSprintf,
'gl-emoji': '<img/>',
}, },
}); });
}; };
...@@ -66,9 +67,11 @@ describe('PipelineTourSuccessModal', () => { ...@@ -66,9 +67,11 @@ describe('PipelineTourSuccessModal', () => {
it('has expected structure', () => { it('has expected structure', () => {
const modal = wrapper.find(GlModal); const modal = wrapper.find(GlModal);
const sprintf = modal.find(GlSprintf); const sprintf = modal.find(GlSprintf);
const emoji = modal.find('img');
expect(modal.attributes('title')).toContain("That's it, well done!"); expect(wrapper.text()).toContain("That's it, well done!");
expect(sprintf.exists()).toBe(true); expect(sprintf.exists()).toBe(true);
expect(emoji.exists()).toBe(true);
}); });
it('renders the link for codeQualityLink', () => { it('renders the link for codeQualityLink', () => {
......
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