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
JavaScript
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"]}