2023-08-18 17:27:11 +08:00
|
|
|
try {
|
|
|
|
// some browsers like PaleMoon don't have full support for Intl.NumberFormat, so do the minimum polyfill to support "relative-time-element"
|
|
|
|
// https://repo.palemoon.org/MoonchildProductions/UXP/issues/2289
|
|
|
|
new Intl.NumberFormat('en', {style: 'unit', unit: 'minute'}).format(1);
|
|
|
|
} catch {
|
|
|
|
const intlNumberFormat = Intl.NumberFormat;
|
2024-10-31 15:57:40 +01:00
|
|
|
// @ts-expect-error - polyfill is incomplete
|
|
|
|
Intl.NumberFormat = function(locales: string | string[], options: Intl.NumberFormatOptions) {
|
2023-08-18 17:27:11 +08:00
|
|
|
if (options.style === 'unit') {
|
|
|
|
return {
|
2024-10-31 15:57:40 +01:00
|
|
|
format(value: number | bigint | string) {
|
2023-08-18 17:27:11 +08:00
|
|
|
return ` ${value} ${options.unit}`;
|
2024-03-22 15:06:53 +01:00
|
|
|
},
|
2023-08-18 17:27:11 +08:00
|
|
|
};
|
|
|
|
}
|
|
|
|
return intlNumberFormat(locales, options);
|
|
|
|
};
|
|
|
|
}
|