@lvble/core 2.0.18 → 2.0.20
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/_bundles/core.js +1 -1
- package/dist/_bundles/core.js.map +1 -1
- package/dist/_bundles/core.min.js +1 -1
- package/dist/_bundles/core.min.js.map +1 -1
- package/dist/lib/lvble.d.ts.map +1 -1
- package/dist/lib/lvble.js +92 -131
- package/dist/lib/lvble.js.map +1 -1
- package/dist/lib-esm/lvble.d.ts.map +1 -1
- package/dist/lib-esm/lvble.js +93 -132
- package/dist/lib-esm/lvble.js.map +1 -1
- package/package.json +1 -1
package/dist/_bundles/core.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define("MyLib",[],t):"object"==typeof exports?exports.MyLib=t():e.MyLib=t()}(self,(()=>(()=>{"use strict";var e={915:function(e,t,n){var o=this&&this.__createBinding||(Object.create?function(e,t,n,o){void 0===o&&(o=n);var i=Object.getOwnPropertyDescriptor(t,n);i&&!("get"in i?!t.__esModule:i.writable||i.configurable)||(i={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,o,i)}:function(e,t,n,o){void 0===o&&(o=n),e[o]=t[n]}),i=this&&this.__exportStar||function(e,t){for(var n in e)"default"===n||Object.prototype.hasOwnProperty.call(t,n)||o(t,e,n)};Object.defineProperty(t,"__esModule",{value:!0}),i(n(755),t)},755:
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define("MyLib",[],t):"object"==typeof exports?exports.MyLib=t():e.MyLib=t()}(self,(()=>(()=>{"use strict";var e={915:function(e,t,n){var o=this&&this.__createBinding||(Object.create?function(e,t,n,o){void 0===o&&(o=n);var i=Object.getOwnPropertyDescriptor(t,n);i&&!("get"in i?!t.__esModule:i.writable||i.configurable)||(i={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,o,i)}:function(e,t,n,o){void 0===o&&(o=n),e[o]=t[n]}),i=this&&this.__exportStar||function(e,t){for(var n in e)"default"===n||Object.prototype.hasOwnProperty.call(t,n)||o(t,e,n)};Object.defineProperty(t,"__esModule",{value:!0}),i(n(755),t)},755:(e,t)=>{var n;Object.defineProperty(t,"__esModule",{value:!0}),t.Lvble=t.Environment=void 0,function(e){e.Local="local",e.Sandbox="sandbox",e.Production="production"}(n||(t.Environment=n={}));const o={[n.Local]:"http://localhost:3001",[n.Sandbox]:"https://widget.sandbox.pms.nowlvble.com",[n.Production]:"https://api.production.partners.nowlvble.com"},i={[n.Local]:"http://localhost:3001",[n.Sandbox]:"https://experience.sandbox.pms.nowlvble.com",[n.Production]:"https://api.production.partners.nowlvble.com"};var r;!function(e){e.FinishOnboarding="finishOnboarding",e.FinishOffboarding="finishOffboarding",e.FinishSplit="finishSplit",e.FinishRepay="finishRepay"}(r||(r={})),r.FinishOnboarding,r.FinishOffboarding,r.FinishSplit,r.FinishRepay;class s extends HTMLElement{constructor(){super(),Object.defineProperty(this,"_typeToEvent",{enumerable:!0,configurable:!0,writable:!0,value:{onboarding:r.FinishOnboarding,offboarding:r.FinishOffboarding,split:r.FinishSplit,repay:r.FinishRepay}}),Object.defineProperty(this,"_iframe",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.attachShadow({mode:"open"})}get mode(){return this.getAttribute("mode")}set mode(e){e?this.setAttribute("mode",e):this.removeAttribute("mode")}get environment(){return this.getAttribute("environment")}set environment(e){e?this.setAttribute("environment",e):this.removeAttribute("environment")}get token(){return this.getAttribute("token")}set token(e){e?this.setAttribute("token",e):this.removeAttribute("token")}connectedCallback(){var e;const t=`${o[this.environment]}?token=${this.token}&environment=${this.environment}`,n=document.createElement("iframe");n.src=t,n.width="100%",n.height="100%",n.style.borderStyle="solid",n.style.borderRadius="10px",n.style.borderColor="transparent",this._iframe=n,null===(e=this.shadowRoot)||void 0===e||e.appendChild(n)}disconnectedCallback(){this.shadowRoot&&(this.shadowRoot.innerHTML="")}}let d;customElements.define("lvble-widget",s),customElements.get("lvble-widget"),customElements.get("lvble-widget"),t.Lvble=e=>({createWidget:t=>{const n=new s;return n.environment=e.environment,n.token=e.token,n.mode=t.mode,window.addEventListener("message",(n=>{if(n.origin!=o[e.environment])return void console.debug(`Received message from unknown origin: ${n.origin}`);const i=n.data;t.onEvent(i.eventType,i)})),n},open:t=>{const n={onboarding:`${i[e.environment]}?token=${e.token}`,offboarding:`${i[e.environment]}?token=${e.token}`,split:`${i[e.environment]}?token=${e.token}`,repay:`${i[e.environment]}?token=${e.token}`},o=t.mode?n[t.mode]:`${i[e.environment]}?token=${e.token}`,r=screen.width/2-225,s=screen.height/2-400;d=window.open(o,"LvblePopup","width=450,height=800,location=no,left="+r+",top="+s),window.addEventListener("message",(n=>{if(n.origin!=i[e.environment])return void console.debug(`Received message from unknown origin: ${n.origin}`);const o=n.data,r=document.querySelectorAll("lvble-widget");n=JSON.parse(JSON.stringify(n)),r.forEach((e=>{var t,o;null===(o=(null===(t=e.shadowRoot)||void 0===t?void 0:t.querySelector("iframe")).contentWindow)||void 0===o||o.postMessage(n,"*")})),t.onEvent(o.eventType,o)}))}})}},t={};return function n(o){var i=t[o];if(void 0!==i)return i.exports;var r=t[o]={exports:{}};return e[o].call(r.exports,r,r.exports,n),r.exports}(915)})()));
|
|
2
2
|
//# sourceMappingURL=core.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"core.js","mappings":"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","sources":["webpack://MyLib/webpack/universalModuleDefinition","webpack://MyLib/./src/lib/index.ts","webpack://MyLib/./src/lib/lvble.ts","webpack://MyLib/webpack/bootstrap","webpack://MyLib/webpack/startup"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"MyLib\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"MyLib\"] = factory();\n\telse\n\t\troot[\"MyLib\"] = factory();\n})(self, () => {\nreturn ","export * from './lvble'\n","export enum Environment {\n Local = \"local\",\n Sandbox = \"sandbox\",\n Production = \"production\",\n}\nconst envToBaseUrlMapWidget: Record<Environment, string> = {\n [Environment.Local]: \"http://localhost:3001\",\n [Environment.Sandbox]: \"https://widget.sandbox.pms.nowlvble.com\",\n [Environment.Production]: \"https://api.production.partners.nowlvble.com\",\n};\n\nconst envToBaseUrlMapExperience: Record<Environment, string> = {\n [Environment.Local]: \"http://localhost:3001\",\n [Environment.Sandbox]: \"https://experience.sandbox.pms.nowlvble.com\",\n [Environment.Production]: \"https://api.production.partners.nowlvble.com\",\n};\n\nexport type Mode = \"onboarding\" | \"offboarding\" | \"split\" | \"repay\";\nexport type ErrorData = {\n type: \"error\";\n reason: string;\n};\nexport type OnboardingData =\n | ErrorData\n | {\n type: \"success\";\n status: string;\n };\nexport type SplitData =\n | ErrorData\n | {\n type: \"success\";\n external_id: string;\n settlement_id: string;\n amount: number;\n };\nexport type CloseData =\n | ErrorData\n | {\n type: \"close\";\n };\n// TODO: Make this the event type in the onEvent callback signature\nexport type EventData = OnboardingData | SplitData | CloseData;\n\nenum EventType {\n FinishOnboarding = \"finishOnboarding\",\n FinishOffboarding = \"finishOffboarding\",\n FinishSplit = \"finishSplit\",\n FinishRepay = \"finishRepay\",\n}\n\nconst modeToEventType = {\n onboarding: EventType.FinishOnboarding,\n offboarding: EventType.FinishOffboarding,\n split: EventType.FinishSplit,\n repay: EventType.FinishRepay,\n};\n\nexport interface InitOptions {\n // The environment to use.\n environment: Environment;\n // The widget token to use.\n token: string;\n}\n\nexport interface OpenOptions {\n // The mode to open the popup in. See Mode for more information.\n mode?: Mode;\n // The callback to invoke when the popup has sent an event (e.g. user clicked a button).\n onEvent: (eventType: string, data: any) => void;\n}\n\nexport interface CreateWidgetOptions extends OpenOptions {\n mode?: Extract<Mode, \"onboarding\" | \"repay\">;\n // The callback to invoke when the popup has sent an event (e.g. user clicked a button).\n onEvent: (eventType: string, data: any) => void;\n}\n\nclass LvbleWidget extends HTMLElement {\n _typeToEvent = {\n onboarding: EventType.FinishOnboarding,\n offboarding: EventType.FinishOffboarding,\n split: EventType.FinishSplit,\n repay: EventType.FinishRepay,\n };\n _iframe?: HTMLIFrameElement;\n\n constructor() {\n super();\n this.attachShadow({ mode: \"open\" });\n }\n\n get mode(): Mode {\n return this.getAttribute(\"mode\") as Mode;\n }\n\n set mode(val: Mode | undefined) {\n if (val) {\n this.setAttribute(\"mode\", val);\n } else {\n this.removeAttribute(\"mode\");\n }\n }\n\n get environment(): Environment {\n return this.getAttribute(\"environment\") as Environment;\n }\n\n set environment(val) {\n if (val) {\n this.setAttribute(\"environment\", val);\n } else {\n this.removeAttribute(\"environment\");\n }\n }\n\n get token() {\n return this.getAttribute(\"token\") as string;\n }\n\n set token(val: string) {\n if (val) {\n this.setAttribute(\"token\", val);\n } else {\n this.removeAttribute(\"token\");\n }\n }\n\n connectedCallback() {\n const iframeSrc = `${envToBaseUrlMapWidget[this.environment]}?token=${\n this.token\n }&environment=${this.environment}`;\n\n const iframe = document.createElement(\"iframe\");\n iframe.src = iframeSrc;\n iframe.width = `100%`;\n iframe.height = `100%`;\n iframe.style.borderStyle = \"solid\";\n iframe.style.borderRadius = \"10px\";\n iframe.style.borderColor = \"transparent\";\n this._iframe = iframe;\n\n this.shadowRoot?.appendChild(iframe);\n }\n\n disconnectedCallback() {\n if (this.shadowRoot) this.shadowRoot.innerHTML = \"\";\n }\n}\n\ncustomElements.define(\"lvble-widget\", LvbleWidget);\n\nconst modeWidgetMap: Record<\n Extract<Mode, \"onboarding\" | \"repay\">,\n CustomElementConstructor | undefined\n> = {\n onboarding: customElements.get(\"lvble-widget\"),\n repay: customElements.get(\"lvble-widget\"),\n};\n\nlet _popup: Window;\n\nconst lvble = (initOptions: InitOptions) => {\n return {\n /**\n * This function creates a widget that can be embedded in your website.\n *\n * @param createOptions The options for creating the widget. See CreateWidgetOptions for more information.\n * @returns The widget.\n */\n // TODO: Add support for no mode\n createWidget: (createOptions: CreateWidgetOptions) => {\n const widget = new LvbleWidget()\n \n // (\n // createOptions.mode\n // ? new modeWidgetMap[createOptions.mode]!()\n // : new (customElements.get(\n // \"lvble-widget\"\n // ) as CustomElementConstructor)()\n // ) as LvbleWidget;\n widget.environment = initOptions.environment;\n widget.token = initOptions.token;\n widget.mode = createOptions.mode;\n\n const messageListener = (message: MessageEvent) => {\n if (message.origin != envToBaseUrlMapWidget[initOptions.environment]) {\n console.debug(\n `Received message from unknown origin: ${message.origin}`\n );\n return;\n }\n\n const data = message.data;\n createOptions.onEvent(data.eventType, data);\n };\n window.addEventListener(\"message\", messageListener);\n return widget;\n },\n /**\n * This function opens a popup with the relevant mode.\n * @param openOptions The options for opening the widget. See OpenOptions for more information.\n * @returns undefined.\n */\n open: (openOptions: OpenOptions) => {\n const modeUrlMap: Record<Mode, string> = {\n onboarding: `${\n envToBaseUrlMapExperience[initOptions.environment]\n }?token=${initOptions.token}`,\n offboarding: `${\n envToBaseUrlMapExperience[initOptions.environment]\n }?token=${initOptions.token}`,\n split: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${\n initOptions.token\n }`,\n repay: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${\n initOptions.token\n }`,\n };\n\n const modeUrl = openOptions.mode ? modeUrlMap[openOptions.mode] : \"\";\n\n const w = 450;\n const h = 800;\n const l = screen.width / 2 - w / 2;\n const t = screen.height / 2 - h / 2;\n _popup = window.open(\n modeUrl,\n \"LvblePopup\",\n \"width=\" + w + \",height=\" + h + \",location=no,left=\" + l + \",top=\" + t\n ) as Window;\n\n const messageListener = (message: MessageEvent) => {\n if (\n message.origin != envToBaseUrlMapExperience[initOptions.environment]\n ) {\n console.debug(\n `Received message from unknown origin: ${message.origin}`\n );\n return;\n }\n const eventData = message.data;\n const iframes = document.querySelectorAll(\"lvble-widget\");\n\n message = JSON.parse(JSON.stringify(message));\n\n iframes.forEach((w) => {\n (\n w.shadowRoot?.querySelector(\"iframe\") as HTMLIFrameElement\n ).contentWindow?.postMessage(message, \"*\");\n });\n\n openOptions.onEvent(eventData.eventType, eventData);\n };\n\n window.addEventListener(\"message\", messageListener);\n },\n };\n};\n\nexport type LvbleType = ReturnType<typeof lvble>;\n\nexport const Lvble = lvble;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// startup\n// Load entry module and return exports\n// This entry module is referenced by other modules so it can't be inlined\nvar __webpack_exports__ = __webpack_require__(915);\n"],"names":["root","factory","exports","module","define","amd","self","Environment","EventType","envToBaseUrlMapWidget","Local","Sandbox","Production","envToBaseUrlMapExperience","FinishOnboarding","FinishOffboarding","FinishSplit","FinishRepay","onboarding","offboarding","split","repay","attachShadow","mode","this","getAttribute","val","setAttribute","removeAttribute","iframeSrc","environment","token","iframe","document","createElement","src","width","height","style","borderStyle","borderRadius","borderColor","_iframe","shadowRoot","appendChild","innerHTML","HTMLElement","customElements","LvbleWidget","get","Lvble","initOptions","createWidget","createOptions","widget","window","addEventListener","message","origin","data","onEvent","eventType","console","debug","open","openOptions","modeUrlMap","modeUrl","l","screen","w","t","h","eventData","iframes","querySelectorAll","JSON","parse","stringify","forEach","querySelector","contentWindow","postMessage","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","call"],"sourceRoot":""}
|
|
1
|
+
{"version":3,"file":"core.js","mappings":"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","sources":["webpack://MyLib/webpack/universalModuleDefinition","webpack://MyLib/./src/lib/index.ts","webpack://MyLib/./src/lib/lvble.ts","webpack://MyLib/webpack/bootstrap","webpack://MyLib/webpack/startup"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"MyLib\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"MyLib\"] = factory();\n\telse\n\t\troot[\"MyLib\"] = factory();\n})(self, () => {\nreturn ","export * from './lvble'\n","export enum Environment {\n Local = \"local\",\n Sandbox = \"sandbox\",\n Production = \"production\",\n}\nconst envToBaseUrlMapWidget: Record<Environment, string> = {\n [Environment.Local]: \"http://localhost:3001\",\n [Environment.Sandbox]: \"https://widget.sandbox.pms.nowlvble.com\",\n [Environment.Production]: \"https://api.production.partners.nowlvble.com\",\n};\n\nconst envToBaseUrlMapExperience: Record<Environment, string> = {\n [Environment.Local]: \"http://localhost:3001\",\n [Environment.Sandbox]: \"https://experience.sandbox.pms.nowlvble.com\",\n [Environment.Production]: \"https://api.production.partners.nowlvble.com\",\n};\n\nexport type Mode = \"onboarding\" | \"offboarding\" | \"split\" | \"repay\";\nexport type ErrorData = {\n type: \"error\";\n reason: string;\n};\nexport type OnboardingData =\n | ErrorData\n | {\n type: \"success\";\n status: string;\n };\nexport type SplitData =\n | ErrorData\n | {\n type: \"success\";\n external_id: string;\n settlement_id: string;\n amount: number;\n };\nexport type CloseData =\n | ErrorData\n | {\n type: \"close\";\n };\n// TODO: Make this the event type in the onEvent callback signature\nexport type EventData = OnboardingData | SplitData | CloseData;\n\nenum EventType {\n FinishOnboarding = \"finishOnboarding\",\n FinishOffboarding = \"finishOffboarding\",\n FinishSplit = \"finishSplit\",\n FinishRepay = \"finishRepay\",\n}\n\nconst modeToEventType = {\n onboarding: EventType.FinishOnboarding,\n offboarding: EventType.FinishOffboarding,\n split: EventType.FinishSplit,\n repay: EventType.FinishRepay,\n};\n\nexport interface InitOptions {\n // The environment to use.\n environment: Environment;\n // The widget token to use.\n token: string;\n}\n\nexport interface OpenOptions {\n // The mode to open the popup in. See Mode for more information.\n mode?: Mode;\n // The callback to invoke when the popup has sent an event (e.g. user clicked a button).\n onEvent: (eventType: string, data: any) => void;\n}\n\nexport interface CreateWidgetOptions extends OpenOptions {\n mode?: Extract<Mode, \"onboarding\" | \"repay\">;\n // The callback to invoke when the popup has sent an event (e.g. user clicked a button).\n onEvent: (eventType: string, data: any) => void;\n}\n\nclass LvbleWidget extends HTMLElement {\n _typeToEvent = {\n onboarding: EventType.FinishOnboarding,\n offboarding: EventType.FinishOffboarding,\n split: EventType.FinishSplit,\n repay: EventType.FinishRepay,\n };\n _iframe?: HTMLIFrameElement;\n\n constructor() {\n super();\n this.attachShadow({ mode: \"open\" });\n }\n\n get mode(): Mode {\n return this.getAttribute(\"mode\") as Mode;\n }\n\n set mode(val: Mode | undefined) {\n if (val) {\n this.setAttribute(\"mode\", val);\n } else {\n this.removeAttribute(\"mode\");\n }\n }\n\n get environment(): Environment {\n return this.getAttribute(\"environment\") as Environment;\n }\n\n set environment(val) {\n if (val) {\n this.setAttribute(\"environment\", val);\n } else {\n this.removeAttribute(\"environment\");\n }\n }\n\n get token() {\n return this.getAttribute(\"token\") as string;\n }\n\n set token(val: string) {\n if (val) {\n this.setAttribute(\"token\", val);\n } else {\n this.removeAttribute(\"token\");\n }\n }\n\n connectedCallback() {\n const iframeSrc = `${envToBaseUrlMapWidget[this.environment]}?token=${\n this.token\n }&environment=${this.environment}`;\n\n const iframe = document.createElement(\"iframe\");\n iframe.src = iframeSrc;\n iframe.width = `100%`;\n iframe.height = `100%`;\n iframe.style.borderStyle = \"solid\";\n iframe.style.borderRadius = \"10px\";\n iframe.style.borderColor = \"transparent\";\n this._iframe = iframe;\n\n this.shadowRoot?.appendChild(iframe);\n }\n\n disconnectedCallback() {\n if (this.shadowRoot) this.shadowRoot.innerHTML = \"\";\n }\n}\n\ncustomElements.define(\"lvble-widget\", LvbleWidget);\n\nconst modeWidgetMap: Record<\n Extract<Mode, \"onboarding\" | \"repay\">,\n CustomElementConstructor | undefined\n> = {\n onboarding: customElements.get(\"lvble-widget\"),\n repay: customElements.get(\"lvble-widget\"),\n};\n\nlet _popup: Window;\n\nconst lvble = (initOptions: InitOptions) => {\n return {\n /**\n * This function creates a widget that can be embedded in your website.\n *\n * @param createOptions The options for creating the widget. See CreateWidgetOptions for more information.\n * @returns The widget.\n */\n // TODO: Add support for no mode\n createWidget: (createOptions: CreateWidgetOptions) => {\n const widget = new LvbleWidget()\n \n // (\n // createOptions.mode\n // ? new modeWidgetMap[createOptions.mode]!()\n // : new (customElements.get(\n // \"lvble-widget\"\n // ) as CustomElementConstructor)()\n // ) as LvbleWidget;\n widget.environment = initOptions.environment;\n widget.token = initOptions.token;\n widget.mode = createOptions.mode;\n\n const messageListener = (message: MessageEvent) => {\n if (message.origin != envToBaseUrlMapWidget[initOptions.environment]) {\n console.debug(\n `Received message from unknown origin: ${message.origin}`\n );\n return;\n }\n\n const data = message.data;\n createOptions.onEvent(data.eventType, data);\n };\n window.addEventListener(\"message\", messageListener);\n return widget;\n },\n /**\n * This function opens a popup with the relevant mode.\n * @param openOptions The options for opening the widget. See OpenOptions for more information.\n * @returns undefined.\n */\n open: (openOptions: OpenOptions) => {\n const modeUrlMap: Record<Mode, string> = {\n onboarding: `${\n envToBaseUrlMapExperience[initOptions.environment]\n }?token=${initOptions.token}`,\n offboarding: `${\n envToBaseUrlMapExperience[initOptions.environment]\n }?token=${initOptions.token}`,\n split: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${\n initOptions.token\n }`,\n repay: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${\n initOptions.token\n }`,\n };\n\n const modeUrl = openOptions.mode ? \n modeUrlMap[openOptions.mode] : \n `${envToBaseUrlMapExperience[initOptions.environment]}?token=${initOptions.token}`;\n\n const w = 450;\n const h = 800;\n const l = screen.width / 2 - w / 2;\n const t = screen.height / 2 - h / 2;\n _popup = window.open(\n modeUrl,\n \"LvblePopup\",\n \"width=\" + w + \",height=\" + h + \",location=no,left=\" + l + \",top=\" + t\n ) as Window;\n\n const messageListener = (message: MessageEvent) => {\n if (\n message.origin != envToBaseUrlMapExperience[initOptions.environment]\n ) {\n console.debug(\n `Received message from unknown origin: ${message.origin}`\n );\n return;\n }\n const eventData = message.data;\n const iframes = document.querySelectorAll(\"lvble-widget\");\n\n message = JSON.parse(JSON.stringify(message));\n\n iframes.forEach((w) => {\n (\n w.shadowRoot?.querySelector(\"iframe\") as HTMLIFrameElement\n ).contentWindow?.postMessage(message, \"*\");\n });\n\n openOptions.onEvent(eventData.eventType, eventData);\n };\n\n window.addEventListener(\"message\", messageListener);\n },\n };\n};\n\nexport type LvbleType = ReturnType<typeof lvble>;\n\nexport const Lvble = lvble;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// startup\n// Load entry module and return exports\n// This entry module is referenced by other modules so it can't be inlined\nvar __webpack_exports__ = __webpack_require__(915);\n"],"names":["root","factory","exports","module","define","amd","self","Environment","envToBaseUrlMapWidget","Local","Sandbox","Production","envToBaseUrlMapExperience","EventType","FinishOnboarding","FinishOffboarding","FinishSplit","FinishRepay","LvbleWidget","HTMLElement","constructor","super","onboarding","offboarding","split","repay","this","attachShadow","mode","getAttribute","val","setAttribute","removeAttribute","environment","token","connectedCallback","iframeSrc","iframe","document","createElement","src","width","height","style","borderStyle","borderRadius","borderColor","_iframe","shadowRoot","appendChild","disconnectedCallback","innerHTML","_popup","customElements","get","Lvble","initOptions","createWidget","createOptions","widget","window","addEventListener","message","origin","console","debug","data","onEvent","eventType","open","openOptions","modeUrlMap","modeUrl","l","screen","w","t","h","eventData","iframes","querySelectorAll","JSON","parse","stringify","forEach","querySelector","contentWindow","postMessage","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","call"],"sourceRoot":""}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define("MyLib",[],t):"object"==typeof exports?exports.MyLib=t():e.MyLib=t()}(self,(()=>(()=>{"use strict";var e={915:function(e,t,n){var o=this&&this.__createBinding||(Object.create?function(e,t,n,o){void 0===o&&(o=n);var i=Object.getOwnPropertyDescriptor(t,n);i&&!("get"in i?!t.__esModule:i.writable||i.configurable)||(i={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,o,i)}:function(e,t,n,o){void 0===o&&(o=n),e[o]=t[n]}),i=this&&this.__exportStar||function(e,t){for(var n in e)"default"===n||Object.prototype.hasOwnProperty.call(t,n)||o(t,e,n)};Object.defineProperty(t,"__esModule",{value:!0}),i(n(755),t)},755:
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define("MyLib",[],t):"object"==typeof exports?exports.MyLib=t():e.MyLib=t()}(self,(()=>(()=>{"use strict";var e={915:function(e,t,n){var o=this&&this.__createBinding||(Object.create?function(e,t,n,o){void 0===o&&(o=n);var i=Object.getOwnPropertyDescriptor(t,n);i&&!("get"in i?!t.__esModule:i.writable||i.configurable)||(i={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,o,i)}:function(e,t,n,o){void 0===o&&(o=n),e[o]=t[n]}),i=this&&this.__exportStar||function(e,t){for(var n in e)"default"===n||Object.prototype.hasOwnProperty.call(t,n)||o(t,e,n)};Object.defineProperty(t,"__esModule",{value:!0}),i(n(755),t)},755:(e,t)=>{var n;Object.defineProperty(t,"__esModule",{value:!0}),t.Lvble=t.Environment=void 0,function(e){e.Local="local",e.Sandbox="sandbox",e.Production="production"}(n||(t.Environment=n={}));const o={[n.Local]:"http://localhost:3001",[n.Sandbox]:"https://widget.sandbox.pms.nowlvble.com",[n.Production]:"https://api.production.partners.nowlvble.com"},i={[n.Local]:"http://localhost:3001",[n.Sandbox]:"https://experience.sandbox.pms.nowlvble.com",[n.Production]:"https://api.production.partners.nowlvble.com"};var r;!function(e){e.FinishOnboarding="finishOnboarding",e.FinishOffboarding="finishOffboarding",e.FinishSplit="finishSplit",e.FinishRepay="finishRepay"}(r||(r={})),r.FinishOnboarding,r.FinishOffboarding,r.FinishSplit,r.FinishRepay;class s extends HTMLElement{constructor(){super(),Object.defineProperty(this,"_typeToEvent",{enumerable:!0,configurable:!0,writable:!0,value:{onboarding:r.FinishOnboarding,offboarding:r.FinishOffboarding,split:r.FinishSplit,repay:r.FinishRepay}}),Object.defineProperty(this,"_iframe",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.attachShadow({mode:"open"})}get mode(){return this.getAttribute("mode")}set mode(e){e?this.setAttribute("mode",e):this.removeAttribute("mode")}get environment(){return this.getAttribute("environment")}set environment(e){e?this.setAttribute("environment",e):this.removeAttribute("environment")}get token(){return this.getAttribute("token")}set token(e){e?this.setAttribute("token",e):this.removeAttribute("token")}connectedCallback(){var e;const t=`${o[this.environment]}?token=${this.token}&environment=${this.environment}`,n=document.createElement("iframe");n.src=t,n.width="100%",n.height="100%",n.style.borderStyle="solid",n.style.borderRadius="10px",n.style.borderColor="transparent",this._iframe=n,null===(e=this.shadowRoot)||void 0===e||e.appendChild(n)}disconnectedCallback(){this.shadowRoot&&(this.shadowRoot.innerHTML="")}}let d;customElements.define("lvble-widget",s),customElements.get("lvble-widget"),customElements.get("lvble-widget"),t.Lvble=e=>({createWidget:t=>{const n=new s;return n.environment=e.environment,n.token=e.token,n.mode=t.mode,window.addEventListener("message",(n=>{if(n.origin!=o[e.environment])return void console.debug(`Received message from unknown origin: ${n.origin}`);const i=n.data;t.onEvent(i.eventType,i)})),n},open:t=>{const n={onboarding:`${i[e.environment]}?token=${e.token}`,offboarding:`${i[e.environment]}?token=${e.token}`,split:`${i[e.environment]}?token=${e.token}`,repay:`${i[e.environment]}?token=${e.token}`},o=t.mode?n[t.mode]:`${i[e.environment]}?token=${e.token}`,r=screen.width/2-225,s=screen.height/2-400;d=window.open(o,"LvblePopup","width=450,height=800,location=no,left="+r+",top="+s),window.addEventListener("message",(n=>{if(n.origin!=i[e.environment])return void console.debug(`Received message from unknown origin: ${n.origin}`);const o=n.data,r=document.querySelectorAll("lvble-widget");n=JSON.parse(JSON.stringify(n)),r.forEach((e=>{var t,o;null===(o=(null===(t=e.shadowRoot)||void 0===t?void 0:t.querySelector("iframe")).contentWindow)||void 0===o||o.postMessage(n,"*")})),t.onEvent(o.eventType,o)}))}})}},t={};return function n(o){var i=t[o];if(void 0!==i)return i.exports;var r=t[o]={exports:{}};return e[o].call(r.exports,r,r.exports,n),r.exports}(915)})()));
|
|
2
2
|
//# sourceMappingURL=core.min.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"core.min.js","mappings":"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","sources":["webpack://MyLib/webpack/universalModuleDefinition","webpack://MyLib/./src/lib/index.ts","webpack://MyLib/./src/lib/lvble.ts","webpack://MyLib/webpack/bootstrap","webpack://MyLib/webpack/startup"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"MyLib\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"MyLib\"] = factory();\n\telse\n\t\troot[\"MyLib\"] = factory();\n})(self, () => {\nreturn ","export * from './lvble'\n","export enum Environment {\n Local = \"local\",\n Sandbox = \"sandbox\",\n Production = \"production\",\n}\nconst envToBaseUrlMapWidget: Record<Environment, string> = {\n [Environment.Local]: \"http://localhost:3001\",\n [Environment.Sandbox]: \"https://widget.sandbox.pms.nowlvble.com\",\n [Environment.Production]: \"https://api.production.partners.nowlvble.com\",\n};\n\nconst envToBaseUrlMapExperience: Record<Environment, string> = {\n [Environment.Local]: \"http://localhost:3001\",\n [Environment.Sandbox]: \"https://experience.sandbox.pms.nowlvble.com\",\n [Environment.Production]: \"https://api.production.partners.nowlvble.com\",\n};\n\nexport type Mode = \"onboarding\" | \"offboarding\" | \"split\" | \"repay\";\nexport type ErrorData = {\n type: \"error\";\n reason: string;\n};\nexport type OnboardingData =\n | ErrorData\n | {\n type: \"success\";\n status: string;\n };\nexport type SplitData =\n | ErrorData\n | {\n type: \"success\";\n external_id: string;\n settlement_id: string;\n amount: number;\n };\nexport type CloseData =\n | ErrorData\n | {\n type: \"close\";\n };\n// TODO: Make this the event type in the onEvent callback signature\nexport type EventData = OnboardingData | SplitData | CloseData;\n\nenum EventType {\n FinishOnboarding = \"finishOnboarding\",\n FinishOffboarding = \"finishOffboarding\",\n FinishSplit = \"finishSplit\",\n FinishRepay = \"finishRepay\",\n}\n\nconst modeToEventType = {\n onboarding: EventType.FinishOnboarding,\n offboarding: EventType.FinishOffboarding,\n split: EventType.FinishSplit,\n repay: EventType.FinishRepay,\n};\n\nexport interface InitOptions {\n // The environment to use.\n environment: Environment;\n // The widget token to use.\n token: string;\n}\n\nexport interface OpenOptions {\n // The mode to open the popup in. See Mode for more information.\n mode?: Mode;\n // The callback to invoke when the popup has sent an event (e.g. user clicked a button).\n onEvent: (eventType: string, data: any) => void;\n}\n\nexport interface CreateWidgetOptions extends OpenOptions {\n mode?: Extract<Mode, \"onboarding\" | \"repay\">;\n // The callback to invoke when the popup has sent an event (e.g. user clicked a button).\n onEvent: (eventType: string, data: any) => void;\n}\n\nclass LvbleWidget extends HTMLElement {\n _typeToEvent = {\n onboarding: EventType.FinishOnboarding,\n offboarding: EventType.FinishOffboarding,\n split: EventType.FinishSplit,\n repay: EventType.FinishRepay,\n };\n _iframe?: HTMLIFrameElement;\n\n constructor() {\n super();\n this.attachShadow({ mode: \"open\" });\n }\n\n get mode(): Mode {\n return this.getAttribute(\"mode\") as Mode;\n }\n\n set mode(val: Mode | undefined) {\n if (val) {\n this.setAttribute(\"mode\", val);\n } else {\n this.removeAttribute(\"mode\");\n }\n }\n\n get environment(): Environment {\n return this.getAttribute(\"environment\") as Environment;\n }\n\n set environment(val) {\n if (val) {\n this.setAttribute(\"environment\", val);\n } else {\n this.removeAttribute(\"environment\");\n }\n }\n\n get token() {\n return this.getAttribute(\"token\") as string;\n }\n\n set token(val: string) {\n if (val) {\n this.setAttribute(\"token\", val);\n } else {\n this.removeAttribute(\"token\");\n }\n }\n\n connectedCallback() {\n const iframeSrc = `${envToBaseUrlMapWidget[this.environment]}?token=${\n this.token\n }&environment=${this.environment}`;\n\n const iframe = document.createElement(\"iframe\");\n iframe.src = iframeSrc;\n iframe.width = `100%`;\n iframe.height = `100%`;\n iframe.style.borderStyle = \"solid\";\n iframe.style.borderRadius = \"10px\";\n iframe.style.borderColor = \"transparent\";\n this._iframe = iframe;\n\n this.shadowRoot?.appendChild(iframe);\n }\n\n disconnectedCallback() {\n if (this.shadowRoot) this.shadowRoot.innerHTML = \"\";\n }\n}\n\ncustomElements.define(\"lvble-widget\", LvbleWidget);\n\nconst modeWidgetMap: Record<\n Extract<Mode, \"onboarding\" | \"repay\">,\n CustomElementConstructor | undefined\n> = {\n onboarding: customElements.get(\"lvble-widget\"),\n repay: customElements.get(\"lvble-widget\"),\n};\n\nlet _popup: Window;\n\nconst lvble = (initOptions: InitOptions) => {\n return {\n /**\n * This function creates a widget that can be embedded in your website.\n *\n * @param createOptions The options for creating the widget. See CreateWidgetOptions for more information.\n * @returns The widget.\n */\n // TODO: Add support for no mode\n createWidget: (createOptions: CreateWidgetOptions) => {\n const widget = new LvbleWidget()\n \n // (\n // createOptions.mode\n // ? new modeWidgetMap[createOptions.mode]!()\n // : new (customElements.get(\n // \"lvble-widget\"\n // ) as CustomElementConstructor)()\n // ) as LvbleWidget;\n widget.environment = initOptions.environment;\n widget.token = initOptions.token;\n widget.mode = createOptions.mode;\n\n const messageListener = (message: MessageEvent) => {\n if (message.origin != envToBaseUrlMapWidget[initOptions.environment]) {\n console.debug(\n `Received message from unknown origin: ${message.origin}`\n );\n return;\n }\n\n const data = message.data;\n createOptions.onEvent(data.eventType, data);\n };\n window.addEventListener(\"message\", messageListener);\n return widget;\n },\n /**\n * This function opens a popup with the relevant mode.\n * @param openOptions The options for opening the widget. See OpenOptions for more information.\n * @returns undefined.\n */\n open: (openOptions: OpenOptions) => {\n const modeUrlMap: Record<Mode, string> = {\n onboarding: `${\n envToBaseUrlMapExperience[initOptions.environment]\n }?token=${initOptions.token}`,\n offboarding: `${\n envToBaseUrlMapExperience[initOptions.environment]\n }?token=${initOptions.token}`,\n split: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${\n initOptions.token\n }`,\n repay: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${\n initOptions.token\n }`,\n };\n\n const modeUrl = openOptions.mode ? modeUrlMap[openOptions.mode] : \"\";\n\n const w = 450;\n const h = 800;\n const l = screen.width / 2 - w / 2;\n const t = screen.height / 2 - h / 2;\n _popup = window.open(\n modeUrl,\n \"LvblePopup\",\n \"width=\" + w + \",height=\" + h + \",location=no,left=\" + l + \",top=\" + t\n ) as Window;\n\n const messageListener = (message: MessageEvent) => {\n if (\n message.origin != envToBaseUrlMapExperience[initOptions.environment]\n ) {\n console.debug(\n `Received message from unknown origin: ${message.origin}`\n );\n return;\n }\n const eventData = message.data;\n const iframes = document.querySelectorAll(\"lvble-widget\");\n\n message = JSON.parse(JSON.stringify(message));\n\n iframes.forEach((w) => {\n (\n w.shadowRoot?.querySelector(\"iframe\") as HTMLIFrameElement\n ).contentWindow?.postMessage(message, \"*\");\n });\n\n openOptions.onEvent(eventData.eventType, eventData);\n };\n\n window.addEventListener(\"message\", messageListener);\n },\n };\n};\n\nexport type LvbleType = ReturnType<typeof lvble>;\n\nexport const Lvble = lvble;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// startup\n// Load entry module and return exports\n// This entry module is referenced by other modules so it can't be inlined\nvar __webpack_exports__ = __webpack_require__(915);\n"],"names":["root","factory","exports","module","define","amd","self","Environment","EventType","envToBaseUrlMapWidget","Local","Sandbox","Production","envToBaseUrlMapExperience","FinishOnboarding","FinishOffboarding","FinishSplit","FinishRepay","onboarding","offboarding","split","repay","attachShadow","mode","this","getAttribute","val","setAttribute","removeAttribute","iframeSrc","environment","token","iframe","document","createElement","src","width","height","style","borderStyle","borderRadius","borderColor","_iframe","shadowRoot","appendChild","innerHTML","HTMLElement","customElements","LvbleWidget","get","Lvble","initOptions","createWidget","createOptions","widget","window","addEventListener","message","origin","data","onEvent","eventType","console","debug","open","openOptions","modeUrlMap","modeUrl","l","screen","w","t","h","eventData","iframes","querySelectorAll","JSON","parse","stringify","forEach","querySelector","contentWindow","postMessage","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","call"],"sourceRoot":""}
|
|
1
|
+
{"version":3,"file":"core.min.js","mappings":"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","sources":["webpack://MyLib/webpack/universalModuleDefinition","webpack://MyLib/./src/lib/index.ts","webpack://MyLib/./src/lib/lvble.ts","webpack://MyLib/webpack/bootstrap","webpack://MyLib/webpack/startup"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"MyLib\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"MyLib\"] = factory();\n\telse\n\t\troot[\"MyLib\"] = factory();\n})(self, () => {\nreturn ","export * from './lvble'\n","export enum Environment {\n Local = \"local\",\n Sandbox = \"sandbox\",\n Production = \"production\",\n}\nconst envToBaseUrlMapWidget: Record<Environment, string> = {\n [Environment.Local]: \"http://localhost:3001\",\n [Environment.Sandbox]: \"https://widget.sandbox.pms.nowlvble.com\",\n [Environment.Production]: \"https://api.production.partners.nowlvble.com\",\n};\n\nconst envToBaseUrlMapExperience: Record<Environment, string> = {\n [Environment.Local]: \"http://localhost:3001\",\n [Environment.Sandbox]: \"https://experience.sandbox.pms.nowlvble.com\",\n [Environment.Production]: \"https://api.production.partners.nowlvble.com\",\n};\n\nexport type Mode = \"onboarding\" | \"offboarding\" | \"split\" | \"repay\";\nexport type ErrorData = {\n type: \"error\";\n reason: string;\n};\nexport type OnboardingData =\n | ErrorData\n | {\n type: \"success\";\n status: string;\n };\nexport type SplitData =\n | ErrorData\n | {\n type: \"success\";\n external_id: string;\n settlement_id: string;\n amount: number;\n };\nexport type CloseData =\n | ErrorData\n | {\n type: \"close\";\n };\n// TODO: Make this the event type in the onEvent callback signature\nexport type EventData = OnboardingData | SplitData | CloseData;\n\nenum EventType {\n FinishOnboarding = \"finishOnboarding\",\n FinishOffboarding = \"finishOffboarding\",\n FinishSplit = \"finishSplit\",\n FinishRepay = \"finishRepay\",\n}\n\nconst modeToEventType = {\n onboarding: EventType.FinishOnboarding,\n offboarding: EventType.FinishOffboarding,\n split: EventType.FinishSplit,\n repay: EventType.FinishRepay,\n};\n\nexport interface InitOptions {\n // The environment to use.\n environment: Environment;\n // The widget token to use.\n token: string;\n}\n\nexport interface OpenOptions {\n // The mode to open the popup in. See Mode for more information.\n mode?: Mode;\n // The callback to invoke when the popup has sent an event (e.g. user clicked a button).\n onEvent: (eventType: string, data: any) => void;\n}\n\nexport interface CreateWidgetOptions extends OpenOptions {\n mode?: Extract<Mode, \"onboarding\" | \"repay\">;\n // The callback to invoke when the popup has sent an event (e.g. user clicked a button).\n onEvent: (eventType: string, data: any) => void;\n}\n\nclass LvbleWidget extends HTMLElement {\n _typeToEvent = {\n onboarding: EventType.FinishOnboarding,\n offboarding: EventType.FinishOffboarding,\n split: EventType.FinishSplit,\n repay: EventType.FinishRepay,\n };\n _iframe?: HTMLIFrameElement;\n\n constructor() {\n super();\n this.attachShadow({ mode: \"open\" });\n }\n\n get mode(): Mode {\n return this.getAttribute(\"mode\") as Mode;\n }\n\n set mode(val: Mode | undefined) {\n if (val) {\n this.setAttribute(\"mode\", val);\n } else {\n this.removeAttribute(\"mode\");\n }\n }\n\n get environment(): Environment {\n return this.getAttribute(\"environment\") as Environment;\n }\n\n set environment(val) {\n if (val) {\n this.setAttribute(\"environment\", val);\n } else {\n this.removeAttribute(\"environment\");\n }\n }\n\n get token() {\n return this.getAttribute(\"token\") as string;\n }\n\n set token(val: string) {\n if (val) {\n this.setAttribute(\"token\", val);\n } else {\n this.removeAttribute(\"token\");\n }\n }\n\n connectedCallback() {\n const iframeSrc = `${envToBaseUrlMapWidget[this.environment]}?token=${\n this.token\n }&environment=${this.environment}`;\n\n const iframe = document.createElement(\"iframe\");\n iframe.src = iframeSrc;\n iframe.width = `100%`;\n iframe.height = `100%`;\n iframe.style.borderStyle = \"solid\";\n iframe.style.borderRadius = \"10px\";\n iframe.style.borderColor = \"transparent\";\n this._iframe = iframe;\n\n this.shadowRoot?.appendChild(iframe);\n }\n\n disconnectedCallback() {\n if (this.shadowRoot) this.shadowRoot.innerHTML = \"\";\n }\n}\n\ncustomElements.define(\"lvble-widget\", LvbleWidget);\n\nconst modeWidgetMap: Record<\n Extract<Mode, \"onboarding\" | \"repay\">,\n CustomElementConstructor | undefined\n> = {\n onboarding: customElements.get(\"lvble-widget\"),\n repay: customElements.get(\"lvble-widget\"),\n};\n\nlet _popup: Window;\n\nconst lvble = (initOptions: InitOptions) => {\n return {\n /**\n * This function creates a widget that can be embedded in your website.\n *\n * @param createOptions The options for creating the widget. See CreateWidgetOptions for more information.\n * @returns The widget.\n */\n // TODO: Add support for no mode\n createWidget: (createOptions: CreateWidgetOptions) => {\n const widget = new LvbleWidget()\n \n // (\n // createOptions.mode\n // ? new modeWidgetMap[createOptions.mode]!()\n // : new (customElements.get(\n // \"lvble-widget\"\n // ) as CustomElementConstructor)()\n // ) as LvbleWidget;\n widget.environment = initOptions.environment;\n widget.token = initOptions.token;\n widget.mode = createOptions.mode;\n\n const messageListener = (message: MessageEvent) => {\n if (message.origin != envToBaseUrlMapWidget[initOptions.environment]) {\n console.debug(\n `Received message from unknown origin: ${message.origin}`\n );\n return;\n }\n\n const data = message.data;\n createOptions.onEvent(data.eventType, data);\n };\n window.addEventListener(\"message\", messageListener);\n return widget;\n },\n /**\n * This function opens a popup with the relevant mode.\n * @param openOptions The options for opening the widget. See OpenOptions for more information.\n * @returns undefined.\n */\n open: (openOptions: OpenOptions) => {\n const modeUrlMap: Record<Mode, string> = {\n onboarding: `${\n envToBaseUrlMapExperience[initOptions.environment]\n }?token=${initOptions.token}`,\n offboarding: `${\n envToBaseUrlMapExperience[initOptions.environment]\n }?token=${initOptions.token}`,\n split: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${\n initOptions.token\n }`,\n repay: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${\n initOptions.token\n }`,\n };\n\n const modeUrl = openOptions.mode ? \n modeUrlMap[openOptions.mode] : \n `${envToBaseUrlMapExperience[initOptions.environment]}?token=${initOptions.token}`;\n\n const w = 450;\n const h = 800;\n const l = screen.width / 2 - w / 2;\n const t = screen.height / 2 - h / 2;\n _popup = window.open(\n modeUrl,\n \"LvblePopup\",\n \"width=\" + w + \",height=\" + h + \",location=no,left=\" + l + \",top=\" + t\n ) as Window;\n\n const messageListener = (message: MessageEvent) => {\n if (\n message.origin != envToBaseUrlMapExperience[initOptions.environment]\n ) {\n console.debug(\n `Received message from unknown origin: ${message.origin}`\n );\n return;\n }\n const eventData = message.data;\n const iframes = document.querySelectorAll(\"lvble-widget\");\n\n message = JSON.parse(JSON.stringify(message));\n\n iframes.forEach((w) => {\n (\n w.shadowRoot?.querySelector(\"iframe\") as HTMLIFrameElement\n ).contentWindow?.postMessage(message, \"*\");\n });\n\n openOptions.onEvent(eventData.eventType, eventData);\n };\n\n window.addEventListener(\"message\", messageListener);\n },\n };\n};\n\nexport type LvbleType = ReturnType<typeof lvble>;\n\nexport const Lvble = lvble;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// startup\n// Load entry module and return exports\n// This entry module is referenced by other modules so it can't be inlined\nvar __webpack_exports__ = __webpack_require__(915);\n"],"names":["root","factory","exports","module","define","amd","self","Environment","envToBaseUrlMapWidget","Local","Sandbox","Production","envToBaseUrlMapExperience","EventType","FinishOnboarding","FinishOffboarding","FinishSplit","FinishRepay","LvbleWidget","HTMLElement","constructor","super","onboarding","offboarding","split","repay","this","attachShadow","mode","getAttribute","val","setAttribute","removeAttribute","environment","token","connectedCallback","iframeSrc","iframe","document","createElement","src","width","height","style","borderStyle","borderRadius","borderColor","_iframe","shadowRoot","appendChild","disconnectedCallback","innerHTML","_popup","customElements","get","Lvble","initOptions","createWidget","createOptions","widget","window","addEventListener","message","origin","console","debug","data","onEvent","eventType","open","openOptions","modeUrlMap","modeUrl","l","screen","w","t","h","eventData","iframes","querySelectorAll","JSON","parse","stringify","forEach","querySelector","contentWindow","postMessage","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","call"],"sourceRoot":""}
|
package/dist/lib/lvble.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lvble.d.ts","sourceRoot":"","sources":["../../src/lib/lvble.ts"],"names":[],"mappings":"AAAA,oBAAY,WAAW;IACrB,KAAK,UAAU;IACf,OAAO,YAAY;IACnB,UAAU,eAAe;CAC1B;AAaD,MAAM,MAAM,IAAI,GAAG,YAAY,GAAG,aAAa,GAAG,OAAO,GAAG,OAAO,CAAC;AACpE,MAAM,MAAM,SAAS,GAAG;IACtB,IAAI,EAAE,OAAO,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AACF,MAAM,MAAM,cAAc,GACtB,SAAS,GACT;IACE,IAAI,EAAE,SAAS,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AACN,MAAM,MAAM,SAAS,GACjB,SAAS,GACT;IACE,IAAI,EAAE,SAAS,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;IACpB,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AACN,MAAM,MAAM,SAAS,GACjB,SAAS,GACT;IACE,IAAI,EAAE,OAAO,CAAC;CACf,CAAC;AAEN,MAAM,MAAM,SAAS,GAAG,cAAc,GAAG,SAAS,GAAG,SAAS,CAAC;AAE/D,aAAK,SAAS;IACZ,gBAAgB,qBAAqB;IACrC,iBAAiB,sBAAsB;IACvC,WAAW,gBAAgB;IAC3B,WAAW,gBAAgB;CAC5B;AASD,MAAM,WAAW,WAAW;IAE1B,WAAW,EAAE,WAAW,CAAC;IAEzB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,WAAW;IAE1B,IAAI,CAAC,EAAE,IAAI,CAAC;IAEZ,OAAO,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,IAAI,CAAC;CACjD;AAED,MAAM,WAAW,mBAAoB,SAAQ,WAAW;IACtD,IAAI,CAAC,EAAE,OAAO,CAAC,IAAI,EAAE,YAAY,GAAG,OAAO,CAAC,CAAC;IAE7C,OAAO,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,IAAI,CAAC;CACjD;AAED,cAAM,WAAY,SAAQ,WAAW;IACnC,YAAY;;;;;MAKV;IACF,OAAO,CAAC,EAAE,iBAAiB,CAAC;;IAO5B,IAAI,IAAI,IAAI,IAAI,CAEf;IAED,IAAI,IAAI,CAAC,GAAG,EAAE,IAAI,GAAG,SAAS,EAM7B;IAED,IAAI,WAAW,IAAI,WAAW,CAE7B;IAED,IAAI,WAAW,CAAC,GAAG,EAJA,WAIA,EAMlB;IAED,IAAI,KAAK,IAIM,MAAM,CAFpB;IAED,IAAI,KAAK,CAAC,GAAG,EAAE,MAAM,EAMpB;IAED,iBAAiB;IAiBjB,oBAAoB;CAGrB;AAcD,QAAA,MAAM,KAAK,gBAAiB,WAAW;IAEnC;;;;;OAKG;kCAE2B,mBAAmB;IA4BjD;;;;OAIG;wBACiB,WAAW;
|
|
1
|
+
{"version":3,"file":"lvble.d.ts","sourceRoot":"","sources":["../../src/lib/lvble.ts"],"names":[],"mappings":"AAAA,oBAAY,WAAW;IACrB,KAAK,UAAU;IACf,OAAO,YAAY;IACnB,UAAU,eAAe;CAC1B;AAaD,MAAM,MAAM,IAAI,GAAG,YAAY,GAAG,aAAa,GAAG,OAAO,GAAG,OAAO,CAAC;AACpE,MAAM,MAAM,SAAS,GAAG;IACtB,IAAI,EAAE,OAAO,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AACF,MAAM,MAAM,cAAc,GACtB,SAAS,GACT;IACE,IAAI,EAAE,SAAS,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AACN,MAAM,MAAM,SAAS,GACjB,SAAS,GACT;IACE,IAAI,EAAE,SAAS,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;IACpB,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AACN,MAAM,MAAM,SAAS,GACjB,SAAS,GACT;IACE,IAAI,EAAE,OAAO,CAAC;CACf,CAAC;AAEN,MAAM,MAAM,SAAS,GAAG,cAAc,GAAG,SAAS,GAAG,SAAS,CAAC;AAE/D,aAAK,SAAS;IACZ,gBAAgB,qBAAqB;IACrC,iBAAiB,sBAAsB;IACvC,WAAW,gBAAgB;IAC3B,WAAW,gBAAgB;CAC5B;AASD,MAAM,WAAW,WAAW;IAE1B,WAAW,EAAE,WAAW,CAAC;IAEzB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,WAAW;IAE1B,IAAI,CAAC,EAAE,IAAI,CAAC;IAEZ,OAAO,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,IAAI,CAAC;CACjD;AAED,MAAM,WAAW,mBAAoB,SAAQ,WAAW;IACtD,IAAI,CAAC,EAAE,OAAO,CAAC,IAAI,EAAE,YAAY,GAAG,OAAO,CAAC,CAAC;IAE7C,OAAO,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,IAAI,CAAC;CACjD;AAED,cAAM,WAAY,SAAQ,WAAW;IACnC,YAAY;;;;;MAKV;IACF,OAAO,CAAC,EAAE,iBAAiB,CAAC;;IAO5B,IAAI,IAAI,IAAI,IAAI,CAEf;IAED,IAAI,IAAI,CAAC,GAAG,EAAE,IAAI,GAAG,SAAS,EAM7B;IAED,IAAI,WAAW,IAAI,WAAW,CAE7B;IAED,IAAI,WAAW,CAAC,GAAG,EAJA,WAIA,EAMlB;IAED,IAAI,KAAK,IAIM,MAAM,CAFpB;IAED,IAAI,KAAK,CAAC,GAAG,EAAE,MAAM,EAMpB;IAED,iBAAiB;IAiBjB,oBAAoB;CAGrB;AAcD,QAAA,MAAM,KAAK,gBAAiB,WAAW;IAEnC;;;;;OAKG;kCAE2B,mBAAmB;IA4BjD;;;;OAIG;wBACiB,WAAW;CAwDlC,CAAC;AAEF,MAAM,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO,KAAK,CAAC,CAAC;AAEjD,eAAO,MAAM,KAAK,gBAtGU,WAAW;IAEnC;;;;;OAKG;kCAE2B,mBAAmB;IA4BjD;;;;OAIG;wBACiB,WAAW;CA4DT,CAAC"}
|
package/dist/lib/lvble.js
CHANGED
|
@@ -1,20 +1,4 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __extends = (this && this.__extends) || (function () {
|
|
3
|
-
var extendStatics = function (d, b) {
|
|
4
|
-
extendStatics = Object.setPrototypeOf ||
|
|
5
|
-
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
6
|
-
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
7
|
-
return extendStatics(d, b);
|
|
8
|
-
};
|
|
9
|
-
return function (d, b) {
|
|
10
|
-
if (typeof b !== "function" && b !== null)
|
|
11
|
-
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
12
|
-
extendStatics(d, b);
|
|
13
|
-
function __() { this.constructor = d; }
|
|
14
|
-
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
15
|
-
};
|
|
16
|
-
})();
|
|
17
|
-
var _a, _b;
|
|
18
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
3
|
exports.Lvble = exports.Environment = void 0;
|
|
20
4
|
var Environment;
|
|
@@ -23,16 +7,16 @@ var Environment;
|
|
|
23
7
|
Environment["Sandbox"] = "sandbox";
|
|
24
8
|
Environment["Production"] = "production";
|
|
25
9
|
})(Environment || (exports.Environment = Environment = {}));
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
10
|
+
const envToBaseUrlMapWidget = {
|
|
11
|
+
[Environment.Local]: "http://localhost:3001",
|
|
12
|
+
[Environment.Sandbox]: "https://widget.sandbox.pms.nowlvble.com",
|
|
13
|
+
[Environment.Production]: "https://api.production.partners.nowlvble.com",
|
|
14
|
+
};
|
|
15
|
+
const envToBaseUrlMapExperience = {
|
|
16
|
+
[Environment.Local]: "http://localhost:3001",
|
|
17
|
+
[Environment.Sandbox]: "https://experience.sandbox.pms.nowlvble.com",
|
|
18
|
+
[Environment.Production]: "https://api.production.partners.nowlvble.com",
|
|
19
|
+
};
|
|
36
20
|
var EventType;
|
|
37
21
|
(function (EventType) {
|
|
38
22
|
EventType["FinishOnboarding"] = "finishOnboarding";
|
|
@@ -40,17 +24,16 @@ var EventType;
|
|
|
40
24
|
EventType["FinishSplit"] = "finishSplit";
|
|
41
25
|
EventType["FinishRepay"] = "finishRepay";
|
|
42
26
|
})(EventType || (EventType = {}));
|
|
43
|
-
|
|
27
|
+
const modeToEventType = {
|
|
44
28
|
onboarding: EventType.FinishOnboarding,
|
|
45
29
|
offboarding: EventType.FinishOffboarding,
|
|
46
30
|
split: EventType.FinishSplit,
|
|
47
31
|
repay: EventType.FinishRepay,
|
|
48
32
|
};
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
Object.defineProperty(_this, "_typeToEvent", {
|
|
33
|
+
class LvbleWidget extends HTMLElement {
|
|
34
|
+
constructor() {
|
|
35
|
+
super();
|
|
36
|
+
Object.defineProperty(this, "_typeToEvent", {
|
|
54
37
|
enumerable: true,
|
|
55
38
|
configurable: true,
|
|
56
39
|
writable: true,
|
|
@@ -61,96 +44,72 @@ var LvbleWidget = /** @class */ (function (_super) {
|
|
|
61
44
|
repay: EventType.FinishRepay,
|
|
62
45
|
}
|
|
63
46
|
});
|
|
64
|
-
Object.defineProperty(
|
|
47
|
+
Object.defineProperty(this, "_iframe", {
|
|
65
48
|
enumerable: true,
|
|
66
49
|
configurable: true,
|
|
67
50
|
writable: true,
|
|
68
51
|
value: void 0
|
|
69
52
|
});
|
|
70
|
-
|
|
71
|
-
return _this;
|
|
53
|
+
this.attachShadow({ mode: "open" });
|
|
72
54
|
}
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
return this.getAttribute("environment");
|
|
91
|
-
},
|
|
92
|
-
set: function (val) {
|
|
93
|
-
if (val) {
|
|
94
|
-
this.setAttribute("environment", val);
|
|
95
|
-
}
|
|
96
|
-
else {
|
|
97
|
-
this.removeAttribute("environment");
|
|
98
|
-
}
|
|
99
|
-
},
|
|
100
|
-
enumerable: false,
|
|
101
|
-
configurable: true
|
|
102
|
-
});
|
|
103
|
-
Object.defineProperty(LvbleWidget.prototype, "token", {
|
|
104
|
-
get: function () {
|
|
105
|
-
return this.getAttribute("token");
|
|
106
|
-
},
|
|
107
|
-
set: function (val) {
|
|
108
|
-
if (val) {
|
|
109
|
-
this.setAttribute("token", val);
|
|
110
|
-
}
|
|
111
|
-
else {
|
|
112
|
-
this.removeAttribute("token");
|
|
113
|
-
}
|
|
114
|
-
},
|
|
115
|
-
enumerable: false,
|
|
116
|
-
configurable: true
|
|
117
|
-
});
|
|
118
|
-
Object.defineProperty(LvbleWidget.prototype, "connectedCallback", {
|
|
119
|
-
enumerable: false,
|
|
120
|
-
configurable: true,
|
|
121
|
-
writable: true,
|
|
122
|
-
value: function () {
|
|
123
|
-
var _a;
|
|
124
|
-
var iframeSrc = "".concat(envToBaseUrlMapWidget[this.environment], "?token=").concat(this.token, "&environment=").concat(this.environment);
|
|
125
|
-
var iframe = document.createElement("iframe");
|
|
126
|
-
iframe.src = iframeSrc;
|
|
127
|
-
iframe.width = "100%";
|
|
128
|
-
iframe.height = "100%";
|
|
129
|
-
iframe.style.borderStyle = "solid";
|
|
130
|
-
iframe.style.borderRadius = "10px";
|
|
131
|
-
iframe.style.borderColor = "transparent";
|
|
132
|
-
this._iframe = iframe;
|
|
133
|
-
(_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.appendChild(iframe);
|
|
55
|
+
get mode() {
|
|
56
|
+
return this.getAttribute("mode");
|
|
57
|
+
}
|
|
58
|
+
set mode(val) {
|
|
59
|
+
if (val) {
|
|
60
|
+
this.setAttribute("mode", val);
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
this.removeAttribute("mode");
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
get environment() {
|
|
67
|
+
return this.getAttribute("environment");
|
|
68
|
+
}
|
|
69
|
+
set environment(val) {
|
|
70
|
+
if (val) {
|
|
71
|
+
this.setAttribute("environment", val);
|
|
134
72
|
}
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
enumerable: false,
|
|
138
|
-
configurable: true,
|
|
139
|
-
writable: true,
|
|
140
|
-
value: function () {
|
|
141
|
-
if (this.shadowRoot)
|
|
142
|
-
this.shadowRoot.innerHTML = "";
|
|
73
|
+
else {
|
|
74
|
+
this.removeAttribute("environment");
|
|
143
75
|
}
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
|
|
76
|
+
}
|
|
77
|
+
get token() {
|
|
78
|
+
return this.getAttribute("token");
|
|
79
|
+
}
|
|
80
|
+
set token(val) {
|
|
81
|
+
if (val) {
|
|
82
|
+
this.setAttribute("token", val);
|
|
83
|
+
}
|
|
84
|
+
else {
|
|
85
|
+
this.removeAttribute("token");
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
connectedCallback() {
|
|
89
|
+
var _a;
|
|
90
|
+
const iframeSrc = `${envToBaseUrlMapWidget[this.environment]}?token=${this.token}&environment=${this.environment}`;
|
|
91
|
+
const iframe = document.createElement("iframe");
|
|
92
|
+
iframe.src = iframeSrc;
|
|
93
|
+
iframe.width = `100%`;
|
|
94
|
+
iframe.height = `100%`;
|
|
95
|
+
iframe.style.borderStyle = "solid";
|
|
96
|
+
iframe.style.borderRadius = "10px";
|
|
97
|
+
iframe.style.borderColor = "transparent";
|
|
98
|
+
this._iframe = iframe;
|
|
99
|
+
(_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.appendChild(iframe);
|
|
100
|
+
}
|
|
101
|
+
disconnectedCallback() {
|
|
102
|
+
if (this.shadowRoot)
|
|
103
|
+
this.shadowRoot.innerHTML = "";
|
|
104
|
+
}
|
|
105
|
+
}
|
|
147
106
|
customElements.define("lvble-widget", LvbleWidget);
|
|
148
|
-
|
|
107
|
+
const modeWidgetMap = {
|
|
149
108
|
onboarding: customElements.get("lvble-widget"),
|
|
150
109
|
repay: customElements.get("lvble-widget"),
|
|
151
110
|
};
|
|
152
|
-
|
|
153
|
-
|
|
111
|
+
let _popup;
|
|
112
|
+
const lvble = (initOptions) => {
|
|
154
113
|
return {
|
|
155
114
|
/**
|
|
156
115
|
* This function creates a widget that can be embedded in your website.
|
|
@@ -159,8 +118,8 @@ var lvble = function (initOptions) {
|
|
|
159
118
|
* @returns The widget.
|
|
160
119
|
*/
|
|
161
120
|
// TODO: Add support for no mode
|
|
162
|
-
createWidget:
|
|
163
|
-
|
|
121
|
+
createWidget: (createOptions) => {
|
|
122
|
+
const widget = new LvbleWidget();
|
|
164
123
|
// (
|
|
165
124
|
// createOptions.mode
|
|
166
125
|
// ? new modeWidgetMap[createOptions.mode]!()
|
|
@@ -171,12 +130,12 @@ var lvble = function (initOptions) {
|
|
|
171
130
|
widget.environment = initOptions.environment;
|
|
172
131
|
widget.token = initOptions.token;
|
|
173
132
|
widget.mode = createOptions.mode;
|
|
174
|
-
|
|
133
|
+
const messageListener = (message) => {
|
|
175
134
|
if (message.origin != envToBaseUrlMapWidget[initOptions.environment]) {
|
|
176
|
-
console.debug(
|
|
135
|
+
console.debug(`Received message from unknown origin: ${message.origin}`);
|
|
177
136
|
return;
|
|
178
137
|
}
|
|
179
|
-
|
|
138
|
+
const data = message.data;
|
|
180
139
|
createOptions.onEvent(data.eventType, data);
|
|
181
140
|
};
|
|
182
141
|
window.addEventListener("message", messageListener);
|
|
@@ -187,28 +146,30 @@ var lvble = function (initOptions) {
|
|
|
187
146
|
* @param openOptions The options for opening the widget. See OpenOptions for more information.
|
|
188
147
|
* @returns undefined.
|
|
189
148
|
*/
|
|
190
|
-
open:
|
|
191
|
-
|
|
192
|
-
onboarding:
|
|
193
|
-
offboarding:
|
|
194
|
-
split:
|
|
195
|
-
repay:
|
|
149
|
+
open: (openOptions) => {
|
|
150
|
+
const modeUrlMap = {
|
|
151
|
+
onboarding: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${initOptions.token}`,
|
|
152
|
+
offboarding: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${initOptions.token}`,
|
|
153
|
+
split: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${initOptions.token}`,
|
|
154
|
+
repay: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${initOptions.token}`,
|
|
196
155
|
};
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
156
|
+
const modeUrl = openOptions.mode ?
|
|
157
|
+
modeUrlMap[openOptions.mode] :
|
|
158
|
+
`${envToBaseUrlMapExperience[initOptions.environment]}?token=${initOptions.token}`;
|
|
159
|
+
const w = 450;
|
|
160
|
+
const h = 800;
|
|
161
|
+
const l = screen.width / 2 - w / 2;
|
|
162
|
+
const t = screen.height / 2 - h / 2;
|
|
202
163
|
_popup = window.open(modeUrl, "LvblePopup", "width=" + w + ",height=" + h + ",location=no,left=" + l + ",top=" + t);
|
|
203
|
-
|
|
164
|
+
const messageListener = (message) => {
|
|
204
165
|
if (message.origin != envToBaseUrlMapExperience[initOptions.environment]) {
|
|
205
|
-
console.debug(
|
|
166
|
+
console.debug(`Received message from unknown origin: ${message.origin}`);
|
|
206
167
|
return;
|
|
207
168
|
}
|
|
208
|
-
|
|
209
|
-
|
|
169
|
+
const eventData = message.data;
|
|
170
|
+
const iframes = document.querySelectorAll("lvble-widget");
|
|
210
171
|
message = JSON.parse(JSON.stringify(message));
|
|
211
|
-
iframes.forEach(
|
|
172
|
+
iframes.forEach((w) => {
|
|
212
173
|
var _a, _b;
|
|
213
174
|
(_b = ((_a = w.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector("iframe")).contentWindow) === null || _b === void 0 ? void 0 : _b.postMessage(message, "*");
|
|
214
175
|
});
|
package/dist/lib/lvble.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lvble.js","sourceRoot":"","sources":["../../src/lib/lvble.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"lvble.js","sourceRoot":"","sources":["../../src/lib/lvble.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lvble.d.ts","sourceRoot":"","sources":["../../src/lib/lvble.ts"],"names":[],"mappings":"AAAA,oBAAY,WAAW;IACrB,KAAK,UAAU;IACf,OAAO,YAAY;IACnB,UAAU,eAAe;CAC1B;AAaD,MAAM,MAAM,IAAI,GAAG,YAAY,GAAG,aAAa,GAAG,OAAO,GAAG,OAAO,CAAC;AACpE,MAAM,MAAM,SAAS,GAAG;IACtB,IAAI,EAAE,OAAO,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AACF,MAAM,MAAM,cAAc,GACtB,SAAS,GACT;IACE,IAAI,EAAE,SAAS,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AACN,MAAM,MAAM,SAAS,GACjB,SAAS,GACT;IACE,IAAI,EAAE,SAAS,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;IACpB,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AACN,MAAM,MAAM,SAAS,GACjB,SAAS,GACT;IACE,IAAI,EAAE,OAAO,CAAC;CACf,CAAC;AAEN,MAAM,MAAM,SAAS,GAAG,cAAc,GAAG,SAAS,GAAG,SAAS,CAAC;AAE/D,aAAK,SAAS;IACZ,gBAAgB,qBAAqB;IACrC,iBAAiB,sBAAsB;IACvC,WAAW,gBAAgB;IAC3B,WAAW,gBAAgB;CAC5B;AASD,MAAM,WAAW,WAAW;IAE1B,WAAW,EAAE,WAAW,CAAC;IAEzB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,WAAW;IAE1B,IAAI,CAAC,EAAE,IAAI,CAAC;IAEZ,OAAO,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,IAAI,CAAC;CACjD;AAED,MAAM,WAAW,mBAAoB,SAAQ,WAAW;IACtD,IAAI,CAAC,EAAE,OAAO,CAAC,IAAI,EAAE,YAAY,GAAG,OAAO,CAAC,CAAC;IAE7C,OAAO,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,IAAI,CAAC;CACjD;AAED,cAAM,WAAY,SAAQ,WAAW;IACnC,YAAY;;;;;MAKV;IACF,OAAO,CAAC,EAAE,iBAAiB,CAAC;;IAO5B,IAAI,IAAI,IAAI,IAAI,CAEf;IAED,IAAI,IAAI,CAAC,GAAG,EAAE,IAAI,GAAG,SAAS,EAM7B;IAED,IAAI,WAAW,IAAI,WAAW,CAE7B;IAED,IAAI,WAAW,CAAC,GAAG,EAJA,WAIA,EAMlB;IAED,IAAI,KAAK,IAIM,MAAM,CAFpB;IAED,IAAI,KAAK,CAAC,GAAG,EAAE,MAAM,EAMpB;IAED,iBAAiB;IAiBjB,oBAAoB;CAGrB;AAcD,QAAA,MAAM,KAAK,gBAAiB,WAAW;IAEnC;;;;;OAKG;kCAE2B,mBAAmB;IA4BjD;;;;OAIG;wBACiB,WAAW;
|
|
1
|
+
{"version":3,"file":"lvble.d.ts","sourceRoot":"","sources":["../../src/lib/lvble.ts"],"names":[],"mappings":"AAAA,oBAAY,WAAW;IACrB,KAAK,UAAU;IACf,OAAO,YAAY;IACnB,UAAU,eAAe;CAC1B;AAaD,MAAM,MAAM,IAAI,GAAG,YAAY,GAAG,aAAa,GAAG,OAAO,GAAG,OAAO,CAAC;AACpE,MAAM,MAAM,SAAS,GAAG;IACtB,IAAI,EAAE,OAAO,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AACF,MAAM,MAAM,cAAc,GACtB,SAAS,GACT;IACE,IAAI,EAAE,SAAS,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AACN,MAAM,MAAM,SAAS,GACjB,SAAS,GACT;IACE,IAAI,EAAE,SAAS,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;IACpB,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AACN,MAAM,MAAM,SAAS,GACjB,SAAS,GACT;IACE,IAAI,EAAE,OAAO,CAAC;CACf,CAAC;AAEN,MAAM,MAAM,SAAS,GAAG,cAAc,GAAG,SAAS,GAAG,SAAS,CAAC;AAE/D,aAAK,SAAS;IACZ,gBAAgB,qBAAqB;IACrC,iBAAiB,sBAAsB;IACvC,WAAW,gBAAgB;IAC3B,WAAW,gBAAgB;CAC5B;AASD,MAAM,WAAW,WAAW;IAE1B,WAAW,EAAE,WAAW,CAAC;IAEzB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,WAAW;IAE1B,IAAI,CAAC,EAAE,IAAI,CAAC;IAEZ,OAAO,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,IAAI,CAAC;CACjD;AAED,MAAM,WAAW,mBAAoB,SAAQ,WAAW;IACtD,IAAI,CAAC,EAAE,OAAO,CAAC,IAAI,EAAE,YAAY,GAAG,OAAO,CAAC,CAAC;IAE7C,OAAO,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,IAAI,CAAC;CACjD;AAED,cAAM,WAAY,SAAQ,WAAW;IACnC,YAAY;;;;;MAKV;IACF,OAAO,CAAC,EAAE,iBAAiB,CAAC;;IAO5B,IAAI,IAAI,IAAI,IAAI,CAEf;IAED,IAAI,IAAI,CAAC,GAAG,EAAE,IAAI,GAAG,SAAS,EAM7B;IAED,IAAI,WAAW,IAAI,WAAW,CAE7B;IAED,IAAI,WAAW,CAAC,GAAG,EAJA,WAIA,EAMlB;IAED,IAAI,KAAK,IAIM,MAAM,CAFpB;IAED,IAAI,KAAK,CAAC,GAAG,EAAE,MAAM,EAMpB;IAED,iBAAiB;IAiBjB,oBAAoB;CAGrB;AAcD,QAAA,MAAM,KAAK,gBAAiB,WAAW;IAEnC;;;;;OAKG;kCAE2B,mBAAmB;IA4BjD;;;;OAIG;wBACiB,WAAW;CAwDlC,CAAC;AAEF,MAAM,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO,KAAK,CAAC,CAAC;AAEjD,eAAO,MAAM,KAAK,gBAtGU,WAAW;IAEnC;;;;;OAKG;kCAE2B,mBAAmB;IA4BjD;;;;OAIG;wBACiB,WAAW;CA4DT,CAAC"}
|
package/dist/lib-esm/lvble.js
CHANGED
|
@@ -1,35 +1,19 @@
|
|
|
1
|
-
var __extends = (this && this.__extends) || (function () {
|
|
2
|
-
var extendStatics = function (d, b) {
|
|
3
|
-
extendStatics = Object.setPrototypeOf ||
|
|
4
|
-
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
5
|
-
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
6
|
-
return extendStatics(d, b);
|
|
7
|
-
};
|
|
8
|
-
return function (d, b) {
|
|
9
|
-
if (typeof b !== "function" && b !== null)
|
|
10
|
-
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
11
|
-
extendStatics(d, b);
|
|
12
|
-
function __() { this.constructor = d; }
|
|
13
|
-
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
14
|
-
};
|
|
15
|
-
})();
|
|
16
|
-
var _a, _b;
|
|
17
1
|
export var Environment;
|
|
18
2
|
(function (Environment) {
|
|
19
3
|
Environment["Local"] = "local";
|
|
20
4
|
Environment["Sandbox"] = "sandbox";
|
|
21
5
|
Environment["Production"] = "production";
|
|
22
6
|
})(Environment || (Environment = {}));
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
7
|
+
const envToBaseUrlMapWidget = {
|
|
8
|
+
[Environment.Local]: "http://localhost:3001",
|
|
9
|
+
[Environment.Sandbox]: "https://widget.sandbox.pms.nowlvble.com",
|
|
10
|
+
[Environment.Production]: "https://api.production.partners.nowlvble.com",
|
|
11
|
+
};
|
|
12
|
+
const envToBaseUrlMapExperience = {
|
|
13
|
+
[Environment.Local]: "http://localhost:3001",
|
|
14
|
+
[Environment.Sandbox]: "https://experience.sandbox.pms.nowlvble.com",
|
|
15
|
+
[Environment.Production]: "https://api.production.partners.nowlvble.com",
|
|
16
|
+
};
|
|
33
17
|
var EventType;
|
|
34
18
|
(function (EventType) {
|
|
35
19
|
EventType["FinishOnboarding"] = "finishOnboarding";
|
|
@@ -37,17 +21,16 @@ var EventType;
|
|
|
37
21
|
EventType["FinishSplit"] = "finishSplit";
|
|
38
22
|
EventType["FinishRepay"] = "finishRepay";
|
|
39
23
|
})(EventType || (EventType = {}));
|
|
40
|
-
|
|
24
|
+
const modeToEventType = {
|
|
41
25
|
onboarding: EventType.FinishOnboarding,
|
|
42
26
|
offboarding: EventType.FinishOffboarding,
|
|
43
27
|
split: EventType.FinishSplit,
|
|
44
28
|
repay: EventType.FinishRepay,
|
|
45
29
|
};
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
Object.defineProperty(_this, "_typeToEvent", {
|
|
30
|
+
class LvbleWidget extends HTMLElement {
|
|
31
|
+
constructor() {
|
|
32
|
+
super();
|
|
33
|
+
Object.defineProperty(this, "_typeToEvent", {
|
|
51
34
|
enumerable: true,
|
|
52
35
|
configurable: true,
|
|
53
36
|
writable: true,
|
|
@@ -58,96 +41,72 @@ var LvbleWidget = /** @class */ (function (_super) {
|
|
|
58
41
|
repay: EventType.FinishRepay,
|
|
59
42
|
}
|
|
60
43
|
});
|
|
61
|
-
Object.defineProperty(
|
|
44
|
+
Object.defineProperty(this, "_iframe", {
|
|
62
45
|
enumerable: true,
|
|
63
46
|
configurable: true,
|
|
64
47
|
writable: true,
|
|
65
48
|
value: void 0
|
|
66
49
|
});
|
|
67
|
-
|
|
68
|
-
return _this;
|
|
50
|
+
this.attachShadow({ mode: "open" });
|
|
69
51
|
}
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
return this.getAttribute("environment");
|
|
88
|
-
},
|
|
89
|
-
set: function (val) {
|
|
90
|
-
if (val) {
|
|
91
|
-
this.setAttribute("environment", val);
|
|
92
|
-
}
|
|
93
|
-
else {
|
|
94
|
-
this.removeAttribute("environment");
|
|
95
|
-
}
|
|
96
|
-
},
|
|
97
|
-
enumerable: false,
|
|
98
|
-
configurable: true
|
|
99
|
-
});
|
|
100
|
-
Object.defineProperty(LvbleWidget.prototype, "token", {
|
|
101
|
-
get: function () {
|
|
102
|
-
return this.getAttribute("token");
|
|
103
|
-
},
|
|
104
|
-
set: function (val) {
|
|
105
|
-
if (val) {
|
|
106
|
-
this.setAttribute("token", val);
|
|
107
|
-
}
|
|
108
|
-
else {
|
|
109
|
-
this.removeAttribute("token");
|
|
110
|
-
}
|
|
111
|
-
},
|
|
112
|
-
enumerable: false,
|
|
113
|
-
configurable: true
|
|
114
|
-
});
|
|
115
|
-
Object.defineProperty(LvbleWidget.prototype, "connectedCallback", {
|
|
116
|
-
enumerable: false,
|
|
117
|
-
configurable: true,
|
|
118
|
-
writable: true,
|
|
119
|
-
value: function () {
|
|
120
|
-
var _a;
|
|
121
|
-
var iframeSrc = "".concat(envToBaseUrlMapWidget[this.environment], "?token=").concat(this.token, "&environment=").concat(this.environment);
|
|
122
|
-
var iframe = document.createElement("iframe");
|
|
123
|
-
iframe.src = iframeSrc;
|
|
124
|
-
iframe.width = "100%";
|
|
125
|
-
iframe.height = "100%";
|
|
126
|
-
iframe.style.borderStyle = "solid";
|
|
127
|
-
iframe.style.borderRadius = "10px";
|
|
128
|
-
iframe.style.borderColor = "transparent";
|
|
129
|
-
this._iframe = iframe;
|
|
130
|
-
(_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.appendChild(iframe);
|
|
52
|
+
get mode() {
|
|
53
|
+
return this.getAttribute("mode");
|
|
54
|
+
}
|
|
55
|
+
set mode(val) {
|
|
56
|
+
if (val) {
|
|
57
|
+
this.setAttribute("mode", val);
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
this.removeAttribute("mode");
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
get environment() {
|
|
64
|
+
return this.getAttribute("environment");
|
|
65
|
+
}
|
|
66
|
+
set environment(val) {
|
|
67
|
+
if (val) {
|
|
68
|
+
this.setAttribute("environment", val);
|
|
131
69
|
}
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
enumerable: false,
|
|
135
|
-
configurable: true,
|
|
136
|
-
writable: true,
|
|
137
|
-
value: function () {
|
|
138
|
-
if (this.shadowRoot)
|
|
139
|
-
this.shadowRoot.innerHTML = "";
|
|
70
|
+
else {
|
|
71
|
+
this.removeAttribute("environment");
|
|
140
72
|
}
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
|
|
73
|
+
}
|
|
74
|
+
get token() {
|
|
75
|
+
return this.getAttribute("token");
|
|
76
|
+
}
|
|
77
|
+
set token(val) {
|
|
78
|
+
if (val) {
|
|
79
|
+
this.setAttribute("token", val);
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
this.removeAttribute("token");
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
connectedCallback() {
|
|
86
|
+
var _a;
|
|
87
|
+
const iframeSrc = `${envToBaseUrlMapWidget[this.environment]}?token=${this.token}&environment=${this.environment}`;
|
|
88
|
+
const iframe = document.createElement("iframe");
|
|
89
|
+
iframe.src = iframeSrc;
|
|
90
|
+
iframe.width = `100%`;
|
|
91
|
+
iframe.height = `100%`;
|
|
92
|
+
iframe.style.borderStyle = "solid";
|
|
93
|
+
iframe.style.borderRadius = "10px";
|
|
94
|
+
iframe.style.borderColor = "transparent";
|
|
95
|
+
this._iframe = iframe;
|
|
96
|
+
(_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.appendChild(iframe);
|
|
97
|
+
}
|
|
98
|
+
disconnectedCallback() {
|
|
99
|
+
if (this.shadowRoot)
|
|
100
|
+
this.shadowRoot.innerHTML = "";
|
|
101
|
+
}
|
|
102
|
+
}
|
|
144
103
|
customElements.define("lvble-widget", LvbleWidget);
|
|
145
|
-
|
|
104
|
+
const modeWidgetMap = {
|
|
146
105
|
onboarding: customElements.get("lvble-widget"),
|
|
147
106
|
repay: customElements.get("lvble-widget"),
|
|
148
107
|
};
|
|
149
|
-
|
|
150
|
-
|
|
108
|
+
let _popup;
|
|
109
|
+
const lvble = (initOptions) => {
|
|
151
110
|
return {
|
|
152
111
|
/**
|
|
153
112
|
* This function creates a widget that can be embedded in your website.
|
|
@@ -156,8 +115,8 @@ var lvble = function (initOptions) {
|
|
|
156
115
|
* @returns The widget.
|
|
157
116
|
*/
|
|
158
117
|
// TODO: Add support for no mode
|
|
159
|
-
createWidget:
|
|
160
|
-
|
|
118
|
+
createWidget: (createOptions) => {
|
|
119
|
+
const widget = new LvbleWidget();
|
|
161
120
|
// (
|
|
162
121
|
// createOptions.mode
|
|
163
122
|
// ? new modeWidgetMap[createOptions.mode]!()
|
|
@@ -168,12 +127,12 @@ var lvble = function (initOptions) {
|
|
|
168
127
|
widget.environment = initOptions.environment;
|
|
169
128
|
widget.token = initOptions.token;
|
|
170
129
|
widget.mode = createOptions.mode;
|
|
171
|
-
|
|
130
|
+
const messageListener = (message) => {
|
|
172
131
|
if (message.origin != envToBaseUrlMapWidget[initOptions.environment]) {
|
|
173
|
-
console.debug(
|
|
132
|
+
console.debug(`Received message from unknown origin: ${message.origin}`);
|
|
174
133
|
return;
|
|
175
134
|
}
|
|
176
|
-
|
|
135
|
+
const data = message.data;
|
|
177
136
|
createOptions.onEvent(data.eventType, data);
|
|
178
137
|
};
|
|
179
138
|
window.addEventListener("message", messageListener);
|
|
@@ -184,28 +143,30 @@ var lvble = function (initOptions) {
|
|
|
184
143
|
* @param openOptions The options for opening the widget. See OpenOptions for more information.
|
|
185
144
|
* @returns undefined.
|
|
186
145
|
*/
|
|
187
|
-
open:
|
|
188
|
-
|
|
189
|
-
onboarding:
|
|
190
|
-
offboarding:
|
|
191
|
-
split:
|
|
192
|
-
repay:
|
|
146
|
+
open: (openOptions) => {
|
|
147
|
+
const modeUrlMap = {
|
|
148
|
+
onboarding: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${initOptions.token}`,
|
|
149
|
+
offboarding: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${initOptions.token}`,
|
|
150
|
+
split: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${initOptions.token}`,
|
|
151
|
+
repay: `${envToBaseUrlMapExperience[initOptions.environment]}?token=${initOptions.token}`,
|
|
193
152
|
};
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
153
|
+
const modeUrl = openOptions.mode ?
|
|
154
|
+
modeUrlMap[openOptions.mode] :
|
|
155
|
+
`${envToBaseUrlMapExperience[initOptions.environment]}?token=${initOptions.token}`;
|
|
156
|
+
const w = 450;
|
|
157
|
+
const h = 800;
|
|
158
|
+
const l = screen.width / 2 - w / 2;
|
|
159
|
+
const t = screen.height / 2 - h / 2;
|
|
199
160
|
_popup = window.open(modeUrl, "LvblePopup", "width=" + w + ",height=" + h + ",location=no,left=" + l + ",top=" + t);
|
|
200
|
-
|
|
161
|
+
const messageListener = (message) => {
|
|
201
162
|
if (message.origin != envToBaseUrlMapExperience[initOptions.environment]) {
|
|
202
|
-
console.debug(
|
|
163
|
+
console.debug(`Received message from unknown origin: ${message.origin}`);
|
|
203
164
|
return;
|
|
204
165
|
}
|
|
205
|
-
|
|
206
|
-
|
|
166
|
+
const eventData = message.data;
|
|
167
|
+
const iframes = document.querySelectorAll("lvble-widget");
|
|
207
168
|
message = JSON.parse(JSON.stringify(message));
|
|
208
|
-
iframes.forEach(
|
|
169
|
+
iframes.forEach((w) => {
|
|
209
170
|
var _a, _b;
|
|
210
171
|
(_b = ((_a = w.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector("iframe")).contentWindow) === null || _b === void 0 ? void 0 : _b.postMessage(message, "*");
|
|
211
172
|
});
|
|
@@ -215,5 +176,5 @@ var lvble = function (initOptions) {
|
|
|
215
176
|
},
|
|
216
177
|
};
|
|
217
178
|
};
|
|
218
|
-
export
|
|
179
|
+
export const Lvble = lvble;
|
|
219
180
|
//# sourceMappingURL=lvble.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lvble.js","sourceRoot":"","sources":["../../src/lib/lvble.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"lvble.js","sourceRoot":"","sources":["../../src/lib/lvble.ts"],"names":[],"mappings":"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"}
|