Commit 3c67673c authored by Florie Guibert's avatar Florie Guibert

Move issue/apic hierarchy items to a tooltip

- Move epic/issue path in tree view to tooltip
parent f552c848
...@@ -15,6 +15,10 @@ export default { ...@@ -15,6 +15,10 @@ export default {
type: Function, type: Function,
required: true, required: true,
}, },
path: {
type: String,
required: true,
},
isOpen: { isOpen: {
type: Boolean, type: Boolean,
required: true, required: true,
...@@ -68,12 +72,16 @@ export default { ...@@ -68,12 +72,16 @@ export default {
<template> <template>
<gl-tooltip :target="getTargetRef()"> <gl-tooltip :target="getTargetRef()">
<span class="bold">
{{ path }}
</span>
<br />
<span class="text-tertiary">
<span class="bold"> <span class="bold">
{{ stateText }} {{ stateText }}
</span> </span>
{{ stateTimeInWords }} {{ stateTimeInWords }}
<br /> <br />
<span class="text-tertiary">
{{ stateTimestamp }} {{ stateTimestamp }}
</span> </span>
</gl-tooltip> </gl-tooltip>
......
...@@ -127,6 +127,7 @@ export default { ...@@ -127,6 +127,7 @@ export default {
/> />
<state-tooltip <state-tooltip
:get-target-ref="() => $refs.stateIconLg" :get-target-ref="() => $refs.stateIconLg"
:path="itemPath + item.pathIdSeparator + itemId"
:is-open="isOpen" :is-open="isOpen"
:state="item.state" :state="item.state"
:created-at="item.createdAt" :created-at="item.createdAt"
...@@ -157,15 +158,12 @@ export default { ...@@ -157,15 +158,12 @@ export default {
/> />
<state-tooltip <state-tooltip
:get-target-ref="() => $refs.stateIconMd" :get-target-ref="() => $refs.stateIconMd"
:path="itemPath + item.pathIdSeparator + itemId"
:is-open="isOpen" :is-open="isOpen"
:state="item.state" :state="item.state"
:created-at="item.createdAt" :created-at="item.createdAt"
:closed-at="item.closedAt || ''" :closed-at="item.closedAt || ''"
/> />
<span v-gl-tooltip :title="itemPath" class="path-id-text d-inline-block">{{
itemPath
}}</span
>{{ item.pathIdSeparator }}{{ itemId }}
</div> </div>
<div <div
class="item-meta-child d-flex align-items-center order-0 flex-wrap mr-md-1 ml-md-auto ml-xl-2 mt-2 mt-md-0 flex-xl-nowrap" class="item-meta-child d-flex align-items-center order-0 flex-wrap mr-md-1 ml-md-auto ml-xl-2 mt-2 mt-md-0 flex-xl-nowrap"
......
---
title: Move issue/apic hierarchy items to a tooltip
merge_request: 27969
author:
type: changed
...@@ -17,6 +17,7 @@ const mockClosedAtYear = currentDate.getFullYear() - 1; ...@@ -17,6 +17,7 @@ const mockClosedAtYear = currentDate.getFullYear() - 1;
const createComponent = ({ const createComponent = ({
getTargetRef = () => {}, getTargetRef = () => {},
isOpen = false, isOpen = false,
path = '/foo/bar#1',
state = 'closed', state = 'closed',
createdAt = mockCreatedAt, createdAt = mockCreatedAt,
closedAt = mockClosedAt, closedAt = mockClosedAt,
...@@ -25,6 +26,7 @@ const createComponent = ({ ...@@ -25,6 +26,7 @@ const createComponent = ({
propsData: { propsData: {
getTargetRef, getTargetRef,
isOpen, isOpen,
path,
state, state,
createdAt, createdAt,
closedAt, closedAt,
...@@ -154,12 +156,21 @@ describe('RelatedItemsTree', () => { ...@@ -154,12 +156,21 @@ describe('RelatedItemsTree', () => {
expect(wrapper.find(GlTooltip).isVisible()).toBe(true); expect(wrapper.find(GlTooltip).isVisible()).toBe(true);
}); });
it('renders stateText in bold', () => { it('renders path in bold', () => {
expect( expect(
wrapper wrapper
.find('span.bold') .find('span.bold')
.text() .text()
.trim(), .trim(),
).toBe('/foo/bar#1');
});
it('renders stateText in bold', () => {
expect(
wrapper
.find('span.text-tertiary span.bold')
.text()
.trim(),
).toBe('Closed'); ).toBe('Closed');
}); });
......
...@@ -287,6 +287,14 @@ describe('RelatedItemsTree', () => { ...@@ -287,6 +287,14 @@ describe('RelatedItemsTree', () => {
expect(stateTooltip.props('state')).toBe(mockItem.state); expect(stateTooltip.props('state')).toBe(mockItem.state);
}); });
it('renders item path in tooltip for large screens', () => {
const stateTooltip = wrapper.findAll(StateTooltip).at(0);
const { itemPath, itemId } = wrapper.vm;
expect(stateTooltip.props('path')).toBe(itemPath + mockItem.pathIdSeparator + itemId);
});
it('renders confidential icon when `item.confidential` is true', () => { it('renders confidential icon when `item.confidential` is true', () => {
const confidentialIcon = wrapper.findAll(Icon).at(1); const confidentialIcon = wrapper.findAll(Icon).at(1);
...@@ -313,19 +321,6 @@ describe('RelatedItemsTree', () => { ...@@ -313,19 +321,6 @@ describe('RelatedItemsTree', () => {
expect(stateTooltip.props('state')).toBe(mockItem.state); expect(stateTooltip.props('state')).toBe(mockItem.state);
}); });
it('renders item path', () => {
const pathEl = wrapper.find('.path-id-text');
expect(pathEl.attributes('title')).toBe('gitlab-org/gitlab-shell');
expect(pathEl.text()).toBe('gitlab-org/gitlab-shell');
});
it('renders item id with separator', () => {
const pathIdEl = wrapper.find('.item-path-id');
expect(pathIdEl.text()).toBe(mockItem.reference);
});
it('renders item milestone when it has milestone', () => { it('renders item milestone when it has milestone', () => {
const milestone = wrapper.find(ItemMilestone); const milestone = wrapper.find(ItemMilestone);
......
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