@capacitor/core 4.2.0 → 4.2.1-dev-20220921T210130.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/capacitor.js CHANGED
@@ -1,3 +1,3 @@
1
1
  /*! Capacitor: https://capacitorjs.com/ - MIT License */
2
- var capacitorExports=function(e){"use strict";const n=(e=>e.CapacitorPlatforms=(e=>{const n=new Map;n.set("web",{name:"web"});const t=e.CapacitorPlatforms||{currentPlatform:{name:"web"},platforms:n};return t.addPlatform=(e,n)=>{t.platforms.set(e,n)},t.setPlatform=e=>{t.platforms.has(e)&&(t.currentPlatform=t.platforms.get(e))},t})(e))("undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:"undefined"!=typeof window?window:"undefined"!=typeof global?global:{}),t=n.addPlatform,i=n.setPlatform;var r;e.ExceptionCode=void 0,(r=e.ExceptionCode||(e.ExceptionCode={})).Unimplemented="UNIMPLEMENTED",r.Unavailable="UNAVAILABLE";class o extends Error{constructor(e,n,t){super(e),this.message=e,this.code=n,this.data=t}}const s=n=>{var t,i,r,s,a;const l=n.CapacitorCustomPlatform||null,d=n.Capacitor||{},c=d.Plugins=d.Plugins||{},u=n.CapacitorPlatforms,m=(null===(t=null==u?void 0:u.currentPlatform)||void 0===t?void 0:t.getPlatform)||(()=>null!==l?l.name:(e=>{var n,t;return(null==e?void 0:e.androidBridge)?"android":(null===(t=null===(n=null==e?void 0:e.webkit)||void 0===n?void 0:n.messageHandlers)||void 0===t?void 0:t.bridge)?"ios":"web"})(n)),f=(null===(i=null==u?void 0:u.currentPlatform)||void 0===i?void 0:i.isNativePlatform)||(()=>"web"!==m()),v=(null===(r=null==u?void 0:u.currentPlatform)||void 0===r?void 0:r.isPluginAvailable)||(e=>{const n=w.get(e);return!!(null==n?void 0:n.platforms.has(m()))||!!g(e)}),g=(null===(s=null==u?void 0:u.currentPlatform)||void 0===s?void 0:s.getPluginHeader)||(e=>{var n;return null===(n=d.PluginHeaders)||void 0===n?void 0:n.find((n=>n.name===e))}),w=new Map,p=(null===(a=null==u?void 0:u.currentPlatform)||void 0===a?void 0:a.registerPlugin)||((n,t={})=>{const i=w.get(n);if(i)return console.warn(`Capacitor plugin "${n}" already registered. Cannot register plugins twice.`),i.proxy;const r=m(),s=g(n);let a;const u=i=>{let c;const u=(...u)=>{const m=(async()=>(!a&&r in t?a=a="function"==typeof t[r]?await t[r]():t[r]:null!==l&&!a&&"web"in t&&(a=a="function"==typeof t.web?await t.web():t.web),a))().then((t=>{const a=((t,i)=>{var a,l;if(!s){if(t)return null===(l=t[i])||void 0===l?void 0:l.bind(t);throw new o(`"${n}" plugin is not implemented on ${r}`,e.ExceptionCode.Unimplemented)}{const e=null==s?void 0:s.methods.find((e=>i===e.name));if(e)return"promise"===e.rtype?e=>d.nativePromise(n,i.toString(),e):(e,t)=>d.nativeCallback(n,i.toString(),e,t);if(t)return null===(a=t[i])||void 0===a?void 0:a.bind(t)}})(t,i);if(a){const e=a(...u);return c=null==e?void 0:e.remove,e}throw new o(`"${n}.${i}()" is not implemented on ${r}`,e.ExceptionCode.Unimplemented)}));return"addListener"===i&&(m.remove=async()=>c()),m};return u.toString=()=>`${i.toString()}() { [capacitor code] }`,Object.defineProperty(u,"name",{value:i,writable:!1,configurable:!1}),u},f=u("addListener"),v=u("removeListener"),p=(e,n)=>{const t=f({eventName:e},n),i=async()=>{const i=await t;v({eventName:e,callbackId:i},n)},r=new Promise((e=>t.then((()=>e({remove:i})))));return r.remove=async()=>{console.warn("Using addListener() without 'await' is deprecated."),await i()},r},h=new Proxy({},{get(e,n){switch(n){case"$$typeof":return;case"toJSON":return()=>({});case"addListener":return s?p:f;case"removeListener":return v;default:return u(n)}}});return c[n]=h,w.set(n,{name:n,proxy:h,platforms:new Set([...Object.keys(t),...s?[r]:[]])}),h});return d.convertFileSrc||(d.convertFileSrc=e=>e),d.getPlatform=m,d.handleError=e=>n.console.error(e),d.isNativePlatform=f,d.isPluginAvailable=v,d.pluginMethodNoop=(e,n,t)=>Promise.reject(`${t} does not have an implementation of "${n}".`),d.registerPlugin=p,d.Exception=o,d.DEBUG=!!d.DEBUG,d.isLoggingEnabled=!!d.isLoggingEnabled,d.platform=d.getPlatform(),d.isNative=d.isNativePlatform(),d},a=(e=>e.Capacitor=s(e))("undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:"undefined"!=typeof window?window:"undefined"!=typeof global?global:{}),l=a.registerPlugin,d=a.Plugins;const c=l("WebView");return e.Capacitor=a,e.CapacitorException=o,e.CapacitorPlatforms=n,e.Plugins=d,e.WebPlugin=class{constructor(e){this.listeners={},this.windowListeners={},e&&(console.warn(`Capacitor WebPlugin "${e.name}" config object was deprecated in v3 and will be removed in v4.`),this.config=e)}addListener(e,n){this.listeners[e]||(this.listeners[e]=[]),this.listeners[e].push(n);const t=this.windowListeners[e];t&&!t.registered&&this.addWindowListener(t);const i=async()=>this.removeListener(e,n),r=Promise.resolve({remove:i});return Object.defineProperty(r,"remove",{value:async()=>{console.warn("Using addListener() without 'await' is deprecated."),await i()}}),r}async removeAllListeners(){this.listeners={};for(const e in this.windowListeners)this.removeWindowListener(this.windowListeners[e]);this.windowListeners={}}notifyListeners(e,n){const t=this.listeners[e];t&&t.forEach((e=>e(n)))}hasListeners(e){return!!this.listeners[e].length}registerWindowListener(e,n){this.windowListeners[n]={registered:!1,windowEventName:e,pluginEventName:n,handler:e=>{this.notifyListeners(n,e)}}}unimplemented(n="not implemented"){return new a.Exception(n,e.ExceptionCode.Unimplemented)}unavailable(n="not available"){return new a.Exception(n,e.ExceptionCode.Unavailable)}async removeListener(e,n){const t=this.listeners[e];if(!t)return;const i=t.indexOf(n);this.listeners[e].splice(i,1),this.listeners[e].length||this.removeWindowListener(this.windowListeners[e])}addWindowListener(e){window.addEventListener(e.windowEventName,e.handler),e.registered=!0}removeWindowListener(e){e&&(window.removeEventListener(e.windowEventName,e.handler),e.registered=!1)}},e.WebView=c,e.addPlatform=t,e.registerPlugin=l,e.registerWebPlugin=e=>((e,n)=>{var t;const i=n.config,r=e.Plugins;if(!i||!i.name)throw new Error('Capacitor WebPlugin is using the deprecated "registerWebPlugin()" function, but without the config. Please use "registerPlugin()" instead to register this web plugin."');console.warn(`Capacitor plugin "${i.name}" is using the deprecated "registerWebPlugin()" function`),r[i.name]&&!(null===(t=null==i?void 0:i.platforms)||void 0===t?void 0:t.includes(e.getPlatform()))||(r[i.name]=n)})(a,e),e.setPlatform=i,Object.defineProperty(e,"__esModule",{value:!0}),e}({});
2
+ var capacitorExports=function(e){"use strict";const t=(e=>e.CapacitorPlatforms=(e=>{const t=new Map;t.set("web",{name:"web"});const n=e.CapacitorPlatforms||{currentPlatform:{name:"web"},platforms:t};return n.addPlatform=(e,t)=>{n.platforms.set(e,t)},n.setPlatform=e=>{n.platforms.has(e)&&(n.currentPlatform=n.platforms.get(e))},n})(e))("undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:"undefined"!=typeof window?window:"undefined"!=typeof global?global:{}),n=t.addPlatform,r=t.setPlatform;var i;e.ExceptionCode=void 0,(i=e.ExceptionCode||(e.ExceptionCode={})).Unimplemented="UNIMPLEMENTED",i.Unavailable="UNAVAILABLE";class o extends Error{constructor(e,t,n){super(e),this.message=e,this.code=t,this.data=n}}const s=t=>{var n,r,i,s,a;const l=t.CapacitorCustomPlatform||null,c=t.Capacitor||{},d=c.Plugins=c.Plugins||{},u=t.CapacitorPlatforms,p=(null===(n=null==u?void 0:u.currentPlatform)||void 0===n?void 0:n.getPlatform)||(()=>null!==l?l.name:(e=>{var t,n;return(null==e?void 0:e.androidBridge)?"android":(null===(n=null===(t=null==e?void 0:e.webkit)||void 0===t?void 0:t.messageHandlers)||void 0===n?void 0:n.bridge)?"ios":"web"})(t)),m=(null===(r=null==u?void 0:u.currentPlatform)||void 0===r?void 0:r.isNativePlatform)||(()=>"web"!==p()),f=(null===(i=null==u?void 0:u.currentPlatform)||void 0===i?void 0:i.isPluginAvailable)||(e=>{const t=g.get(e);return!!(null==t?void 0:t.platforms.has(p()))||!!w(e)}),w=(null===(s=null==u?void 0:u.currentPlatform)||void 0===s?void 0:s.getPluginHeader)||(e=>{var t;return null===(t=c.PluginHeaders)||void 0===t?void 0:t.find((t=>t.name===e))}),g=new Map,h=(null===(a=null==u?void 0:u.currentPlatform)||void 0===a?void 0:a.registerPlugin)||((t,n={})=>{const r=g.get(t);if(r)return console.warn(`Capacitor plugin "${t}" already registered. Cannot register plugins twice.`),r.proxy;const i=p(),s=w(t);let a;const u=r=>{let d;const u=(...u)=>{const p=(async()=>(!a&&i in n?a=a="function"==typeof n[i]?await n[i]():n[i]:null!==l&&!a&&"web"in n&&(a=a="function"==typeof n.web?await n.web():n.web),a))().then((n=>{const a=((n,r)=>{var a,l;if(!s){if(n)return null===(l=n[r])||void 0===l?void 0:l.bind(n);throw new o(`"${t}" plugin is not implemented on ${i}`,e.ExceptionCode.Unimplemented)}{const e=null==s?void 0:s.methods.find((e=>r===e.name));if(e)return"promise"===e.rtype?e=>c.nativePromise(t,r.toString(),e):(e,n)=>c.nativeCallback(t,r.toString(),e,n);if(n)return null===(a=n[r])||void 0===a?void 0:a.bind(n)}})(n,r);if(a){const e=a(...u);return d=null==e?void 0:e.remove,e}throw new o(`"${t}.${r}()" is not implemented on ${i}`,e.ExceptionCode.Unimplemented)}));return"addListener"===r&&(p.remove=async()=>d()),p};return u.toString=()=>`${r.toString()}() { [capacitor code] }`,Object.defineProperty(u,"name",{value:r,writable:!1,configurable:!1}),u},m=u("addListener"),f=u("removeListener"),h=(e,t)=>{const n=m({eventName:e},t),r=async()=>{const r=await n;f({eventName:e,callbackId:r},t)},i=new Promise((e=>n.then((()=>e({remove:r})))));return i.remove=async()=>{console.warn("Using addListener() without 'await' is deprecated."),await r()},i},v=new Proxy({},{get(e,t){switch(t){case"$$typeof":return;case"toJSON":return()=>({});case"addListener":return s?h:m;case"removeListener":return f;default:return u(t)}}});return d[t]=v,g.set(t,{name:t,proxy:v,platforms:new Set([...Object.keys(n),...s?[i]:[]])}),v});return c.convertFileSrc||(c.convertFileSrc=e=>e),c.getPlatform=p,c.handleError=e=>t.console.error(e),c.isNativePlatform=m,c.isPluginAvailable=f,c.pluginMethodNoop=(e,t,n)=>Promise.reject(`${n} does not have an implementation of "${t}".`),c.registerPlugin=h,c.Exception=o,c.DEBUG=!!c.DEBUG,c.isLoggingEnabled=!!c.isLoggingEnabled,c.platform=c.getPlatform(),c.isNative=c.isNativePlatform(),c},a=(e=>e.Capacitor=s(e))("undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:"undefined"!=typeof window?window:"undefined"!=typeof global?global:{}),l=a.registerPlugin,c=a.Plugins;class d{constructor(e){this.listeners={},this.windowListeners={},e&&(console.warn(`Capacitor WebPlugin "${e.name}" config object was deprecated in v3 and will be removed in v4.`),this.config=e)}addListener(e,t){this.listeners[e]||(this.listeners[e]=[]),this.listeners[e].push(t);const n=this.windowListeners[e];n&&!n.registered&&this.addWindowListener(n);const r=async()=>this.removeListener(e,t),i=Promise.resolve({remove:r});return Object.defineProperty(i,"remove",{value:async()=>{console.warn("Using addListener() without 'await' is deprecated."),await r()}}),i}async removeAllListeners(){this.listeners={};for(const e in this.windowListeners)this.removeWindowListener(this.windowListeners[e]);this.windowListeners={}}notifyListeners(e,t){const n=this.listeners[e];n&&n.forEach((e=>e(t)))}hasListeners(e){return!!this.listeners[e].length}registerWindowListener(e,t){this.windowListeners[t]={registered:!1,windowEventName:e,pluginEventName:t,handler:e=>{this.notifyListeners(t,e)}}}unimplemented(t="not implemented"){return new a.Exception(t,e.ExceptionCode.Unimplemented)}unavailable(t="not available"){return new a.Exception(t,e.ExceptionCode.Unavailable)}async removeListener(e,t){const n=this.listeners[e];if(!n)return;const r=n.indexOf(t);this.listeners[e].splice(r,1),this.listeners[e].length||this.removeWindowListener(this.windowListeners[e])}addWindowListener(e){window.addEventListener(e.windowEventName,e.handler),e.registered=!0}removeWindowListener(e){e&&(window.removeEventListener(e.windowEventName,e.handler),e.registered=!1)}}const u=l("WebView"),p=e=>encodeURIComponent(e).replace(/%(2[346B]|5E|60|7C)/g,decodeURIComponent).replace(/[()]/g,escape);class m extends d{async setCookie(e){try{const t=p(e.key),n=p(e.value),r=`; expires=${(e.expires||"").replace("expires=","")}`,i=(e.path||"/").replace("path=","");document.cookie=`${t}=${n||""}${r}; path=${i}`}catch(e){return Promise.reject(e)}}async deleteCookie(e){try{document.cookie=`${e.key}=; Max-Age=0`}catch(e){return Promise.reject(e)}}async clearCookies(){try{const e=document.cookie.split(";")||[];for(const t of e)document.cookie=t.replace(/^ +/,"").replace(/=.*/,`=;expires=${(new Date).toUTCString()};path=/`)}catch(e){return Promise.reject(e)}}async clearAllCookies(){try{await this.clearCookies()}catch(e){return Promise.reject(e)}}}const f=l("CapacitorCookies",{web:()=>new m}),w=(e,t={})=>{const n=Object.assign({method:e.method||"GET",headers:e.headers},t),r=((e={})=>{const t=Object.keys(e);return Object.keys(e).map((e=>e.toLocaleLowerCase())).reduce(((n,r,i)=>(n[r]=e[t[i]],n)),{})})(e.headers)["content-type"]||"";if("string"==typeof e.data)n.body=e.data;else if(r.includes("application/x-www-form-urlencoded")){const t=new URLSearchParams;for(const[n,r]of Object.entries(e.data||{}))t.set(n,r);n.body=t.toString()}else if(r.includes("multipart/form-data")){const t=new FormData;if(e.data instanceof FormData)e.data.forEach(((e,n)=>{t.append(n,e)}));else for(const n of Object.keys(e.data))t.append(n,e.data[n]);n.body=t;const r=new Headers(n.headers);r.delete("content-type"),n.headers=r}else(r.includes("application/json")||"object"==typeof e.data)&&(n.body=JSON.stringify(e.data));return n};class g extends d{async request(e){const t=w(e,e.webFetchExtra),n=((e,t=!0)=>e?Object.entries(e).reduce(((e,n)=>{const[r,i]=n;let o,s;return Array.isArray(i)?(s="",i.forEach((e=>{o=t?encodeURIComponent(e):e,s+=`${r}=${o}&`})),s.slice(0,-1)):(o=t?encodeURIComponent(i):i,s=`${r}=${o}`),`${e}&${s}`}),"").substr(1):null)(e.params,e.shouldEncodeUrlParams),r=n?`${e.url}?${n}`:e.url,i=await fetch(r,t),o=i.headers.get("content-type")||"";let s,a,{responseType:l="text"}=i.ok?e:{};switch(o.includes("application/json")&&(l="json"),l){case"arraybuffer":case"blob":a=await i.blob(),s=await(async e=>new Promise(((t,n)=>{const r=new FileReader;r.onload=()=>{const e=r.result;t(e.indexOf(",")>=0?e.split(",")[1]:e)},r.onerror=e=>n(e),r.readAsDataURL(e)})))(a);break;case"json":s=await i.json();break;default:s=await i.text()}const c={};return i.headers.forEach(((e,t)=>{c[t]=e})),{data:s,headers:c,status:i.status,url:i.url}}async get(e){return this.request(Object.assign(Object.assign({},e),{method:"GET"}))}async post(e){return this.request(Object.assign(Object.assign({},e),{method:"POST"}))}async put(e){return this.request(Object.assign(Object.assign({},e),{method:"PUT"}))}async patch(e){return this.request(Object.assign(Object.assign({},e),{method:"PATCH"}))}async delete(e){return this.request(Object.assign(Object.assign({},e),{method:"DELETE"}))}}const h=l("CapacitorHttp",{web:()=>new g});return e.Capacitor=a,e.CapacitorCookies=f,e.CapacitorException=o,e.CapacitorHttp=h,e.CapacitorPlatforms=t,e.Plugins=c,e.WebPlugin=d,e.WebView=u,e.addPlatform=n,e.registerPlugin=l,e.registerWebPlugin=e=>((e,t)=>{var n;const r=t.config,i=e.Plugins;if(!r||!r.name)throw new Error('Capacitor WebPlugin is using the deprecated "registerWebPlugin()" function, but without the config. Please use "registerPlugin()" instead to register this web plugin."');console.warn(`Capacitor plugin "${r.name}" is using the deprecated "registerWebPlugin()" function`),i[r.name]&&!(null===(n=null==r?void 0:r.platforms)||void 0===n?void 0:n.includes(e.getPlatform()))||(i[r.name]=t)})(a,e),e.setPlatform=r,Object.defineProperty(e,"__esModule",{value:!0}),e}({});
3
3
  //# sourceMappingURL=capacitor.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"capacitor.js","sources":["../build/platforms.js","../build/util.js","../build/runtime.js","../build/global.js","../build/core-plugins.js","../build/web-plugin.js","../build/legacy/legacy-web-plugin-merge.js"],"sourcesContent":["const createCapacitorPlatforms = (win) => {\n const defaultPlatformMap = new Map();\n defaultPlatformMap.set('web', { name: 'web' });\n const capPlatforms = win.CapacitorPlatforms || {\n currentPlatform: { name: 'web' },\n platforms: defaultPlatformMap,\n };\n const addPlatform = (name, platform) => {\n capPlatforms.platforms.set(name, platform);\n };\n const setPlatform = (name) => {\n if (capPlatforms.platforms.has(name)) {\n capPlatforms.currentPlatform = capPlatforms.platforms.get(name);\n }\n };\n capPlatforms.addPlatform = addPlatform;\n capPlatforms.setPlatform = setPlatform;\n return capPlatforms;\n};\nconst initPlatforms = (win) => (win.CapacitorPlatforms = createCapacitorPlatforms(win));\n/**\n * @deprecated Set `CapacitorCustomPlatform` on the window object prior to runtime executing in the web app instead\n */\nexport const CapacitorPlatforms = /*#__PURE__*/ initPlatforms((typeof globalThis !== 'undefined'\n ? globalThis\n : typeof self !== 'undefined'\n ? self\n : typeof window !== 'undefined'\n ? window\n : typeof global !== 'undefined'\n ? global\n : {}));\n/**\n * @deprecated Set `CapacitorCustomPlatform` on the window object prior to runtime executing in the web app instead\n */\nexport const addPlatform = CapacitorPlatforms.addPlatform;\n/**\n * @deprecated Set `CapacitorCustomPlatform` on the window object prior to runtime executing in the web app instead\n */\nexport const setPlatform = CapacitorPlatforms.setPlatform;\n//# sourceMappingURL=platforms.js.map","export var ExceptionCode;\n(function (ExceptionCode) {\n /**\n * API is not implemented.\n *\n * This usually means the API can't be used because it is not implemented for\n * the current platform.\n */\n ExceptionCode[\"Unimplemented\"] = \"UNIMPLEMENTED\";\n /**\n * API is not available.\n *\n * This means the API can't be used right now because:\n * - it is currently missing a prerequisite, such as network connectivity\n * - it requires a particular platform or browser version\n */\n ExceptionCode[\"Unavailable\"] = \"UNAVAILABLE\";\n})(ExceptionCode || (ExceptionCode = {}));\nexport class CapacitorException extends Error {\n constructor(message, code, data) {\n super(message);\n this.message = message;\n this.code = code;\n this.data = data;\n }\n}\nexport const getPlatformId = (win) => {\n var _a, _b;\n if (win === null || win === void 0 ? void 0 : win.androidBridge) {\n return 'android';\n }\n else if ((_b = (_a = win === null || win === void 0 ? void 0 : win.webkit) === null || _a === void 0 ? void 0 : _a.messageHandlers) === null || _b === void 0 ? void 0 : _b.bridge) {\n return 'ios';\n }\n else {\n return 'web';\n }\n};\n//# sourceMappingURL=util.js.map","import { CapacitorException, getPlatformId, ExceptionCode } from './util';\nexport const createCapacitor = (win) => {\n var _a, _b, _c, _d, _e;\n const capCustomPlatform = win.CapacitorCustomPlatform || null;\n const cap = win.Capacitor || {};\n const Plugins = (cap.Plugins = cap.Plugins || {});\n /**\n * @deprecated Use `capCustomPlatform` instead, default functions like registerPlugin will function with the new object.\n */\n const capPlatforms = win.CapacitorPlatforms;\n const defaultGetPlatform = () => {\n return capCustomPlatform !== null\n ? capCustomPlatform.name\n : getPlatformId(win);\n };\n const getPlatform = ((_a = capPlatforms === null || capPlatforms === void 0 ? void 0 : capPlatforms.currentPlatform) === null || _a === void 0 ? void 0 : _a.getPlatform) || defaultGetPlatform;\n const defaultIsNativePlatform = () => getPlatform() !== 'web';\n const isNativePlatform = ((_b = capPlatforms === null || capPlatforms === void 0 ? void 0 : capPlatforms.currentPlatform) === null || _b === void 0 ? void 0 : _b.isNativePlatform) || defaultIsNativePlatform;\n const defaultIsPluginAvailable = (pluginName) => {\n const plugin = registeredPlugins.get(pluginName);\n if (plugin === null || plugin === void 0 ? void 0 : plugin.platforms.has(getPlatform())) {\n // JS implementation available for the current platform.\n return true;\n }\n if (getPluginHeader(pluginName)) {\n // Native implementation available.\n return true;\n }\n return false;\n };\n const isPluginAvailable = ((_c = capPlatforms === null || capPlatforms === void 0 ? void 0 : capPlatforms.currentPlatform) === null || _c === void 0 ? void 0 : _c.isPluginAvailable) ||\n defaultIsPluginAvailable;\n const defaultGetPluginHeader = (pluginName) => { var _a; return (_a = cap.PluginHeaders) === null || _a === void 0 ? void 0 : _a.find(h => h.name === pluginName); };\n const getPluginHeader = ((_d = capPlatforms === null || capPlatforms === void 0 ? void 0 : capPlatforms.currentPlatform) === null || _d === void 0 ? void 0 : _d.getPluginHeader) || defaultGetPluginHeader;\n const handleError = (err) => win.console.error(err);\n const pluginMethodNoop = (_target, prop, pluginName) => {\n return Promise.reject(`${pluginName} does not have an implementation of \"${prop}\".`);\n };\n const registeredPlugins = new Map();\n const defaultRegisterPlugin = (pluginName, jsImplementations = {}) => {\n const registeredPlugin = registeredPlugins.get(pluginName);\n if (registeredPlugin) {\n console.warn(`Capacitor plugin \"${pluginName}\" already registered. Cannot register plugins twice.`);\n return registeredPlugin.proxy;\n }\n const platform = getPlatform();\n const pluginHeader = getPluginHeader(pluginName);\n let jsImplementation;\n const loadPluginImplementation = async () => {\n if (!jsImplementation && platform in jsImplementations) {\n jsImplementation =\n typeof jsImplementations[platform] === 'function'\n ? (jsImplementation = await jsImplementations[platform]())\n : (jsImplementation = jsImplementations[platform]);\n }\n else if (capCustomPlatform !== null &&\n !jsImplementation &&\n 'web' in jsImplementations) {\n jsImplementation =\n typeof jsImplementations['web'] === 'function'\n ? (jsImplementation = await jsImplementations['web']())\n : (jsImplementation = jsImplementations['web']);\n }\n return jsImplementation;\n };\n const createPluginMethod = (impl, prop) => {\n var _a, _b;\n if (pluginHeader) {\n const methodHeader = pluginHeader === null || pluginHeader === void 0 ? void 0 : pluginHeader.methods.find(m => prop === m.name);\n if (methodHeader) {\n if (methodHeader.rtype === 'promise') {\n return (options) => cap.nativePromise(pluginName, prop.toString(), options);\n }\n else {\n return (options, callback) => cap.nativeCallback(pluginName, prop.toString(), options, callback);\n }\n }\n else if (impl) {\n return (_a = impl[prop]) === null || _a === void 0 ? void 0 : _a.bind(impl);\n }\n }\n else if (impl) {\n return (_b = impl[prop]) === null || _b === void 0 ? void 0 : _b.bind(impl);\n }\n else {\n throw new CapacitorException(`\"${pluginName}\" plugin is not implemented on ${platform}`, ExceptionCode.Unimplemented);\n }\n };\n const createPluginMethodWrapper = (prop) => {\n let remove;\n const wrapper = (...args) => {\n const p = loadPluginImplementation().then(impl => {\n const fn = createPluginMethod(impl, prop);\n if (fn) {\n const p = fn(...args);\n remove = p === null || p === void 0 ? void 0 : p.remove;\n return p;\n }\n else {\n throw new CapacitorException(`\"${pluginName}.${prop}()\" is not implemented on ${platform}`, ExceptionCode.Unimplemented);\n }\n });\n if (prop === 'addListener') {\n p.remove = async () => remove();\n }\n return p;\n };\n // Some flair ✨\n wrapper.toString = () => `${prop.toString()}() { [capacitor code] }`;\n Object.defineProperty(wrapper, 'name', {\n value: prop,\n writable: false,\n configurable: false,\n });\n return wrapper;\n };\n const addListener = createPluginMethodWrapper('addListener');\n const removeListener = createPluginMethodWrapper('removeListener');\n const addListenerNative = (eventName, callback) => {\n const call = addListener({ eventName }, callback);\n const remove = async () => {\n const callbackId = await call;\n removeListener({\n eventName,\n callbackId,\n }, callback);\n };\n const p = new Promise(resolve => call.then(() => resolve({ remove })));\n p.remove = async () => {\n console.warn(`Using addListener() without 'await' is deprecated.`);\n await remove();\n };\n return p;\n };\n const proxy = new Proxy({}, {\n get(_, prop) {\n switch (prop) {\n // https://github.com/facebook/react/issues/20030\n case '$$typeof':\n return undefined;\n case 'toJSON':\n return () => ({});\n case 'addListener':\n return pluginHeader ? addListenerNative : addListener;\n case 'removeListener':\n return removeListener;\n default:\n return createPluginMethodWrapper(prop);\n }\n },\n });\n Plugins[pluginName] = proxy;\n registeredPlugins.set(pluginName, {\n name: pluginName,\n proxy,\n platforms: new Set([\n ...Object.keys(jsImplementations),\n ...(pluginHeader ? [platform] : []),\n ]),\n });\n return proxy;\n };\n const registerPlugin = ((_e = capPlatforms === null || capPlatforms === void 0 ? void 0 : capPlatforms.currentPlatform) === null || _e === void 0 ? void 0 : _e.registerPlugin) || defaultRegisterPlugin;\n // Add in convertFileSrc for web, it will already be available in native context\n if (!cap.convertFileSrc) {\n cap.convertFileSrc = filePath => filePath;\n }\n cap.getPlatform = getPlatform;\n cap.handleError = handleError;\n cap.isNativePlatform = isNativePlatform;\n cap.isPluginAvailable = isPluginAvailable;\n cap.pluginMethodNoop = pluginMethodNoop;\n cap.registerPlugin = registerPlugin;\n cap.Exception = CapacitorException;\n cap.DEBUG = !!cap.DEBUG;\n cap.isLoggingEnabled = !!cap.isLoggingEnabled;\n // Deprecated props\n cap.platform = cap.getPlatform();\n cap.isNative = cap.isNativePlatform();\n return cap;\n};\nexport const initCapacitorGlobal = (win) => (win.Capacitor = createCapacitor(win));\n//# sourceMappingURL=runtime.js.map","import { legacyRegisterWebPlugin } from './legacy/legacy-web-plugin-merge';\nimport { initCapacitorGlobal } from './runtime';\nexport const Capacitor = /*#__PURE__*/ initCapacitorGlobal(typeof globalThis !== 'undefined'\n ? globalThis\n : typeof self !== 'undefined'\n ? self\n : typeof window !== 'undefined'\n ? window\n : typeof global !== 'undefined'\n ? global\n : {});\nexport const registerPlugin = Capacitor.registerPlugin;\n/**\n * @deprecated Provided for backwards compatibility for Capacitor v2 plugins.\n * Capacitor v3 plugins should import the plugin directly. This \"Plugins\"\n * export is deprecated in v3, and will be removed in v4.\n */\nexport const Plugins = Capacitor.Plugins;\n/**\n * Provided for backwards compatibility. Use the registerPlugin() API\n * instead, and provide the web plugin as the \"web\" implmenetation.\n * For example\n *\n * export const Example = registerPlugin('Example', {\n * web: () => import('./web').then(m => new m.Example())\n * })\n *\n * @deprecated Deprecated in v3, will be removed from v4.\n */\nexport const registerWebPlugin = (plugin) => legacyRegisterWebPlugin(Capacitor, plugin);\n//# sourceMappingURL=global.js.map","import { registerPlugin } from './global';\nexport const WebView = /*#__PURE__*/ registerPlugin('WebView');\n//# sourceMappingURL=core-plugins.js.map","import { Capacitor } from './global';\nimport { ExceptionCode } from './util';\n/**\n * Base class web plugins should extend.\n */\nexport class WebPlugin {\n constructor(config) {\n this.listeners = {};\n this.windowListeners = {};\n if (config) {\n // TODO: add link to upgrade guide\n console.warn(`Capacitor WebPlugin \"${config.name}\" config object was deprecated in v3 and will be removed in v4.`);\n this.config = config;\n }\n }\n addListener(eventName, listenerFunc) {\n const listeners = this.listeners[eventName];\n if (!listeners) {\n this.listeners[eventName] = [];\n }\n this.listeners[eventName].push(listenerFunc);\n // If we haven't added a window listener for this event and it requires one,\n // go ahead and add it\n const windowListener = this.windowListeners[eventName];\n if (windowListener && !windowListener.registered) {\n this.addWindowListener(windowListener);\n }\n const remove = async () => this.removeListener(eventName, listenerFunc);\n const p = Promise.resolve({ remove });\n Object.defineProperty(p, 'remove', {\n value: async () => {\n console.warn(`Using addListener() without 'await' is deprecated.`);\n await remove();\n },\n });\n return p;\n }\n async removeAllListeners() {\n this.listeners = {};\n for (const listener in this.windowListeners) {\n this.removeWindowListener(this.windowListeners[listener]);\n }\n this.windowListeners = {};\n }\n notifyListeners(eventName, data) {\n const listeners = this.listeners[eventName];\n if (listeners) {\n listeners.forEach(listener => listener(data));\n }\n }\n hasListeners(eventName) {\n return !!this.listeners[eventName].length;\n }\n registerWindowListener(windowEventName, pluginEventName) {\n this.windowListeners[pluginEventName] = {\n registered: false,\n windowEventName,\n pluginEventName,\n handler: event => {\n this.notifyListeners(pluginEventName, event);\n },\n };\n }\n unimplemented(msg = 'not implemented') {\n return new Capacitor.Exception(msg, ExceptionCode.Unimplemented);\n }\n unavailable(msg = 'not available') {\n return new Capacitor.Exception(msg, ExceptionCode.Unavailable);\n }\n async removeListener(eventName, listenerFunc) {\n const listeners = this.listeners[eventName];\n if (!listeners) {\n return;\n }\n const index = listeners.indexOf(listenerFunc);\n this.listeners[eventName].splice(index, 1);\n // If there are no more listeners for this type of event,\n // remove the window listener\n if (!this.listeners[eventName].length) {\n this.removeWindowListener(this.windowListeners[eventName]);\n }\n }\n addWindowListener(handle) {\n window.addEventListener(handle.windowEventName, handle.handler);\n handle.registered = true;\n }\n removeWindowListener(handle) {\n if (!handle) {\n return;\n }\n window.removeEventListener(handle.windowEventName, handle.handler);\n handle.registered = false;\n }\n}\n//# sourceMappingURL=web-plugin.js.map","export const legacyRegisterWebPlugin = (cap, webPlugin) => {\n var _a;\n const config = webPlugin.config;\n const Plugins = cap.Plugins;\n if (!config || !config.name) {\n // TODO: add link to upgrade guide\n throw new Error(`Capacitor WebPlugin is using the deprecated \"registerWebPlugin()\" function, but without the config. Please use \"registerPlugin()\" instead to register this web plugin.\"`);\n }\n // TODO: add link to upgrade guide\n console.warn(`Capacitor plugin \"${config.name}\" is using the deprecated \"registerWebPlugin()\" function`);\n if (!Plugins[config.name] || ((_a = config === null || config === void 0 ? void 0 : config.platforms) === null || _a === void 0 ? void 0 : _a.includes(cap.getPlatform()))) {\n // Add the web plugin into the plugins registry if there already isn't\n // an existing one. If it doesn't already exist, that means\n // there's no existing native implementation for it.\n // - OR -\n // If we already have a plugin registered (meaning it was defined in the native layer),\n // then we should only overwrite it if the corresponding web plugin activates on\n // a certain platform. For example: Geolocation uses the WebPlugin on Android but not iOS\n Plugins[config.name] = webPlugin;\n }\n};\n//# sourceMappingURL=legacy-web-plugin-merge.js.map"],"names":["CapacitorPlatforms","win","defaultPlatformMap","Map","set","name","capPlatforms","currentPlatform","platforms","addPlatform","platform","setPlatform","has","get","createCapacitorPlatforms","initPlatforms","globalThis","self","window","global","ExceptionCode","exports","CapacitorException","Error","constructor","message","code","data","super","this","createCapacitor","_a","_b","_c","_d","_e","capCustomPlatform","CapacitorCustomPlatform","cap","Capacitor","Plugins","getPlatform","androidBridge","webkit","messageHandlers","bridge","getPlatformId","isNativePlatform","isPluginAvailable","pluginName","plugin","registeredPlugins","getPluginHeader","PluginHeaders","find","h","registerPlugin","jsImplementations","registeredPlugin","console","warn","proxy","pluginHeader","jsImplementation","createPluginMethodWrapper","prop","remove","wrapper","args","p","async","loadPluginImplementation","then","impl","fn","bind","Unimplemented","methodHeader","methods","m","rtype","options","nativePromise","toString","callback","nativeCallback","createPluginMethod","Object","defineProperty","value","writable","configurable","addListener","removeListener","addListenerNative","eventName","call","callbackId","Promise","resolve","Proxy","_","Set","keys","convertFileSrc","filePath","handleError","err","error","pluginMethodNoop","_target","reject","Exception","DEBUG","isLoggingEnabled","isNative","initCapacitorGlobal","WebView","config","listeners","windowListeners","listenerFunc","push","windowListener","registered","addWindowListener","listener","removeWindowListener","notifyListeners","forEach","hasListeners","length","registerWindowListener","windowEventName","pluginEventName","handler","event","unimplemented","msg","unavailable","Unavailable","index","indexOf","splice","handle","addEventListener","removeEventListener","webPlugin","includes","legacyRegisterWebPlugin"],"mappings":";8CAAA,MAuBaA,EAJS,CAACC,GAASA,EAAID,mBAnBH,CAACC,IAC9B,MAAMC,EAAqB,IAAIC,IAC/BD,EAAmBE,IAAI,MAAO,CAAEC,KAAM,QACtC,MAAMC,EAAeL,EAAID,oBAAsB,CAC3CO,gBAAiB,CAAEF,KAAM,OACzBG,UAAWN,GAYf,OAFAI,EAAaG,YARO,CAACJ,EAAMK,KACvBJ,EAAaE,UAAUJ,IAAIC,EAAMK,EAAS,EAQ9CJ,EAAaK,YANQN,IACbC,EAAaE,UAAUI,IAAIP,KAC3BC,EAAaC,gBAAkBD,EAAaE,UAAUK,IAAIR,GAC7D,EAIEC,CAAY,EAEkCQ,CAAyBb,GAIlCc,CAAqC,oBAAfC,WAChEA,WACgB,oBAATC,KACHA,KACkB,oBAAXC,OACHA,OACkB,oBAAXC,OACHA,OACA,IAILV,EAAcT,EAAmBS,YAIjCE,EAAcX,EAAmBW,YCtC9C,IAAWS,EADcC,EAAAD,mBAAA,GACdA,EAgBRA,kBAAkBA,EAAAA,cAAgB,CAAE,IATN,cAAI,gBAQjCA,EAA2B,YAAI,cAE5B,MAAME,UAA2BC,MACpCC,YAAYC,EAASC,EAAMC,GACvBC,MAAMH,GACNI,KAAKJ,QAAUA,EACfI,KAAKH,KAAOA,EACZG,KAAKF,KAAOA,CACf,EAEE,MCzBMG,EAAmB7B,IAC5B,IAAI8B,EAAIC,EAAIC,EAAIC,EAAIC,EACpB,MAAMC,EAAoBnC,EAAIoC,yBAA2B,KACnDC,EAAMrC,EAAIsC,WAAa,GACvBC,EAAWF,EAAIE,QAAUF,EAAIE,SAAW,CAAA,EAIxClC,EAAeL,EAAID,mBAMnByC,GAAmH,QAAnGV,EAAKzB,aAAmD,EAASA,EAAaC,uBAAoC,IAAPwB,OAAgB,EAASA,EAAGU,cALlI,KACM,OAAtBL,EACDA,EAAkB/B,KDcH,CAACJ,IAC1B,IAAI8B,EAAIC,EACR,OAAI/B,aAAiC,EAASA,EAAIyC,eACvC,WAE6H,QAA9HV,EAAqE,QAA/DD,EAAK9B,aAAiC,EAASA,EAAI0C,cAA2B,IAAPZ,OAAgB,EAASA,EAAGa,uBAAoC,IAAPZ,OAAgB,EAASA,EAAGa,QACjK,MAGA,KACV,ECvBSC,CAAc7C,IAIlB8C,GAAwH,QAAnGf,EAAK1B,aAAmD,EAASA,EAAaC,uBAAoC,IAAPyB,OAAgB,EAASA,EAAGe,mBADlI,KAAwB,QAAlBN,KAchCO,GAAyH,QAAnGf,EAAK3B,aAAmD,EAASA,EAAaC,uBAAoC,IAAP0B,OAAgB,EAASA,EAAGe,oBAZlI,CAACC,IAC9B,MAAMC,EAASC,EAAkBtC,IAAIoC,GACrC,SAAIC,aAAuC,EAASA,EAAO1C,UAAUI,IAAI6B,SAIrEW,EAAgBH,EAIR,GAKVG,GAAuH,QAAnGlB,EAAK5B,aAAmD,EAASA,EAAaC,uBAAoC,IAAP2B,OAAgB,EAASA,EAAGkB,kBADlI,CAACH,IAAiB,IAAIlB,EAAI,OAAoC,QAA5BA,EAAKO,EAAIe,qBAAkC,IAAPtB,OAAgB,EAASA,EAAGuB,MAAKC,GAAKA,EAAElD,OAAS4C,GAAW,GAM3JE,EAAoB,IAAIhD,IA4HxBqD,GAAsH,QAAnGrB,EAAK7B,aAAmD,EAASA,EAAaC,uBAAoC,IAAP4B,OAAgB,EAASA,EAAGqB,iBA3HlI,EAACP,EAAYQ,EAAoB,CAAA,KAC3D,MAAMC,EAAmBP,EAAkBtC,IAAIoC,GAC/C,GAAIS,EAEA,OADAC,QAAQC,KAAK,qBAAqBX,yDAC3BS,EAAiBG,MAE5B,MAAMnD,EAAW+B,IACXqB,EAAeV,EAAgBH,GACrC,IAAIc,EACJ,MAwCMC,EAA6BC,IAC/B,IAAIC,EACJ,MAAMC,EAAU,IAAIC,KAChB,MAAMC,EA3CmBC,YACxBP,GAAoBrD,KAAY+C,EACjCM,EAEWA,EADgC,mBAAhCN,EAAkB/C,SACO+C,EAAkB/C,KACxB+C,EAAkB/C,GAErB,OAAtB0B,IACJ2B,GACD,QAASN,IACTM,EAEWA,EAD6B,mBAA7BN,EAAuB,UACEA,EAAuB,MAC7BA,EAAuB,KAElDM,GA4BOQ,GAA2BC,MAAKC,IACtC,MAAMC,EA3BS,EAACD,EAAMR,KAC9B,IAAIlC,EAAIC,EACR,IAAI8B,EAcC,IAAIW,EACL,OAA6B,QAArBzC,EAAKyC,EAAKR,UAA0B,IAAPjC,OAAgB,EAASA,EAAG2C,KAAKF,GAGtE,MAAM,IAAInD,EAAmB,IAAI2B,mCAA4CvC,IAAYU,gBAAcwD,cAC1G,CAnBiB,CACd,MAAMC,EAAef,aAAmD,EAASA,EAAagB,QAAQxB,MAAKyB,GAAKd,IAASc,EAAE1E,OAC3H,GAAIwE,EACA,MAA2B,YAAvBA,EAAaG,MACLC,GAAY3C,EAAI4C,cAAcjC,EAAYgB,EAAKkB,WAAYF,GAG5D,CAACA,EAASG,IAAa9C,EAAI+C,eAAepC,EAAYgB,EAAKkB,WAAYF,EAASG,GAG1F,GAAIX,EACL,OAA6B,QAArB1C,EAAK0C,EAAKR,UAA0B,IAAPlC,OAAgB,EAASA,EAAG4C,KAAKF,EAE7E,CAMA,EAMkBa,CAAmBb,EAAMR,GACpC,GAAIS,EAAI,CACJ,MAAML,EAAIK,KAAMN,GAEhB,OADAF,EAASG,aAA6B,EAASA,EAAEH,OAC1CG,CACV,CAEG,MAAM,IAAI/C,EAAmB,IAAI2B,KAAcgB,8BAAiCvD,IAAYU,EAAaA,cAACwD,cAC7G,IAKL,MAHa,gBAATX,IACAI,EAAEH,OAASI,SAAYJ,KAEpBG,CAAC,EASZ,OANAF,EAAQgB,SAAW,IAAM,GAAGlB,EAAKkB,oCACjCI,OAAOC,eAAerB,EAAS,OAAQ,CACnCsB,MAAOxB,EACPyB,UAAU,EACVC,cAAc,IAEXxB,CAAO,EAEZyB,EAAc5B,EAA0B,eACxC6B,EAAiB7B,EAA0B,kBAC3C8B,EAAoB,CAACC,EAAWX,KAClC,MAAMY,EAAOJ,EAAY,CAAEG,aAAaX,GAClClB,EAASI,UACX,MAAM2B,QAAmBD,EACzBH,EAAe,CACXE,YACAE,cACDb,EAAS,EAEVf,EAAI,IAAI6B,SAAQC,GAAWH,EAAKxB,MAAK,IAAM2B,EAAQ,CAAEjC,eAK3D,OAJAG,EAAEH,OAASI,UACPX,QAAQC,KAAK,4DACPM,GAAQ,EAEXG,CAAC,EAENR,EAAQ,IAAIuC,MAAM,GAAI,CACxBvF,IAAIwF,EAAGpC,GACH,OAAQA,GAEJ,IAAK,WACD,OACJ,IAAK,SACD,MAAO,KAAA,CAAS,GACpB,IAAK,cACD,OAAOH,EAAegC,EAAoBF,EAC9C,IAAK,iBACD,OAAOC,EACX,QACI,OAAO7B,EAA0BC,GAE5C,IAWL,OATAzB,EAAQS,GAAcY,EACtBV,EAAkB/C,IAAI6C,EAAY,CAC9B5C,KAAM4C,EACNY,QACArD,UAAW,IAAI8F,IAAI,IACZf,OAAOgB,KAAK9C,MACXK,EAAe,CAACpD,GAAY,OAGjCmD,CAAK,GAmBhB,OAfKvB,EAAIkE,iBACLlE,EAAIkE,eAAiBC,GAAYA,GAErCnE,EAAIG,YAAcA,EAClBH,EAAIoE,YAtIiBC,GAAQ1G,EAAI0D,QAAQiD,MAAMD,GAuI/CrE,EAAIS,iBAAmBA,EACvBT,EAAIU,kBAAoBA,EACxBV,EAAIuE,iBAxIqB,CAACC,EAAS7C,EAAMhB,IAC9BiD,QAAQa,OAAO,GAAG9D,yCAAkDgB,OAwI/E3B,EAAIkB,eAAiBA,EACrBlB,EAAI0E,UAAY1F,EAChBgB,EAAI2E,QAAU3E,EAAI2E,MAClB3E,EAAI4E,mBAAqB5E,EAAI4E,iBAE7B5E,EAAI5B,SAAW4B,EAAIG,cACnBH,EAAI6E,SAAW7E,EAAIS,mBACZT,CAAG,ECjLDC,EDmLsB,CAACtC,GAASA,EAAIsC,UAAYT,EAAgB7B,GCnLtCmH,CAA0C,oBAAfpG,WAC5DA,WACgB,oBAATC,KACHA,KACkB,oBAAXC,OACHA,OACkB,oBAAXC,OACHA,OACA,IACLqC,EAAiBjB,EAAUiB,eAM3BhB,EAAUD,EAAUC,QChBrB,MAAC6E,EAAwB7D,EAAe,sGCI7C,MACHhC,YAAY8F,GACRzF,KAAK0F,UAAY,GACjB1F,KAAK2F,gBAAkB,GACnBF,IAEA3D,QAAQC,KAAK,wBAAwB0D,EAAOjH,uEAC5CwB,KAAKyF,OAASA,EAErB,CACD1B,YAAYG,EAAW0B,GACD5F,KAAK0F,UAAUxB,KAE7BlE,KAAK0F,UAAUxB,GAAa,IAEhClE,KAAK0F,UAAUxB,GAAW2B,KAAKD,GAG/B,MAAME,EAAiB9F,KAAK2F,gBAAgBzB,GACxC4B,IAAmBA,EAAeC,YAClC/F,KAAKgG,kBAAkBF,GAE3B,MAAMzD,EAASI,SAAYzC,KAAKgE,eAAeE,EAAW0B,GACpDpD,EAAI6B,QAAQC,QAAQ,CAAEjC,WAO5B,OANAqB,OAAOC,eAAenB,EAAG,SAAU,CAC/BoB,MAAOnB,UACHX,QAAQC,KAAK,4DACPM,GAAQ,IAGfG,CACV,CACDC,2BACIzC,KAAK0F,UAAY,GACjB,IAAK,MAAMO,KAAYjG,KAAK2F,gBACxB3F,KAAKkG,qBAAqBlG,KAAK2F,gBAAgBM,IAEnDjG,KAAK2F,gBAAkB,EAC1B,CACDQ,gBAAgBjC,EAAWpE,GACvB,MAAM4F,EAAY1F,KAAK0F,UAAUxB,GAC7BwB,GACAA,EAAUU,SAAQH,GAAYA,EAASnG,IAE9C,CACDuG,aAAanC,GACT,QAASlE,KAAK0F,UAAUxB,GAAWoC,MACtC,CACDC,uBAAuBC,EAAiBC,GACpCzG,KAAK2F,gBAAgBc,GAAmB,CACpCV,YAAY,EACZS,kBACAC,kBACAC,QAASC,IACL3G,KAAKmG,gBAAgBM,EAAiBE,EAAM,EAGvD,CACDC,cAAcC,EAAM,mBAChB,OAAO,IAAInG,EAAUyE,UAAU0B,EAAKtH,EAAaA,cAACwD,cACrD,CACD+D,YAAYD,EAAM,iBACd,OAAO,IAAInG,EAAUyE,UAAU0B,EAAKtH,EAAaA,cAACwH,YACrD,CACDtE,qBAAqByB,EAAW0B,GAC5B,MAAMF,EAAY1F,KAAK0F,UAAUxB,GACjC,IAAKwB,EACD,OAEJ,MAAMsB,EAAQtB,EAAUuB,QAAQrB,GAChC5F,KAAK0F,UAAUxB,GAAWgD,OAAOF,EAAO,GAGnChH,KAAK0F,UAAUxB,GAAWoC,QAC3BtG,KAAKkG,qBAAqBlG,KAAK2F,gBAAgBzB,GAEtD,CACD8B,kBAAkBmB,GACd9H,OAAO+H,iBAAiBD,EAAOX,gBAAiBW,EAAOT,SACvDS,EAAOpB,YAAa,CACvB,CACDG,qBAAqBiB,GACZA,IAGL9H,OAAOgI,oBAAoBF,EAAOX,gBAAiBW,EAAOT,SAC1DS,EAAOpB,YAAa,EACvB,sEF/D6B1E,GG7BK,EAACZ,EAAK6G,KACzC,IAAIpH,EACJ,MAAMuF,EAAS6B,EAAU7B,OACnB9E,EAAUF,EAAIE,QACpB,IAAK8E,IAAWA,EAAOjH,KAEnB,MAAM,IAAIkB,MAAM,2KAGpBoC,QAAQC,KAAK,qBAAqB0D,EAAOjH,gEACpCmC,EAAQ8E,EAAOjH,SAAsF,QAA3E0B,EAAKuF,aAAuC,EAASA,EAAO9G,iBAA8B,IAAPuB,OAAgB,EAASA,EAAGqH,SAAS9G,EAAIG,kBAQvJD,EAAQ8E,EAAOjH,MAAQ8I,EAC1B,EHUwCE,CAAwB9G,EAAWW"}
1
+ {"version":3,"file":"capacitor.js","sources":["../build/platforms.js","../build/util.js","../build/runtime.js","../build/global.js","../build/web-plugin.js","../build/core-plugins.js","../build/legacy/legacy-web-plugin-merge.js"],"sourcesContent":["const createCapacitorPlatforms = (win) => {\n const defaultPlatformMap = new Map();\n defaultPlatformMap.set('web', { name: 'web' });\n const capPlatforms = win.CapacitorPlatforms || {\n currentPlatform: { name: 'web' },\n platforms: defaultPlatformMap,\n };\n const addPlatform = (name, platform) => {\n capPlatforms.platforms.set(name, platform);\n };\n const setPlatform = (name) => {\n if (capPlatforms.platforms.has(name)) {\n capPlatforms.currentPlatform = capPlatforms.platforms.get(name);\n }\n };\n capPlatforms.addPlatform = addPlatform;\n capPlatforms.setPlatform = setPlatform;\n return capPlatforms;\n};\nconst initPlatforms = (win) => (win.CapacitorPlatforms = createCapacitorPlatforms(win));\n/**\n * @deprecated Set `CapacitorCustomPlatform` on the window object prior to runtime executing in the web app instead\n */\nexport const CapacitorPlatforms = /*#__PURE__*/ initPlatforms((typeof globalThis !== 'undefined'\n ? globalThis\n : typeof self !== 'undefined'\n ? self\n : typeof window !== 'undefined'\n ? window\n : typeof global !== 'undefined'\n ? global\n : {}));\n/**\n * @deprecated Set `CapacitorCustomPlatform` on the window object prior to runtime executing in the web app instead\n */\nexport const addPlatform = CapacitorPlatforms.addPlatform;\n/**\n * @deprecated Set `CapacitorCustomPlatform` on the window object prior to runtime executing in the web app instead\n */\nexport const setPlatform = CapacitorPlatforms.setPlatform;\n//# sourceMappingURL=platforms.js.map","export var ExceptionCode;\n(function (ExceptionCode) {\n /**\n * API is not implemented.\n *\n * This usually means the API can't be used because it is not implemented for\n * the current platform.\n */\n ExceptionCode[\"Unimplemented\"] = \"UNIMPLEMENTED\";\n /**\n * API is not available.\n *\n * This means the API can't be used right now because:\n * - it is currently missing a prerequisite, such as network connectivity\n * - it requires a particular platform or browser version\n */\n ExceptionCode[\"Unavailable\"] = \"UNAVAILABLE\";\n})(ExceptionCode || (ExceptionCode = {}));\nexport class CapacitorException extends Error {\n constructor(message, code, data) {\n super(message);\n this.message = message;\n this.code = code;\n this.data = data;\n }\n}\nexport const getPlatformId = (win) => {\n var _a, _b;\n if (win === null || win === void 0 ? void 0 : win.androidBridge) {\n return 'android';\n }\n else if ((_b = (_a = win === null || win === void 0 ? void 0 : win.webkit) === null || _a === void 0 ? void 0 : _a.messageHandlers) === null || _b === void 0 ? void 0 : _b.bridge) {\n return 'ios';\n }\n else {\n return 'web';\n }\n};\n//# sourceMappingURL=util.js.map","import { CapacitorException, getPlatformId, ExceptionCode } from './util';\nexport const createCapacitor = (win) => {\n var _a, _b, _c, _d, _e;\n const capCustomPlatform = win.CapacitorCustomPlatform || null;\n const cap = win.Capacitor || {};\n const Plugins = (cap.Plugins = cap.Plugins || {});\n /**\n * @deprecated Use `capCustomPlatform` instead, default functions like registerPlugin will function with the new object.\n */\n const capPlatforms = win.CapacitorPlatforms;\n const defaultGetPlatform = () => {\n return capCustomPlatform !== null\n ? capCustomPlatform.name\n : getPlatformId(win);\n };\n const getPlatform = ((_a = capPlatforms === null || capPlatforms === void 0 ? void 0 : capPlatforms.currentPlatform) === null || _a === void 0 ? void 0 : _a.getPlatform) || defaultGetPlatform;\n const defaultIsNativePlatform = () => getPlatform() !== 'web';\n const isNativePlatform = ((_b = capPlatforms === null || capPlatforms === void 0 ? void 0 : capPlatforms.currentPlatform) === null || _b === void 0 ? void 0 : _b.isNativePlatform) || defaultIsNativePlatform;\n const defaultIsPluginAvailable = (pluginName) => {\n const plugin = registeredPlugins.get(pluginName);\n if (plugin === null || plugin === void 0 ? void 0 : plugin.platforms.has(getPlatform())) {\n // JS implementation available for the current platform.\n return true;\n }\n if (getPluginHeader(pluginName)) {\n // Native implementation available.\n return true;\n }\n return false;\n };\n const isPluginAvailable = ((_c = capPlatforms === null || capPlatforms === void 0 ? void 0 : capPlatforms.currentPlatform) === null || _c === void 0 ? void 0 : _c.isPluginAvailable) ||\n defaultIsPluginAvailable;\n const defaultGetPluginHeader = (pluginName) => { var _a; return (_a = cap.PluginHeaders) === null || _a === void 0 ? void 0 : _a.find(h => h.name === pluginName); };\n const getPluginHeader = ((_d = capPlatforms === null || capPlatforms === void 0 ? void 0 : capPlatforms.currentPlatform) === null || _d === void 0 ? void 0 : _d.getPluginHeader) || defaultGetPluginHeader;\n const handleError = (err) => win.console.error(err);\n const pluginMethodNoop = (_target, prop, pluginName) => {\n return Promise.reject(`${pluginName} does not have an implementation of \"${prop}\".`);\n };\n const registeredPlugins = new Map();\n const defaultRegisterPlugin = (pluginName, jsImplementations = {}) => {\n const registeredPlugin = registeredPlugins.get(pluginName);\n if (registeredPlugin) {\n console.warn(`Capacitor plugin \"${pluginName}\" already registered. Cannot register plugins twice.`);\n return registeredPlugin.proxy;\n }\n const platform = getPlatform();\n const pluginHeader = getPluginHeader(pluginName);\n let jsImplementation;\n const loadPluginImplementation = async () => {\n if (!jsImplementation && platform in jsImplementations) {\n jsImplementation =\n typeof jsImplementations[platform] === 'function'\n ? (jsImplementation = await jsImplementations[platform]())\n : (jsImplementation = jsImplementations[platform]);\n }\n else if (capCustomPlatform !== null &&\n !jsImplementation &&\n 'web' in jsImplementations) {\n jsImplementation =\n typeof jsImplementations['web'] === 'function'\n ? (jsImplementation = await jsImplementations['web']())\n : (jsImplementation = jsImplementations['web']);\n }\n return jsImplementation;\n };\n const createPluginMethod = (impl, prop) => {\n var _a, _b;\n if (pluginHeader) {\n const methodHeader = pluginHeader === null || pluginHeader === void 0 ? void 0 : pluginHeader.methods.find(m => prop === m.name);\n if (methodHeader) {\n if (methodHeader.rtype === 'promise') {\n return (options) => cap.nativePromise(pluginName, prop.toString(), options);\n }\n else {\n return (options, callback) => cap.nativeCallback(pluginName, prop.toString(), options, callback);\n }\n }\n else if (impl) {\n return (_a = impl[prop]) === null || _a === void 0 ? void 0 : _a.bind(impl);\n }\n }\n else if (impl) {\n return (_b = impl[prop]) === null || _b === void 0 ? void 0 : _b.bind(impl);\n }\n else {\n throw new CapacitorException(`\"${pluginName}\" plugin is not implemented on ${platform}`, ExceptionCode.Unimplemented);\n }\n };\n const createPluginMethodWrapper = (prop) => {\n let remove;\n const wrapper = (...args) => {\n const p = loadPluginImplementation().then(impl => {\n const fn = createPluginMethod(impl, prop);\n if (fn) {\n const p = fn(...args);\n remove = p === null || p === void 0 ? void 0 : p.remove;\n return p;\n }\n else {\n throw new CapacitorException(`\"${pluginName}.${prop}()\" is not implemented on ${platform}`, ExceptionCode.Unimplemented);\n }\n });\n if (prop === 'addListener') {\n p.remove = async () => remove();\n }\n return p;\n };\n // Some flair ✨\n wrapper.toString = () => `${prop.toString()}() { [capacitor code] }`;\n Object.defineProperty(wrapper, 'name', {\n value: prop,\n writable: false,\n configurable: false,\n });\n return wrapper;\n };\n const addListener = createPluginMethodWrapper('addListener');\n const removeListener = createPluginMethodWrapper('removeListener');\n const addListenerNative = (eventName, callback) => {\n const call = addListener({ eventName }, callback);\n const remove = async () => {\n const callbackId = await call;\n removeListener({\n eventName,\n callbackId,\n }, callback);\n };\n const p = new Promise(resolve => call.then(() => resolve({ remove })));\n p.remove = async () => {\n console.warn(`Using addListener() without 'await' is deprecated.`);\n await remove();\n };\n return p;\n };\n const proxy = new Proxy({}, {\n get(_, prop) {\n switch (prop) {\n // https://github.com/facebook/react/issues/20030\n case '$$typeof':\n return undefined;\n case 'toJSON':\n return () => ({});\n case 'addListener':\n return pluginHeader ? addListenerNative : addListener;\n case 'removeListener':\n return removeListener;\n default:\n return createPluginMethodWrapper(prop);\n }\n },\n });\n Plugins[pluginName] = proxy;\n registeredPlugins.set(pluginName, {\n name: pluginName,\n proxy,\n platforms: new Set([\n ...Object.keys(jsImplementations),\n ...(pluginHeader ? [platform] : []),\n ]),\n });\n return proxy;\n };\n const registerPlugin = ((_e = capPlatforms === null || capPlatforms === void 0 ? void 0 : capPlatforms.currentPlatform) === null || _e === void 0 ? void 0 : _e.registerPlugin) || defaultRegisterPlugin;\n // Add in convertFileSrc for web, it will already be available in native context\n if (!cap.convertFileSrc) {\n cap.convertFileSrc = filePath => filePath;\n }\n cap.getPlatform = getPlatform;\n cap.handleError = handleError;\n cap.isNativePlatform = isNativePlatform;\n cap.isPluginAvailable = isPluginAvailable;\n cap.pluginMethodNoop = pluginMethodNoop;\n cap.registerPlugin = registerPlugin;\n cap.Exception = CapacitorException;\n cap.DEBUG = !!cap.DEBUG;\n cap.isLoggingEnabled = !!cap.isLoggingEnabled;\n // Deprecated props\n cap.platform = cap.getPlatform();\n cap.isNative = cap.isNativePlatform();\n return cap;\n};\nexport const initCapacitorGlobal = (win) => (win.Capacitor = createCapacitor(win));\n//# sourceMappingURL=runtime.js.map","import { legacyRegisterWebPlugin } from './legacy/legacy-web-plugin-merge';\nimport { initCapacitorGlobal } from './runtime';\nexport const Capacitor = /*#__PURE__*/ initCapacitorGlobal(typeof globalThis !== 'undefined'\n ? globalThis\n : typeof self !== 'undefined'\n ? self\n : typeof window !== 'undefined'\n ? window\n : typeof global !== 'undefined'\n ? global\n : {});\nexport const registerPlugin = Capacitor.registerPlugin;\n/**\n * @deprecated Provided for backwards compatibility for Capacitor v2 plugins.\n * Capacitor v3 plugins should import the plugin directly. This \"Plugins\"\n * export is deprecated in v3, and will be removed in v4.\n */\nexport const Plugins = Capacitor.Plugins;\n/**\n * Provided for backwards compatibility. Use the registerPlugin() API\n * instead, and provide the web plugin as the \"web\" implmenetation.\n * For example\n *\n * export const Example = registerPlugin('Example', {\n * web: () => import('./web').then(m => new m.Example())\n * })\n *\n * @deprecated Deprecated in v3, will be removed from v4.\n */\nexport const registerWebPlugin = (plugin) => legacyRegisterWebPlugin(Capacitor, plugin);\n//# sourceMappingURL=global.js.map","import { Capacitor } from './global';\nimport { ExceptionCode } from './util';\n/**\n * Base class web plugins should extend.\n */\nexport class WebPlugin {\n constructor(config) {\n this.listeners = {};\n this.windowListeners = {};\n if (config) {\n // TODO: add link to upgrade guide\n console.warn(`Capacitor WebPlugin \"${config.name}\" config object was deprecated in v3 and will be removed in v4.`);\n this.config = config;\n }\n }\n addListener(eventName, listenerFunc) {\n const listeners = this.listeners[eventName];\n if (!listeners) {\n this.listeners[eventName] = [];\n }\n this.listeners[eventName].push(listenerFunc);\n // If we haven't added a window listener for this event and it requires one,\n // go ahead and add it\n const windowListener = this.windowListeners[eventName];\n if (windowListener && !windowListener.registered) {\n this.addWindowListener(windowListener);\n }\n const remove = async () => this.removeListener(eventName, listenerFunc);\n const p = Promise.resolve({ remove });\n Object.defineProperty(p, 'remove', {\n value: async () => {\n console.warn(`Using addListener() without 'await' is deprecated.`);\n await remove();\n },\n });\n return p;\n }\n async removeAllListeners() {\n this.listeners = {};\n for (const listener in this.windowListeners) {\n this.removeWindowListener(this.windowListeners[listener]);\n }\n this.windowListeners = {};\n }\n notifyListeners(eventName, data) {\n const listeners = this.listeners[eventName];\n if (listeners) {\n listeners.forEach(listener => listener(data));\n }\n }\n hasListeners(eventName) {\n return !!this.listeners[eventName].length;\n }\n registerWindowListener(windowEventName, pluginEventName) {\n this.windowListeners[pluginEventName] = {\n registered: false,\n windowEventName,\n pluginEventName,\n handler: event => {\n this.notifyListeners(pluginEventName, event);\n },\n };\n }\n unimplemented(msg = 'not implemented') {\n return new Capacitor.Exception(msg, ExceptionCode.Unimplemented);\n }\n unavailable(msg = 'not available') {\n return new Capacitor.Exception(msg, ExceptionCode.Unavailable);\n }\n async removeListener(eventName, listenerFunc) {\n const listeners = this.listeners[eventName];\n if (!listeners) {\n return;\n }\n const index = listeners.indexOf(listenerFunc);\n this.listeners[eventName].splice(index, 1);\n // If there are no more listeners for this type of event,\n // remove the window listener\n if (!this.listeners[eventName].length) {\n this.removeWindowListener(this.windowListeners[eventName]);\n }\n }\n addWindowListener(handle) {\n window.addEventListener(handle.windowEventName, handle.handler);\n handle.registered = true;\n }\n removeWindowListener(handle) {\n if (!handle) {\n return;\n }\n window.removeEventListener(handle.windowEventName, handle.handler);\n handle.registered = false;\n }\n}\n//# sourceMappingURL=web-plugin.js.map","import { registerPlugin } from './global';\nimport { WebPlugin } from './web-plugin';\nexport const WebView = /*#__PURE__*/ registerPlugin('WebView');\n/******** END WEB VIEW PLUGIN ********/\n/******** COOKIES PLUGIN ********/\n/**\n * Safely web encode a string value (inspired by js-cookie)\n * @param str The string value to encode\n */\nconst encode = (str) => encodeURIComponent(str)\n .replace(/%(2[346B]|5E|60|7C)/g, decodeURIComponent)\n .replace(/[()]/g, escape);\nexport class CapacitorCookiesPluginWeb extends WebPlugin {\n async setCookie(options) {\n try {\n // Safely Encoded Key/Value\n const encodedKey = encode(options.key);\n const encodedValue = encode(options.value);\n // Clean & sanitize options\n const expires = `; expires=${(options.expires || '').replace('expires=', '')}`; // Default is \"; expires=\"\n const path = (options.path || '/').replace('path=', ''); // Default is \"path=/\"\n document.cookie = `${encodedKey}=${encodedValue || ''}${expires}; path=${path}`;\n }\n catch (error) {\n return Promise.reject(error);\n }\n }\n async deleteCookie(options) {\n try {\n document.cookie = `${options.key}=; Max-Age=0`;\n }\n catch (error) {\n return Promise.reject(error);\n }\n }\n async clearCookies() {\n try {\n const cookies = document.cookie.split(';') || [];\n for (const cookie of cookies) {\n document.cookie = cookie\n .replace(/^ +/, '')\n .replace(/=.*/, `=;expires=${new Date().toUTCString()};path=/`);\n }\n }\n catch (error) {\n return Promise.reject(error);\n }\n }\n async clearAllCookies() {\n try {\n await this.clearCookies();\n }\n catch (error) {\n return Promise.reject(error);\n }\n }\n}\nexport const CapacitorCookies = registerPlugin('CapacitorCookies', {\n web: () => new CapacitorCookiesPluginWeb(),\n});\n// UTILITY FUNCTIONS\n/**\n * Read in a Blob value and return it as a base64 string\n * @param blob The blob value to convert to a base64 string\n */\nexport const readBlobAsBase64 = async (blob) => new Promise((resolve, reject) => {\n const reader = new FileReader();\n reader.onload = () => {\n const base64String = reader.result;\n // remove prefix \"data:application/pdf;base64,\"\n resolve(base64String.indexOf(',') >= 0\n ? base64String.split(',')[1]\n : base64String);\n };\n reader.onerror = (error) => reject(error);\n reader.readAsDataURL(blob);\n});\n/**\n * Normalize an HttpHeaders map by lowercasing all of the values\n * @param headers The HttpHeaders object to normalize\n */\nconst normalizeHttpHeaders = (headers = {}) => {\n const originalKeys = Object.keys(headers);\n const loweredKeys = Object.keys(headers).map(k => k.toLocaleLowerCase());\n const normalized = loweredKeys.reduce((acc, key, index) => {\n acc[key] = headers[originalKeys[index]];\n return acc;\n }, {});\n return normalized;\n};\n/**\n * Builds a string of url parameters that\n * @param params A map of url parameters\n * @param shouldEncode true if you should encodeURIComponent() the values (true by default)\n */\nconst buildUrlParams = (params, shouldEncode = true) => {\n if (!params)\n return null;\n const output = Object.entries(params).reduce((accumulator, entry) => {\n const [key, value] = entry;\n let encodedValue;\n let item;\n if (Array.isArray(value)) {\n item = '';\n value.forEach(str => {\n encodedValue = shouldEncode ? encodeURIComponent(str) : str;\n item += `${key}=${encodedValue}&`;\n });\n // last character will always be \"&\" so slice it off\n item.slice(0, -1);\n }\n else {\n encodedValue = shouldEncode ? encodeURIComponent(value) : value;\n item = `${key}=${encodedValue}`;\n }\n return `${accumulator}&${item}`;\n }, '');\n // Remove initial \"&\" from the reduce\n return output.substr(1);\n};\n/**\n * Build the RequestInit object based on the options passed into the initial request\n * @param options The Http plugin options\n * @param extra Any extra RequestInit values\n */\nexport const buildRequestInit = (options, extra = {}) => {\n const output = Object.assign({ method: options.method || 'GET', headers: options.headers }, extra);\n // Get the content-type\n const headers = normalizeHttpHeaders(options.headers);\n const type = headers['content-type'] || '';\n // If body is already a string, then pass it through as-is.\n if (typeof options.data === 'string') {\n output.body = options.data;\n }\n // Build request initializers based off of content-type\n else if (type.includes('application/x-www-form-urlencoded')) {\n const params = new URLSearchParams();\n for (const [key, value] of Object.entries(options.data || {})) {\n params.set(key, value);\n }\n output.body = params.toString();\n }\n else if (type.includes('multipart/form-data')) {\n const form = new FormData();\n if (options.data instanceof FormData) {\n options.data.forEach((value, key) => {\n form.append(key, value);\n });\n }\n else {\n for (const key of Object.keys(options.data)) {\n form.append(key, options.data[key]);\n }\n }\n output.body = form;\n const headers = new Headers(output.headers);\n headers.delete('content-type'); // content-type will be set by `window.fetch` to includy boundary\n output.headers = headers;\n }\n else if (type.includes('application/json') ||\n typeof options.data === 'object') {\n output.body = JSON.stringify(options.data);\n }\n return output;\n};\n// WEB IMPLEMENTATION\nexport class CapacitorHttpPluginWeb extends WebPlugin {\n /**\n * Perform an Http request given a set of options\n * @param options Options to build the HTTP request\n */\n async request(options) {\n const requestInit = buildRequestInit(options, options.webFetchExtra);\n const urlParams = buildUrlParams(options.params, options.shouldEncodeUrlParams);\n const url = urlParams ? `${options.url}?${urlParams}` : options.url;\n const response = await fetch(url, requestInit);\n const contentType = response.headers.get('content-type') || '';\n // Default to 'text' responseType so no parsing happens\n let { responseType = 'text' } = response.ok ? options : {};\n // If the response content-type is json, force the response to be json\n if (contentType.includes('application/json')) {\n responseType = 'json';\n }\n let data;\n let blob;\n switch (responseType) {\n case 'arraybuffer':\n case 'blob':\n blob = await response.blob();\n data = await readBlobAsBase64(blob);\n break;\n case 'json':\n data = await response.json();\n break;\n case 'document':\n case 'text':\n default:\n data = await response.text();\n }\n // Convert fetch headers to Capacitor HttpHeaders\n const headers = {};\n response.headers.forEach((value, key) => {\n headers[key] = value;\n });\n return {\n data,\n headers,\n status: response.status,\n url: response.url,\n };\n }\n /**\n * Perform an Http GET request given a set of options\n * @param options Options to build the HTTP request\n */\n async get(options) {\n return this.request(Object.assign(Object.assign({}, options), { method: 'GET' }));\n }\n /**\n * Perform an Http POST request given a set of options\n * @param options Options to build the HTTP request\n */\n async post(options) {\n return this.request(Object.assign(Object.assign({}, options), { method: 'POST' }));\n }\n /**\n * Perform an Http PUT request given a set of options\n * @param options Options to build the HTTP request\n */\n async put(options) {\n return this.request(Object.assign(Object.assign({}, options), { method: 'PUT' }));\n }\n /**\n * Perform an Http PATCH request given a set of options\n * @param options Options to build the HTTP request\n */\n async patch(options) {\n return this.request(Object.assign(Object.assign({}, options), { method: 'PATCH' }));\n }\n /**\n * Perform an Http DELETE request given a set of options\n * @param options Options to build the HTTP request\n */\n async delete(options) {\n return this.request(Object.assign(Object.assign({}, options), { method: 'DELETE' }));\n }\n}\nexport const CapacitorHttp = registerPlugin('CapacitorHttp', {\n web: () => new CapacitorHttpPluginWeb(),\n});\n/******** END HTTP PLUGIN ********/\n//# sourceMappingURL=core-plugins.js.map","export const legacyRegisterWebPlugin = (cap, webPlugin) => {\n var _a;\n const config = webPlugin.config;\n const Plugins = cap.Plugins;\n if (!config || !config.name) {\n // TODO: add link to upgrade guide\n throw new Error(`Capacitor WebPlugin is using the deprecated \"registerWebPlugin()\" function, but without the config. Please use \"registerPlugin()\" instead to register this web plugin.\"`);\n }\n // TODO: add link to upgrade guide\n console.warn(`Capacitor plugin \"${config.name}\" is using the deprecated \"registerWebPlugin()\" function`);\n if (!Plugins[config.name] || ((_a = config === null || config === void 0 ? void 0 : config.platforms) === null || _a === void 0 ? void 0 : _a.includes(cap.getPlatform()))) {\n // Add the web plugin into the plugins registry if there already isn't\n // an existing one. If it doesn't already exist, that means\n // there's no existing native implementation for it.\n // - OR -\n // If we already have a plugin registered (meaning it was defined in the native layer),\n // then we should only overwrite it if the corresponding web plugin activates on\n // a certain platform. For example: Geolocation uses the WebPlugin on Android but not iOS\n Plugins[config.name] = webPlugin;\n }\n};\n//# sourceMappingURL=legacy-web-plugin-merge.js.map"],"names":["CapacitorPlatforms","win","defaultPlatformMap","Map","set","name","capPlatforms","currentPlatform","platforms","addPlatform","platform","setPlatform","has","get","createCapacitorPlatforms","initPlatforms","globalThis","self","window","global","ExceptionCode","exports","CapacitorException","Error","constructor","message","code","data","super","this","createCapacitor","_a","_b","_c","_d","_e","capCustomPlatform","CapacitorCustomPlatform","cap","Capacitor","Plugins","getPlatform","androidBridge","webkit","messageHandlers","bridge","getPlatformId","isNativePlatform","isPluginAvailable","pluginName","plugin","registeredPlugins","getPluginHeader","PluginHeaders","find","h","registerPlugin","jsImplementations","registeredPlugin","console","warn","proxy","pluginHeader","jsImplementation","createPluginMethodWrapper","prop","remove","wrapper","args","p","async","loadPluginImplementation","then","impl","fn","bind","Unimplemented","methodHeader","methods","m","rtype","options","nativePromise","toString","callback","nativeCallback","createPluginMethod","Object","defineProperty","value","writable","configurable","addListener","removeListener","addListenerNative","eventName","call","callbackId","Promise","resolve","Proxy","_","Set","keys","convertFileSrc","filePath","handleError","err","error","pluginMethodNoop","_target","reject","Exception","DEBUG","isLoggingEnabled","isNative","initCapacitorGlobal","WebPlugin","config","listeners","windowListeners","listenerFunc","push","windowListener","registered","addWindowListener","listener","removeWindowListener","notifyListeners","forEach","hasListeners","length","registerWindowListener","windowEventName","pluginEventName","handler","event","unimplemented","msg","unavailable","Unavailable","index","indexOf","splice","handle","addEventListener","removeEventListener","WebView","encode","str","encodeURIComponent","replace","decodeURIComponent","escape","CapacitorCookiesPluginWeb","encodedKey","key","encodedValue","expires","path","document","cookie","cookies","split","Date","toUTCString","clearCookies","CapacitorCookies","web","buildRequestInit","extra","output","assign","method","headers","type","originalKeys","map","k","toLocaleLowerCase","reduce","acc","normalizeHttpHeaders","body","includes","params","URLSearchParams","entries","form","FormData","append","Headers","delete","JSON","stringify","CapacitorHttpPluginWeb","requestInit","webFetchExtra","urlParams","shouldEncode","accumulator","entry","item","Array","isArray","slice","substr","buildUrlParams","shouldEncodeUrlParams","url","response","fetch","contentType","blob","responseType","ok","reader","FileReader","onload","base64String","result","onerror","readAsDataURL","readBlobAsBase64","json","text","status","request","CapacitorHttp","webPlugin","legacyRegisterWebPlugin"],"mappings":"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"}
package/dist/index.cjs.js CHANGED
@@ -410,9 +410,259 @@ class WebPlugin {
410
410
  }
411
411
 
412
412
  const WebView = /*#__PURE__*/ registerPlugin('WebView');
413
+ /******** END WEB VIEW PLUGIN ********/
414
+ /******** COOKIES PLUGIN ********/
415
+ /**
416
+ * Safely web encode a string value (inspired by js-cookie)
417
+ * @param str The string value to encode
418
+ */
419
+ const encode = (str) => encodeURIComponent(str)
420
+ .replace(/%(2[346B]|5E|60|7C)/g, decodeURIComponent)
421
+ .replace(/[()]/g, escape);
422
+ class CapacitorCookiesPluginWeb extends WebPlugin {
423
+ async setCookie(options) {
424
+ try {
425
+ // Safely Encoded Key/Value
426
+ const encodedKey = encode(options.key);
427
+ const encodedValue = encode(options.value);
428
+ // Clean & sanitize options
429
+ const expires = `; expires=${(options.expires || '').replace('expires=', '')}`; // Default is "; expires="
430
+ const path = (options.path || '/').replace('path=', ''); // Default is "path=/"
431
+ document.cookie = `${encodedKey}=${encodedValue || ''}${expires}; path=${path}`;
432
+ }
433
+ catch (error) {
434
+ return Promise.reject(error);
435
+ }
436
+ }
437
+ async deleteCookie(options) {
438
+ try {
439
+ document.cookie = `${options.key}=; Max-Age=0`;
440
+ }
441
+ catch (error) {
442
+ return Promise.reject(error);
443
+ }
444
+ }
445
+ async clearCookies() {
446
+ try {
447
+ const cookies = document.cookie.split(';') || [];
448
+ for (const cookie of cookies) {
449
+ document.cookie = cookie
450
+ .replace(/^ +/, '')
451
+ .replace(/=.*/, `=;expires=${new Date().toUTCString()};path=/`);
452
+ }
453
+ }
454
+ catch (error) {
455
+ return Promise.reject(error);
456
+ }
457
+ }
458
+ async clearAllCookies() {
459
+ try {
460
+ await this.clearCookies();
461
+ }
462
+ catch (error) {
463
+ return Promise.reject(error);
464
+ }
465
+ }
466
+ }
467
+ const CapacitorCookies = registerPlugin('CapacitorCookies', {
468
+ web: () => new CapacitorCookiesPluginWeb(),
469
+ });
470
+ // UTILITY FUNCTIONS
471
+ /**
472
+ * Read in a Blob value and return it as a base64 string
473
+ * @param blob The blob value to convert to a base64 string
474
+ */
475
+ const readBlobAsBase64 = async (blob) => new Promise((resolve, reject) => {
476
+ const reader = new FileReader();
477
+ reader.onload = () => {
478
+ const base64String = reader.result;
479
+ // remove prefix "data:application/pdf;base64,"
480
+ resolve(base64String.indexOf(',') >= 0
481
+ ? base64String.split(',')[1]
482
+ : base64String);
483
+ };
484
+ reader.onerror = (error) => reject(error);
485
+ reader.readAsDataURL(blob);
486
+ });
487
+ /**
488
+ * Normalize an HttpHeaders map by lowercasing all of the values
489
+ * @param headers The HttpHeaders object to normalize
490
+ */
491
+ const normalizeHttpHeaders = (headers = {}) => {
492
+ const originalKeys = Object.keys(headers);
493
+ const loweredKeys = Object.keys(headers).map(k => k.toLocaleLowerCase());
494
+ const normalized = loweredKeys.reduce((acc, key, index) => {
495
+ acc[key] = headers[originalKeys[index]];
496
+ return acc;
497
+ }, {});
498
+ return normalized;
499
+ };
500
+ /**
501
+ * Builds a string of url parameters that
502
+ * @param params A map of url parameters
503
+ * @param shouldEncode true if you should encodeURIComponent() the values (true by default)
504
+ */
505
+ const buildUrlParams = (params, shouldEncode = true) => {
506
+ if (!params)
507
+ return null;
508
+ const output = Object.entries(params).reduce((accumulator, entry) => {
509
+ const [key, value] = entry;
510
+ let encodedValue;
511
+ let item;
512
+ if (Array.isArray(value)) {
513
+ item = '';
514
+ value.forEach(str => {
515
+ encodedValue = shouldEncode ? encodeURIComponent(str) : str;
516
+ item += `${key}=${encodedValue}&`;
517
+ });
518
+ // last character will always be "&" so slice it off
519
+ item.slice(0, -1);
520
+ }
521
+ else {
522
+ encodedValue = shouldEncode ? encodeURIComponent(value) : value;
523
+ item = `${key}=${encodedValue}`;
524
+ }
525
+ return `${accumulator}&${item}`;
526
+ }, '');
527
+ // Remove initial "&" from the reduce
528
+ return output.substr(1);
529
+ };
530
+ /**
531
+ * Build the RequestInit object based on the options passed into the initial request
532
+ * @param options The Http plugin options
533
+ * @param extra Any extra RequestInit values
534
+ */
535
+ const buildRequestInit = (options, extra = {}) => {
536
+ const output = Object.assign({ method: options.method || 'GET', headers: options.headers }, extra);
537
+ // Get the content-type
538
+ const headers = normalizeHttpHeaders(options.headers);
539
+ const type = headers['content-type'] || '';
540
+ // If body is already a string, then pass it through as-is.
541
+ if (typeof options.data === 'string') {
542
+ output.body = options.data;
543
+ }
544
+ // Build request initializers based off of content-type
545
+ else if (type.includes('application/x-www-form-urlencoded')) {
546
+ const params = new URLSearchParams();
547
+ for (const [key, value] of Object.entries(options.data || {})) {
548
+ params.set(key, value);
549
+ }
550
+ output.body = params.toString();
551
+ }
552
+ else if (type.includes('multipart/form-data')) {
553
+ const form = new FormData();
554
+ if (options.data instanceof FormData) {
555
+ options.data.forEach((value, key) => {
556
+ form.append(key, value);
557
+ });
558
+ }
559
+ else {
560
+ for (const key of Object.keys(options.data)) {
561
+ form.append(key, options.data[key]);
562
+ }
563
+ }
564
+ output.body = form;
565
+ const headers = new Headers(output.headers);
566
+ headers.delete('content-type'); // content-type will be set by `window.fetch` to includy boundary
567
+ output.headers = headers;
568
+ }
569
+ else if (type.includes('application/json') ||
570
+ typeof options.data === 'object') {
571
+ output.body = JSON.stringify(options.data);
572
+ }
573
+ return output;
574
+ };
575
+ // WEB IMPLEMENTATION
576
+ class CapacitorHttpPluginWeb extends WebPlugin {
577
+ /**
578
+ * Perform an Http request given a set of options
579
+ * @param options Options to build the HTTP request
580
+ */
581
+ async request(options) {
582
+ const requestInit = buildRequestInit(options, options.webFetchExtra);
583
+ const urlParams = buildUrlParams(options.params, options.shouldEncodeUrlParams);
584
+ const url = urlParams ? `${options.url}?${urlParams}` : options.url;
585
+ const response = await fetch(url, requestInit);
586
+ const contentType = response.headers.get('content-type') || '';
587
+ // Default to 'text' responseType so no parsing happens
588
+ let { responseType = 'text' } = response.ok ? options : {};
589
+ // If the response content-type is json, force the response to be json
590
+ if (contentType.includes('application/json')) {
591
+ responseType = 'json';
592
+ }
593
+ let data;
594
+ let blob;
595
+ switch (responseType) {
596
+ case 'arraybuffer':
597
+ case 'blob':
598
+ blob = await response.blob();
599
+ data = await readBlobAsBase64(blob);
600
+ break;
601
+ case 'json':
602
+ data = await response.json();
603
+ break;
604
+ case 'document':
605
+ case 'text':
606
+ default:
607
+ data = await response.text();
608
+ }
609
+ // Convert fetch headers to Capacitor HttpHeaders
610
+ const headers = {};
611
+ response.headers.forEach((value, key) => {
612
+ headers[key] = value;
613
+ });
614
+ return {
615
+ data,
616
+ headers,
617
+ status: response.status,
618
+ url: response.url,
619
+ };
620
+ }
621
+ /**
622
+ * Perform an Http GET request given a set of options
623
+ * @param options Options to build the HTTP request
624
+ */
625
+ async get(options) {
626
+ return this.request(Object.assign(Object.assign({}, options), { method: 'GET' }));
627
+ }
628
+ /**
629
+ * Perform an Http POST request given a set of options
630
+ * @param options Options to build the HTTP request
631
+ */
632
+ async post(options) {
633
+ return this.request(Object.assign(Object.assign({}, options), { method: 'POST' }));
634
+ }
635
+ /**
636
+ * Perform an Http PUT request given a set of options
637
+ * @param options Options to build the HTTP request
638
+ */
639
+ async put(options) {
640
+ return this.request(Object.assign(Object.assign({}, options), { method: 'PUT' }));
641
+ }
642
+ /**
643
+ * Perform an Http PATCH request given a set of options
644
+ * @param options Options to build the HTTP request
645
+ */
646
+ async patch(options) {
647
+ return this.request(Object.assign(Object.assign({}, options), { method: 'PATCH' }));
648
+ }
649
+ /**
650
+ * Perform an Http DELETE request given a set of options
651
+ * @param options Options to build the HTTP request
652
+ */
653
+ async delete(options) {
654
+ return this.request(Object.assign(Object.assign({}, options), { method: 'DELETE' }));
655
+ }
656
+ }
657
+ const CapacitorHttp = registerPlugin('CapacitorHttp', {
658
+ web: () => new CapacitorHttpPluginWeb(),
659
+ });
660
+ /******** END HTTP PLUGIN ********/
413
661
 
414
662
  exports.Capacitor = Capacitor;
663
+ exports.CapacitorCookies = CapacitorCookies;
415
664
  exports.CapacitorException = CapacitorException;
665
+ exports.CapacitorHttp = CapacitorHttp;
416
666
  exports.CapacitorPlatforms = CapacitorPlatforms;
417
667
  exports.Plugins = Plugins;
418
668
  exports.WebPlugin = WebPlugin;