import IS_WEBP_SUPPORTED from './webpSupport'; const IMAGE_MIME_TYPES_SUPPORTED = new Set([ 'image/jpeg', 'image/png', 'image/bmp' ]); if(IS_WEBP_SUPPORTED) { IMAGE_MIME_TYPES_SUPPORTED.add('image/webp'); } const possible: [string, string][] = [ ['image/jxl', ''], ['image/avif', ''] ]; const promises = possible.map(([mime, data]) => { const img = new Image(); const promise = new Promise((resolve) => { img.onload = img.onerror = () => { const supported = img.height === 2; resolve(supported ? mime : undefined); }; }); img.src = data; return promise; }); export const IMAGE_MIME_TYPES_SUPPORTED_PROMISE = Promise.all(promises).then((mimeTypes) => mimeTypes.filter(Boolean)); export default IMAGE_MIME_TYPES_SUPPORTED;