diff --git a/dist/FlamSaasSDK.js b/dist/FlamSaasSDK.js index 3b2fccd..6427cc5 100644 --- a/dist/FlamSaasSDK.js +++ b/dist/FlamSaasSDK.js @@ -12,6 +12,7 @@ }(this, (function (exports) { 'use strict'; const SDK_BASE_URL = 'https://saas-sdk-flam.vercel.app'; + // const SDK_BASE_URL = 'http://localhost:3000'; const PAGES = { main: SDK_BASE_URL, @@ -429,4 +430,3 @@ Object.defineProperty(exports, '__esModule', { value: true }); }))); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"FlamSaasSDK.js","sources":["../src/constants.js","../src/renderWithRetry.js","../src/closeIFrame.js","../src/helper/assert.js","../src/placeOrder.js","../src/receiveMessage.js","../src/sendMessage.js","../src/sdk.js","../src/version.js","../src/index.js"],"sourcesContent":["const SDK_BASE_URL = 'https://saas-sdk-flam.vercel.app';\n\nexport const PAGES = {\n  main: SDK_BASE_URL,\n  error: `${SDK_BASE_URL}/error`\n};\n","import { PAGES } from './constants';\n\nexport let trackOrder = null;\nexport default async function renderWithRetry({ url }) {\n  const body = document.querySelector('body');\n\n  const styleSheet = document.createElement('style');\n  styleSheet.type = 'text/css';\n  styleSheet.id = 'saas-sdk-style';\n  styleSheet.innerText = `\n    .flam-sdk-bg {\n      position: fixed;\n      top: 0;\n      right: 0;\n      bottom: 0;\n      left: 0;\n\n      min-height: 100vh;\n      min-width: 100vw;\n      border: none;\n      background: rgba(0,0,0, 0.4);\n\n      display: flex;\n      justify-content: center;\n      align-items: center;\n    }\n\n    #flam-sdk-iframe {\n      position: fixed;\n      top: 0;\n      right: 0;\n      bottom: 0;\n      left: 0;\n\n      min-height: 100vh;\n      min-width: 100vw;\n      border: none;\n    }\n\n    .flam-sdk-loading {\n      display: inline-block;\n      position: relative;\n      width: 80px;\n      height: 80px;\n    }\n    .flam-sdk-loading div {\n      box-sizing: border-box;\n      display: block;\n      position: absolute;\n      width: 64px;\n      height: 64px;\n      margin: 8px;\n      border: 3px solid #000;\n      border-radius: 50%;\n      animation: flam-sdk-loading 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;\n      border-color: #000 transparent transparent transparent;\n    }\n    .flam-sdk-loading div:nth-child(1) {\n      animation-delay: -0.45s;\n    }\n    .flam-sdk-loading div:nth-child(2) {\n      animation-delay: -0.3s;\n    }\n    .flam-sdk-loading div:nth-child(3) {\n      animation-delay: -0.15s;\n    }\n    @keyframes flam-sdk-loading {\n      0% {\n        transform: rotate(0deg);\n      }\n      100% {\n        transform: rotate(360deg);\n      }\n    }\n  `;\n\n  await document.head.appendChild(styleSheet);\n\n  const UI = await document.createElement('div');\n  UI.id = 'flam-sdk-wrapper';\n\n  var RegExp = /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i;\n\n  const newUrl = () => {\n    if (\n      this.order_details &&\n      this.order_details.theme &&\n      this.order_details.theme.color &&\n      RegExp.test(this.order_details.theme.color)\n    ) {\n      const x = '/?theme=';\n      return url + x + encodeURIComponent(this.order_details.theme.color);\n    }\n    return url;\n  };\n\n  UI.innerHTML = `\n      <div class=\"flam-sdk-ui\" id=\"flam-sdk-ui\">\n        <div class=\"flam-sdk-bg\" id=\"flam-sdk-bg\">\n          <div class=\"flam-sdk-loading\" id=\"flam-sdk-loading\"><div></div><div></div><div></div><div></div></div>\n        </div>\n        <iframe id=\"flam-sdk-iframe\" style=\"opacity: 0\" name=\"flam-sdk-iframe\" src=\"${newUrl()}\" style=\"opacity: 0\"></iframe>      \n  </div>\n    `;\n\n  await body.appendChild(UI);\n\n  const iFrame = document.getElementById('flam-sdk-iframe');\n\n  iFrame.addEventListener('load', async e => {\n    e.preventDefault();\n\n    try {\n      if (this.clientData.environment == 'PRODUCTION') {\n        await fetch(PAGES.main);\n      }\n\n      // hide loading\n      document.getElementById('flam-sdk-bg').style.display = 'none';\n\n      // Bring the iframe back\n      iFrame.style.opacity = '1';\n\n      trackOrder = e => {\n        this.receiveMessage(e);\n      };\n\n      // for receiving messages from iframe\n      window.addEventListener('message', trackOrder);\n\n      // for sending messages to iframe\n      this.iWindow = document.getElementById('flam-sdk-iframe').contentWindow;\n    } catch (err) {\n      if (err.message === 'Failed to fetch') {\n        this.close();\n        this.callback({\n          code: 500,\n          message: 'SDK down!'\n        });\n      }\n    }\n  });\n}\n","import { trackOrder } from './renderWithRetry';\n\nexport default function close() {\n  window.removeEventListener('message', trackOrder);\n\n  // remove the UI\n  const element = document.getElementById('flam-sdk-wrapper');\n  if (element) {\n    element.remove();\n  }\n\n  // remove the styles\n  const styleSheet = document.getElementById('saas-sdk-style');\n\n  if (styleSheet) {\n    styleSheet.remove();\n  }\n}\n","var toString = Object.prototype.toString;\n\nfunction attribute(o, attr, type, text) {\n    type = type === 'array' ? 'object' : type;\n    if (o && typeof o[attr] !== type) {\n        throw new Error(text);\n    }\n}\n\nfunction variable(o, type, text) {\n    if (typeof o !== type) {\n        throw new Error(text);\n    }\n}\n\nfunction value(o, values, text) {\n    if (values.indexOf(o) === -1) {\n        throw new Error(text);\n    }\n}\n\nfunction check(o, config, attributes) {\n    if (!config.optional || o) {\n        variable(o, config.type, config.message);\n    }\n    if (config.type === 'object' && attributes) {\n        var keys = Object.keys(attributes);\n\n        for (var index = 0; index < keys.length; index++) {\n            var a = keys[index];\n            if (!attributes[a].optional || o[a]) {\n                if (!attributes[a].condition || attributes[a].condition(o)) {\n                    attribute(o, a, attributes[a].type, attributes[a].message);\n                    if (attributes[a].values) {\n                        value(o[a], attributes[a].values, attributes[a].value_message);\n                    }\n                }\n            }\n        }\n    }\n}\n\n/**\n * Wrap `Array.isArray` Polyfill for IE9\n * source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/isArray\n *\n * @param {Array} array\n * @private\n */\nfunction isArray(array) {\n    if (this.supportsIsArray()) {\n        return Array.isArray(array);\n    }\n\n    return toString.call(array) === '[object Array]';\n}\n\nfunction supportsIsArray() {\n    return Array.isArray != null;\n}\n\nexport default {\n    check: check,\n    attribute: attribute,\n    variable: variable,\n    value: value,\n    isArray: isArray,\n    supportsIsArray: supportsIsArray\n};","import { PAGES } from './constants';\nimport assert from './helper/assert';\n\nexport default function placeOrder(order_details, callback) {\n  this.order_details = order_details;\n  try {\n    assert.check(\n      this.clientData,\n      { type: 'object', message: 'init data is invalid' },\n      {\n        key: { type: 'string', message: 'key is required in init data' },\n        environment: {\n          optional: true,\n          type: 'string',\n          message: 'environment must be a string in init data'\n        }\n      }\n    );\n\n    assert.check(\n      order_details,\n      {\n        type: 'object',\n        message: 'options parameter is invalid'\n      },\n      {\n        productId: { type: 'string', message: 'productId is required!' }\n      },\n      {\n        refId: { type: 'string', message: 'refId is required!' }\n      }\n    );\n\n    if (callback) {\n      let url = `${PAGES.main}`;\n      this.callback = callback;\n      this.renderWithRetry({ url, error: false });\n    } else {\n      throw new Error('callback function is required!');\n    }\n  } catch (err) {\n    if (callback) {\n      let url = `${PAGES.error}/Something went wrong!`;\n      this.renderWithRetry({\n        url,\n        error: true\n      });\n      callback({ code: 400, message: err.message }, null);\n    } else {\n      throw new Error('callback function is required!');\n    }\n  }\n}\n","import { PAGES } from './constants';\n\nexport default function receiveMessage(event) {\n  if (event.origin == PAGES.main) {\n    switch (event.data.type) {\n      case 'CLOSE':\n        this.close();\n        break;\n      case 'READY_TO_RECEIVE':\n        this.sendMessage(\n          {\n            type: 'INITIAL_DATA',\n            payload: {\n              client_data: this.clientData,\n              order_details: this.order_details\n            }\n          },\n          '*'\n        );\n        break;\n      case 'READY_TO_RECEIVE_ERR':\n        this.sendMessage(\n          {\n            type: 'INITIAL_DATA_ERR',\n            payload: {\n              email:\n                this.order_details &&\n                this.order_details.prefill &&\n                this.order_details.prefill.email\n                  ? this.order_details.prefill.email\n                  : '',\n              phone:\n                this.order_details &&\n                this.order_details.prefill &&\n                this.order_details.prefill.phone\n                  ? this.order_details.prefill.phone\n                  : ''\n            }\n          },\n          '*'\n        );\n        break;\n      case 'CREATED':\n        this.callback(null, {\n          code: 201,\n          data: event.data.payload,\n          message: 'Order placed successfully'\n        });\n        this.close();\n        break;\n      case 'ERROR':\n        this.callback(\n          {\n            code: event.data.payload.code,\n            message: event.data.payload.message\n          },\n          null\n        );\n        break;\n    }\n  }\n}\n","export default function sendMessage(message) {\n  this.iWindow.postMessage(message, '*');\n}\n","import closeIframe from './closeIFrame';\nimport assert from './helper/assert';\nimport placeOrder from './placeOrder';\nimport receiveMessage from './receiveMessage';\nimport renderWithRetry from './renderWithRetry';\nimport sendMessage from './sendMessage';\n\n/**\n * Handles all the browser's AuthN/AuthZ flows\n * @constructor\n * @param {Object} options\n * @param {String} options.key the API Key found on your Application settings page\n * @param {String} [options.environment] enviornment sandbox | production\n * @param {String} [options.name] name of client\n * @param {String} [options.logoUrl] client's brand logo url\n * @param {String} [options.email] client's support email for error page\n * @param {String} [options.phone] client's support phone for error page\n */\nfunction init(options) {\n  /* eslint-disable */\n  try {\n    assert.check(\n      options,\n      { type: 'object', message: 'clientData parameter is not valid' },\n      {\n        key: { type: 'string', message: 'key is required' },\n        environment: {\n          optional: true,\n          type: 'string',\n          message: 'environment is required'\n        }\n      }\n    );\n\n    if (options.overrides) {\n      assert.check(options.overrides, {\n        type: 'object',\n        message: 'overrides option is not valid'\n      });\n    }\n  } catch (err) {\n    throw new Error(err.message);\n  }\n\n  options.environment =\n    options &&\n    typeof options.environment === 'string' &&\n    options.environment.toUpperCase() === 'PRODUCTION'\n      ? 'PRODUCTION'\n      : 'SANDBOX';\n\n  this.clientData = options;\n  /* eslint-enable */\n}\n\n// core methods\ninit.prototype.renderWithRetry = renderWithRetry;\ninit.prototype.placeOrder = placeOrder;\ninit.prototype.receiveMessage = receiveMessage;\ninit.prototype.sendMessage = sendMessage;\ninit.prototype.close = closeIframe;\n\nexport default init;\n","module.exports = { raw: '1.0.0' };","import init from './sdk';\nimport version from './version';\n\nexport { version, init };\n\nexport default { version: version, init: init };\n"],"names":["closeIframe"],"mappings":"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"} diff --git a/dist/FlamSaasSDK.min.esm.js b/dist/FlamSaasSDK.min.esm.js new file mode 100644 index 0000000..b70d295 --- /dev/null +++ b/dist/FlamSaasSDK.min.esm.js @@ -0,0 +1,9 @@ +/** + * flamsdk v1.0.0 + * Author: bucharitesh + * Date: 2022-09-02 + * License: MIT + */ + +const PAGES_main="https://saas-sdk-flam.vercel.app",PAGES_error="https://saas-sdk-flam.vercel.app/error";let trackOrder=null;var toString=Object.prototype.toString;function attribute(o,attr,type,text){if(type="array"===type?"object":type,o&&typeof o[attr]!==type)throw new Error(text)}function variable(o,type,text){if(typeof o!==type)throw new Error(text)}function value(o,values,text){if(-1===values.indexOf(o))throw new Error(text)}var assert={check:function(o,config,attributes){if(config.optional&&!o||variable(o,config.type,config.message),"object"===config.type&&attributes)for(var keys=Object.keys(attributes),index=0;index\n
\n
\n
\n \n \n `,await body.appendChild(UI);const iFrame=document.getElementById("flam-sdk-iframe");iFrame.addEventListener("load",async e=>{e.preventDefault();try{"PRODUCTION"==this.clientData.environment&&await fetch(PAGES_main),document.getElementById("flam-sdk-bg").style.display="none",iFrame.style.opacity="1",trackOrder=e=>{this.receiveMessage(e)},window.addEventListener("message",trackOrder),this.iWindow=document.getElementById("flam-sdk-iframe").contentWindow}catch(err){"Failed to fetch"===err.message&&(this.close(),this.callback({code:500,message:"SDK down!"}))}})},init.prototype.placeOrder=function(order_details,callback){this.order_details=order_details;try{if(assert.check(this.clientData,{type:"object",message:"init data is invalid"},{key:{type:"string",message:"key is required in init data"},environment:{optional:!0,type:"string",message:"environment must be a string in init data"}}),assert.check(order_details,{type:"object",message:"options parameter is invalid"},{productId:{type:"string",message:"productId is required!"}},{refId:{type:"string",message:"refId is required!"}}),!callback)throw new Error("callback function is required!");{let url=""+PAGES_main;this.callback=callback,this.renderWithRetry({url:url,error:!1})}}catch(err){if(!callback)throw new Error("callback function is required!");{let url=PAGES_error+"/Something went wrong!";this.renderWithRetry({url:url,error:!0}),callback({code:400,message:err.message},null)}}},init.prototype.receiveMessage=function(event){if(event.origin==PAGES_main)switch(event.data.type){case"CLOSE":this.close();break;case"READY_TO_RECEIVE":this.sendMessage({type:"INITIAL_DATA",payload:{client_data:this.clientData,order_details:this.order_details}},"*");break;case"READY_TO_RECEIVE_ERR":this.sendMessage({type:"INITIAL_DATA_ERR",payload:{email:this.order_details&&this.order_details.prefill&&this.order_details.prefill.email?this.order_details.prefill.email:"",phone:this.order_details&&this.order_details.prefill&&this.order_details.prefill.phone?this.order_details.prefill.phone:""}},"*");break;case"CREATED":this.callback(null,{code:201,data:event.data.payload,message:"Order placed successfully"}),this.close();break;case"ERROR":this.callback({code:event.data.payload.code,message:event.data.payload.message},null)}},init.prototype.sendMessage=function(message){this.iWindow.postMessage(message,"*")},init.prototype.close=function(){window.removeEventListener("message",trackOrder);const element=document.getElementById("flam-sdk-wrapper");element&&element.remove();const styleSheet=document.getElementById("saas-sdk-style");styleSheet&&styleSheet.remove()};var version={raw:"1.0.0"},index={version:version,init:init};export default index;export{init,version}; +//# sourceMappingURL=FlamSaasSDK.min.esm.js.map diff --git a/dist/FlamSaasSDK.min.esm.js.map b/dist/FlamSaasSDK.min.esm.js.map new file mode 100644 index 0000000..f85f6ab --- /dev/null +++ b/dist/FlamSaasSDK.min.esm.js.map @@ -0,0 +1 @@ +{"version":3,"file":"FlamSaasSDK.min.esm.js","sources":["../src/constants.js","../src/renderWithRetry.js","../src/helper/assert.js","../src/sdk.js","../src/placeOrder.js","../src/receiveMessage.js","../src/sendMessage.js","../src/closeIFrame.js","../src/version.js","../src/index.js"],"sourcesContent":["const SDK_BASE_URL = 'https://saas-sdk-flam.vercel.app';\n// const SDK_BASE_URL = 'http://localhost:3000';\n\nexport const PAGES = {\n main: SDK_BASE_URL,\n error: `${SDK_BASE_URL}/error`\n};\n","import { PAGES } from './constants';\n\nexport let trackOrder = null;\nexport default async function renderWithRetry({ url }) {\n const body = document.querySelector('body');\n\n const styleSheet = document.createElement('style');\n styleSheet.type = 'text/css';\n styleSheet.id = 'saas-sdk-style';\n styleSheet.innerText = `\n .flam-sdk-bg {\n position: fixed;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n\n min-height: 100vh;\n min-width: 100vw;\n border: none;\n background: rgba(0,0,0, 0.4);\n\n display: flex;\n justify-content: center;\n align-items: center;\n }\n\n #flam-sdk-iframe {\n position: fixed;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n\n min-height: 100vh;\n min-width: 100vw;\n border: none;\n }\n\n .flam-sdk-loading {\n display: inline-block;\n position: relative;\n width: 80px;\n height: 80px;\n }\n .flam-sdk-loading div {\n box-sizing: border-box;\n display: block;\n position: absolute;\n width: 64px;\n height: 64px;\n margin: 8px;\n border: 3px solid #000;\n border-radius: 50%;\n animation: flam-sdk-loading 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;\n border-color: #000 transparent transparent transparent;\n }\n .flam-sdk-loading div:nth-child(1) {\n animation-delay: -0.45s;\n }\n .flam-sdk-loading div:nth-child(2) {\n animation-delay: -0.3s;\n }\n .flam-sdk-loading div:nth-child(3) {\n animation-delay: -0.15s;\n }\n @keyframes flam-sdk-loading {\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n }\n `;\n\n await document.head.appendChild(styleSheet);\n\n const UI = await document.createElement('div');\n UI.id = 'flam-sdk-wrapper';\n\n var RegExp = /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i;\n\n const newUrl = () => {\n if (\n this.order_details &&\n this.order_details.theme &&\n this.order_details.theme.color &&\n RegExp.test(this.order_details.theme.color)\n ) {\n const x = '/?theme=';\n return url + x + encodeURIComponent(this.order_details.theme.color);\n }\n return url;\n };\n\n UI.innerHTML = `\n
\n
\n
\n
\n \n
\n `;\n\n await body.appendChild(UI);\n\n const iFrame = document.getElementById('flam-sdk-iframe');\n\n iFrame.addEventListener('load', async e => {\n e.preventDefault();\n\n try {\n if (this.clientData.environment == 'PRODUCTION') {\n await fetch(PAGES.main);\n }\n\n // hide loading\n document.getElementById('flam-sdk-bg').style.display = 'none';\n\n // Bring the iframe back\n iFrame.style.opacity = '1';\n\n trackOrder = e => {\n this.receiveMessage(e);\n };\n\n // for receiving messages from iframe\n window.addEventListener('message', trackOrder);\n\n // for sending messages to iframe\n this.iWindow = document.getElementById('flam-sdk-iframe').contentWindow;\n } catch (err) {\n if (err.message === 'Failed to fetch') {\n this.close();\n this.callback({\n code: 500,\n message: 'SDK down!'\n });\n }\n }\n });\n}\n","var toString = Object.prototype.toString;\n\nfunction attribute(o, attr, type, text) {\n type = type === 'array' ? 'object' : type;\n if (o && typeof o[attr] !== type) {\n throw new Error(text);\n }\n}\n\nfunction variable(o, type, text) {\n if (typeof o !== type) {\n throw new Error(text);\n }\n}\n\nfunction value(o, values, text) {\n if (values.indexOf(o) === -1) {\n throw new Error(text);\n }\n}\n\nfunction check(o, config, attributes) {\n if (!config.optional || o) {\n variable(o, config.type, config.message);\n }\n if (config.type === 'object' && attributes) {\n var keys = Object.keys(attributes);\n\n for (var index = 0; index < keys.length; index++) {\n var a = keys[index];\n if (!attributes[a].optional || o[a]) {\n if (!attributes[a].condition || attributes[a].condition(o)) {\n attribute(o, a, attributes[a].type, attributes[a].message);\n if (attributes[a].values) {\n value(o[a], attributes[a].values, attributes[a].value_message);\n }\n }\n }\n }\n }\n}\n\n/**\n * Wrap `Array.isArray` Polyfill for IE9\n * source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/isArray\n *\n * @param {Array} array\n * @private\n */\nfunction isArray(array) {\n if (this.supportsIsArray()) {\n return Array.isArray(array);\n }\n\n return toString.call(array) === '[object Array]';\n}\n\nfunction supportsIsArray() {\n return Array.isArray != null;\n}\n\nexport default {\n check: check,\n attribute: attribute,\n variable: variable,\n value: value,\n isArray: isArray,\n supportsIsArray: supportsIsArray\n};","import closeIframe from './closeIFrame';\nimport assert from './helper/assert';\nimport placeOrder from './placeOrder';\nimport receiveMessage from './receiveMessage';\nimport renderWithRetry from './renderWithRetry';\nimport sendMessage from './sendMessage';\n\n/**\n * Handles all the browser's AuthN/AuthZ flows\n * @constructor\n * @param {Object} options\n * @param {String} options.key the API Key found on your Application settings page\n * @param {String} [options.environment] enviornment sandbox | production\n * @param {String} [options.name] name of client\n * @param {String} [options.logoUrl] client's brand logo url\n * @param {String} [options.email] client's support email for error page\n * @param {String} [options.phone] client's support phone for error page\n */\nfunction init(options) {\n /* eslint-disable */\n try {\n assert.check(\n options,\n { type: 'object', message: 'clientData parameter is not valid' },\n {\n key: { type: 'string', message: 'key is required' },\n environment: {\n optional: true,\n type: 'string',\n message: 'environment is required'\n }\n }\n );\n\n if (options.overrides) {\n assert.check(options.overrides, {\n type: 'object',\n message: 'overrides option is not valid'\n });\n }\n } catch (err) {\n throw new Error(err.message);\n }\n\n options.environment =\n options &&\n typeof options.environment === 'string' &&\n options.environment.toUpperCase() === 'PRODUCTION'\n ? 'PRODUCTION'\n : 'SANDBOX';\n\n this.clientData = options;\n /* eslint-enable */\n}\n\n// core methods\ninit.prototype.renderWithRetry = renderWithRetry;\ninit.prototype.placeOrder = placeOrder;\ninit.prototype.receiveMessage = receiveMessage;\ninit.prototype.sendMessage = sendMessage;\ninit.prototype.close = closeIframe;\n\nexport default init;\n","import { PAGES } from './constants';\nimport assert from './helper/assert';\n\nexport default function placeOrder(order_details, callback) {\n this.order_details = order_details;\n try {\n assert.check(\n this.clientData,\n { type: 'object', message: 'init data is invalid' },\n {\n key: { type: 'string', message: 'key is required in init data' },\n environment: {\n optional: true,\n type: 'string',\n message: 'environment must be a string in init data'\n }\n }\n );\n\n assert.check(\n order_details,\n {\n type: 'object',\n message: 'options parameter is invalid'\n },\n {\n productId: { type: 'string', message: 'productId is required!' }\n },\n {\n refId: { type: 'string', message: 'refId is required!' }\n }\n );\n\n if (callback) {\n let url = `${PAGES.main}`;\n this.callback = callback;\n this.renderWithRetry({ url, error: false });\n } else {\n throw new Error('callback function is required!');\n }\n } catch (err) {\n if (callback) {\n let url = `${PAGES.error}/Something went wrong!`;\n this.renderWithRetry({\n url,\n error: true\n });\n callback({ code: 400, message: err.message }, null);\n } else {\n throw new Error('callback function is required!');\n }\n }\n}\n","import { PAGES } from './constants';\n\nexport default function receiveMessage(event) {\n if (event.origin == PAGES.main) {\n switch (event.data.type) {\n case 'CLOSE':\n this.close();\n break;\n case 'READY_TO_RECEIVE':\n this.sendMessage(\n {\n type: 'INITIAL_DATA',\n payload: {\n client_data: this.clientData,\n order_details: this.order_details\n }\n },\n '*'\n );\n break;\n case 'READY_TO_RECEIVE_ERR':\n this.sendMessage(\n {\n type: 'INITIAL_DATA_ERR',\n payload: {\n email:\n this.order_details &&\n this.order_details.prefill &&\n this.order_details.prefill.email\n ? this.order_details.prefill.email\n : '',\n phone:\n this.order_details &&\n this.order_details.prefill &&\n this.order_details.prefill.phone\n ? this.order_details.prefill.phone\n : ''\n }\n },\n '*'\n );\n break;\n case 'CREATED':\n this.callback(null, {\n code: 201,\n data: event.data.payload,\n message: 'Order placed successfully'\n });\n this.close();\n break;\n case 'ERROR':\n this.callback(\n {\n code: event.data.payload.code,\n message: event.data.payload.message\n },\n null\n );\n break;\n }\n }\n}\n","export default function sendMessage(message) {\n this.iWindow.postMessage(message, '*');\n}\n","import { trackOrder } from './renderWithRetry';\n\nexport default function close() {\n window.removeEventListener('message', trackOrder);\n\n // remove the UI\n const element = document.getElementById('flam-sdk-wrapper');\n if (element) {\n element.remove();\n }\n\n // remove the styles\n const styleSheet = document.getElementById('saas-sdk-style');\n\n if (styleSheet) {\n styleSheet.remove();\n }\n}\n","module.exports = { raw: '1.0.0' };","import init from './sdk';\nimport version from './version';\n\nexport { version, init };\n\nexport default { version: version, init: init };\n"],"names":["PAGES","trackOrder","toString","Object","prototype","attribute","o","attr","type","text","Error","variable","value","values","indexOf","check","config","attributes","optional","message","keys","index","length","a","condition","value_message","isArray","array","this","supportsIsArray","Array","call","init","options","assert","key","environment","overrides","err","toUpperCase","clientData","renderWithRetry","async","url","body","document","querySelector","styleSheet","createElement","id","innerText","head","appendChild","UI","RegExp","innerHTML","order_details","theme","color","test","encodeURIComponent","newUrl","iFrame","getElementById","addEventListener","e","preventDefault","fetch","style","display","opacity","receiveMessage","window","iWindow","contentWindow","close","callback","code","placeOrder","productId","refId","error","event","origin","data","sendMessage","payload","client_data","email","prefill","phone","postMessage","removeEventListener","element","remove","raw","version"],"mappings":"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"} \ No newline at end of file diff --git a/dist/FlamSaasSDK.min.js b/dist/FlamSaasSDK.min.js new file mode 100644 index 0000000..9a0b6fa --- /dev/null +++ b/dist/FlamSaasSDK.min.js @@ -0,0 +1,9 @@ +/** + * flamsdk v1.0.0 + * Author: bucharitesh + * Date: 2022-09-02 + * License: MIT + */ + +!function(global,factory){"object"==typeof exports&&"undefined"!=typeof module?factory(exports):"function"==typeof define&&define.amd?define(["exports"],factory):factory((global=global||self).FlamSaasSDK={})}(this,(function(exports){"use strict";const PAGES_main="https://saas-sdk-flam.vercel.app",PAGES_error="https://saas-sdk-flam.vercel.app/error";let trackOrder=null;var toString=Object.prototype.toString;function attribute(o,attr,type,text){if(type="array"===type?"object":type,o&&typeof o[attr]!==type)throw new Error(text)}function variable(o,type,text){if(typeof o!==type)throw new Error(text)}function value(o,values,text){if(-1===values.indexOf(o))throw new Error(text)}var assert={check:function(o,config,attributes){if(config.optional&&!o||variable(o,config.type,config.message),"object"===config.type&&attributes)for(var keys=Object.keys(attributes),index=0;index\n
\n
\n
\n \n \n `,await body.appendChild(UI);const iFrame=document.getElementById("flam-sdk-iframe");iFrame.addEventListener("load",async e=>{e.preventDefault();try{"PRODUCTION"==this.clientData.environment&&await fetch(PAGES_main),document.getElementById("flam-sdk-bg").style.display="none",iFrame.style.opacity="1",trackOrder=e=>{this.receiveMessage(e)},window.addEventListener("message",trackOrder),this.iWindow=document.getElementById("flam-sdk-iframe").contentWindow}catch(err){"Failed to fetch"===err.message&&(this.close(),this.callback({code:500,message:"SDK down!"}))}})},init.prototype.placeOrder=function(order_details,callback){this.order_details=order_details;try{if(assert.check(this.clientData,{type:"object",message:"init data is invalid"},{key:{type:"string",message:"key is required in init data"},environment:{optional:!0,type:"string",message:"environment must be a string in init data"}}),assert.check(order_details,{type:"object",message:"options parameter is invalid"},{productId:{type:"string",message:"productId is required!"}},{refId:{type:"string",message:"refId is required!"}}),!callback)throw new Error("callback function is required!");{let url=""+PAGES_main;this.callback=callback,this.renderWithRetry({url:url,error:!1})}}catch(err){if(!callback)throw new Error("callback function is required!");{let url=PAGES_error+"/Something went wrong!";this.renderWithRetry({url:url,error:!0}),callback({code:400,message:err.message},null)}}},init.prototype.receiveMessage=function(event){if(event.origin==PAGES_main)switch(event.data.type){case"CLOSE":this.close();break;case"READY_TO_RECEIVE":this.sendMessage({type:"INITIAL_DATA",payload:{client_data:this.clientData,order_details:this.order_details}},"*");break;case"READY_TO_RECEIVE_ERR":this.sendMessage({type:"INITIAL_DATA_ERR",payload:{email:this.order_details&&this.order_details.prefill&&this.order_details.prefill.email?this.order_details.prefill.email:"",phone:this.order_details&&this.order_details.prefill&&this.order_details.prefill.phone?this.order_details.prefill.phone:""}},"*");break;case"CREATED":this.callback(null,{code:201,data:event.data.payload,message:"Order placed successfully"}),this.close();break;case"ERROR":this.callback({code:event.data.payload.code,message:event.data.payload.message},null)}},init.prototype.sendMessage=function(message){this.iWindow.postMessage(message,"*")},init.prototype.close=function(){window.removeEventListener("message",trackOrder);const element=document.getElementById("flam-sdk-wrapper");element&&element.remove();const styleSheet=document.getElementById("saas-sdk-style");styleSheet&&styleSheet.remove()};var version={raw:"1.0.0"},index={version:version,init:init};exports.default=index,exports.init=init,exports.version=version,Object.defineProperty(exports,"__esModule",{value:!0})})); +//# sourceMappingURL=FlamSaasSDK.min.js.map diff --git a/dist/FlamSaasSDK.min.js.map b/dist/FlamSaasSDK.min.js.map new file mode 100644 index 0000000..390239e --- /dev/null +++ b/dist/FlamSaasSDK.min.js.map @@ -0,0 +1 @@ +{"version":3,"file":"FlamSaasSDK.min.js","sources":["../src/constants.js","../src/renderWithRetry.js","../src/helper/assert.js","../src/sdk.js","../src/placeOrder.js","../src/receiveMessage.js","../src/sendMessage.js","../src/closeIFrame.js","../src/version.js","../src/index.js"],"sourcesContent":["const SDK_BASE_URL = 'https://saas-sdk-flam.vercel.app';\n// const SDK_BASE_URL = 'http://localhost:3000';\n\nexport const PAGES = {\n main: SDK_BASE_URL,\n error: `${SDK_BASE_URL}/error`\n};\n","import { PAGES } from './constants';\n\nexport let trackOrder = null;\nexport default async function renderWithRetry({ url }) {\n const body = document.querySelector('body');\n\n const styleSheet = document.createElement('style');\n styleSheet.type = 'text/css';\n styleSheet.id = 'saas-sdk-style';\n styleSheet.innerText = `\n .flam-sdk-bg {\n position: fixed;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n\n min-height: 100vh;\n min-width: 100vw;\n border: none;\n background: rgba(0,0,0, 0.4);\n\n display: flex;\n justify-content: center;\n align-items: center;\n }\n\n #flam-sdk-iframe {\n position: fixed;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n\n min-height: 100vh;\n min-width: 100vw;\n border: none;\n }\n\n .flam-sdk-loading {\n display: inline-block;\n position: relative;\n width: 80px;\n height: 80px;\n }\n .flam-sdk-loading div {\n box-sizing: border-box;\n display: block;\n position: absolute;\n width: 64px;\n height: 64px;\n margin: 8px;\n border: 3px solid #000;\n border-radius: 50%;\n animation: flam-sdk-loading 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;\n border-color: #000 transparent transparent transparent;\n }\n .flam-sdk-loading div:nth-child(1) {\n animation-delay: -0.45s;\n }\n .flam-sdk-loading div:nth-child(2) {\n animation-delay: -0.3s;\n }\n .flam-sdk-loading div:nth-child(3) {\n animation-delay: -0.15s;\n }\n @keyframes flam-sdk-loading {\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n }\n `;\n\n await document.head.appendChild(styleSheet);\n\n const UI = await document.createElement('div');\n UI.id = 'flam-sdk-wrapper';\n\n var RegExp = /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i;\n\n const newUrl = () => {\n if (\n this.order_details &&\n this.order_details.theme &&\n this.order_details.theme.color &&\n RegExp.test(this.order_details.theme.color)\n ) {\n const x = '/?theme=';\n return url + x + encodeURIComponent(this.order_details.theme.color);\n }\n return url;\n };\n\n UI.innerHTML = `\n
\n
\n
\n
\n \n
\n `;\n\n await body.appendChild(UI);\n\n const iFrame = document.getElementById('flam-sdk-iframe');\n\n iFrame.addEventListener('load', async e => {\n e.preventDefault();\n\n try {\n if (this.clientData.environment == 'PRODUCTION') {\n await fetch(PAGES.main);\n }\n\n // hide loading\n document.getElementById('flam-sdk-bg').style.display = 'none';\n\n // Bring the iframe back\n iFrame.style.opacity = '1';\n\n trackOrder = e => {\n this.receiveMessage(e);\n };\n\n // for receiving messages from iframe\n window.addEventListener('message', trackOrder);\n\n // for sending messages to iframe\n this.iWindow = document.getElementById('flam-sdk-iframe').contentWindow;\n } catch (err) {\n if (err.message === 'Failed to fetch') {\n this.close();\n this.callback({\n code: 500,\n message: 'SDK down!'\n });\n }\n }\n });\n}\n","var toString = Object.prototype.toString;\n\nfunction attribute(o, attr, type, text) {\n type = type === 'array' ? 'object' : type;\n if (o && typeof o[attr] !== type) {\n throw new Error(text);\n }\n}\n\nfunction variable(o, type, text) {\n if (typeof o !== type) {\n throw new Error(text);\n }\n}\n\nfunction value(o, values, text) {\n if (values.indexOf(o) === -1) {\n throw new Error(text);\n }\n}\n\nfunction check(o, config, attributes) {\n if (!config.optional || o) {\n variable(o, config.type, config.message);\n }\n if (config.type === 'object' && attributes) {\n var keys = Object.keys(attributes);\n\n for (var index = 0; index < keys.length; index++) {\n var a = keys[index];\n if (!attributes[a].optional || o[a]) {\n if (!attributes[a].condition || attributes[a].condition(o)) {\n attribute(o, a, attributes[a].type, attributes[a].message);\n if (attributes[a].values) {\n value(o[a], attributes[a].values, attributes[a].value_message);\n }\n }\n }\n }\n }\n}\n\n/**\n * Wrap `Array.isArray` Polyfill for IE9\n * source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/isArray\n *\n * @param {Array} array\n * @private\n */\nfunction isArray(array) {\n if (this.supportsIsArray()) {\n return Array.isArray(array);\n }\n\n return toString.call(array) === '[object Array]';\n}\n\nfunction supportsIsArray() {\n return Array.isArray != null;\n}\n\nexport default {\n check: check,\n attribute: attribute,\n variable: variable,\n value: value,\n isArray: isArray,\n supportsIsArray: supportsIsArray\n};","import closeIframe from './closeIFrame';\nimport assert from './helper/assert';\nimport placeOrder from './placeOrder';\nimport receiveMessage from './receiveMessage';\nimport renderWithRetry from './renderWithRetry';\nimport sendMessage from './sendMessage';\n\n/**\n * Handles all the browser's AuthN/AuthZ flows\n * @constructor\n * @param {Object} options\n * @param {String} options.key the API Key found on your Application settings page\n * @param {String} [options.environment] enviornment sandbox | production\n * @param {String} [options.name] name of client\n * @param {String} [options.logoUrl] client's brand logo url\n * @param {String} [options.email] client's support email for error page\n * @param {String} [options.phone] client's support phone for error page\n */\nfunction init(options) {\n /* eslint-disable */\n try {\n assert.check(\n options,\n { type: 'object', message: 'clientData parameter is not valid' },\n {\n key: { type: 'string', message: 'key is required' },\n environment: {\n optional: true,\n type: 'string',\n message: 'environment is required'\n }\n }\n );\n\n if (options.overrides) {\n assert.check(options.overrides, {\n type: 'object',\n message: 'overrides option is not valid'\n });\n }\n } catch (err) {\n throw new Error(err.message);\n }\n\n options.environment =\n options &&\n typeof options.environment === 'string' &&\n options.environment.toUpperCase() === 'PRODUCTION'\n ? 'PRODUCTION'\n : 'SANDBOX';\n\n this.clientData = options;\n /* eslint-enable */\n}\n\n// core methods\ninit.prototype.renderWithRetry = renderWithRetry;\ninit.prototype.placeOrder = placeOrder;\ninit.prototype.receiveMessage = receiveMessage;\ninit.prototype.sendMessage = sendMessage;\ninit.prototype.close = closeIframe;\n\nexport default init;\n","import { PAGES } from './constants';\nimport assert from './helper/assert';\n\nexport default function placeOrder(order_details, callback) {\n this.order_details = order_details;\n try {\n assert.check(\n this.clientData,\n { type: 'object', message: 'init data is invalid' },\n {\n key: { type: 'string', message: 'key is required in init data' },\n environment: {\n optional: true,\n type: 'string',\n message: 'environment must be a string in init data'\n }\n }\n );\n\n assert.check(\n order_details,\n {\n type: 'object',\n message: 'options parameter is invalid'\n },\n {\n productId: { type: 'string', message: 'productId is required!' }\n },\n {\n refId: { type: 'string', message: 'refId is required!' }\n }\n );\n\n if (callback) {\n let url = `${PAGES.main}`;\n this.callback = callback;\n this.renderWithRetry({ url, error: false });\n } else {\n throw new Error('callback function is required!');\n }\n } catch (err) {\n if (callback) {\n let url = `${PAGES.error}/Something went wrong!`;\n this.renderWithRetry({\n url,\n error: true\n });\n callback({ code: 400, message: err.message }, null);\n } else {\n throw new Error('callback function is required!');\n }\n }\n}\n","import { PAGES } from './constants';\n\nexport default function receiveMessage(event) {\n if (event.origin == PAGES.main) {\n switch (event.data.type) {\n case 'CLOSE':\n this.close();\n break;\n case 'READY_TO_RECEIVE':\n this.sendMessage(\n {\n type: 'INITIAL_DATA',\n payload: {\n client_data: this.clientData,\n order_details: this.order_details\n }\n },\n '*'\n );\n break;\n case 'READY_TO_RECEIVE_ERR':\n this.sendMessage(\n {\n type: 'INITIAL_DATA_ERR',\n payload: {\n email:\n this.order_details &&\n this.order_details.prefill &&\n this.order_details.prefill.email\n ? this.order_details.prefill.email\n : '',\n phone:\n this.order_details &&\n this.order_details.prefill &&\n this.order_details.prefill.phone\n ? this.order_details.prefill.phone\n : ''\n }\n },\n '*'\n );\n break;\n case 'CREATED':\n this.callback(null, {\n code: 201,\n data: event.data.payload,\n message: 'Order placed successfully'\n });\n this.close();\n break;\n case 'ERROR':\n this.callback(\n {\n code: event.data.payload.code,\n message: event.data.payload.message\n },\n null\n );\n break;\n }\n }\n}\n","export default function sendMessage(message) {\n this.iWindow.postMessage(message, '*');\n}\n","import { trackOrder } from './renderWithRetry';\n\nexport default function close() {\n window.removeEventListener('message', trackOrder);\n\n // remove the UI\n const element = document.getElementById('flam-sdk-wrapper');\n if (element) {\n element.remove();\n }\n\n // remove the styles\n const styleSheet = document.getElementById('saas-sdk-style');\n\n if (styleSheet) {\n styleSheet.remove();\n }\n}\n","module.exports = { raw: '1.0.0' };","import init from './sdk';\nimport version from './version';\n\nexport { version, init };\n\nexport default { version: version, init: init };\n"],"names":["PAGES","trackOrder","toString","Object","prototype","attribute","o","attr","type","text","Error","variable","value","values","indexOf","check","config","attributes","optional","message","keys","index","length","a","condition","value_message","isArray","array","this","supportsIsArray","Array","call","init","options","assert","key","environment","overrides","err","toUpperCase","clientData","renderWithRetry","async","url","body","document","querySelector","styleSheet","createElement","id","innerText","head","appendChild","UI","RegExp","innerHTML","order_details","theme","color","test","encodeURIComponent","newUrl","iFrame","getElementById","addEventListener","e","preventDefault","fetch","style","display","opacity","receiveMessage","window","iWindow","contentWindow","close","callback","code","placeOrder","productId","refId","error","event","origin","data","sendMessage","payload","client_data","email","prefill","phone","postMessage","removeEventListener","element","remove","raw","version"],"mappings":"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"} \ No newline at end of file diff --git a/examples/vanilla-js/index.html b/examples/vanilla-js/index.html index cbd8ace..4422230 100644 --- a/examples/vanilla-js/index.html +++ b/examples/vanilla-js/index.html @@ -14,6 +14,8 @@ /> + + diff --git a/src/constants.js b/src/constants.js index 95db58c..11ae80a 100644 --- a/src/constants.js +++ b/src/constants.js @@ -1,4 +1,5 @@ const SDK_BASE_URL = 'https://saas-sdk-flam.vercel.app'; +// const SDK_BASE_URL = 'http://localhost:3000'; export const PAGES = { main: SDK_BASE_URL,