Commit 33576731 authored by Tristan Read's avatar Tristan Read Committed by Enrique Alcántara

Update on-call rotation time interval restrictions

parent 83b0a4b7
...@@ -101,7 +101,6 @@ export default { ...@@ -101,7 +101,6 @@ export default {
return { return {
participantsArr: [], participantsArr: [],
endDateEnabled: false, endDateEnabled: false,
restrictToTimeEnabled: false,
}; };
}, },
methods: { methods: {
...@@ -295,15 +294,21 @@ export default { ...@@ -295,15 +294,21 @@ export default {
</gl-card> </gl-card>
<gl-toggle <gl-toggle
v-model="restrictToTimeEnabled" :value="form.isRestrictedToTime"
data-testid="restricted-to-toggle" data-testid="restricted-to-toggle"
:label="$options.i18n.fields.restrictToTime.enableToggle" :label="$options.i18n.fields.restrictToTime.enableToggle"
label-position="left" label-position="left"
class="gl-mt-5" class="gl-mt-5"
@change="
$emit('update-rotation-form', {
type: 'isRestrictedToTime',
value: !form.isRestrictedToTime,
})
"
/> />
<gl-card <gl-card
v-if="restrictToTimeEnabled" v-if="form.isRestrictedToTime"
data-testid="restricted-to-time" data-testid="restricted-to-time"
class="gl-mt-5 gl-border-gray-400 gl-bg-gray-10" class="gl-mt-5 gl-border-gray-400 gl-bg-gray-10"
> >
...@@ -317,15 +322,17 @@ export default { ...@@ -317,15 +322,17 @@ export default {
<span> {{ __('From') }} </span> <span> {{ __('From') }} </span>
<gl-dropdown <gl-dropdown
data-testid="restricted-from" data-testid="restricted-from"
:text="format24HourTimeStringFromInt(form.restrictedTo.from)" :text="format24HourTimeStringFromInt(form.restrictedTo.startTime)"
class="gl-px-3" class="gl-px-3"
> >
<gl-dropdown-item <gl-dropdown-item
v-for="time in $options.HOURS_IN_DAY" v-for="time in $options.HOURS_IN_DAY"
:key="time" :key="time"
:is-checked="form.restrictedTo.from === time" :is-checked="form.restrictedTo.startTime === time"
is-check-item is-check-item
@click="$emit('update-rotation-form', { type: 'restrictedTo.from', value: time })" @click="
$emit('update-rotation-form', { type: 'restrictedTo.startTime', value: time })
"
> >
<span class="gl-white-space-nowrap"> <span class="gl-white-space-nowrap">
{{ format24HourTimeStringFromInt(time) }}</span {{ format24HourTimeStringFromInt(time) }}</span
...@@ -335,15 +342,17 @@ export default { ...@@ -335,15 +342,17 @@ export default {
<span> {{ __('To') }} </span> <span> {{ __('To') }} </span>
<gl-dropdown <gl-dropdown
data-testid="restricted-to" data-testid="restricted-to"
:text="format24HourTimeStringFromInt(form.restrictedTo.to)" :text="format24HourTimeStringFromInt(form.restrictedTo.endTime)"
class="gl-px-3" class="gl-px-3"
> >
<gl-dropdown-item <gl-dropdown-item
v-for="time in $options.HOURS_IN_DAY" v-for="time in $options.HOURS_IN_DAY"
:key="time" :key="time"
:is-checked="form.restrictedTo.to === time" :is-checked="form.restrictedTo.endTime === time"
is-check-item is-check-item
@click="$emit('update-rotation-form', { type: 'restrictedTo.to', value: time })" @click="
$emit('update-rotation-form', { type: 'restrictedTo.endTime', value: time })
"
> >
<span class="gl-white-space-nowrap"> <span class="gl-white-space-nowrap">
{{ format24HourTimeStringFromInt(time) }}</span {{ format24HourTimeStringFromInt(time) }}</span
......
<script> <script>
import { GlModal, GlAlert } from '@gitlab/ui'; import { GlModal, GlAlert } from '@gitlab/ui';
import { set } from 'lodash'; import { cloneDeep, set } from 'lodash';
import { LENGTH_ENUM } from 'ee/oncall_schedules/constants'; import { LENGTH_ENUM } from 'ee/oncall_schedules/constants';
import createOncallScheduleRotationMutation from 'ee/oncall_schedules/graphql/mutations/create_oncall_schedule_rotation.mutation.graphql'; import createOncallScheduleRotationMutation from 'ee/oncall_schedules/graphql/mutations/create_oncall_schedule_rotation.mutation.graphql';
import updateOncallScheduleRotationMutation from 'ee/oncall_schedules/graphql/mutations/update_oncall_schedule_rotation.mutation.graphql'; import updateOncallScheduleRotationMutation from 'ee/oncall_schedules/graphql/mutations/update_oncall_schedule_rotation.mutation.graphql';
...@@ -21,9 +21,30 @@ export const i18n = { ...@@ -21,9 +21,30 @@ export const i18n = {
cancel: __('Cancel'), cancel: __('Cancel'),
}; };
export const formEmptyState = {
name: '',
participants: [],
rotationLength: {
length: 1,
unit: LENGTH_ENUM.days,
},
startsAt: {
date: null,
time: 0,
},
endsAt: {
date: null,
time: 0,
},
isRestrictedToTime: false,
restrictedTo: {
startTime: 0,
endTime: 0,
},
};
export default { export default {
i18n, i18n,
LENGTH_ENUM,
components: { components: {
GlModal, GlModal,
GlAlert, GlAlert,
...@@ -67,26 +88,7 @@ export default { ...@@ -67,26 +88,7 @@ export default {
participants: [], participants: [],
loading: false, loading: false,
ptSearchTerm: '', ptSearchTerm: '',
form: { form: cloneDeep(formEmptyState),
name: '',
participants: [],
rotationLength: {
length: 1,
unit: this.$options.LENGTH_ENUM.days,
},
startsAt: {
date: null,
time: 0,
},
endsAt: {
date: null,
time: 0,
},
restrictedTo: {
from: 0,
to: 0,
},
},
error: '', error: '',
validationState: { validationState: {
name: true, name: true,
...@@ -134,7 +136,7 @@ export default { ...@@ -134,7 +136,7 @@ export default {
endsAt: { date: endDate, time: endTime }, endsAt: { date: endDate, time: endTime },
} = this.form; } = this.form;
return { const variables = {
projectPath: this.projectPath, projectPath: this.projectPath,
scheduleIid: this.schedule.iid, scheduleIid: this.schedule.iid,
name, name,
...@@ -154,6 +156,13 @@ export default { ...@@ -154,6 +156,13 @@ export default {
}, },
participants: getParticipantsForSave(participants), participants: getParticipantsForSave(participants),
}; };
if (this.form.isRestrictedToTime) {
variables.activePeriod = {
startTime: format24HourTimeStringFromInt(this.form.restrictedTo.startTime),
endTime: format24HourTimeStringFromInt(this.form.restrictedTo.endTime),
};
}
return variables;
}, },
title() { title() {
return this.isEditMode ? this.$options.i18n.editRotation : this.$options.i18n.addRotation; return this.isEditMode ? this.$options.i18n.editRotation : this.$options.i18n.addRotation;
...@@ -273,6 +282,9 @@ export default { ...@@ -273,6 +282,9 @@ export default {
this.validationState.endsAt = this.isEndDateValid; this.validationState.endsAt = this.isEndDateValid;
} }
}, },
afterCloseModal() {
this.form = cloneDeep(formEmptyState);
},
}, },
}; };
</script> </script>
...@@ -286,6 +298,7 @@ export default { ...@@ -286,6 +298,7 @@ export default {
:action-cancel="actionsProps.cancel" :action-cancel="actionsProps.cancel"
modal-class="rotations-modal" modal-class="rotations-modal"
@primary.prevent="isEditMode ? editRotation() : createRotation()" @primary.prevent="isEditMode ? editRotation() : createRotation()"
@hide="afterCloseModal"
> >
<gl-alert v-if="error" variant="danger" @dismiss="error = ''"> <gl-alert v-if="error" variant="danger" @dismiss="error = ''">
{{ error || $options.i18n.errorMsg }} {{ error || $options.i18n.errorMsg }}
......
...@@ -135,6 +135,7 @@ export default { ...@@ -135,6 +135,7 @@ export default {
:title="$options.i18n.editRotationLabel" :title="$options.i18n.editRotationLabel"
icon="pencil" icon="pencil"
:aria-label="$options.i18n.editRotationLabel" :aria-label="$options.i18n.editRotationLabel"
@click="setRotationToUpdate(rotation)"
/> />
<gl-button <gl-button
v-gl-modal="$options.deleteRotationModalId" v-gl-modal="$options.deleteRotationModalId"
......
...@@ -7,6 +7,10 @@ fragment OnCallRotation on IncidentManagementOncallRotation { ...@@ -7,6 +7,10 @@ fragment OnCallRotation on IncidentManagementOncallRotation {
endsAt endsAt
length length
lengthUnit lengthUnit
activePeriod {
startTime
endTime
}
participants { participants {
nodes { nodes {
...OnCallParticipant ...OnCallParticipant
......
...@@ -10,6 +10,7 @@ export const participants = [ ...@@ -10,6 +10,7 @@ export const participants = [
name: 'test', name: 'test',
avatar: '', avatar: '',
avatarUrl: '', avatarUrl: '',
webUrl: '',
}, },
{ {
id: '2', id: '2',
...@@ -17,6 +18,7 @@ export const participants = [ ...@@ -17,6 +18,7 @@ export const participants = [
name: 'hello', name: 'hello',
avatar: '', avatar: '',
avatarUrl: '', avatarUrl: '',
webUrl: '',
}, },
]; ];
...@@ -142,6 +144,10 @@ export const createRotationResponse = { ...@@ -142,6 +144,10 @@ export const createRotationResponse = {
endsAt: '2021-03-17T12:00:00Z', endsAt: '2021-03-17T12:00:00Z',
length: 5, length: 5,
lengthUnit: 'WEEKS', lengthUnit: 'WEEKS',
activePeriod: {
startTime: '02:00',
endTime: '10:00',
},
participants: { participants: {
nodes: [ nodes: [
{ {
...@@ -176,6 +182,10 @@ export const createRotationResponseWithErrors = { ...@@ -176,6 +182,10 @@ export const createRotationResponseWithErrors = {
endsAt: '2021-03-17T12:00:00Z', endsAt: '2021-03-17T12:00:00Z',
length: 5, length: 5,
lengthUnit: 'WEEKS', lengthUnit: 'WEEKS',
activePeriod: {
startTime: '02:00',
endTime: '10:00',
},
participants: { participants: {
nodes: [ nodes: [
{ {
......
...@@ -5,6 +5,10 @@ ...@@ -5,6 +5,10 @@
"endsAt": "2021-03-13T10:04:56.333Z", "endsAt": "2021-03-13T10:04:56.333Z",
"length": 1, "length": 1,
"lengthUnit": "WEEKS", "lengthUnit": "WEEKS",
"activePeriod": {
"startTime": "02:00",
"endTime": "10:00"
},
"participants": { "participants": {
"nodes": [ "nodes": [
{ {
...@@ -58,6 +62,10 @@ ...@@ -58,6 +62,10 @@
"endsAt": "2021-03-13T10:04:56.333Z", "endsAt": "2021-03-13T10:04:56.333Z",
"length": 1, "length": 1,
"lengthUnit": "WEEKS", "lengthUnit": "WEEKS",
"activePeriod": {
"startTime": "02:00",
"endTime": "10:00"
},
"participants": { "participants": {
"nodes": [ "nodes": [
{ {
...@@ -107,6 +115,10 @@ ...@@ -107,6 +115,10 @@
"endsAt": "2021-01-10T10:04:56.333Z", "endsAt": "2021-01-10T10:04:56.333Z",
"length": 1, "length": 1,
"lengthUnit": "WEEKS", "lengthUnit": "WEEKS",
"activePeriod": {
"startTime": "02:00",
"endTime": "10:00"
},
"participants": { "participants": {
"nodes": [ "nodes": [
{ {
...@@ -156,6 +168,10 @@ ...@@ -156,6 +168,10 @@
"endsAt": "2021-01-11T10:04:56.333Z", "endsAt": "2021-01-11T10:04:56.333Z",
"length": 1, "length": 1,
"lengthUnit": "WEEKS", "lengthUnit": "WEEKS",
"activePeriod": {
"startTime": "02:00",
"endTime": "10:00"
},
"participants": { "participants": {
"nodes": [ "nodes": [
{ {
......
import { GlModal, GlAlert } from '@gitlab/ui'; import { GlAlert, GlModal } from '@gitlab/ui';
import { shallowMount, createLocalVue } from '@vue/test-utils'; import { createLocalVue, shallowMount } from '@vue/test-utils';
import VueApollo from 'vue-apollo'; import VueApollo from 'vue-apollo';
import AddEditRotationForm from 'ee/oncall_schedules/components/rotations/components/add_edit_rotation_form.vue'; import AddEditRotationForm from 'ee/oncall_schedules/components/rotations/components/add_edit_rotation_form.vue';
import AddEditRotationModal, { import AddEditRotationModal, {
...@@ -18,6 +18,7 @@ import { ...@@ -18,6 +18,7 @@ import {
createRotationResponse, createRotationResponse,
createRotationResponseWithErrors, createRotationResponseWithErrors,
} from '../../mocks/apollo_mock'; } from '../../mocks/apollo_mock';
import mockRotation from '../../mocks/mock_rotation.json';
jest.mock('~/flash'); jest.mock('~/flash');
...@@ -102,6 +103,7 @@ describe('AddEditRotationModal', () => { ...@@ -102,6 +103,7 @@ describe('AddEditRotationModal', () => {
propsData: { propsData: {
modalId: addRotationModalId, modalId: addRotationModalId,
schedule, schedule,
rotation: mockRotation[0],
}, },
apolloProvider: fakeApollo, apolloProvider: fakeApollo,
data() { data() {
......
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