2017-05-30 14:11:15 +01:00
// 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).
2023-05-31 22:43:39 +01:00
import { loadIntlPolyfills } from './intl' ;
2017-05-30 14:11:15 +01:00
function importBasePolyfills() {
return import ( /* webpackChunkName: "base_polyfills" */ './base_polyfills' ) ;
}
function importExtraPolyfills() {
return import ( /* webpackChunkName: "extra_polyfills" */ './extra_polyfills' ) ;
}
2023-05-09 13:55:35 +01:00
export function loadPolyfills() {
2017-05-30 14:11:15 +01:00
const needsBasePolyfills = ! (
2023-05-09 13:55:35 +01:00
'toBlob' in HTMLCanvasElement . prototype &&
'assign' in Object &&
'values' in Object &&
'Symbol' in window &&
'finally' in Promise . prototype
2017-05-30 14:11:15 +01:00
) ;
// Latest version of Firefox and Safari do not have IntersectionObserver.
2023-01-05 12:32:02 +00:00
// Edge does not have requestIdleCallback.
2017-05-30 14:11:15 +01:00
// This avoids shipping them all the polyfills.
2023-07-13 10:49:16 +01:00
/* eslint-disable @typescript-eslint/no-unnecessary-condition -- those properties might not exist in old browsers, even if they are always here in types */
2017-05-30 14:11:15 +01:00
const needsExtraPolyfills = ! (
2022-10-14 02:16:37 +01:00
window . AbortController &&
2017-05-30 14:11:15 +01:00
window . IntersectionObserver &&
2017-07-31 18:40:20 +01:00
window . IntersectionObserverEntry &&
'isIntersecting' in IntersectionObserverEntry . prototype &&
2023-01-05 12:32:02 +00:00
window . requestIdleCallback
2017-05-30 14:11:15 +01:00
) ;
2023-07-13 10:49:16 +01:00
/* eslint-enable @typescript-eslint/no-unnecessary-condition */
2017-05-30 14:11:15 +01:00
return Promise . all ( [
2023-05-31 22:43:39 +01:00
loadIntlPolyfills ( ) ,
2017-05-30 14:11:15 +01:00
needsBasePolyfills && importBasePolyfills ( ) ,
needsExtraPolyfills && importExtraPolyfills ( ) ,
] ) ;
}