diff --git a/CHANGELOG.md b/CHANGELOG.md index 125629b2..d3a1a11b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,16 +4,19 @@ All notable changes to this project will be documented in this file. ## [Unreleased] +- [#252](https://github.com/os2display/display-admin-client/pull/252) + - Reverted change in https://github.com/os2display/display-admin-client/commit/65762066c708f541305a48fbd6b28264dca593b5 regarding rrule dtstart. + - Added comments about how rrules are handled. - [#242](https://github.com/os2display/display-admin-client/pull/243) - - Add entry in example config for midttrafik api key - - Clean up multi select component a bit, replace reduce with Map logic - - Make the station selector call new api - - Add config to context in app.jsx + - Add entry in example config for midttrafik api key + - Clean up multi select component a bit, replace reduce with Map logic + - Make the station selector call new api + - Add config to context in app.jsx ## [2.0.3] - 2024-08-01 - [#243](https://github.com/os2display/display-admin-client/pull/251) - - Fix null bug: replace valueAsDate with target.value as valueAsDate was null + - Fix null bug: replace valueAsDate with target.value as valueAsDate was null ## [2.0.2] - 2024-04-25 diff --git a/src/components/util/schedule/schedule-util.js b/src/components/util/schedule/schedule-util.js index 73138a4e..f2a778d7 100644 --- a/src/components/util/schedule/schedule-util.js +++ b/src/components/util/schedule/schedule-util.js @@ -11,6 +11,8 @@ dayjs.extend(localizedFormat); /** * Get rrule string from schedule. * + * + * * @param {object} schedule - The schedule. * @returns {string} - RRule string. */ @@ -56,7 +58,18 @@ const createNewSchedule = () => { id: ulid(nowTimestamp), duration: 60 * 60 * 24, // Default one day. freq: RRule.WEEKLY, - dtstart: new Date(), + // For evaluation with the RRule library we pretend that "now" is in UTC instead of the local timezone. + // That is 9:00 in Europe/Copenhagen time will be evaluated as if it was 9:00 in UTC. + // @see https://github.com/jkbrzt/rrule#important-use-utc-dates + dtstart: new Date( + Date.UTC( + now.getFullYear(), + now.getMonth(), + now.getDate(), + now.getHours(), + now.getMinutes() + ) + ), until: null, wkst: RRule.MO, byhour: null, diff --git a/src/components/util/schedule/schedule.jsx b/src/components/util/schedule/schedule.jsx index e12d036e..50e86fe8 100644 --- a/src/components/util/schedule/schedule.jsx +++ b/src/components/util/schedule/schedule.jsx @@ -120,7 +120,17 @@ function Schedule({ schedules, onChange }) { */ const setDateValue = (scheduleId, target) => { const date = new Date(target.value); - changeSchedule(scheduleId, target.id, date); + + // For evaluation with the RRule library we pretend that the date is in UTC instead of the local timezone. + // That is 9:00 in Europe/Copenhagen time will be evaluated as if it was 9:00 in UTC. + // @see https://github.com/jkbrzt/rrule#important-use-utc-dates + changeSchedule(scheduleId, target.id, new Date(Date.UTC( + date.getFullYear(), + date.getMonth(), + date.getDate(), + date.getHours(), + date.getMinutes() + ))); }; /** @@ -130,7 +140,7 @@ function Schedule({ schedules, onChange }) { * @returns {string} - The date formatted for datetime-local. */ const getDateValue = (date) => { - return date ? dayjs(date).format("YYYY-MM-DDTHH:mm") : ""; + return date ? dayjs(date).utc().format("YYYY-MM-DDTHH:mm") : ""; }; /** @@ -342,6 +352,7 @@ function Schedule({ schedules, onChange }) {
{t("schedule.rrulestring")}: {schedule.rrule} + {t("schedule.rrulestring-z-ignored")}
{t("schedule.next-occurrences")}: {getNextOccurrences(schedule.rruleObject).map( diff --git a/src/translations/da/common.json b/src/translations/da/common.json index c59ff732..e3b0b5b9 100644 --- a/src/translations/da/common.json +++ b/src/translations/da/common.json @@ -776,6 +776,7 @@ "hourly": "Time", "minutely": "Minut", "rrulestring": "RRule", + "rrulestring-z-ignored": "Bemærk at tidszonen (Z) bliver ignoreret i evalueringen af reglen. Tidsangivelserne vil altid blive behandlet i lokal tid.", "dtstart": "Startdato", "until": "Slutdato", "next-occurrences": "Næste 5 forekomster",