36 lines
1.3 KiB
TypeScript
36 lines
1.3 KiB
TypeScript
// Convenience function to load polyfills and return a promise when it's done.
|
|
// If there are no polyfills, then this is just Promise.resolve() which means
|
|
// it will execute in the same tick of the event loop (i.e. near-instant).
|
|
|
|
// eslint-disable-next-line import/extensions -- This file is virtual so it thinks it has an extension
|
|
import 'vite/modulepreload-polyfill';
|
|
|
|
import { loadIntlPolyfills } from './intl';
|
|
|
|
function importExtraPolyfills() {
|
|
return import('./extra_polyfills');
|
|
}
|
|
|
|
export function loadPolyfills() {
|
|
// Safari does not have requestIdleCallback.
|
|
// This avoids shipping them all the polyfills.
|
|
const needsExtraPolyfills = !window.requestIdleCallback;
|
|
|
|
return Promise.all([
|
|
loadIntlPolyfills(),
|
|
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition -- those properties might not exist in old browsers, even if they are always here in types
|
|
needsExtraPolyfills ? importExtraPolyfills() : Promise.resolve(),
|
|
loadEmojiPolyfills(),
|
|
]);
|
|
}
|
|
|
|
// In the case of no /v support, rely on the emojibase data.
|
|
async function loadEmojiPolyfills() {
|
|
if (!('unicodeSets' in RegExp.prototype)) {
|
|
emojiRegexPolyfill = (await import('emojibase-regex/emoji')).default;
|
|
}
|
|
}
|
|
|
|
// Null unless polyfill is needed.
|
|
export let emojiRegexPolyfill: RegExp | null = null;
|