diff --git a/Userland/Libraries/LibJS/Runtime/DateConstructor.cpp b/Userland/Libraries/LibJS/Runtime/DateConstructor.cpp index 317161df5b..3b96e7b949 100644 --- a/Userland/Libraries/LibJS/Runtime/DateConstructor.cpp +++ b/Userland/Libraries/LibJS/Runtime/DateConstructor.cpp @@ -147,9 +147,10 @@ static double parse_simplified_iso8601(DeprecatedString const& iso_8601) return time_clip(time_ms); } -static constexpr AK::Array extra_formats = { +static constexpr AK::Array extra_formats = { "%a %b %e %T %z %Y"sv, - "%m/%e/%Y"sv + "%m/%e/%Y"sv, + "%m/%e/%Y %R %z"sv, }; static double parse_date_string(DeprecatedString const& date_string) @@ -161,6 +162,7 @@ static double parse_date_string(DeprecatedString const& date_string) // Date.parse() is allowed to accept an arbitrary number of implementation-defined formats. // Parse formats of this type: "Wed Apr 17 23:08:53 +0000 2019" // And: "4/17/2019" + // And: "12/05/2022 10:00 -0800" // FIXME: Exactly what timezone and which additional formats we should support is unclear. // Both Chrome and Firefox seem to support "4/17/2019 11:08 PM +0000" with most parts // being optional, however this is not clearly documented anywhere. diff --git a/Userland/Libraries/LibJS/Tests/builtins/Date/Date.parse.js b/Userland/Libraries/LibJS/Tests/builtins/Date/Date.parse.js index e8cb6531e4..fff54c0b52 100644 --- a/Userland/Libraries/LibJS/Tests/builtins/Date/Date.parse.js +++ b/Userland/Libraries/LibJS/Tests/builtins/Date/Date.parse.js @@ -78,3 +78,9 @@ test("extra date extension", () => { expectStringToGiveDate("7/07/1977", 1977, 7, 7); expectStringToGiveDate("2/27/3058", 3058, 2, 27); }); + +test("mm/dd/yy hh:mm timezone-offset extension", () => { + // Examples from Discord's JavaScript for Christmas 2022. + expect(Date.parse("12/05/2022 10:00 -0800")).toBe(1670263200000); + expect(Date.parse("01/03/2023 10:00 -0800")).toBe(1672768800000); +});