UNPKG

tb-react-live-chat-loader

Version:

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

129 lines (119 loc) 14.5 kB
const _excluded = ["color"]; function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } import React, { memo } from 'react'; import useProvider from "../../hooks/useProvider"; import useChat from "../../hooks/useChat"; const 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 const CustomerChat = /*#__PURE__*/memo(({ providerKey, color, loggedInGreeting, loggedOutGreeting, greetingDialogDisplay, greetingDialogDelay }) => { const 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))); }); const Widget = ({ color }) => { const [state, loadChat] = useChat({ loadWhenIdle: true }); if (state === 'complete') { return null; } return /*#__PURE__*/React.createElement("div", { style: styles, role: "button", "aria-label": "Load Chat", "aria-busy": "true", "aria-live": "polite", onClick: () => loadChat({ open: true }), onMouseEnter: () => loadChat({ open: false }) }, /*#__PURE__*/React.createElement("svg", { width: "60px", height: "60px", viewBox: "0 0 60 60" }, /*#__PURE__*/React.createElement("svg", { x: "0", y: "0", width: "60px", height: "60px" }, /*#__PURE__*/React.createElement("g", { stroke: "none", strokeWidth: "1", fill: "none", fillRule: "evenodd" }, /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("circle", { fill: color ? color : '#0084FF', cx: "30", cy: "30", r: "30" }), /*#__PURE__*/React.createElement("svg", { x: "10", y: "10" }, /*#__PURE__*/React.createElement("g", { transform: "translate(0.000000, -10.000000)", fill: "#FFFFFF" }, /*#__PURE__*/React.createElement("g", { id: "logo", transform: "translate(0.000000, 10.000000)" }, /*#__PURE__*/React.createElement("path", { d: "M20,0 C31.2666,0 40,8.2528 40,19.4 C40,30.5472 31.2666,38.8 20,38.8 C17.9763,38.8 16.0348,38.5327 14.2106,38.0311 C13.856,37.9335 13.4789,37.9612 13.1424,38.1098 L9.1727,39.8621 C8.1343,40.3205 6.9621,39.5819 6.9273,38.4474 L6.8184,34.8894 C6.805,34.4513 6.6078,34.0414 6.2811,33.7492 C2.3896,30.2691 0,25.2307 0,19.4 C0,8.2528 8.7334,0 20,0 Z M7.99009,25.07344 C7.42629,25.96794 8.52579,26.97594 9.36809,26.33674 L15.67879,21.54734 C16.10569,21.22334 16.69559,21.22164 17.12429,21.54314 L21.79709,25.04774 C23.19919,26.09944 25.20039,25.73014 26.13499,24.24744 L32.00999,14.92654 C32.57369,14.03204 31.47419,13.02404 30.63189,13.66324 L24.32119,18.45264 C23.89429,18.77664 23.30439,18.77834 22.87569,18.45674 L18.20299,14.95224 C16.80079,13.90064 14.79959,14.26984 13.86509,15.75264 L7.99009,25.07344 Z" }))))))))); }; const Messenger = _ref => { let { color = '' } = _ref, props = _objectWithoutProperties(_ref, _excluded); const { providerKey: provKey } = useProvider(); return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(CustomerChat, _extends({ color: color, providerKey: provKey }, props)), /*#__PURE__*/React.createElement(Widget, { color: color })); }; export default Messenger; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/Messenger/index.tsx"],"names":["React","memo","useProvider","useChat","styles","appearance","background","borderRadius","bottom","display","height","padding","position","right","top","width","zIndex","overflow","boxShadow","transition","cursor","outline","userSelect","CustomerChat","providerKey","color","loggedInGreeting","loggedOutGreeting","greetingDialogDisplay","greetingDialogDelay","fields","page_id","theme_color","logged_in_greeting","logged_out_greeting","greeting_dialog_display","greeting_dialog_delay","Widget","state","loadChat","loadWhenIdle","open","Messenger","props","provKey"],"mappings":"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","sourcesContent":["import React, { CSSProperties, memo } from 'react'\n\nimport { Provider } from '../../types'\nimport useProvider from '../../hooks/useProvider'\nimport useChat from '../../hooks/useChat'\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 {\n  providerKey: Provider | undefined\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\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  }: Props) => {\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 = ({ color }: { color: string }): 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      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      <svg width=\"60px\" height=\"60px\" viewBox=\"0 0 60 60\">\n        <svg x=\"0\" y=\"0\" width=\"60px\" height=\"60px\">\n          <g stroke=\"none\" strokeWidth=\"1\" fill=\"none\" fillRule=\"evenodd\">\n            <g>\n              <circle fill={color ? color : '#0084FF'} cx=\"30\" cy=\"30\" r=\"30\" />\n              <svg x=\"10\" y=\"10\">\n                <g transform=\"translate(0.000000, -10.000000)\" fill=\"#FFFFFF\">\n                  <g id=\"logo\" transform=\"translate(0.000000, 10.000000)\">\n                    <path d=\"M20,0 C31.2666,0 40,8.2528 40,19.4 C40,30.5472 31.2666,38.8 20,38.8 C17.9763,38.8 16.0348,38.5327 14.2106,38.0311 C13.856,37.9335 13.4789,37.9612 13.1424,38.1098 L9.1727,39.8621 C8.1343,40.3205 6.9621,39.5819 6.9273,38.4474 L6.8184,34.8894 C6.805,34.4513 6.6078,34.0414 6.2811,33.7492 C2.3896,30.2691 0,25.2307 0,19.4 C0,8.2528 8.7334,0 20,0 Z M7.99009,25.07344 C7.42629,25.96794 8.52579,26.97594 9.36809,26.33674 L15.67879,21.54734 C16.10569,21.22334 16.69559,21.22164 17.12429,21.54314 L21.79709,25.04774 C23.19919,26.09944 25.20039,25.73014 26.13499,24.24744 L32.00999,14.92654 C32.57369,14.03204 31.47419,13.02404 30.63189,13.66324 L24.32119,18.45264 C23.89429,18.77664 23.30439,18.77834 22.87569,18.45674 L18.20299,14.95224 C16.80079,13.90064 14.79959,14.26984 13.86509,15.75264 L7.99009,25.07344 Z\" />\n                  </g>\n                </g>\n              </svg>\n            </g>\n          </g>\n        </svg>\n      </svg>\n    </div>\n  )\n}\n\nconst Messenger = ({ color = '', ...props }: Props): JSX.Element => {\n  const { providerKey: provKey } = useProvider()\n\n  return (\n    <>\n      <CustomerChat color={color} providerKey={provKey} {...props} />\n      <Widget color={color} />\n    </>\n  )\n}\n\nexport default Messenger\n"]}