Commit dd7d8c50 authored by Samantha Ming's avatar Samantha Ming

Add tooltip squash commits in MR widget

Issue: https://gitlab.com/gitlab-org/gitlab/-/issues/223029

It will add a tooltip message when the
squash commit checkbox is disabled.
It will indicate whether it is required or not.
parent 4591e71c
<script>
import Icon from '~/vue_shared/components/icon.vue';
import tooltip from '~/vue_shared/directives/tooltip';
import { __ } from '~/locale';
export default {
components: {
......@@ -25,12 +26,22 @@ export default {
default: false,
},
},
computed: {
tooltipTitle() {
return this.isDisabled ? __('Required in this project.') : false;
},
},
};
</script>
<template>
<div class="inline">
<label :class="{ 'gl-text-gray-600': isDisabled }" data-testid="squashLabel">
<label
v-tooltip
:class="{ 'gl-text-gray-600': isDisabled }"
data-testid="squashLabel"
:data-title="tooltipTitle"
>
<input
:checked="value"
:disabled="isDisabled"
......
......@@ -19464,6 +19464,9 @@ msgstr ""
msgid "Required approvals (%{approvals_given} given, you've approved)"
msgstr ""
msgid "Required in this project."
msgstr ""
msgid "Requirement"
msgstr ""
......
......@@ -19,6 +19,8 @@ describe('Squash before merge component', () => {
wrapper.destroy();
});
const findLabel = () => wrapper.find('[data-testid="squashLabel"]');
describe('checkbox', () => {
const findCheckbox = () => wrapper.find('.js-squash-checkbox');
......@@ -64,8 +66,6 @@ describe('Squash before merge component', () => {
});
describe('label', () => {
const findLabel = () => wrapper.find('[data-testid="squashLabel"]');
describe.each`
isDisabled | expectation
${true} | ${'grays out text if it is true'}
......@@ -84,6 +84,27 @@ describe('Squash before merge component', () => {
});
});
describe('tooltip', () => {
const tooltipTitle = () => findLabel().element.dataset.title;
it('does not render when isDisabled is false', () => {
createComponent({
value: true,
isDisabled: false,
});
expect(tooltipTitle()).toBeUndefined();
});
it('display message when when isDisabled is true', () => {
createComponent({
value: true,
isDisabled: true,
});
expect(tooltipTitle()).toBe('Required in this project.');
});
});
describe('about link', () => {
it('is not rendered if no help path is passed', () => {
createComponent({
......
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