UNPKG

react-live-chat-loader

Version:

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

132 lines 18.3 kB
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); } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(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; } import React from 'react'; import useChat from "../../hooks/useChat"; import { ClassNames } from "../../types"; var styles = { wrapper: { fontFamily: 'intercom-font, "Helvetica Neue", "Apple Color Emoji", Helvetica, Arial, sans-serif', color: 'white', fontSize: '16px', lineHeight: 1.5, WebkitTextSizeAdjust: '100%', WebkitFontSmoothing: 'antialiased' }, launcher: { position: 'fixed', // z-index is 1 more than Intercom's actual launcher as when the real widget loads // it might not initially reflect the fake icon's current state (open/closed) zIndex: 2147483004, padding: '0 !important', margin: '0 !important', border: 'none', bottom: '20px', right: '20px', maxWidth: '48px', width: '48px', maxHeight: '48px', height: '48px', borderRadius: '50%', cursor: 'pointer', boxShadow: '0 1px 6px 0 rgba(0, 0, 0, 0.06), 0 2px 32px 0 rgba(0, 0, 0, 0.16)', transition: 'transform 167ms cubic-bezier(0.33, 0.00, 0.00, 1.00)', boxSizing: 'content-box' }, icon: { display: 'flex', alignItems: 'center', justifyContent: 'center', position: 'absolute', top: '0', left: '0', width: '48px', height: '48px', transition: 'transform 100ms linear, opacity 80ms linear' }, logo: { transform: 'rotate(0deg) scale(1)' }, close: { transform: 'rotate(-60deg) scale(0)' } }; var Intercom = function Intercom(_ref) { var _ref$color = _ref.color, color = _ref$color === void 0 ? '#333333' : _ref$color, Icon = _ref.icon, _ref$containerClass = _ref.containerClass, containerClass = _ref$containerClass === void 0 ? ClassNames.container : _ref$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: _objectSpread({}, styles.wrapper) }, /*#__PURE__*/React.createElement("div", { 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 }); }, style: _objectSpread(_objectSpread({}, styles.launcher), {}, { background: color }) }, /*#__PURE__*/React.createElement("div", { style: _objectSpread(_objectSpread(_objectSpread({}, styles.icon), styles.logo), {}, { opacity: state === 'initial' ? 1 : 0 }) }, Icon || /*#__PURE__*/React.createElement("svg", { height: "24px", width: "24px", focusable: "false", "aria-hidden": "true", viewBox: "0 0 28 32" }, /*#__PURE__*/React.createElement("path", { fill: "white", d: "M28 32s-4.714-1.855-8.527-3.34H3.437C1.54 28.66 0 27.026 0 25.013V3.644C0 1.633 1.54 0 3.437 0h21.125c1.898 0 3.437 1.632 3.437 3.645v18.404H28V32zm-4.139-11.982a.88.88 0 00-1.292-.105c-.03.026-3.015 2.681-8.57 2.681-5.486 0-8.517-2.636-8.571-2.684a.88.88 0 00-1.29.107 1.01 1.01 0 00-.219.708.992.992 0 00.318.664c.142.128 3.537 3.15 9.762 3.15 6.226 0 9.621-3.022 9.763-3.15a.992.992 0 00.317-.664 1.01 1.01 0 00-.218-.707z" }))), /*#__PURE__*/React.createElement("div", { style: _objectSpread(_objectSpread(_objectSpread({}, styles.icon), styles.close), {}, { opacity: state === 'initial' ? 0 : 1, transform: state === 'initial' ? 'rotate(-30deg)' : 'rotate(0deg)' }) }, /*#__PURE__*/React.createElement("svg", { focusable: "false", width: "24", height: "24", viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg" }, /*#__PURE__*/React.createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M18.601 8.39897C18.269 8.06702 17.7309 8.06702 17.3989 8.39897L12 13.7979L6.60099 8.39897C6.26904 8.06702 5.73086 8.06702 5.39891 8.39897C5.06696 8.73091 5.06696 9.2691 5.39891 9.60105L11.3989 15.601C11.7309 15.933 12.269 15.933 12.601 15.601L18.601 9.60105C18.9329 9.2691 18.9329 8.73091 18.601 8.39897Z", fill: "white" }))))); }; export default Intercom; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useChat","ClassNames","styles","wrapper","fontFamily","color","fontSize","lineHeight","WebkitTextSizeAdjust","WebkitFontSmoothing","launcher","position","zIndex","padding","margin","border","bottom","right","maxWidth","width","maxHeight","height","borderRadius","cursor","boxShadow","transition","boxSizing","icon","display","alignItems","justifyContent","top","left","logo","transform","close","Intercom","_ref","_ref$color","Icon","_ref$containerClass","containerClass","container","_useChat","loadWhenIdle","_useChat2","_slicedToArray","state","loadChat","createElement","className","style","_objectSpread","role","onClick","open","onMouseEnter","background","opacity","focusable","viewBox","fill","d","xmlns","fillRule","clipRule"],"sources":["../../../src/components/Intercom/index.tsx"],"sourcesContent":["import React, { ReactElement, CSSProperties } from 'react'\n\nimport useChat from '../../hooks/useChat'\nimport { ProviderProps, ClassNames } from '../../types'\n\nconst styles: {\n  wrapper: CSSProperties\n  launcher: CSSProperties\n  icon: CSSProperties\n  logo: CSSProperties\n  close: CSSProperties\n} = {\n  wrapper: {\n    fontFamily:\n      'intercom-font, \"Helvetica Neue\", \"Apple Color Emoji\", Helvetica, Arial, sans-serif',\n    color: 'white',\n    fontSize: '16px',\n    lineHeight: 1.5,\n    WebkitTextSizeAdjust: '100%',\n    WebkitFontSmoothing: 'antialiased'\n  },\n  launcher: {\n    position: 'fixed',\n    // z-index is 1 more than Intercom's actual launcher as when the real widget loads\n    // it might not initially reflect the fake icon's current state (open/closed)\n    zIndex: 2147483004,\n    padding: '0 !important',\n    margin: '0 !important',\n    border: 'none',\n    bottom: '20px',\n    right: '20px',\n    maxWidth: '48px',\n    width: '48px',\n    maxHeight: '48px',\n    height: '48px',\n    borderRadius: '50%',\n    cursor: 'pointer',\n    boxShadow:\n      '0 1px 6px 0 rgba(0, 0, 0, 0.06), 0 2px 32px 0 rgba(0, 0, 0, 0.16)',\n    transition: 'transform 167ms cubic-bezier(0.33, 0.00, 0.00, 1.00)',\n    boxSizing: 'content-box'\n  },\n  icon: {\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    position: 'absolute',\n    top: '0',\n    left: '0',\n    width: '48px',\n    height: '48px',\n    transition: 'transform 100ms linear, opacity 80ms linear'\n  },\n  logo: {\n    transform: 'rotate(0deg) scale(1)'\n  },\n  close: {\n    transform: 'rotate(-60deg) scale(0)'\n  }\n}\n\ninterface Props extends ProviderProps {\n  color?: string\n  icon?: ReactElement\n}\n\nconst Intercom = ({\n  color = '#333333',\n  icon: Icon,\n  containerClass = ClassNames.container\n}: Props): 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={{\n        ...styles.wrapper\n      }}\n    >\n      <div\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        style={{\n          ...styles.launcher,\n          background: color\n        }}\n      >\n        <div\n          style={{\n            ...styles.icon,\n            ...styles.logo,\n            opacity: state === 'initial' ? 1 : 0\n          }}\n        >\n          {\n            Icon ||\n            <svg\n              height=\"24px\"\n              width=\"24px\"\n              focusable=\"false\"\n              aria-hidden=\"true\"\n              viewBox=\"0 0 28 32\"\n            >\n              <path\n                fill=\"white\"\n                d=\"M28 32s-4.714-1.855-8.527-3.34H3.437C1.54 28.66 0 27.026 0 25.013V3.644C0 1.633 1.54 0 3.437 0h21.125c1.898 0 3.437 1.632 3.437 3.645v18.404H28V32zm-4.139-11.982a.88.88 0 00-1.292-.105c-.03.026-3.015 2.681-8.57 2.681-5.486 0-8.517-2.636-8.571-2.684a.88.88 0 00-1.29.107 1.01 1.01 0 00-.219.708.992.992 0 00.318.664c.142.128 3.537 3.15 9.762 3.15 6.226 0 9.621-3.022 9.763-3.15a.992.992 0 00.317-.664 1.01 1.01 0 00-.218-.707z\"\n              ></path>\n            </svg>\n          }\n        </div>\n        <div\n          style={{\n            ...styles.icon,\n            ...styles.close,\n            opacity: state === 'initial' ? 0 : 1,\n            transform: state === 'initial' ? 'rotate(-30deg)' : 'rotate(0deg)'\n          }}\n        >\n          <svg\n            focusable=\"false\"\n            width=\"24\"\n            height=\"24\"\n            viewBox=\"0 0 24 24\"\n            fill=\"none\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n          >\n            <path\n              fillRule=\"evenodd\"\n              clipRule=\"evenodd\"\n              d=\"M18.601 8.39897C18.269 8.06702 17.7309 8.06702 17.3989 8.39897L12 13.7979L6.60099 8.39897C6.26904 8.06702 5.73086 8.06702 5.39891 8.39897C5.06696 8.73091 5.06696 9.2691 5.39891 9.60105L11.3989 15.601C11.7309 15.933 12.269 15.933 12.601 15.601L18.601 9.60105C18.9329 9.2691 18.9329 8.73091 18.601 8.39897Z\"\n              fill=\"white\"\n            ></path>\n          </svg>\n        </div>\n      </div>\n    </div>\n  )\n}\n\nexport default Intercom\n"],"mappings":"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","ignoreList":[]}