From 841cc4e0b6f0bc91e5d99d339b69ea834479d5f9 Mon Sep 17 00:00:00 2001 From: Massedil Date: Mon, 4 Nov 2024 17:11:04 +0100 Subject: [PATCH] Issue #1571 Replace by Solves the "date is not updated issue" on iOS 17 --- src/views/Event/EditView.vue | 92 +++++++++++++++++++++++------------- 1 file changed, 58 insertions(+), 34 deletions(-) diff --git a/src/views/Event/EditView.vue b/src/views/Event/EditView.vue index ebb9bacb5..a4b634e68 100644 --- a/src/views/Event/EditView.vue +++ b/src/views/Event/EditView.vue @@ -66,19 +66,13 @@ class="items-center" label-for="begins-on-field" > - - + + {{ t("Show the time when the event begins") }} @@ -90,20 +84,13 @@ label-for="ends-on-field" class="items-center" > - - + {{ t("Show the time when the event ends") }} @@ -1218,6 +1205,34 @@ const isEventModified = computed((): boolean => { const beginsOn = ref(new Date()); const endsOn = ref(new Date()); +const beginsOnComponentDateTime = computed({ + get() { + // UTC to local + const localDate = new Date( + beginsOn.value.getTime() - beginsOn.value.getTimezoneOffset() * 60000 + ); + return localDate.toISOString().slice(0, 16); // Format to 'YYYY-MM-DDTHH:MM' + }, + set(value) { + // Local timezone + beginsOn.value = new Date(value); + }, +}); + +const endsOnComponentDateTime = computed({ + get() { + // UTC to local + const localDate = new Date( + endsOn.value.getTime() - endsOn.value.getTimezoneOffset() * 60000 + ); + return localDate.toISOString().slice(0, 16); // Format to 'YYYY-MM-DDTHH:MM' + }, + set(value) { + // Local timezone + endsOn.value = new Date(value); + }, +}); + const updateEventDateRelatedToTimezone = () => { // update event.value.beginsOn taking care of timezone const dateBeginsOn = new Date(beginsOn.value.getTime()); @@ -1242,13 +1257,6 @@ watch(beginsOn, (newBeginsOn) => { // update event.value.beginsOn taking care of timezone updateEventDateRelatedToTimezone(); - - // Update endsOn to make sure endsOn is later than beginsOn - if (endsOn.value && endsOn.value <= newBeginsOn) { - const newEndsOn = new Date(newBeginsOn); - newEndsOn.setUTCHours(newBeginsOn.getUTCHours() + 1); - endsOn.value = newEndsOn; - } }); watch(endsOn, (newEndsOn) => { @@ -1265,6 +1273,22 @@ watch(endsOn, (newEndsOn) => { updateEventDateRelatedToTimezone(); }); +/* +For endsOn, we need to check consistencyBeginsOnBeforeEndsOn() at blur +because the datetime-local component update itself immediately +Ex : your event start at 10:00 and stops at 12:00 +To type "10" hours, you will first have "1" hours, then "10" hours +So you cannot check consistensy in real time, only onBlur because of the moment we falsely have "1:00" + */ +const consistencyBeginsOnBeforeEndsOn = () => { + // Update endsOn to make sure endsOn is later than beginsOn + if (endsOn.value && endsOn.value <= beginsOn.value) { + const newEndsOn = new Date(beginsOn.value); + newEndsOn.setUTCHours(beginsOn.value.getUTCHours() + 1); + endsOn.value = newEndsOn; + } +}; + const { timezones: rawTimezones, loading: timezoneLoading } = useTimezones(); const timezones = computed((): Record => {