Commit a46d2491 authored by Abhijeet Chatterjee's avatar Abhijeet Chatterjee Committed by Kushal Pandya

Refactor V-html project.vue

parent fc35570a
<script> <script>
import { isEmpty } from 'lodash'; import { isEmpty } from 'lodash';
import { mapActions } from 'vuex'; import { mapActions } from 'vuex';
import { GlSprintf } from '@gitlab/ui';
import Alerts from 'ee/vue_shared/dashboards/components/alerts.vue'; import Alerts from 'ee/vue_shared/dashboards/components/alerts.vue';
import ProjectPipeline from 'ee/vue_shared/dashboards/components/project_pipeline.vue'; import ProjectPipeline from 'ee/vue_shared/dashboards/components/project_pipeline.vue';
import TimeAgo from 'ee/vue_shared/dashboards/components/time_ago.vue'; import TimeAgo from 'ee/vue_shared/dashboards/components/time_ago.vue';
import { STATUS_FAILED, STATUS_RUNNING } from 'ee/vue_shared/dashboards/constants'; import { STATUS_FAILED, STATUS_RUNNING } from 'ee/vue_shared/dashboards/constants';
import { __, sprintf } from '~/locale'; import { __ } from '~/locale';
import Commit from '~/vue_shared/components/commit.vue'; import Commit from '~/vue_shared/components/commit.vue';
import UserAvatarLink from '~/vue_shared/components/user_avatar/user_avatar_link.vue'; import UserAvatarLink from '~/vue_shared/components/user_avatar/user_avatar_link.vue';
import timeagoMixin from '~/vue_shared/mixins/timeago'; import timeagoMixin from '~/vue_shared/mixins/timeago';
...@@ -19,6 +20,7 @@ export default { ...@@ -19,6 +20,7 @@ export default {
Alerts, Alerts,
ProjectPipeline, ProjectPipeline,
TimeAgo, TimeAgo,
GlSprintf,
}, },
mixins: [timeagoMixin], mixins: [timeagoMixin],
props: { props: {
...@@ -31,29 +33,15 @@ export default { ...@@ -31,29 +33,15 @@ export default {
timeAgo: __('Finished'), timeAgo: __('Finished'),
triggerer: __('Triggerer'), triggerer: __('Triggerer'),
}, },
unlicensedMessages: {
canUpgrade: __(
"To see this project's operational details, %{linkStart}upgrade its group plan to Premium%{linkEnd}. You can also remove the project from the dashboard.",
),
cannotUpgrade: __(
"To see this project's operational details, contact an owner of group %{groupName} to upgrade the plan. You can also remove the project from the dashboard.",
),
},
computed: { computed: {
unlicensedMessage() {
if (this.project.upgrade_path) {
return sprintf(
__(
"To see this project's operational details, %{linkStart}upgrade its group plan to Premium%{linkEnd}. You can also remove the project from the dashboard.",
),
{
linkStart: `<a href="${this.project.upgrade_path}" target="_blank" rel="noopener noreferrer">`,
linkEnd: '</a>',
},
false,
);
}
return sprintf(
__(
"To see this project's operational details, contact an owner of group %{groupName} to upgrade the plan. You can also remove the project from the dashboard.",
),
{
groupName: this.project.namespace.name,
},
);
},
hasPipelineFailed() { hasPipelineFailed() {
return ( return (
this.lastPipeline && this.lastPipeline &&
...@@ -126,9 +114,21 @@ export default { ...@@ -126,9 +114,21 @@ export default {
<div <div
v-if="project.upgrade_required" v-if="project.upgrade_required"
data-testid="dashboard-card-body"
class="dashboard-card-body card-body bg-secondary" class="dashboard-card-body card-body bg-secondary"
v-html="unlicensedMessage /* eslint-disable-line vue/no-v-html */" >
></div> <gl-sprintf v-if="project.upgrade_path" :message="$options.unlicensedMessages.canUpgrade">
<template #link="{ content }">
<gl-link :href="project.upgrade_path" target="_blank">
{{ content }}
</gl-link>
</template>
</gl-sprintf>
<gl-sprintf v-else :message="$options.unlicensedMessages.cannotUpgrade">
<template #groupName>{{ project.namespace.name }}</template>
</gl-sprintf>
</div>
<div v-else :class="cardClasses" class="dashboard-card-body card-body"> <div v-else :class="cardClasses" class="dashboard-card-body card-body">
<div v-if="lastPipeline" class="row"> <div v-if="lastPipeline" class="row">
......
import { GlSprintf, GlLink } from '@gitlab/ui';
import { shallowMount, createLocalVue } from '@vue/test-utils'; import { shallowMount, createLocalVue } from '@vue/test-utils';
import Vuex from 'vuex'; import Vuex from 'vuex';
import Project from 'ee/operations/components/dashboard/project.vue'; import Project from 'ee/operations/components/dashboard/project.vue';
...@@ -21,9 +22,15 @@ describe('project component', () => { ...@@ -21,9 +22,15 @@ describe('project component', () => {
project: mockOneProject, project: mockOneProject,
...props, ...props,
}, },
stubs: {
GlSprintf,
GlLink,
},
}); });
}; };
const findDashboardCard = () => wrapper.find('[data-testid="dashboard-card-body"]');
afterEach(() => { afterEach(() => {
wrapper.destroy(); wrapper.destroy();
}); });
...@@ -53,8 +60,8 @@ describe('project component', () => { ...@@ -53,8 +60,8 @@ describe('project component', () => {
}); });
it('shows upgrade license text', () => { it('shows upgrade license text', () => {
expect(wrapper.find('.dashboard-card-body').html()).toContain(wrapper.vm.unlicensedMessage); expect(findDashboardCard().text()).toContain('upgrade its group plan to Premium');
expect(wrapper.vm.unlicensedMessage).toContain('upgrade its group plan to Premium'); expect(findDashboardCard().find(GlLink).attributes('href')).toBe(project.upgrade_path);
}); });
it('hides commit info', () => { it('hides commit info', () => {
...@@ -74,9 +81,8 @@ describe('project component', () => { ...@@ -74,9 +81,8 @@ describe('project component', () => {
}); });
it('shows upgrade license text', () => { it('shows upgrade license text', () => {
expect(wrapper.find('.dashboard-card-body').html()).toContain(wrapper.vm.unlicensedMessage); expect(findDashboardCard().text()).not.toContain('upgrade its group plan to Premium');
expect(wrapper.vm.unlicensedMessage).not.toContain('upgrade its group plan to Premium'); expect(findDashboardCard().text()).toContain(
expect(wrapper.vm.unlicensedMessage).toContain(
`contact an owner of group ${project.namespace.name}`, `contact an owner of group ${project.namespace.name}`,
); );
}); });
......
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