Issue #1511 Restore timezone consideration
- tz-offset is not a valid parameter for <o-datetimepicker> so the offset was ignored. - also remove invalid horizontal-time-picker and first-day-of-week parameters from <o-datetimepicker>
This commit is contained in:
parent
8044dbde86
commit
6c189b2d6c
|
@ -72,9 +72,6 @@
|
||||||
icon="calendar-today"
|
icon="calendar-today"
|
||||||
:locale="$i18n.locale.replace('_', '-')"
|
:locale="$i18n.locale.replace('_', '-')"
|
||||||
v-model="beginsOn"
|
v-model="beginsOn"
|
||||||
horizontal-time-picker
|
|
||||||
:tz-offset="tzOffset(beginsOn)"
|
|
||||||
:first-day-of-week="firstDayOfWeek"
|
|
||||||
:datepicker="{
|
:datepicker="{
|
||||||
id: 'begins-on-field',
|
id: 'begins-on-field',
|
||||||
'aria-next-label': t('Next month'),
|
'aria-next-label': t('Next month'),
|
||||||
|
@ -99,10 +96,7 @@
|
||||||
icon="calendar-today"
|
icon="calendar-today"
|
||||||
:locale="$i18n.locale.replace('_', '-')"
|
:locale="$i18n.locale.replace('_', '-')"
|
||||||
v-model="endsOn"
|
v-model="endsOn"
|
||||||
horizontal-time-picker
|
|
||||||
:min-datetime="beginsOn"
|
:min-datetime="beginsOn"
|
||||||
:tz-offset="tzOffset(endsOn)"
|
|
||||||
:first-day-of-week="firstDayOfWeek"
|
|
||||||
:datepicker="{
|
:datepicker="{
|
||||||
id: 'ends-on-field',
|
id: 'ends-on-field',
|
||||||
'aria-next-label': t('Next month'),
|
'aria-next-label': t('Next month'),
|
||||||
|
@ -671,7 +665,6 @@ import { Dialog } from "@/plugins/dialog";
|
||||||
import { Notifier } from "@/plugins/notifier";
|
import { Notifier } from "@/plugins/notifier";
|
||||||
import { useHead } from "@/utils/head";
|
import { useHead } from "@/utils/head";
|
||||||
import { useOruga } from "@oruga-ui/oruga-next";
|
import { useOruga } from "@oruga-ui/oruga-next";
|
||||||
import type { Locale } from "date-fns";
|
|
||||||
import sortBy from "lodash/sortBy";
|
import sortBy from "lodash/sortBy";
|
||||||
import { escapeHtml } from "@/utils/html";
|
import { escapeHtml } from "@/utils/html";
|
||||||
|
|
||||||
|
@ -1210,37 +1203,63 @@ const isEventModified = computed((): boolean => {
|
||||||
|
|
||||||
const beginsOn = computed({
|
const beginsOn = computed({
|
||||||
get(): Date | null {
|
get(): Date | null {
|
||||||
// if (this.timezone && this.event.beginsOn) {
|
if (!event.value.beginsOn) {
|
||||||
// return utcToZonedTime(this.event.beginsOn, this.timezone);
|
return null;
|
||||||
// }
|
}
|
||||||
return event.value.beginsOn ? new Date(event.value.beginsOn) : null;
|
// return event.value.beginsOn taking care of timezone
|
||||||
|
const date = new Date(event.value.beginsOn);
|
||||||
|
date.setMinutes(date.getMinutes() + tzOffset(date));
|
||||||
|
return date;
|
||||||
},
|
},
|
||||||
set(newBeginsOn: Date | null) {
|
set(newBeginsOn: Date | null) {
|
||||||
event.value.beginsOn = newBeginsOn?.toISOString() ?? null;
|
if (!newBeginsOn) {
|
||||||
if (!event.value.endsOn || !newBeginsOn) return;
|
event.value.beginsOn = null;
|
||||||
const dateBeginsOn = new Date(newBeginsOn);
|
return;
|
||||||
const dateEndsOn = new Date(event.value.endsOn);
|
|
||||||
let endsOn = new Date(event.value.endsOn);
|
|
||||||
if (dateEndsOn < dateBeginsOn) {
|
|
||||||
endsOn = dateBeginsOn;
|
|
||||||
endsOn.setHours(dateBeginsOn.getHours() + 1);
|
|
||||||
}
|
}
|
||||||
if (dateEndsOn === dateBeginsOn) {
|
|
||||||
endsOn.setHours(dateEndsOn.getHours() + 1);
|
// usefull for comparaison
|
||||||
|
newBeginsOn.setSeconds(0);
|
||||||
|
newBeginsOn.setMilliseconds(0);
|
||||||
|
|
||||||
|
// update event.value.beginsOn taking care of timezone
|
||||||
|
const date = new Date(newBeginsOn.getTime());
|
||||||
|
date.setMinutes(date.getMinutes() - tzOffset(newBeginsOn));
|
||||||
|
event.value.beginsOn = date.toISOString();
|
||||||
|
|
||||||
|
// Update endsOn to make sure endsOn is later than beginsOn
|
||||||
|
if (endsOn.value && endsOn.value <= newBeginsOn) {
|
||||||
|
const newEndsOn = new Date(newBeginsOn);
|
||||||
|
newEndsOn.setHours(newBeginsOn.getHours() + 1);
|
||||||
|
endsOn.value = newEndsOn;
|
||||||
}
|
}
|
||||||
event.value.endsOn = endsOn.toISOString();
|
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
const endsOn = computed({
|
const endsOn = computed({
|
||||||
get(): Date | null {
|
get(): Date | null {
|
||||||
// if (this.event.endsOn && this.timezone) {
|
if (!event.value.endsOn) {
|
||||||
// return utcToZonedTime(this.event.endsOn, this.timezone);
|
return null;
|
||||||
// }
|
}
|
||||||
return event.value.endsOn ? new Date(event.value.endsOn) : null;
|
|
||||||
|
// return event.value.endsOn taking care of timezone
|
||||||
|
const date = new Date(event.value.endsOn);
|
||||||
|
date.setMinutes(date.getMinutes() + tzOffset(date));
|
||||||
|
return date;
|
||||||
},
|
},
|
||||||
set(newEndsOn: Date | null) {
|
set(newEndsOn: Date | null) {
|
||||||
event.value.endsOn = newEndsOn?.toISOString() ?? null;
|
if (!newEndsOn) {
|
||||||
|
event.value.endsOn = null;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// usefull for comparaison
|
||||||
|
newEndsOn.setSeconds(0);
|
||||||
|
newEndsOn.setMilliseconds(0);
|
||||||
|
|
||||||
|
// update event.value.endsOn taking care of timezone
|
||||||
|
const date = new Date(newEndsOn.getTime());
|
||||||
|
date.setMinutes(date.getMinutes() - tzOffset(newEndsOn));
|
||||||
|
event.value.endsOn = date.toISOString();
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -1355,12 +1374,6 @@ const maximumAttendeeCapacity = computed({
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
const dateFnsLocale = inject<Locale>("dateFnsLocale");
|
|
||||||
|
|
||||||
const firstDayOfWeek = computed((): number => {
|
|
||||||
return dateFnsLocale?.options?.weekStartsOn || 0;
|
|
||||||
});
|
|
||||||
|
|
||||||
const { event: fetchedEvent, onResult: onFetchEventResult } = useFetchEvent(
|
const { event: fetchedEvent, onResult: onFetchEventResult } = useFetchEvent(
|
||||||
eventId.value
|
eventId.value
|
||||||
);
|
);
|
||||||
|
|
Loading…
Reference in a new issue