2023-09-02 01:27:33 +02:00
|
|
|
const defaultLocaleStringFormats: Record<string, string> = {
|
2023-01-13 05:40:33 +01:00
|
|
|
weekday: "narrow",
|
|
|
|
era: "narrow",
|
|
|
|
year: "numeric",
|
|
|
|
month: "numeric",
|
|
|
|
day: "numeric",
|
|
|
|
hour: "numeric",
|
|
|
|
minute: "numeric",
|
|
|
|
second: "numeric",
|
|
|
|
timeZoneName: "short",
|
2019-07-08 06:46:31 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
function formatLocaleString(date: Date, format: string): string {
|
2023-01-13 05:40:33 +01:00
|
|
|
return format.replace(
|
|
|
|
/\{\{(\w+)(:(\w+))?\}\}/g,
|
|
|
|
(match: string, kind: string, unused?, option?: string) => {
|
|
|
|
if (
|
|
|
|
[
|
|
|
|
"weekday",
|
|
|
|
"era",
|
|
|
|
"year",
|
|
|
|
"month",
|
|
|
|
"day",
|
|
|
|
"hour",
|
|
|
|
"minute",
|
|
|
|
"second",
|
|
|
|
"timeZoneName",
|
|
|
|
].includes(kind)
|
|
|
|
) {
|
|
|
|
return date.toLocaleString(window.navigator.language, {
|
2023-09-02 01:27:33 +02:00
|
|
|
[kind]: option || defaultLocaleStringFormats[kind],
|
2023-01-13 05:40:33 +01:00
|
|
|
});
|
|
|
|
} else {
|
|
|
|
return match;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
);
|
2019-07-08 06:46:31 +02:00
|
|
|
}
|
|
|
|
|
2019-07-24 18:36:48 +02:00
|
|
|
export function formatDateTimeString(date: Date, format: string): string {
|
2019-07-08 06:46:31 +02:00
|
|
|
return format
|
|
|
|
.replace(/yyyy/g, date.getFullYear().toString())
|
|
|
|
.replace(/yy/g, date.getFullYear().toString().slice(-2))
|
2023-01-13 05:40:33 +01:00
|
|
|
.replace(
|
|
|
|
/MMMM/g,
|
|
|
|
date.toLocaleString(window.navigator.language, { month: "long" }),
|
|
|
|
)
|
|
|
|
.replace(
|
|
|
|
/MMM/g,
|
|
|
|
date.toLocaleString(window.navigator.language, { month: "short" }),
|
|
|
|
)
|
|
|
|
.replace(/MM/g, `0${date.getMonth() + 1}`.slice(-2))
|
2019-07-08 06:46:31 +02:00
|
|
|
.replace(/M/g, (date.getMonth() + 1).toString())
|
2023-01-13 05:40:33 +01:00
|
|
|
.replace(/dd/g, `0${date.getDate()}`.slice(-2))
|
2019-07-08 06:46:31 +02:00
|
|
|
.replace(/d/g, date.getDate().toString())
|
2023-01-13 05:40:33 +01:00
|
|
|
.replace(/HH/g, `0${date.getHours()}`.slice(-2))
|
2019-07-08 06:46:31 +02:00
|
|
|
.replace(/H/g, date.getHours().toString())
|
2023-01-13 05:40:33 +01:00
|
|
|
.replace(/hh/g, `0${date.getHours() % 12 || 12}`.slice(-2))
|
|
|
|
.replace(/h/g, (date.getHours() % 12 || 12).toString())
|
|
|
|
.replace(/mm/g, `0${date.getMinutes()}`.slice(-2))
|
2019-07-08 06:46:31 +02:00
|
|
|
.replace(/m/g, date.getMinutes().toString())
|
2023-01-13 05:40:33 +01:00
|
|
|
.replace(/ss/g, `0${date.getSeconds()}`.slice(-2))
|
2019-07-08 06:46:31 +02:00
|
|
|
.replace(/s/g, date.getSeconds().toString())
|
2023-01-13 05:40:33 +01:00
|
|
|
.replace(/tt/g, date.getHours() >= 12 ? "PM" : "AM");
|
2019-07-08 06:46:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export function formatTimeString(date: Date, format: string): string {
|
2023-01-13 05:40:33 +01:00
|
|
|
return format.replace(
|
|
|
|
/\[(([^\[]|\[\])*)\]|(([yMdHhmst])\4{0,3})/g,
|
|
|
|
(
|
|
|
|
match: string,
|
|
|
|
localeformat?: string,
|
|
|
|
unused?,
|
|
|
|
datetimeformat?: string,
|
|
|
|
) => {
|
|
|
|
if (localeformat) return formatLocaleString(date, localeformat);
|
|
|
|
if (datetimeformat) return formatDateTimeString(date, datetimeformat);
|
|
|
|
return match;
|
|
|
|
},
|
|
|
|
);
|
2019-07-08 06:46:31 +02:00
|
|
|
}
|