UNPKG

react-live-chat-loader

Version:

Implement live chat in your react app without taking a performance hit.

107 lines (104 loc) 15.6 kB
"use strict"; function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = require("react"); var _context = require("../context"); var Providers = _interopRequireWildcard(require("../providers")); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } var requestIdleCallback = typeof window !== 'undefined' ? window.requestIdleCallback : null; var connection = typeof window !== 'undefined' ? // eslint-disable-next-line @typescript-eslint/no-explicit-any window.navigator && window.navigator.connection : null; var useChat = function useChat() { var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : { loadWhenIdle: false }, loadWhenIdle = _ref.loadWhenIdle; var _useContext = (0, _react.useContext)(_context.LiveChatLoaderContext), provider = _useContext.provider, providerKey = _useContext.providerKey, idlePeriod = _useContext.idlePeriod, state = _useContext.state, setState = _useContext.setState, appID = _useContext.appID, locale = _useContext.locale, baseUrl = _useContext.baseUrl, instanceId = _useContext.instanceId, env = _useContext.env, geo = _useContext.geo, beforeInit = _useContext.beforeInit, onReady = _useContext.onReady; (0, _react.useEffect)(function () { // Don't load if idlePeriod is 0, null or undefined if (typeof window === 'undefined' || !loadWhenIdle || !idlePeriod) return; // Don't load if 2g connection or save-data is enabled if (connection && (connection.saveData || /2g/.test(connection.effectiveType))) return; if (isNaN(idlePeriod)) return; // deadline.timeRemaining() has an upper limit of 50 milliseconds // We want to ensure the page has been idle for a significant period of time // Therefore we count consecutive maximum timeRemaining counts and load chat when we reach our threshold var elapsedIdlePeriod = 0; var previousTimeRemaining = 0; var _scheduleLoadChat = function scheduleLoadChat(deadline) { if (elapsedIdlePeriod > idlePeriod) return loadChat({ open: false }); var timeRemaining = deadline.timeRemaining(); // To ensure browser is idle, only accumalte elapsedIdlePeriod when // two consecutive maximum timeRemaining's have been observed if (previousTimeRemaining > 49 && timeRemaining > 49) elapsedIdlePeriod += timeRemaining; previousTimeRemaining = timeRemaining; requestIdleCallback === null || requestIdleCallback === void 0 || requestIdleCallback(_scheduleLoadChat); }; if (requestIdleCallback) { requestIdleCallback(_scheduleLoadChat); } else { setTimeout(function () { return loadChat({ open: false }); }, idlePeriod); } }, []); var chatProvider = Providers[provider]; var loadChat = (0, _react.useCallback)(function () { var _ref2 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : { open: true }, _ref2$open = _ref2.open, open = _ref2$open === void 0 ? true : _ref2$open; if (!providerKey) { //eslint-disable-next-line no-console console.error('No api key given to react-live-chat-loader'); return; } if (!provider) { //eslint-disable-next-line no-console console.error('No provider given to react-live-chat-loader'); return; } chatProvider.load({ providerKey: providerKey, setState: setState, appID: appID, locale: locale, baseUrl: baseUrl, instanceId: instanceId, env: env, geo: geo, beforeInit: beforeInit, onReady: onReady }); if (open) { chatProvider.open(); if (state !== 'complete') setState('open'); } }, [state]); return [state, loadChat]; }; var _default = exports.default = useChat; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_context","Providers","_interopRequireWildcard","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","requestIdleCallback","window","connection","navigator","useChat","_ref","arguments","length","undefined","loadWhenIdle","_useContext","useContext","LiveChatLoaderContext","provider","providerKey","idlePeriod","state","setState","appID","locale","baseUrl","instanceId","env","geo","beforeInit","onReady","useEffect","saveData","test","effectiveType","isNaN","elapsedIdlePeriod","previousTimeRemaining","scheduleLoadChat","deadline","loadChat","open","timeRemaining","setTimeout","chatProvider","useCallback","_ref2","_ref2$open","console","error","load","_default","exports"],"sources":["../../src/hooks/useChat.ts"],"sourcesContent":["import { useContext, useCallback, useEffect } from 'react'\n\nimport { State } from '../types'\nimport { LiveChatLoaderContext } from '../context'\nimport * as Providers from '../providers'\n\nconst requestIdleCallback =\n  typeof window !== 'undefined' ? window.requestIdleCallback : null\nconst connection =\n  typeof window !== 'undefined'\n    ? // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      window.navigator && (window.navigator as any).connection\n    : null\n\nconst useChat = (\n  {\n    loadWhenIdle\n  }: {\n    loadWhenIdle: boolean\n  } = { loadWhenIdle: false }\n): [State, ({ open }: { open: boolean }) => void] => {\n  const {\n    provider,\n    providerKey,\n    idlePeriod,\n    state,\n    setState,\n    appID,\n    locale,\n    baseUrl,\n    // instanceId, env and geo are only relevant for Adobe Dynamic Chat\n    instanceId,\n    env,\n    geo,\n    beforeInit,\n    onReady\n  } = useContext(LiveChatLoaderContext)\n\n  useEffect(() => {\n    // Don't load if idlePeriod is 0, null or undefined\n    if (typeof window === 'undefined' || !loadWhenIdle || !idlePeriod) return\n\n    // Don't load if 2g connection or save-data is enabled\n    if (\n      connection &&\n      (connection.saveData || /2g/.test(connection.effectiveType))\n    )\n      return\n\n    if (isNaN(idlePeriod)) return\n\n    // deadline.timeRemaining() has an upper limit of 50 milliseconds\n    // We want to ensure the page has been idle for a significant period of time\n    // Therefore we count consecutive maximum timeRemaining counts and load chat when we reach our threshold\n    let elapsedIdlePeriod = 0\n    let previousTimeRemaining = 0\n    const scheduleLoadChat = (deadline: IdleDeadline) => {\n      if (elapsedIdlePeriod > idlePeriod) return loadChat({ open: false })\n\n      const timeRemaining = deadline.timeRemaining()\n      // To ensure browser is idle, only accumalte elapsedIdlePeriod when\n      // two consecutive maximum timeRemaining's have been observed\n      if (previousTimeRemaining > 49 && timeRemaining > 49)\n        elapsedIdlePeriod += timeRemaining\n\n      previousTimeRemaining = timeRemaining\n      requestIdleCallback?.(scheduleLoadChat)\n    }\n\n    if (requestIdleCallback) {\n      requestIdleCallback(scheduleLoadChat)\n    } else {\n      setTimeout(() => loadChat({ open: false }), idlePeriod)\n    }\n  }, [])\n\n  const chatProvider = Providers[provider]\n\n  const loadChat = useCallback<(args: { open: boolean }) => void>(\n    ({ open = true } = { open: true }) => {\n      if (!providerKey) {\n        //eslint-disable-next-line no-console\n        console.error('No api key given to react-live-chat-loader')\n        return\n      }\n\n      if (!provider) {\n        //eslint-disable-next-line no-console\n        console.error('No provider given to react-live-chat-loader')\n        return\n      }\n\n      chatProvider.load({\n        providerKey,\n        setState,\n        appID,\n        locale,\n        baseUrl,\n        instanceId,\n        env,\n        geo,\n        beforeInit,\n        onReady\n      })\n\n      if (open) {\n        chatProvider.open()\n        if (state !== 'complete') setState('open')\n      }\n    },\n    [state]\n  )\n\n  return [state, loadChat]\n}\n\nexport default useChat\n"],"mappings":"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","ignoreList":[]}