react-live-chat-loader
Version:
Implement live chat in your react app without taking a performance hit.
121 lines • 16.7 kB
JavaScript
var _excluded = ["color", "containerClass"];
function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var n = Object.getOwnPropertySymbols(e); for (r = 0; r < n.length; r++) o = n[r], -1 === t.indexOf(o) && {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (-1 !== e.indexOf(n)) continue; t[n] = r[n]; } return t; }
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
import React, { memo } from 'react';
import useProvider from "../../hooks/useProvider";
import useChat from "../../hooks/useChat";
import { ClassNames } from "../../types";
var styles = {
appearance: 'none',
background: 'none',
borderRadius: '50%',
bottom: '18pt',
display: 'inline',
height: '45pt',
padding: '0px',
position: 'fixed',
right: '18pt',
top: 'auto',
width: '45pt',
zIndex: 2147483647,
// 1 more than the actual widget
overflow: 'hidden',
boxShadow: '0 3px 12px rgba(0, 0, 0, .15)',
transition: 'box-shadow 150ms linear',
cursor: 'pointer',
outline: 'none',
userSelect: 'none'
};
// eslint-disable-next-line react/display-name
var CustomerChat = /*#__PURE__*/memo(function (_ref) {
var providerKey = _ref.providerKey,
color = _ref.color,
loggedInGreeting = _ref.loggedInGreeting,
loggedOutGreeting = _ref.loggedOutGreeting,
greetingDialogDisplay = _ref.greetingDialogDisplay,
greetingDialogDelay = _ref.greetingDialogDelay;
var fields = {
page_id: providerKey,
theme_color: color,
logged_in_greeting: loggedInGreeting,
logged_out_greeting: loggedOutGreeting,
greeting_dialog_display: greetingDialogDisplay,
greeting_dialog_delay: greetingDialogDelay
};
return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("div", _extends({
className: "fb-customerchat"
}, fields)));
});
var Widget = function Widget(_ref2) {
var color = _ref2.color,
containerClass = _ref2.containerClass;
var _useChat = useChat({
loadWhenIdle: true
}),
_useChat2 = _slicedToArray(_useChat, 2),
state = _useChat2[0],
loadChat = _useChat2[1];
if (state === 'complete') {
return null;
}
return /*#__PURE__*/React.createElement("div", {
className: containerClass,
style: styles,
role: "button",
"aria-label": "Load Chat",
"aria-busy": "true",
"aria-live": "polite",
onClick: function onClick() {
return loadChat({
open: true
});
},
onMouseEnter: function onMouseEnter() {
return loadChat({
open: false
});
}
}, /*#__PURE__*/React.createElement("div", {
style: {
width: '60px',
height: '60px',
backgroundColor: color ? color : '#0A7CFF',
display: 'flex',
justifyContent: 'center',
alignItems: 'center',
borderRadius: '60px'
}
}, /*#__PURE__*/React.createElement("svg", {
width: "36",
height: "36",
viewBox: "0 0 36 36"
}, /*#__PURE__*/React.createElement("path", {
fill: "white",
d: "M1 17.99C1 8.51488 8.42339 1.5 18 1.5C27.5766 1.5 35 8.51488 35 17.99C35 27.4651 27.5766 34.48 18 34.48C16.2799 34.48 14.6296 34.2528 13.079 33.8264C12.7776 33.7435 12.4571 33.767 12.171 33.8933L8.79679 35.3828C7.91415 35.7724 6.91779 35.1446 6.88821 34.1803L6.79564 31.156C6.78425 30.7836 6.61663 30.4352 6.33893 30.1868C3.03116 27.2287 1 22.9461 1 17.99ZM12.7854 14.8897L7.79161 22.8124C7.31238 23.5727 8.24695 24.4295 8.96291 23.8862L14.327 19.8152C14.6899 19.5398 15.1913 19.5384 15.5557 19.8116L19.5276 22.7905C20.7193 23.6845 22.4204 23.3706 23.2148 22.1103L28.2085 14.1875C28.6877 13.4272 27.7531 12.5704 27.0371 13.1137L21.673 17.1847C21.3102 17.4601 20.8088 17.4616 20.4444 17.1882L16.4726 14.2094C15.2807 13.3155 13.5797 13.6293 12.7854 14.8897Z"
}))));
};
var Messenger = function Messenger(_ref3) {
var _ref3$color = _ref3.color,
color = _ref3$color === void 0 ? '' : _ref3$color,
_ref3$containerClass = _ref3.containerClass,
containerClass = _ref3$containerClass === void 0 ? ClassNames.container : _ref3$containerClass,
props = _objectWithoutProperties(_ref3, _excluded);
var _useProvider = useProvider(),
providerKey = _useProvider.providerKey;
return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(CustomerChat, _extends({
color: color,
providerKey: providerKey
}, props)), /*#__PURE__*/React.createElement(Widget, {
color: color,
containerClass: containerClass
}));
};
export default Messenger;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","memo","useProvider","useChat","ClassNames","styles","appearance","background","borderRadius","bottom","display","height","padding","position","right","top","width","zIndex","overflow","boxShadow","transition","cursor","outline","userSelect","CustomerChat","_ref","providerKey","color","loggedInGreeting","loggedOutGreeting","greetingDialogDisplay","greetingDialogDelay","fields","page_id","theme_color","logged_in_greeting","logged_out_greeting","greeting_dialog_display","greeting_dialog_delay","createElement","_extends","className","Widget","_ref2","containerClass","_useChat","loadWhenIdle","_useChat2","_slicedToArray","state","loadChat","style","role","onClick","open","onMouseEnter","backgroundColor","justifyContent","alignItems","viewBox","fill","d","Messenger","_ref3","_ref3$color","_ref3$containerClass","container","props","_objectWithoutProperties","_excluded","_useProvider","Fragment"],"sources":["../../../src/components/Messenger/index.tsx"],"sourcesContent":["import React, { CSSProperties, memo } from 'react'\n\nimport useProvider from '../../hooks/useProvider'\nimport useChat from '../../hooks/useChat'\nimport { ProviderProps, ClassNames } from '../../types'\n\nconst styles: CSSProperties = {\n  appearance: 'none',\n  background: 'none',\n  borderRadius: '50%',\n  bottom: '18pt',\n  display: 'inline',\n  height: '45pt',\n  padding: '0px',\n  position: 'fixed',\n  right: '18pt',\n  top: 'auto',\n  width: '45pt',\n  zIndex: 2147483647, // 1 more than the actual widget\n  overflow: 'hidden',\n  boxShadow: '0 3px 12px rgba(0, 0, 0, .15)',\n  transition: 'box-shadow 150ms linear',\n  cursor: 'pointer',\n  outline: 'none',\n  userSelect: 'none'\n}\n\ninterface Props extends ProviderProps {\n  themeColor?: string\n  loggedInGreeting?: string\n  loggedOutGreeting?: string\n  show?: string\n  hide?: string\n  fade?: string\n  greetingDialogDelay?: string\n  greetingDialogDisplay?: string\n  color?: string\n}\n\ninterface ChatProps extends Props {\n  providerKey: string\n}\n\n// eslint-disable-next-line react/display-name\nconst CustomerChat = memo(\n  ({\n    providerKey,\n    color,\n    loggedInGreeting,\n    loggedOutGreeting,\n    greetingDialogDisplay,\n    greetingDialogDelay\n  }: ChatProps) => {\n    const fields = {\n      page_id: providerKey,\n      theme_color: color,\n      logged_in_greeting: loggedInGreeting,\n      logged_out_greeting: loggedOutGreeting,\n      greeting_dialog_display: greetingDialogDisplay,\n      greeting_dialog_delay: greetingDialogDelay\n    }\n\n    return (\n      <div>\n        <div className=\"fb-customerchat\" {...fields} />\n      </div>\n    )\n  }\n)\n\nconst Widget = ({\n  color,\n  containerClass\n}: {\n  color: string\n  containerClass: string\n}): JSX.Element | null => {\n  const [state, loadChat] = useChat({ loadWhenIdle: true })\n\n  if (state === 'complete') {\n    return null\n  }\n\n  return (\n    <div\n      className={containerClass}\n      style={styles}\n      role=\"button\"\n      aria-label=\"Load Chat\"\n      aria-busy=\"true\"\n      aria-live=\"polite\"\n      onClick={() => loadChat({ open: true })}\n      onMouseEnter={() => loadChat({ open: false })}\n    >\n      <div\n        style={{\n          width: '60px',\n          height: '60px',\n          backgroundColor: color ? color : '#0A7CFF',\n          display: 'flex',\n          justifyContent: 'center',\n          alignItems: 'center',\n          borderRadius: '60px'\n        }}\n      >\n        <svg width=\"36\" height=\"36\" viewBox=\"0 0 36 36\">\n          <path\n            fill=\"white\"\n            d=\"M1 17.99C1 8.51488 8.42339 1.5 18 1.5C27.5766 1.5 35 8.51488 35 17.99C35 27.4651 27.5766 34.48 18 34.48C16.2799 34.48 14.6296 34.2528 13.079 33.8264C12.7776 33.7435 12.4571 33.767 12.171 33.8933L8.79679 35.3828C7.91415 35.7724 6.91779 35.1446 6.88821 34.1803L6.79564 31.156C6.78425 30.7836 6.61663 30.4352 6.33893 30.1868C3.03116 27.2287 1 22.9461 1 17.99ZM12.7854 14.8897L7.79161 22.8124C7.31238 23.5727 8.24695 24.4295 8.96291 23.8862L14.327 19.8152C14.6899 19.5398 15.1913 19.5384 15.5557 19.8116L19.5276 22.7905C20.7193 23.6845 22.4204 23.3706 23.2148 22.1103L28.2085 14.1875C28.6877 13.4272 27.7531 12.5704 27.0371 13.1137L21.673 17.1847C21.3102 17.4601 20.8088 17.4616 20.4444 17.1882L16.4726 14.2094C15.2807 13.3155 13.5797 13.6293 12.7854 14.8897Z\"\n          ></path>\n        </svg>\n      </div>\n    </div>\n  )\n}\n\nconst Messenger = ({\n  color = '',\n  containerClass = ClassNames.container,\n  ...props\n}: Props): JSX.Element => {\n  const { providerKey } = useProvider()\n\n  return (\n    <>\n      <CustomerChat color={color} providerKey={providerKey} {...props} />\n      <Widget color={color} containerClass={containerClass} />\n    </>\n  )\n}\n\nexport default Messenger\n"],"mappings":";;;;;;;;;;AAAA,OAAOA,KAAK,IAAmBC,IAAI,QAAQ,OAAO;AAElD,OAAOC,WAAW;AAClB,OAAOC,OAAO;AACd,SAAwBC,UAAU;AAElC,IAAMC,MAAqB,GAAG;EAC5BC,UAAU,EAAE,MAAM;EAClBC,UAAU,EAAE,MAAM;EAClBC,YAAY,EAAE,KAAK;EACnBC,MAAM,EAAE,MAAM;EACdC,OAAO,EAAE,QAAQ;EACjBC,MAAM,EAAE,MAAM;EACdC,OAAO,EAAE,KAAK;EACdC,QAAQ,EAAE,OAAO;EACjBC,KAAK,EAAE,MAAM;EACbC,GAAG,EAAE,MAAM;EACXC,KAAK,EAAE,MAAM;EACbC,MAAM,EAAE,UAAU;EAAE;EACpBC,QAAQ,EAAE,QAAQ;EAClBC,SAAS,EAAE,+BAA+B;EAC1CC,UAAU,EAAE,yBAAyB;EACrCC,MAAM,EAAE,SAAS;EACjBC,OAAO,EAAE,MAAM;EACfC,UAAU,EAAE;AACd,CAAC;AAkBD;AACA,IAAMC,YAAY,gBAAGvB,IAAI,CACvB,UAAAwB,IAAA,EAOiB;EAAA,IANfC,WAAW,GAAAD,IAAA,CAAXC,WAAW;IACXC,KAAK,GAAAF,IAAA,CAALE,KAAK;IACLC,gBAAgB,GAAAH,IAAA,CAAhBG,gBAAgB;IAChBC,iBAAiB,GAAAJ,IAAA,CAAjBI,iBAAiB;IACjBC,qBAAqB,GAAAL,IAAA,CAArBK,qBAAqB;IACrBC,mBAAmB,GAAAN,IAAA,CAAnBM,mBAAmB;EAEnB,IAAMC,MAAM,GAAG;IACbC,OAAO,EAAEP,WAAW;IACpBQ,WAAW,EAAEP,KAAK;IAClBQ,kBAAkB,EAAEP,gBAAgB;IACpCQ,mBAAmB,EAAEP,iBAAiB;IACtCQ,uBAAuB,EAAEP,qBAAqB;IAC9CQ,qBAAqB,EAAEP;EACzB,CAAC;EAED,oBACE/B,KAAA,CAAAuC,aAAA,2BACEvC,KAAA,CAAAuC,aAAA,QAAAC,QAAA;IAAKC,SAAS,EAAC;EAAiB,GAAKT,MAAM,CAAG,CAC3C,CAAC;AAEV,CACF,CAAC;AAED,IAAMU,MAAM,GAAG,SAATA,MAAMA,CAAAC,KAAA,EAMc;EAAA,IALxBhB,KAAK,GAAAgB,KAAA,CAALhB,KAAK;IACLiB,cAAc,GAAAD,KAAA,CAAdC,cAAc;EAKd,IAAAC,QAAA,GAA0B1C,OAAO,CAAC;MAAE2C,YAAY,EAAE;IAAK,CAAC,CAAC;IAAAC,SAAA,GAAAC,cAAA,CAAAH,QAAA;IAAlDI,KAAK,GAAAF,SAAA;IAAEG,QAAQ,GAAAH,SAAA;EAEtB,IAAIE,KAAK,KAAK,UAAU,EAAE;IACxB,OAAO,IAAI;EACb;EAEA,oBACEjD,KAAA,CAAAuC,aAAA;IACEE,SAAS,EAAEG,cAAe;IAC1BO,KAAK,EAAE9C,MAAO;IACd+C,IAAI,EAAC,QAAQ;IACb,cAAW,WAAW;IACtB,aAAU,MAAM;IAChB,aAAU,QAAQ;IAClBC,OAAO,EAAE,SAATA,OAAOA,CAAA;MAAA,OAAQH,QAAQ,CAAC;QAAEI,IAAI,EAAE;MAAK,CAAC,CAAC;IAAA,CAAC;IACxCC,YAAY,EAAE,SAAdA,YAAYA,CAAA;MAAA,OAAQL,QAAQ,CAAC;QAAEI,IAAI,EAAE;MAAM,CAAC,CAAC;IAAA;EAAC,gBAE9CtD,KAAA,CAAAuC,aAAA;IACEY,KAAK,EAAE;MACLnC,KAAK,EAAE,MAAM;MACbL,MAAM,EAAE,MAAM;MACd6C,eAAe,EAAE7B,KAAK,GAAGA,KAAK,GAAG,SAAS;MAC1CjB,OAAO,EAAE,MAAM;MACf+C,cAAc,EAAE,QAAQ;MACxBC,UAAU,EAAE,QAAQ;MACpBlD,YAAY,EAAE;IAChB;EAAE,gBAEFR,KAAA,CAAAuC,aAAA;IAAKvB,KAAK,EAAC,IAAI;IAACL,MAAM,EAAC,IAAI;IAACgD,OAAO,EAAC;EAAW,gBAC7C3D,KAAA,CAAAuC,aAAA;IACEqB,IAAI,EAAC,OAAO;IACZC,CAAC,EAAC;EAAqvB,CAClvB,CACJ,CACF,CACF,CAAC;AAEV,CAAC;AAED,IAAMC,SAAS,GAAG,SAAZA,SAASA,CAAAC,KAAA,EAIW;EAAA,IAAAC,WAAA,GAAAD,KAAA,CAHxBpC,KAAK;IAALA,KAAK,GAAAqC,WAAA,cAAG,EAAE,GAAAA,WAAA;IAAAC,oBAAA,GAAAF,KAAA,CACVnB,cAAc;IAAdA,cAAc,GAAAqB,oBAAA,cAAG7D,UAAU,CAAC8D,SAAS,GAAAD,oBAAA;IAClCE,KAAK,GAAAC,wBAAA,CAAAL,KAAA,EAAAM,SAAA;EAER,IAAAC,YAAA,GAAwBpE,WAAW,CAAC,CAAC;IAA7BwB,WAAW,GAAA4C,YAAA,CAAX5C,WAAW;EAEnB,oBACE1B,KAAA,CAAAuC,aAAA,CAAAvC,KAAA,CAAAuE,QAAA,qBACEvE,KAAA,CAAAuC,aAAA,CAACf,YAAY,EAAAgB,QAAA;IAACb,KAAK,EAAEA,KAAM;IAACD,WAAW,EAAEA;EAAY,GAAKyC,KAAK,CAAG,CAAC,eACnEnE,KAAA,CAAAuC,aAAA,CAACG,MAAM;IAACf,KAAK,EAAEA,KAAM;IAACiB,cAAc,EAAEA;EAAe,CAAE,CACvD,CAAC;AAEP,CAAC;AAED,eAAekB,SAAS","ignoreList":[]}