mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-12 13:24:25 +00:00
rdv: plages de disponibilités: various UX/UI improvements
This commit is contained in:
parent
0a274eb2a4
commit
82e76d7d5a
@ -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) {
|
||||||
|
@ -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"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user