Commit bb607158 authored by Nicolò Maria Mezzopera's avatar Nicolò Maria Mezzopera

Merge branch '219951-improve-styling-of-design-pins' into 'master'

Improve styling of design pins

See merge request gitlab-org/gitlab!39797
parents e89c6aa8 67411c28
...@@ -17,19 +17,11 @@ export default { ...@@ -17,19 +17,11 @@ export default {
required: false, required: false,
default: null, default: null,
}, },
repositioning: {
type: Boolean,
required: false,
default: false,
},
}, },
computed: { computed: {
isNewNote() { isNewNote() {
return this.label === null; return this.label === null;
}, },
pinStyle() {
return this.repositioning ? { ...this.position, cursor: 'move' } : this.position;
},
pinLabel() { pinLabel() {
return this.isNewNote return this.isNewNote
? __('Comment form position') ? __('Comment form position')
...@@ -41,13 +33,13 @@ export default { ...@@ -41,13 +33,13 @@ export default {
<template> <template>
<button <button
:style="pinStyle" :style="position"
:aria-label="pinLabel" :aria-label="pinLabel"
:class="{ :class="{
'btn-transparent comment-indicator': isNewNote, 'btn-transparent comment-indicator gl-p-0': isNewNote,
'js-image-badge badge badge-pill': !isNewNote, 'js-image-badge badge badge-pill': !isNewNote,
}" }"
class="design-pin gl-absolute gl-display-flex gl-align-items-center gl-justify-content-center gl-p-0" class="gl-absolute gl-display-flex gl-align-items-center gl-justify-content-center gl-font-lg gl-outline-0!"
type="button" type="button"
@mousedown="$emit('mousedown', $event)" @mousedown="$emit('mousedown', $event)"
@mouseup="$emit('mouseup', $event)" @mouseup="$emit('mouseup', $event)"
......
...@@ -266,7 +266,7 @@ export default { ...@@ -266,7 +266,7 @@ export default {
type="button" type="button"
role="button" role="button"
:aria-label="$options.i18n.newCommentButtonLabel" :aria-label="$options.i18n.newCommentButtonLabel"
class="gl-absolute gl-w-full gl-h-full gl-p-0 gl-top-0 gl-left-0 gl-outline-0! btn-transparent design-detail-overlay-add-comment" class="gl-absolute gl-w-full gl-h-full gl-p-0 gl-top-0 gl-left-0 gl-outline-0! btn-transparent gl-hover-cursor-crosshair"
data-qa-selector="design_image_button" data-qa-selector="design_image_button"
@mouseup="onAddCommentMouseup" @mouseup="onAddCommentMouseup"
></button> ></button>
...@@ -276,7 +276,6 @@ export default { ...@@ -276,7 +276,6 @@ export default {
v-if="resolvedDiscussionsExpanded || !note.resolved" v-if="resolvedDiscussionsExpanded || !note.resolved"
:key="note.id" :key="note.id"
:label="note.index" :label="note.index"
:repositioning="isMovingNote(note.id)"
:position=" :position="
isMovingNote(note.id) && movingNoteNewPosition isMovingNote(note.id) && movingNoteNewPosition
? getNotePositionStyle(movingNoteNewPosition) ? getNotePositionStyle(movingNoteNewPosition)
...@@ -290,7 +289,6 @@ export default { ...@@ -290,7 +289,6 @@ export default {
<design-note-pin <design-note-pin
v-if="currentCommentForm" v-if="currentCommentForm"
:position="currentCommentPositionStyle" :position="currentCommentPositionStyle"
:repositioning="isMovingCurrentComment"
@mousedown.stop="onNoteMousedown" @mousedown.stop="onNoteMousedown"
@mouseup.stop="onNoteMouseup" @mouseup.stop="onNoteMouseup"
/> />
......
$design-pin-diameter: 28px;
$t-gray-a-16-design-pin: rgba($black, 0.16);
.layout-page.design-detail-layout { .layout-page.design-detail-layout {
max-height: 100vh; max-height: 100vh;
} }
...@@ -9,34 +12,61 @@ ...@@ -9,34 +12,61 @@
top: 35px; top: 35px;
} }
.design-pin {
transition: opacity $gl-transition-duration-medium $general-hover-transition-curve;
&.inactive {
@include gl-opacity-5;
&:hover {
@include gl-opacity-10;
}
}
}
.badge.badge-pill { .badge.badge-pill {
display: flex; display: flex;
height: 28px; height: $design-pin-diameter;
width: 28px; width: $design-pin-diameter;
background-color: $blue-400; box-sizing: content-box;
background-color: $purple-500;
color: $white; color: $white;
border: $white 1px solid; font-weight: $gl-font-weight-bold;
border-radius: 50%; border-radius: 50%;
z-index: 1;
padding: 0;
&.resolved { &.resolved {
background-color: $gray-500; background-color: $gray-500;
} }
} }
.design-detail-overlay-add-comment { .comment-indicator {
cursor: crosshair; border-radius: 50%;
}
.comment-indicator,
.frame .badge.badge-pill {
&:active {
cursor: grabbing;
}
}
/**
* Design pin that overlays the design
*/
.frame .badge.badge-pill {
box-shadow: 0 2px 4px $t-gray-a-08, 0 0 1px $t-gray-a-24;
border: $white 2px solid;
will-change: transform, box-shadow, opacity;
// NOTE: verbose transition property required for Safari
transition: transform $general-hover-transition-duration linear, box-shadow $general-hover-transition-duration linear, opacity $general-hover-transition-duration linear;
transform-origin: 0 0;
transform: translate(-50%, -50%);
&:hover {
transform: scale(1.2) translate(-50%, -50%);
}
&:active {
box-shadow: 0 0 4px $t-gray-a-16-design-pin, 0 4px 12px $t-gray-a-16-design-pin;
}
&.inactive {
@include gl-opacity-5;
&:hover {
@include gl-opacity-10;
}
}
} }
} }
...@@ -105,8 +135,8 @@ ...@@ -105,8 +135,8 @@
border-left: 1px solid $gray-100; border-left: 1px solid $gray-100;
position: absolute; position: absolute;
left: 28px; left: 28px;
top: -18px; top: -17px;
height: 18px; height: 17px;
} }
.design-note { .design-note {
......
---
title: Update styling of design comment pins
merge_request: 39797
author:
type: changed
// Jest Snapshot v1, https://goo.gl/fbAQLP // Jest Snapshot v1, https://goo.gl/fbAQLP
exports[`Design note pin component should match the snapshot of note when repositioning 1`] = `
<button
aria-label="Comment form position"
class="design-pin gl-absolute gl-display-flex gl-align-items-center gl-justify-content-center gl-p-0 btn-transparent comment-indicator"
style="left: 10px; top: 10px; cursor: move;"
type="button"
>
<gl-icon-stub
name="image-comment-dark"
size="24"
/>
</button>
`;
exports[`Design note pin component should match the snapshot of note with index 1`] = ` exports[`Design note pin component should match the snapshot of note with index 1`] = `
<button <button
aria-label="Comment '1' position" aria-label="Comment '1' position"
class="design-pin gl-absolute gl-display-flex gl-align-items-center gl-justify-content-center gl-p-0 js-image-badge badge badge-pill" class="gl-absolute gl-display-flex gl-align-items-center gl-justify-content-center gl-font-lg gl-outline-0! js-image-badge badge badge-pill"
style="left: 10px; top: 10px;" style="left: 10px; top: 10px;"
type="button" type="button"
> >
...@@ -30,7 +16,7 @@ exports[`Design note pin component should match the snapshot of note with index ...@@ -30,7 +16,7 @@ exports[`Design note pin component should match the snapshot of note with index
exports[`Design note pin component should match the snapshot of note without index 1`] = ` exports[`Design note pin component should match the snapshot of note without index 1`] = `
<button <button
aria-label="Comment form position" aria-label="Comment form position"
class="design-pin gl-absolute gl-display-flex gl-align-items-center gl-justify-content-center gl-p-0 btn-transparent comment-indicator" class="gl-absolute gl-display-flex gl-align-items-center gl-justify-content-center gl-font-lg gl-outline-0! btn-transparent comment-indicator gl-p-0"
style="left: 10px; top: 10px;" style="left: 10px; top: 10px;"
type="button" type="button"
> >
......
...@@ -29,21 +29,4 @@ describe('Design note pin component', () => { ...@@ -29,21 +29,4 @@ describe('Design note pin component', () => {
createComponent({ label: 1 }); createComponent({ label: 1 });
expect(wrapper.element).toMatchSnapshot(); expect(wrapper.element).toMatchSnapshot();
}); });
it('should match the snapshot of note when repositioning', () => {
createComponent({ repositioning: true });
expect(wrapper.element).toMatchSnapshot();
});
describe('pinStyle', () => {
it('sets cursor to `move` when repositioning = true', () => {
createComponent({ repositioning: true });
expect(wrapper.vm.pinStyle.cursor).toBe('move');
});
it('does not set cursor when repositioning = false', () => {
createComponent();
expect(wrapper.vm.pinStyle.cursor).toBe(undefined);
});
});
}); });
...@@ -202,7 +202,7 @@ describe('Design overlay component', () => { ...@@ -202,7 +202,7 @@ describe('Design overlay component', () => {
{ x: position.x, y: position.y }, { x: position.x, y: position.y },
{ x: 20, y: 20 }, { x: 20, y: 20 },
).then(() => { ).then(() => {
expect(findFirstBadge().attributes().style).toBe('left: 20px; top: 20px; cursor: move;'); expect(findFirstBadge().attributes().style).toBe('left: 20px; top: 20px;');
}); });
}); });
...@@ -300,9 +300,7 @@ describe('Design overlay component', () => { ...@@ -300,9 +300,7 @@ describe('Design overlay component', () => {
{ x: position.x, y: position.y }, { x: position.x, y: position.y },
{ x: 20, y: 20 }, { x: 20, y: 20 },
).then(() => { ).then(() => {
expect(findCommentBadge().attributes().style).toBe( expect(findCommentBadge().attributes().style).toBe('left: 20px; top: 20px;');
'left: 20px; top: 20px; cursor: move;',
);
}); });
}); });
......
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