tb-react-live-chat-loader
Version:
Implement live chat in your react app without taking a performance hit.
90 lines (80 loc) • 9.53 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireDefault(require("react"));
var _useChat = _interopRequireDefault(require("../../hooks/useChat"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
const styles = {
button: {
borderRadius: '100px',
bottom: '20px',
right: '20px',
boxShadow: '0 8px 24px rgb(0 0 0 / 16%)',
cursor: 'pointer',
height: '64px',
position: 'fixed',
width: '64px',
zIndex: 2147483001,
// 1 more than the actual widget
userSelect: 'none'
},
img: {
height: '24px',
margin: '20px',
width: '24px'
},
close: {
backgroundColor: '#fff',
height: '24px',
left: '32px',
position: 'absolute',
top: '20px',
width: '2px'
}
};
const Provider = ({
color
}) => {
const [state, loadChat] = (0, _useChat.default)({
loadWhenIdle: true
});
if (state === 'complete') return null;
return /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("div", {
role: "button",
"aria-label": "Load Chat",
"aria-busy": "true",
"aria-live": "polite",
onClick: () => loadChat({
open: true
}),
onMouseEnter: () => loadChat({
open: false
}),
style: _objectSpread(_objectSpread({}, styles.button), {}, {
backgroundColor: color
})
}, state === 'initial' ? /*#__PURE__*/_react.default.createElement("img", {
style: styles.img,
src: "",
alt: "bubble-icon"
}) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
style: _objectSpread(_objectSpread({}, styles.close), {}, {
transform: 'rotate(45deg)'
})
}), /*#__PURE__*/_react.default.createElement("div", {
style: _objectSpread(_objectSpread({}, styles.close), {}, {
transform: 'rotate(-45deg)'
})
}))));
};
Provider.defaultProps = {
color: '#1f93ff'
};
var _default = Provider;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NoYXR3b290L2luZGV4LnRzeCJdLCJuYW1lcyI6WyJzdHlsZXMiLCJidXR0b24iLCJib3JkZXJSYWRpdXMiLCJib3R0b20iLCJyaWdodCIsImJveFNoYWRvdyIsImN1cnNvciIsImhlaWdodCIsInBvc2l0aW9uIiwid2lkdGgiLCJ6SW5kZXgiLCJ1c2VyU2VsZWN0IiwiaW1nIiwibWFyZ2luIiwiY2xvc2UiLCJiYWNrZ3JvdW5kQ29sb3IiLCJsZWZ0IiwidG9wIiwiUHJvdmlkZXIiLCJjb2xvciIsInN0YXRlIiwibG9hZENoYXQiLCJsb2FkV2hlbklkbGUiLCJvcGVuIiwidHJhbnNmb3JtIiwiZGVmYXVsdFByb3BzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7O0FBRUE7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxNQUlMLEdBQUc7QUFDRkMsRUFBQUEsTUFBTSxFQUFFO0FBQ05DLElBQUFBLFlBQVksRUFBRSxPQURSO0FBRU5DLElBQUFBLE1BQU0sRUFBRSxNQUZGO0FBR05DLElBQUFBLEtBQUssRUFBRSxNQUhEO0FBSU5DLElBQUFBLFNBQVMsRUFBRSw2QkFKTDtBQUtOQyxJQUFBQSxNQUFNLEVBQUUsU0FMRjtBQU1OQyxJQUFBQSxNQUFNLEVBQUUsTUFORjtBQU9OQyxJQUFBQSxRQUFRLEVBQUUsT0FQSjtBQVFOQyxJQUFBQSxLQUFLLEVBQUUsTUFSRDtBQVNOQyxJQUFBQSxNQUFNLEVBQUUsVUFURjtBQVNjO0FBQ3BCQyxJQUFBQSxVQUFVLEVBQUU7QUFWTixHQUROO0FBYUZDLEVBQUFBLEdBQUcsRUFBRTtBQUNITCxJQUFBQSxNQUFNLEVBQUUsTUFETDtBQUVITSxJQUFBQSxNQUFNLEVBQUUsTUFGTDtBQUdISixJQUFBQSxLQUFLLEVBQUU7QUFISixHQWJIO0FBa0JGSyxFQUFBQSxLQUFLLEVBQUU7QUFDTEMsSUFBQUEsZUFBZSxFQUFFLE1BRFo7QUFFTFIsSUFBQUEsTUFBTSxFQUFFLE1BRkg7QUFHTFMsSUFBQUEsSUFBSSxFQUFFLE1BSEQ7QUFJTFIsSUFBQUEsUUFBUSxFQUFFLFVBSkw7QUFLTFMsSUFBQUEsR0FBRyxFQUFFLE1BTEE7QUFNTFIsSUFBQUEsS0FBSyxFQUFFO0FBTkY7QUFsQkwsQ0FKSjs7QUFvQ0EsTUFBTVMsUUFBUSxHQUFHLENBQUM7QUFBRUMsRUFBQUE7QUFBRixDQUFELEtBQTBDO0FBQ3pELFFBQU0sQ0FBQ0MsS0FBRCxFQUFRQyxRQUFSLElBQW9CLHNCQUFRO0FBQUVDLElBQUFBLFlBQVksRUFBRTtBQUFoQixHQUFSLENBQTFCO0FBRUEsTUFBSUYsS0FBSyxLQUFLLFVBQWQsRUFBMEIsT0FBTyxJQUFQO0FBRTFCLHNCQUNFLHVEQUNFO0FBQ0UsSUFBQSxJQUFJLEVBQUMsUUFEUDtBQUVFLGtCQUFXLFdBRmI7QUFHRSxpQkFBVSxNQUhaO0FBSUUsaUJBQVUsUUFKWjtBQUtFLElBQUEsT0FBTyxFQUFFLE1BQU1DLFFBQVEsQ0FBQztBQUFFRSxNQUFBQSxJQUFJLEVBQUU7QUFBUixLQUFELENBTHpCO0FBTUUsSUFBQSxZQUFZLEVBQUUsTUFBTUYsUUFBUSxDQUFDO0FBQUVFLE1BQUFBLElBQUksRUFBRTtBQUFSLEtBQUQsQ0FOOUI7QUFPRSxJQUFBLEtBQUssa0NBQ0F2QixNQUFNLENBQUNDLE1BRFA7QUFFSGMsTUFBQUEsZUFBZSxFQUFFSTtBQUZkO0FBUFAsS0FZR0MsS0FBSyxLQUFLLFNBQVYsZ0JBQ0M7QUFDRSxJQUFBLEtBQUssRUFBRXBCLE1BQU0sQ0FBQ1ksR0FEaEI7QUFFRSxJQUFBLEdBQUcsRUFBQyxnbEJBRk47QUFHRSxJQUFBLEdBQUcsRUFBQztBQUhOLElBREQsZ0JBT0MseUVBQ0U7QUFBSyxJQUFBLEtBQUssa0NBQU9aLE1BQU0sQ0FBQ2MsS0FBZDtBQUFxQlUsTUFBQUEsU0FBUyxFQUFFO0FBQWhDO0FBQVYsSUFERixlQUVFO0FBQUssSUFBQSxLQUFLLGtDQUFPeEIsTUFBTSxDQUFDYyxLQUFkO0FBQXFCVSxNQUFBQSxTQUFTLEVBQUU7QUFBaEM7QUFBVixJQUZGLENBbkJKLENBREYsQ0FERjtBQTZCRCxDQWxDRDs7QUFvQ0FOLFFBQVEsQ0FBQ08sWUFBVCxHQUF3QjtBQUN0Qk4sRUFBQUEsS0FBSyxFQUFFO0FBRGUsQ0FBeEI7ZUFJZUQsUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyBDU1NQcm9wZXJ0aWVzIH0gZnJvbSAncmVhY3QnXG5cbmltcG9ydCB1c2VDaGF0IGZyb20gJy4uLy4uL2hvb2tzL3VzZUNoYXQnXG5cbmNvbnN0IHN0eWxlczoge1xuICBidXR0b246IENTU1Byb3BlcnRpZXNcbiAgaW1nOiBDU1NQcm9wZXJ0aWVzXG4gIGNsb3NlOiBDU1NQcm9wZXJ0aWVzXG59ID0ge1xuICBidXR0b246IHtcbiAgICBib3JkZXJSYWRpdXM6ICcxMDBweCcsXG4gICAgYm90dG9tOiAnMjBweCcsXG4gICAgcmlnaHQ6ICcyMHB4JyxcbiAgICBib3hTaGFkb3c6ICcwIDhweCAyNHB4IHJnYigwIDAgMCAvIDE2JSknLFxuICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgIGhlaWdodDogJzY0cHgnLFxuICAgIHBvc2l0aW9uOiAnZml4ZWQnLFxuICAgIHdpZHRoOiAnNjRweCcsXG4gICAgekluZGV4OiAyMTQ3NDgzMDAxLCAvLyAxIG1vcmUgdGhhbiB0aGUgYWN0dWFsIHdpZGdldFxuICAgIHVzZXJTZWxlY3Q6ICdub25lJ1xuICB9LFxuICBpbWc6IHtcbiAgICBoZWlnaHQ6ICcyNHB4JyxcbiAgICBtYXJnaW46ICcyMHB4JyxcbiAgICB3aWR0aDogJzI0cHgnXG4gIH0sXG4gIGNsb3NlOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2ZmZicsXG4gICAgaGVpZ2h0OiAnMjRweCcsXG4gICAgbGVmdDogJzMycHgnLFxuICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgIHRvcDogJzIwcHgnLFxuICAgIHdpZHRoOiAnMnB4J1xuICB9XG59XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGNvbG9yPzogc3RyaW5nXG59XG5cbmNvbnN0IFByb3ZpZGVyID0gKHsgY29sb3IgfTogUHJvcHMpOiBKU1guRWxlbWVudCB8IG51bGwgPT4ge1xuICBjb25zdCBbc3RhdGUsIGxvYWRDaGF0XSA9IHVzZUNoYXQoeyBsb2FkV2hlbklkbGU6IHRydWUgfSlcblxuICBpZiAoc3RhdGUgPT09ICdjb21wbGV0ZScpIHJldHVybiBudWxsXG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2PlxuICAgICAgPGRpdlxuICAgICAgICByb2xlPVwiYnV0dG9uXCJcbiAgICAgICAgYXJpYS1sYWJlbD1cIkxvYWQgQ2hhdFwiXG4gICAgICAgIGFyaWEtYnVzeT1cInRydWVcIlxuICAgICAgICBhcmlhLWxpdmU9XCJwb2xpdGVcIlxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBsb2FkQ2hhdCh7IG9wZW46IHRydWUgfSl9XG4gICAgICAgIG9uTW91c2VFbnRlcj17KCkgPT4gbG9hZENoYXQoeyBvcGVuOiBmYWxzZSB9KX1cbiAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAuLi5zdHlsZXMuYnV0dG9uLFxuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogY29sb3JcbiAgICAgICAgfX1cbiAgICAgID5cbiAgICAgICAge3N0YXRlID09PSAnaW5pdGlhbCcgPyAoXG4gICAgICAgICAgPGltZ1xuICAgICAgICAgICAgc3R5bGU9e3N0eWxlcy5pbWd9XG4gICAgICAgICAgICBzcmM9XCJkYXRhOmltYWdlL3BuZztiYXNlNjQsaVZCT1J3MEtHZ29BQUFBTlNVaEVVZ0FBQURBQUFBQXdDQU1BQUFCZzNBbTFBQUFBVVZCTVZFVUFBQUQvLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vOElOK2RlQUFBQUduUlNUbE1BQXdnSkVCazBUVmhlWTJSNWVvK3V0OGpiNU9YczhmWDIrY2pSRFRJQUFBRHNTVVJCVkhnQmxkWmJrb01nRklUaFJnUXY4U0tLZ0dmL0M1MVVuSnFhUkkzMC85emZlK05RVVEzVHZHN2JPazlEVmVDbXNobWovQ3VPVFlucmRCZmtVT2cwemxPdGw5T1dWdUVrNCtReVozRElldm1TdC9pb1R2SzFWSC9zNWJZM1lkTTlTQlovbVVVeVdneCtVMDZ5Y2dwN0Q4bXN4U3Z0YzRIWEw5QkxkajJlbFNFZmhCSkFJMFFOZ0pFQkkxQkVCc1FDbFZCVkdEZ3dZT0xBaEprRE0xWU9yTmc0c0xGQXNMSmdac0hFZ29FRkZRdDBKQUZHRmpRc0tBTUowTEZBZXhLZ1pZRnlKSUR4SklCTkpFRE5BdFNKQkxDZUJEQ09CRkFQendGQTk0RUQrem1od0RPOTM1OHI4QU50SXNNWGk3cVZBd0FBQUFCSlJVNUVya0pnZ2c9PVwiXG4gICAgICAgICAgICBhbHQ9XCJidWJibGUtaWNvblwiXG4gICAgICAgICAgLz5cbiAgICAgICAgKSA6IChcbiAgICAgICAgICA8PlxuICAgICAgICAgICAgPGRpdiBzdHlsZT17eyAuLi5zdHlsZXMuY2xvc2UsIHRyYW5zZm9ybTogJ3JvdGF0ZSg0NWRlZyknIH19IC8+XG4gICAgICAgICAgICA8ZGl2IHN0eWxlPXt7IC4uLnN0eWxlcy5jbG9zZSwgdHJhbnNmb3JtOiAncm90YXRlKC00NWRlZyknIH19IC8+XG4gICAgICAgICAgPC8+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKVxufVxuXG5Qcm92aWRlci5kZWZhdWx0UHJvcHMgPSB7XG4gIGNvbG9yOiAnIzFmOTNmZidcbn1cblxuZXhwb3J0IGRlZmF1bHQgUHJvdmlkZXJcbiJdfQ==
;