react-live-chat-loader
Version:
Implement live chat in your react app without taking a performance hit.
107 lines (104 loc) • 15.6 kB
JavaScript
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":[]}
;