Commit 622fca45 authored by David O'Regan's avatar David O'Regan Committed by Natalia Tepluhina

Oncall schedule collapse UI

parent 22c2ff1a
...@@ -4,6 +4,7 @@ import { ...@@ -4,6 +4,7 @@ import {
GlButtonGroup, GlButtonGroup,
GlCard, GlCard,
GlCollapse, GlCollapse,
GlIcon,
GlModalDirective, GlModalDirective,
GlTooltipDirective, GlTooltipDirective,
} from '@gitlab/ui'; } from '@gitlab/ui';
...@@ -63,6 +64,7 @@ export default { ...@@ -63,6 +64,7 @@ export default {
GlButtonGroup, GlButtonGroup,
GlCard, GlCard,
GlCollapse, GlCollapse,
GlIcon,
AddEditRotationModal, AddEditRotationModal,
DeleteRotationModal, DeleteRotationModal,
DeleteScheduleModal, DeleteScheduleModal,
...@@ -177,7 +179,7 @@ export default { ...@@ -177,7 +179,7 @@ export default {
: this.$options.i18n.scheduleClose; : this.$options.i18n.scheduleClose;
}, },
scheduleVisibleAngleIcon() { scheduleVisibleAngleIcon() {
return this.scheduleVisible ? 'angle-up' : 'angle-down'; return this.scheduleVisible ? 'angle-down' : 'angle-right';
}, },
selectedTimezone() { selectedTimezone() {
return this.timezones.find((tz) => tz.identifier === this.schedule.timezone); return this.timezones.find((tz) => tz.identifier === this.schedule.timezone);
...@@ -231,13 +233,28 @@ export default { ...@@ -231,13 +233,28 @@ export default {
<template> <template>
<div> <div>
<gl-card class="gl-mt-5" header-class="gl-py-3"> <gl-card
class="gl-mt-5"
:class="{ 'gl-border-bottom-0': !scheduleVisible }"
:body-class="{ 'gl-p-0': !scheduleVisible }"
header-class="gl-py-3"
>
<template #header> <template #header>
<div <div
class="gl-display-flex gl-justify-content-space-between gl-align-items-center gl-m-0" class="gl-display-flex gl-justify-content-space-between gl-align-items-center gl-m-0"
data-testid="scheduleHeader" data-testid="scheduleHeader"
> >
<span class="gl-font-weight-bold gl-font-lg">{{ schedule.name }}</span> <div class="gl-font-weight-bold gl-font-lg">
<gl-icon
v-gl-tooltip
class="gl-hover-cursor-pointer"
:aria-label="scheduleVisibleAriaLabel"
:size="12"
:name="scheduleVisibleAngleIcon"
@click="scheduleVisible = !scheduleVisible"
/>
<span class="gl-pl-2">{{ schedule.name }}</span>
</div>
<gl-button-group> <gl-button-group>
<gl-button <gl-button
v-gl-modal="editScheduleModalId" v-gl-modal="editScheduleModalId"
...@@ -253,12 +270,6 @@ export default { ...@@ -253,12 +270,6 @@ export default {
icon="remove" icon="remove"
:aria-label="$options.i18n.deleteScheduleLabel" :aria-label="$options.i18n.deleteScheduleLabel"
/> />
<gl-button
v-gl-tooltip
:icon="scheduleVisibleAngleIcon"
:aria-label="scheduleVisibleAriaLabel"
@click="scheduleVisible = !scheduleVisible"
/>
</gl-button-group> </gl-button-group>
</div> </div>
</template> </template>
......
import { GlButton, GlCard, GlCollapse } from '@gitlab/ui'; import { GlButton, GlCard, GlIcon, GlCollapse } from '@gitlab/ui';
import { shallowMount, createLocalVue } from '@vue/test-utils'; import { shallowMount, createLocalVue } from '@vue/test-utils';
import { nextTick } from 'vue'; import { nextTick } from 'vue';
import VueApollo from 'vue-apollo'; import VueApollo from 'vue-apollo';
...@@ -104,6 +104,7 @@ describe('On-call schedule', () => { ...@@ -104,6 +104,7 @@ describe('On-call schedule', () => {
const findLoadPreviousTimeframeBtn = () => wrapper.findByTestId('previous-timeframe-btn'); const findLoadPreviousTimeframeBtn = () => wrapper.findByTestId('previous-timeframe-btn');
const findLoadNextTimeframeBtn = () => wrapper.findByTestId('next-timeframe-btn'); const findLoadNextTimeframeBtn = () => wrapper.findByTestId('next-timeframe-btn');
const findCollapsible = () => wrapper.findComponent(GlCollapse); const findCollapsible = () => wrapper.findComponent(GlCollapse);
const findCollapsibleIcon = () => wrapper.findComponent(GlIcon);
it('shows schedule title', () => { it('shows schedule title', () => {
expect(findScheduleHeader().text()).toBe(mockSchedule.name); expect(findScheduleHeader().text()).toBe(mockSchedule.name);
...@@ -160,11 +161,13 @@ describe('On-call schedule', () => { ...@@ -160,11 +161,13 @@ describe('On-call schedule', () => {
it('renders a open card for the first in the list by default', () => { it('renders a open card for the first in the list by default', () => {
expect(findCollapsible().attributes('visible')).toBe('true'); expect(findCollapsible().attributes('visible')).toBe('true');
expect(findCollapsibleIcon().props('name')).toBe('angle-down');
}); });
it('renders a collapsed card if not the first in the list by default', () => { it('renders a collapsed card if not the first in the list by default', () => {
createComponent({ scheduleIndex: 1 }); createComponent({ scheduleIndex: 1 });
expect(findCollapsible().attributes('visible')).toBeUndefined(); expect(findCollapsible().attributes('visible')).toBeUndefined();
expect(findCollapsibleIcon().props('name')).toBe('angle-right');
}); });
describe('Timeframe shift preset type', () => { describe('Timeframe shift preset type', () => {
......
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