rdv: plages de disponibilités: various UX/UI improvements

This commit is contained in:
nobohan 2021-09-06 14:50:48 +02:00
parent 0a274eb2a4
commit 82e76d7d5a
3 changed files with 77 additions and 37 deletions

View File

@ -1,6 +1,16 @@
<template> <template>
<div> <div>
<h2 class="chill-red">{{ $t('edit_your_calendar_range') }}</h2> <h2 class="chill-red">{{ $t('edit_your_calendar_range') }}</h2>
<div class="form-check">
<input type="checkbox" id="myCalendar" class="form-check-input" v-model="showMyCalendarWidget" />
<label class="form-check-label" for="myCalendar">{{ $t('show_my_calendar') }}</label>
</div>
<div class="form-check">
<input type="checkbox" id="weekends" class="form-check-input" @click="toggleWeekends" />
<label class="form-check-label" for="weekends">{{ $t('show_weekends') }}</label>
</div>
<FullCalendar ref="fullCalendar" :options="calendarOptions"> <FullCalendar ref="fullCalendar" :options="calendarOptions">
<template v-slot:eventContent='arg' > <template v-slot:eventContent='arg' >
<span class='calendarRangeItems'> <span class='calendarRangeItems'>
@ -12,24 +22,52 @@
</span> </span>
</template> </template>
</FullCalendar> </FullCalendar>
<button class="btn btn-save" <div>
@click.prevent="onClickSave"> <button class="btn btn-save" :disabled="!dirty"
{{ $t('action.save')}} @click.prevent="onClickSave">
</button> {{ $t('action.save')}}
<div class="form-check"> </button>
<input type="checkbox" id="myCalendar" class="form-check-input" v-model="showMyCalendarWidget" /> <span v-if="flag.loading" class="loading">
<label class="form-check-label" for="myCalendar">{{ $t('show_my_calendar') }}</label> <i class="fa fa-circle-o-notch fa-spin fa-fw"></i>
</div> <span class="sr-only">{{ $t('loading') }}</span>
<div class="form-check"> </span>
<input type="checkbox" id="weekends" class="form-check-input" @click="toggleWeekends" />
<label class="form-check-label" for="weekends">{{ $t('show_weekends') }}</label>
</div> </div>
<div> <div>
<button class="btn btn-action" <button v-if="disableCopyDayButton" class="btn btn-action" disabled>
@click.prevent="copyDay"> {{ $t('copy_range_to_next_day')}}
{{ $t('copy_range_to_next_day')}} </button>
</button> <button v-if="!disableCopyDayButton" class="btn btn-action"
<p>{{ $t('copy_range_how_to')}}</p> @click.prevent="copyDay">
{{ $t('copy_range_from_day')}} {{this.lastNewDate.toLocaleDateString()}} {{ $t('to_the_next_day')}}
</button>
<p>{{ $t('copy_range_how_to')}}</p>
</div>
<div>
<div v-if="newCalendarRanges.length > 0">
<h4>{{ $t('new_range_to_save') }}</h4>
<ul>
<li v-for="i in newCalendarRanges" :key="i.start">
{{ i.start.toLocaleString() }} - {{ i.end.toLocaleString() }}
</li>
</ul>
</div>
<div v-if="updateCalendarRanges.length > 0">
<h4>{{ $t('update_range_to_save') }}</h4>
<ul>
<li v-for="i in updateCalendarRanges" :key="i.start">
{{ i.start.toLocaleString() }} - {{ i.end.toLocaleString() }}
</li>
</ul>
</div>
<div v-if="deleteCalendarRanges.length > 0">
<h4>{{ $t('delete_range_to_save') }}</h4>
<ul>
<li v-for="i in deleteCalendarRanges" :key="i.start">
{{ i.start.toLocaleString() }} - {{ i.end.toLocaleString() }}
</li>
</ul>
</div>
</div> </div>
</div> </div>
</template> </template>
@ -42,6 +80,7 @@ import dayGridPlugin from '@fullcalendar/daygrid';
import interactionPlugin from '@fullcalendar/interaction'; import interactionPlugin from '@fullcalendar/interaction';
import timeGridPlugin from '@fullcalendar/timegrid'; import timeGridPlugin from '@fullcalendar/timegrid';
import { deleteCalendarRange, fetchCalendar, fetchCalendarRangesByUser, patchCalendarRange, postCalendarRange } from '../_api/api'; import { deleteCalendarRange, fetchCalendar, fetchCalendarRangesByUser, patchCalendarRange, postCalendarRange } from '../_api/api';
import { mapState } from 'vuex';
export default { export default {
name: "App", name: "App",
@ -51,6 +90,9 @@ export default {
data() { data() {
return { return {
errorMsg: [], errorMsg: [],
flag: {
loading: false
},
userId: window.userId, userId: window.userId,
showMyCalendar: true, showMyCalendar: true,
calendarEvents: { calendarEvents: {
@ -61,6 +103,8 @@ export default {
color: "#3788d8" color: "#3788d8"
} }
}, },
lastNewDate: null,
disableCopyDayButton: true,
calendarOptions: { calendarOptions: {
locale: frLocale, locale: frLocale,
plugins: [ dayGridPlugin, interactionPlugin, timeGridPlugin ], plugins: [ dayGridPlugin, interactionPlugin, timeGridPlugin ],
@ -85,6 +129,12 @@ export default {
} }
}, },
computed: { computed: {
...mapState({
newCalendarRanges: state => state.newCalendarRanges,
updateCalendarRanges: state => state.updateCalendarRanges,
deleteCalendarRanges: state => state.deleteCalendarRanges,
dirty: state => state.newCalendarRanges.length > 0 || state.updateCalendarRanges.length > 0 || state.deleteCalendarRanges.length > 0
}),
showMyCalendarWidget: { showMyCalendarWidget: {
set(value) { set(value) {
this.toggleMyCalendar(value); this.toggleMyCalendar(value);
@ -108,6 +158,7 @@ export default {
this.updateEventsSource(); this.updateEventsSource();
}, },
fetchData() { fetchData() {
this.flag.loading = true;
fetchCalendarRangesByUser(this.userId).then(calendarRanges => new Promise((resolve, reject) => { fetchCalendarRangesByUser(this.userId).then(calendarRanges => new Promise((resolve, reject) => {
let events = calendarRanges.results.map(i => let events = calendarRanges.results.map(i =>
({ ({
@ -138,6 +189,7 @@ export default {
}; };
this.calendarEvents.userCalendar = calendarEventsCurrentUser; this.calendarEvents.userCalendar = calendarEventsCurrentUser;
this.updateEventsSource(); this.updateEventsSource();
this.flag.loading = false;
resolve(); resolve();
})); }));
@ -169,6 +221,7 @@ export default {
events: events, events: events,
color: "#3788d8" color: "#3788d8"
}; };
this.disableCopyDayButton = false;
this.lastNewDate = new Date(payload.startStr); this.lastNewDate = new Date(payload.startStr);
this.updateEventsSource(); this.updateEventsSource();
this.$store.dispatch('createRange', payload); this.$store.dispatch('createRange', payload);
@ -179,7 +232,8 @@ export default {
payload.event.setProp('color', '#3788d8'); payload.event.setProp('color', '#3788d8');
this.$store.dispatch('updateRange', payload); this.$store.dispatch('updateRange', payload);
}, },
onClickSave(payload) { onClickSave(payload) {
this.flag.loading = true;
if (this.$store.state.newCalendarRanges.length > 0){ if (this.$store.state.newCalendarRanges.length > 0){
this.$store.state.newCalendarRanges.map(cr => { this.$store.state.newCalendarRanges.map(cr => {
postCalendarRange({ postCalendarRange({
@ -231,9 +285,6 @@ export default {
isFriday(date) { isFriday(date) {
return date.getDay() === 5 return date.getDay() === 5
}, },
// disableCopyDayButton() { //TODO does not update!
// return this.calendarEvents.new.events.length === 0
// },
copyDay(_payload) { copyDay(_payload) {
console.log(this.calendarEvents.new); console.log(this.calendarEvents.new);
if (this.calendarEvents.new.events.length > 0) { if (this.calendarEvents.new.events.length > 0) {

View File

@ -4,8 +4,13 @@ const appMessages = {
show_my_calendar: "Afficher mon calendrier", show_my_calendar: "Afficher mon calendrier",
show_weekends: "Afficher les week-ends", show_weekends: "Afficher les week-ends",
copy_range_to_next_day: "Copier les plages du jour au jour suivant", copy_range_to_next_day: "Copier les plages du jour au jour suivant",
copy_range_from_day: "Copier les plages du ",
to_the_next_day: " au jour suivant",
copy_range_to_next_week: "Copier les plages de la semaine à la semaine suivante", copy_range_to_next_week: "Copier les plages de la semaine à la semaine suivante",
copy_range_how_to: "Créez les plages de disponibilités durant une journée et copiez-les facilement au jour suivant avec ce bouton. Si les week-ends sont cachés, le jour suivant un vendredi sera le lundi." copy_range_how_to: "Créez les plages de disponibilités durant une journée et copiez-les facilement au jour suivant avec ce bouton. Si les week-ends sont cachés, le jour suivant un vendredi sera le lundi.",
new_range_to_save: "Nouvelles plages à enregistrer",
update_range_to_save: "Plages à modifier",
delete_range_to_save: "Plages à supprimer"
} }
} }

View File

@ -90,22 +90,6 @@ const deleteCalendarRange = (id) => {
}); });
}; };
// const deleteCalendarRange = (id) => {
// const url = `/api/1.0/calendar/calendar-range.json`;
// return fetch(url, {
// method: 'DELETE',
// headers: {
// 'Content-Type': 'application/json;charset=utf-8'
// },
// body: JSON.stringify({
// id: id
// })
// }).then(response => {
// if (response.ok) { return response.json(); }
// throw Error('Error with request resource response');
// });
// };
export { export {
fetchCalendarRanges, fetchCalendarRanges,
fetchCalendar, fetchCalendar,