// 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;