diff --git a/dist/FlamSaasSDK.js b/dist/FlamSaasSDK.js index abcd949..cec5e91 100644 --- a/dist/FlamSaasSDK.js +++ b/dist/FlamSaasSDK.js @@ -1,7 +1,7 @@ /** * flamsdk v1.0.0 * Author: bucharitesh - * Date: 2022-09-07 + * Date: 2022-09-12 * License: MIT */ @@ -11,8 +11,8 @@ (global = global || self, factory(global.FlamSaasSDK = {})); }(this, (function (exports) { 'use strict'; - const SDK_BASE_URL = 'https://saas-sdk-flam.vpercel.app'; - // const SDK_BASE_URL = 'http://localhost:3000'; + // const SDK_BASE_URL = 'https://saas-sdk-flam.vercel.app'; + const SDK_BASE_URL = 'http://localhost:3000'; const PAGES = { main: SDK_BASE_URL, @@ -276,7 +276,7 @@ // TODO: write the parameter descriptions - function placeOrder(order_details, callback) { + async function placeOrder(order_details, callback) { try { // validate client data assert.check( @@ -350,18 +350,19 @@ // render the success UI let url = `${PAGES.main}`; this.callback = callback; - this.renderWithRetry(url); + await this.renderWithRetry(url); } catch (err) { if (callback && typeof callback === 'function') { // render error UI let url = `${PAGES.error}/Something went wrong!`; - this.renderWithRetry(url); + await this.renderWithRetry(url); // callback to client with error - callback({ code: 400, message: err.message }, null); + await callback({ code: 400, message: err.message }, null); } else { throw "'callback' is required function."; } } + document.activeElement.blur(); } function receiveMessage(event) { @@ -487,4 +488,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.vpercel.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;\n\n/**\n * Renders the UI for Placing Order\n * @function\n * @param {String} url url to either order flow or error page\n */\n\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    body {\n      overflow: hidden;\n    }\n\n    .flam-sdk-loading-wrapper {\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      overflow: hidden;\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      position: relative;\n      width: 80px;\n      height: 80px;\n    }\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  document.head.appendChild(styleSheet);\n\n  const UI = 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-loading-wrapper\" id=\"flam-sdk-loading-wrapper\">\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    `;\n\n  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      // check if website available in PRODUCTION\n      if (this.clientData.environment == 'PRODUCTION') {\n        await fetch(PAGES.main);\n      }\n\n      // hide initial loading\n      document.getElementById('flam-sdk-loading-wrapper').style.display =\n        'none';\n\n      // Show the iframe content\n      iFrame.style.opacity = '1';\n\n      // message event handler\n      trackOrder = e => {\n        this.receiveMessage(e);\n      };\n\n      // event listener for receiving messages from iframe\n      window.addEventListener('message', trackOrder);\n\n      // save window context 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: 'Unable to acess SDK Website!'\n        });\n        return;\n      }\n      this.callback({\n        code: 500,\n        message: 'Something went wrong!'\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\n/**\n * Runs the SDK for Placing Order\n * @function\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 */\n\n// TODO: write the parameter descriptions\n\nexport default function placeOrder(order_details, callback) {\n  try {\n    // validate client data\n    assert.check(\n      this.clientData,\n      { type: 'object', message: 'init data is invalid' },\n      {\n        key: { type: 'string', message: \"'key' is required string.\" },\n        environment: {\n          optional: true,\n          type: 'string',\n          message: \"'environment' must be string.\"\n        }\n      }\n    );\n\n    // validate order_details\n    assert.check(\n      order_details,\n      {\n        type: 'object',\n        message: \"'order_details' is not valid.\"\n      },\n      {\n        productId: {\n          type: 'string',\n          message: \"'productId' is required string.\"\n        },\n        refId: { type: 'string', message: \"'refId' is required string.\" },\n        photo: {\n          optional: true,\n          type: 'string',\n          message: \"'photo' must be string.\"\n        },\n        video: {\n          optional: true,\n          type: 'string',\n          message: \"'video' must be string.\"\n        },\n        prefill: {\n          optional: true,\n          type: 'object',\n          message: \"'prefill' must be object.\"\n        },\n        animation: {\n          optional: true,\n          type: 'string',\n          message: \"'animation' must be string.\"\n        },\n        theme: {\n          optional: true,\n          type: 'object',\n          message: \"'theme' must be object.\"\n        },\n        logo: {\n          optional: true,\n          type: 'object',\n          message: \"'logo' must be string.\"\n        }\n      }\n    );\n\n    // validate callback function\n    assert.check(callback, {\n      type: 'function',\n      message: \"'callback' is required function.\"\n    });\n\n    // save order_details\n    this.order_details = order_details;\n\n    // render the success UI\n    let url = `${PAGES.main}`;\n    this.callback = callback;\n    this.renderWithRetry(url);\n  } catch (err) {\n    if (callback && typeof callback === 'function') {\n      // render error UI\n      let url = `${PAGES.error}/Something went wrong!`;\n      this.renderWithRetry(url);\n      // callback to client with error\n      callback({ code: 400, message: err.message }, null);\n    } else {\n      throw \"'callback' is required function.\";\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          type: 'INITIAL_DATA',\n          payload: {\n            client_data: this.clientData,\n            order_details: this.order_details\n          }\n        });\n        break;\n      case 'READY_TO_RECEIVE_ERR':\n        this.sendMessage({\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        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","import { PAGES } from './constants';\n\nexport default function sendMessage(message) {\n  this.iWindow.postMessage(message, PAGES.main);\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 * Initializes a SDK instance\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 */\nfunction init(options) {\n  /* eslint-disable */\n\n  // validate the client's input for 'init'\n  try {\n    assert.check(\n      options,\n      { type: 'object', message: 'init parameter is not valid.' },\n      {\n        key: { type: 'string', message: \"'key' is required string.\" },\n        environment: {\n          optional: true,\n          type: 'string',\n          message: \"'environment' must be string.\"\n        }\n      }\n    );\n  } catch (err) {\n    // assert method above throws error with given message which we further throw to client.\n    if (err && err.message) {\n      throw err.message;\n    }\n    throw 'Something went wrong!';\n  }\n\n  // set environment to 'PRODUCTION' if stated by client, otherwise 'SANDBOX'\n  options.environment =\n    options &&\n    typeof options.environment === 'string' &&\n    options.environment.toUpperCase() === 'PRODUCTION'\n      ? 'PRODUCTION'\n      : 'SANDBOX';\n\n  // save options to clientData\n  this.clientData = options;\n\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..270c580 --- /dev/null +++ b/dist/FlamSaasSDK.min.esm.js @@ -0,0 +1,9 @@ +/** + * flamsdk v1.0.0 + * Author: bucharitesh + * Date: 2022-09-12 + * License: MIT + */ + +const PAGES_main="http://localhost:3000",PAGES_error="http://localhost:3000/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 `,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-loading-wrapper").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){if("Failed to fetch"===err.message)return this.close(),void this.callback({code:500,message:"Unable to acess SDK Website!"});this.callback({code:500,message:"Something went wrong!"})}})},init.prototype.placeOrder=async function(order_details,callback){try{assert.check(this.clientData,{type:"object",message:"init data is invalid"},{key:{type:"string",message:"'key' is required string."},environment:{optional:!0,type:"string",message:"'environment' must be string."}}),assert.check(order_details,{type:"object",message:"'order_details' is not valid."},{productId:{type:"string",message:"'productId' is required string."},refId:{type:"string",message:"'refId' is required string."},photo:{optional:!0,type:"string",message:"'photo' must be string."},video:{optional:!0,type:"string",message:"'video' must be string."},prefill:{optional:!0,type:"object",message:"'prefill' must be object."},animation:{optional:!0,type:"string",message:"'animation' must be string."},theme:{optional:!0,type:"object",message:"'theme' must be object."},logo:{optional:!0,type:"object",message:"'logo' must be string."}}),assert.check(callback,{type:"function",message:"'callback' is required function."}),this.order_details=order_details;let url=""+PAGES_main;this.callback=callback,await this.renderWithRetry(url)}catch(err){if(!callback||"function"!=typeof callback)throw"'callback' is required function.";{let url=PAGES_error+"/Something went wrong!";await this.renderWithRetry(url),await callback({code:400,message:err.message},null)}}document.activeElement.blur()},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,PAGES_main)},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..54dadf9 --- /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';\nconst 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;\n\n/**\n * Renders the UI for Placing Order\n * @function\n * @param {String} url url to either order flow or error page\n */\n\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 body {\n overflow: hidden;\n }\n\n .flam-sdk-loading-wrapper {\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 overflow: hidden;\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 position: relative;\n width: 80px;\n height: 80px;\n }\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 document.head.appendChild(styleSheet);\n\n const UI = 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 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 // check if website available in PRODUCTION\n if (this.clientData.environment == 'PRODUCTION') {\n await fetch(PAGES.main);\n }\n\n // hide initial loading\n document.getElementById('flam-sdk-loading-wrapper').style.display =\n 'none';\n\n // Show the iframe content\n iFrame.style.opacity = '1';\n\n // message event handler\n trackOrder = e => {\n this.receiveMessage(e);\n };\n\n // event listener for receiving messages from iframe\n window.addEventListener('message', trackOrder);\n\n // save window context 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: 'Unable to acess SDK Website!'\n });\n return;\n }\n this.callback({\n code: 500,\n message: 'Something went wrong!'\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 * Initializes a SDK instance\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 */\nfunction init(options) {\n /* eslint-disable */\n\n // validate the client's input for 'init'\n try {\n assert.check(\n options,\n { type: 'object', message: 'init parameter is not valid.' },\n {\n key: { type: 'string', message: \"'key' is required string.\" },\n environment: {\n optional: true,\n type: 'string',\n message: \"'environment' must be string.\"\n }\n }\n );\n } catch (err) {\n // assert method above throws error with given message which we further throw to client.\n if (err && err.message) {\n throw err.message;\n }\n throw 'Something went wrong!';\n }\n\n // set environment to 'PRODUCTION' if stated by client, otherwise 'SANDBOX'\n options.environment =\n options &&\n typeof options.environment === 'string' &&\n options.environment.toUpperCase() === 'PRODUCTION'\n ? 'PRODUCTION'\n : 'SANDBOX';\n\n // save options to clientData\n this.clientData = options;\n\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\n/**\n * Runs the SDK for Placing Order\n * @function\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 */\n\n// TODO: write the parameter descriptions\n\nexport default async function placeOrder(order_details, callback) {\n try {\n // validate client data\n assert.check(\n this.clientData,\n { type: 'object', message: 'init data is invalid' },\n {\n key: { type: 'string', message: \"'key' is required string.\" },\n environment: {\n optional: true,\n type: 'string',\n message: \"'environment' must be string.\"\n }\n }\n );\n\n // validate order_details\n assert.check(\n order_details,\n {\n type: 'object',\n message: \"'order_details' is not valid.\"\n },\n {\n productId: {\n type: 'string',\n message: \"'productId' is required string.\"\n },\n refId: { type: 'string', message: \"'refId' is required string.\" },\n photo: {\n optional: true,\n type: 'string',\n message: \"'photo' must be string.\"\n },\n video: {\n optional: true,\n type: 'string',\n message: \"'video' must be string.\"\n },\n prefill: {\n optional: true,\n type: 'object',\n message: \"'prefill' must be object.\"\n },\n animation: {\n optional: true,\n type: 'string',\n message: \"'animation' must be string.\"\n },\n theme: {\n optional: true,\n type: 'object',\n message: \"'theme' must be object.\"\n },\n logo: {\n optional: true,\n type: 'object',\n message: \"'logo' must be string.\"\n }\n }\n );\n\n // validate callback function\n assert.check(callback, {\n type: 'function',\n message: \"'callback' is required function.\"\n });\n\n // save order_details\n this.order_details = order_details;\n\n // render the success UI\n let url = `${PAGES.main}`;\n this.callback = callback;\n await this.renderWithRetry(url);\n } catch (err) {\n if (callback && typeof callback === 'function') {\n // render error UI\n let url = `${PAGES.error}/Something went wrong!`;\n await this.renderWithRetry(url);\n // callback to client with error\n await callback({ code: 400, message: err.message }, null);\n } else {\n throw \"'callback' is required function.\";\n }\n }\n document.activeElement.blur();\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 type: 'INITIAL_DATA',\n payload: {\n client_data: this.clientData,\n order_details: this.order_details\n }\n });\n break;\n case 'READY_TO_RECEIVE_ERR':\n this.sendMessage({\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 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","import { PAGES } from './constants';\n\nexport default function sendMessage(message) {\n this.iWindow.postMessage(message, PAGES.main);\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","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","photo","video","prefill","animation","logo","activeElement","blur","event","origin","data","sendMessage","payload","client_data","email","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..bc73ff7 --- /dev/null +++ b/dist/FlamSaasSDK.min.js @@ -0,0 +1,9 @@ +/** + * flamsdk v1.0.0 + * Author: bucharitesh + * Date: 2022-09-12 + * 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="http://localhost:3000",PAGES_error="http://localhost:3000/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 `,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-loading-wrapper").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){if("Failed to fetch"===err.message)return this.close(),void this.callback({code:500,message:"Unable to acess SDK Website!"});this.callback({code:500,message:"Something went wrong!"})}})},init.prototype.placeOrder=async function(order_details,callback){try{assert.check(this.clientData,{type:"object",message:"init data is invalid"},{key:{type:"string",message:"'key' is required string."},environment:{optional:!0,type:"string",message:"'environment' must be string."}}),assert.check(order_details,{type:"object",message:"'order_details' is not valid."},{productId:{type:"string",message:"'productId' is required string."},refId:{type:"string",message:"'refId' is required string."},photo:{optional:!0,type:"string",message:"'photo' must be string."},video:{optional:!0,type:"string",message:"'video' must be string."},prefill:{optional:!0,type:"object",message:"'prefill' must be object."},animation:{optional:!0,type:"string",message:"'animation' must be string."},theme:{optional:!0,type:"object",message:"'theme' must be object."},logo:{optional:!0,type:"object",message:"'logo' must be string."}}),assert.check(callback,{type:"function",message:"'callback' is required function."}),this.order_details=order_details;let url=""+PAGES_main;this.callback=callback,await this.renderWithRetry(url)}catch(err){if(!callback||"function"!=typeof callback)throw"'callback' is required function.";{let url=PAGES_error+"/Something went wrong!";await this.renderWithRetry(url),await callback({code:400,message:err.message},null)}}document.activeElement.blur()},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,PAGES_main)},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/examples/vanilla-js/index.html b/examples/vanilla-js/index.html index eb55608..02159dd 100644 --- a/examples/vanilla-js/index.html +++ b/examples/vanilla-js/index.html @@ -10,11 +10,11 @@ - - + + - diff --git a/package.json b/package.json index 11edd8e..82b51e0 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "flamsdk", - "version": "1.0.0", + "version": "1.0.2", "description": "flamSdk for saas", "author": "bucharitesh", "license": "MIT", diff --git a/src/constants.js b/src/constants.js index ceb53eb..11ae80a 100644 --- a/src/constants.js +++ b/src/constants.js @@ -1,4 +1,4 @@ -const SDK_BASE_URL = 'https://saas-sdk-flam.vpercel.app'; +const SDK_BASE_URL = 'https://saas-sdk-flam.vercel.app'; // const SDK_BASE_URL = 'http://localhost:3000'; export const PAGES = { diff --git a/src/placeOrder.js b/src/placeOrder.js index a793b43..2681643 100644 --- a/src/placeOrder.js +++ b/src/placeOrder.js @@ -11,7 +11,7 @@ import assert from './helper/assert'; // TODO: write the parameter descriptions -export default function placeOrder(order_details, callback) { +export default async function placeOrder(order_details, callback) { try { // validate client data assert.check( @@ -85,16 +85,17 @@ export default function placeOrder(order_details, callback) { // render the success UI let url = `${PAGES.main}`; this.callback = callback; - this.renderWithRetry(url); + await this.renderWithRetry(url); } catch (err) { if (callback && typeof callback === 'function') { // render error UI let url = `${PAGES.error}/Something went wrong!`; - this.renderWithRetry(url); + await this.renderWithRetry(url); // callback to client with error - callback({ code: 400, message: err.message }, null); + await callback({ code: 400, message: err.message }, null); } else { throw "'callback' is required function."; } } + document.activeElement.blur(); } diff --git a/ui/pages/index.tsx b/ui/pages/index.tsx index 2dfe4b1..0037dc9 100644 --- a/ui/pages/index.tsx +++ b/ui/pages/index.tsx @@ -5,13 +5,7 @@ import { useEffect, useState } from 'react'; import { toast, Toaster } from 'react-hot-toast'; import { IoIosCloseCircleOutline } from 'react-icons/io'; -import { - createCard, - getCLientData, - getProductData, - getSignedURL, - UploadURLv2 -} from '../api'; +import { createCard, getCLientData, getProductData, getSignedURL, UploadURLv2 } from '../api'; import Card from '../components/atoms/Card'; import FlexCenter from '../components/atoms/FlexCenter'; import Loading from '../components/atoms/Loading'; @@ -26,7 +20,6 @@ import useMessage from '../hooks/useMessage'; const Home = ({ theme }: { theme: string }) => { const router = useRouter(); const [shakeModal, setShakeModal] = useState(false); - const [isLoading, setIsLoading] = useState(true); const [dataFromClient, setDataFromClient] = useState(null); const [productData, setProductData] = useState(null); @@ -43,7 +36,7 @@ const Home = ({ theme }: { theme: string }) => { }) => { if (event.origin.concat('/') === parentUrl) { if (event.data.type === 'INITIAL_DATA') { - let eventData = event.data.payload; + const eventData = event.data.payload; if ( !eventData.order_details.logo || !eventData.order_details?.prefill?.name || @@ -58,7 +51,6 @@ const Home = ({ theme }: { theme: string }) => { if (res.status == 200) { console.log('RES', res.data); console.log('INIT', eventData); - setDataFromClient(eventData); setDataFromClient({ ...eventData, order_details: { @@ -235,7 +227,7 @@ const Home = ({ theme }: { theme: string }) => { setIsCreateLoading(false); // send message to parent - sendMessage({ + await sendMessage({ type: 'CREATED', payload: { ...finalRes.data, @@ -244,7 +236,7 @@ const Home = ({ theme }: { theme: string }) => { }); } else { // send message to parent - sendMessage({ + await sendMessage({ type: 'ERROR', payload: { message: finalRes?.data?.message || 'Something went wrong!', @@ -256,7 +248,7 @@ const Home = ({ theme }: { theme: string }) => { } } catch (err: any) { // send message to parent - sendMessage({ + await sendMessage({ type: 'ERROR', payload: { code: 500, @@ -269,16 +261,17 @@ const Home = ({ theme }: { theme: string }) => { useEffect(() => { window.addEventListener('message', receiveMessage); - return () => window.removeEventListener('message', receiveMessage); }, [parentUrl]); useEffect(() => { - if (ready) { - sendMessage({ - type: 'READY_TO_RECEIVE' - }); - } + (async () => { + if (ready) { + await sendMessage({ + type: 'READY_TO_RECEIVE' + }); + } + })(); }, [ready]); useEffect(() => { @@ -301,7 +294,7 @@ const Home = ({ theme }: { theme: string }) => { } setIsLoading(false); } catch (err: any) { - sendMessage({ + await sendMessage({ type: 'ERROR', payload: { code: 500, @@ -330,7 +323,7 @@ const Home = ({ theme }: { theme: string }) => { > sendMessage({ type: 'CLOSE' })} + onClick={async () => await sendMessage({ type: 'CLOSE' })} /> {isLoading ? (