UNPKG

bulmil

Version:

![bulmil](https://user-images.githubusercontent.com/2362138/65766959-c721a080-e16f-11e9-9fb9-45a5a2ad0391.jpg)

151 lines (147 loc) 6.64 kB
import { B as BUILD, C as CSS, p as plt, w as win, a as promiseResolve, c as consoleDevInfo, H, d as doc, N as NAMESPACE } from './index-75c52ae9.js'; /* Stencil Client Patch v1.17.3 | MIT Licensed | https://stenciljs.com */ const noop = () => { /* noop*/ }; const IS_DENO_ENV = typeof Deno !== 'undefined'; const IS_NODE_ENV = !IS_DENO_ENV && typeof global !== 'undefined' && typeof require === 'function' && !!global.process && typeof __filename === 'string' && (!global.origin || typeof global.origin !== 'string'); const IS_DENO_WINDOWS_ENV = IS_DENO_ENV && Deno.build.os === 'windows'; const getCurrentDirectory = IS_NODE_ENV ? process.cwd : IS_DENO_ENV ? Deno.cwd : () => '/'; const exit = IS_NODE_ENV ? process.exit : IS_DENO_ENV ? Deno.exit : noop; const getDynamicImportFunction = (namespace) => `__sc_import_${namespace.replace(/\s|-/g, '_')}`; const patchEsm = () => { // NOTE!! This fn cannot use async/await! // @ts-ignore if (BUILD.cssVarShim && !(CSS && CSS.supports && CSS.supports('color', 'var(--c)'))) { // @ts-ignore return __sc_import_bulmil(/* webpackChunkName: "polyfills-css-shim" */ './css-shim-a659079f.js').then(() => { if ((plt.$cssShim$ = win.__cssshim)) { return plt.$cssShim$.i(); } else { // for better minification return 0; } }); } return promiseResolve(); }; const patchBrowser = () => { // NOTE!! This fn cannot use async/await! if (BUILD.isDev && !BUILD.isTesting) { consoleDevInfo('Running in development mode.'); } if (BUILD.cssVarShim) { // shim css vars plt.$cssShim$ = win.__cssshim; } if (BUILD.cloneNodeFix) { // opted-in to polyfill cloneNode() for slot polyfilled components patchCloneNodeFix(H.prototype); } if (BUILD.profile && !performance.mark) { // not all browsers support performance.mark/measure (Safari 10) performance.mark = performance.measure = () => { /*noop*/ }; performance.getEntriesByName = () => []; } // @ts-ignore const scriptElm = BUILD.scriptDataOpts || BUILD.safari10 || BUILD.dynamicImportShim ? Array.from(doc.querySelectorAll('script')).find(s => new RegExp(`\/${NAMESPACE}(\\.esm)?\\.js($|\\?|#)`).test(s.src) || s.getAttribute('data-stencil-namespace') === NAMESPACE) : null; const importMeta = ""; const opts = BUILD.scriptDataOpts ? scriptElm['data-opts'] || {} : {}; if (BUILD.safari10 && 'onbeforeload' in scriptElm && !history.scrollRestoration /* IS_ESM_BUILD */) { // Safari < v11 support: This IF is true if it's Safari below v11. // This fn cannot use async/await since Safari didn't support it until v11, // however, Safari 10 did support modules. Safari 10 also didn't support "nomodule", // so both the ESM file and nomodule file would get downloaded. Only Safari // has 'onbeforeload' in the script, and "history.scrollRestoration" was added // to Safari in v11. Return a noop then() so the async/await ESM code doesn't continue. // IS_ESM_BUILD is replaced at build time so this check doesn't happen in systemjs builds. return { then() { /* promise noop */ }, }; } if (!BUILD.safari10 && importMeta !== '') { opts.resourcesUrl = new URL('.', importMeta).href; } else if (BUILD.dynamicImportShim || BUILD.safari10) { opts.resourcesUrl = new URL('.', new URL(scriptElm.getAttribute('data-resources-url') || scriptElm.src, win.location.href)).href; if (BUILD.dynamicImportShim) { patchDynamicImport(opts.resourcesUrl, scriptElm); } if (BUILD.dynamicImportShim && !win.customElements) { // module support, but no custom elements support (Old Edge) // @ts-ignore return __sc_import_bulmil(/* webpackChunkName: "polyfills-dom" */ './dom-4061ceba.js').then(() => opts); } } return promiseResolve(opts); }; const patchDynamicImport = (base, orgScriptElm) => { const importFunctionName = getDynamicImportFunction(NAMESPACE); try { // test if this browser supports dynamic imports // There is a caching issue in V8, that breaks using import() in Function // By generating a random string, we can workaround it // Check https://bugs.chromium.org/p/chromium/issues/detail?id=990810 for more info win[importFunctionName] = new Function('w', `return import(w);//${Math.random()}`); } catch (e) { // this shim is specifically for browsers that do support "esm" imports // however, they do NOT support "dynamic" imports // basically this code is for old Edge, v18 and below const moduleMap = new Map(); win[importFunctionName] = (src) => { const url = new URL(src, base).href; let mod = moduleMap.get(url); if (!mod) { const script = doc.createElement('script'); script.type = 'module'; script.crossOrigin = orgScriptElm.crossOrigin; script.src = URL.createObjectURL(new Blob([`import * as m from '${url}'; window.${importFunctionName}.m = m;`], { type: 'application/javascript' })); mod = new Promise(resolve => { script.onload = () => { resolve(win[importFunctionName].m); script.remove(); }; }); moduleMap.set(url, mod); doc.head.appendChild(script); } return mod; }; } }; const patchCloneNodeFix = (HTMLElementPrototype) => { const nativeCloneNodeFn = HTMLElementPrototype.cloneNode; HTMLElementPrototype.cloneNode = function (deep) { if (this.nodeName === 'TEMPLATE') { return nativeCloneNodeFn.call(this, deep); } const clonedNode = nativeCloneNodeFn.call(this, false); const srcChildNodes = this.childNodes; if (deep) { for (let i = 0; i < srcChildNodes.length; i++) { // Node.ATTRIBUTE_NODE === 2, and checking because IE11 if (srcChildNodes[i].nodeType !== 2) { clonedNode.appendChild(srcChildNodes[i].cloneNode(true)); } } } return clonedNode; }; }; const globalScripts = () => {}; export { patchEsm as a, globalScripts as g, patchBrowser as p };