This is a DatoCMS field editor plugin for storing zoned datetime information in a JSON field. It provides a GUI for picking a date, time, and IANA timezone, then stores a JSON object that includes an ISO 8601 datetime string, a RFC 9557/IXDTF zoned datetime string, a UNIX timestamp, and other helpful fields.
Date & time picker
Time zone picker (uses IANA TZ strings)
Once you select a date, time, and time zone, the plugin stores an object like this:
{ datetime_iso8601: "1996-12-19T16:39:57-08:00", // ISO8601 string zone: "America/Los_Angeles", // IANA TZ identifier offset: "-08:00", // Offset from UTC, same as ISO8601 date: "1996-12-19", // ISO date time_24hr: "16:39:57", // 24-hour time time_12hr: "04:39:57", // 12-hour time am_pm: "pm", // AM/PM for 12-hour time timestamp_epoch_seconds: "851042397", // Unix epoch timestamp zoned_datetime_ixdtf: "1996-12-19T16:39:57-08:00[America/Los_Angeles]", // For future use with Temporal API; see RFC 9557}
DatoCMS's default datetime picker converts the entered time to UTC on record save. When you pick a time like 1996-12-19T16:39:57-08:00
, the system actually converts it to 1996-12-20T00:39:57.000Z
once you save.
For some use cases, this is a problem because:
It makes cross-time-zone marketing difficult. It unrecoverably loses the original offset (-08:00
). If your event was in America/Los_Angeles
, your website was in Europe/Rome
, and your visitor was in Europe/London
, your frontend would have no way to know which time zone to use.
It doesn't respect daylight savings time. With an ISO 8601 offset like -06:00
, there is no way to know if that is being used for a region that observes daylight savings time (like CDT, Central Daylight Time, in the USA) or one that doesn't (like Mexico City, which uses CST, Central Standard Time, instead). Depending on the time of the year, the timestamp may be off by an hour if used in two different time zones within the same offset.
The plugin does two things to address this situation:
-08:00
, it stays that way and does not get coerced to UTC.America/Los_Angeles
. Your frontend can then use that time zone to ensure proper display via Intl.DateTimeFormat()
or a helper library like Luxon.The plugin supports localized datetime entry and time zone names in the following languages (same as in DatoCMS itself):
This plugin was made with: