2023-08-18 03:27:11 -06: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 08:57:40 -06:00
|
|
|
// @ts-expect-error - polyfill is incomplete
|
|
|
|
Intl.NumberFormat = function(locales: string | string[], options: Intl.NumberFormatOptions) {
|
2023-08-18 03:27:11 -06:00
|
|
|
if (options.style === 'unit') {
|
|
|
|
return {
|
2024-10-31 08:57:40 -06:00
|
|
|
format(value: number | bigint | string) {
|
2023-08-18 03:27:11 -06:00
|
|
|
return ` ${value} ${options.unit}`;
|
2024-03-22 08:06:53 -06:00
|
|
|
},
|
2023-08-18 03:27:11 -06:00
|
|
|
};
|
|
|
|
}
|
|
|
|
return intlNumberFormat(locales, options);
|
|
|
|
};
|
|
|
|
}
|