react-live-chat-loader
Version:
Implement live chat in your react app without taking a performance hit.
111 lines • 14.5 kB
JavaScript
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 = {
container: {
zIndex: 2147483648,
// one more than provider
position: 'fixed',
border: '0',
width: '64px',
height: '64px',
boxShadow: 'rgba(0, 0, 0, 0.24) 0px 8px 16px 0px',
left: 'auto'
},
button: {
position: 'relative',
display: 'flex',
justifyContent: 'center',
alignItems: 'center',
width: '64px',
minWidth: '64px',
height: '64px',
minHeight: '64px',
padding: '0',
cursor: 'pointer',
border: '0'
},
icon: {
fontSize: '40px'
}
};
var Userlike = function Userlike(_ref) {
var _ref$color = _ref.color,
color = _ref$color === void 0 ? 'white' : _ref$color,
_ref$backgroundColor = _ref.backgroundColor,
backgroundColor = _ref$backgroundColor === void 0 ? '#0d8cff' : _ref$backgroundColor,
_ref$position = _ref.position,
position = _ref$position === void 0 ? 'right' : _ref$position,
_ref$vOffset = _ref.vOffset,
vOffset = _ref$vOffset === void 0 ? 'calc(0% + 20px)' : _ref$vOffset,
_ref$hOffset = _ref.hOffset,
hOffset = _ref$hOffset === void 0 ? 'calc(0% + 24px)' : _ref$hOffset,
_ref$style = _ref.style,
style = _ref$style === void 0 ? 'round' : _ref$style,
_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];
var positionStyles = {
bottom: vOffset,
right: position === 'left' ? 'auto' : hOffset,
left: position === 'right' ? 'auto' : hOffset
};
var shapeStyle = {
borderRadius: style === 'round' ? '50%' : '0'
};
if (state === 'complete') {
return null;
}
return /*#__PURE__*/React.createElement("div", {
className: containerClass,
style: _objectSpread(_objectSpread(_objectSpread({}, styles.container), positionStyles), shapeStyle)
}, /*#__PURE__*/React.createElement("button", {
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(_objectSpread({}, styles.button), shapeStyle), {}, {
backgroundColor: backgroundColor
})
}, /*#__PURE__*/React.createElement("svg", {
width: "1em",
height: "1em",
viewBox: "0 0 40 40",
fill: "none",
style: _objectSpread(_objectSpread({}, styles.icon), {}, {
color: color
})
}, /*#__PURE__*/React.createElement("path", {
d: "M37.4 30.7c-.1-.5 0-.9.2-1.4 1.5-2.8 2.3-6 2.3-9.4C40 9 31 0 20 0 9 0 0 9 0 20s9 20 20 20c3.3 0 6.5-.9 9.4-2.3.4-.2.9-.3 1.4-.2l6.8 1.3c.7.1 1.3-.5 1.2-1.2l-1.4-6.9zM21 29h-8c-1.1 0-2-.9-2-2s.9-2 2-2h8c1.1 0 2 .9 2 2s-.9 2-2 2zm6-7H13c-1.1 0-2-.9-2-2s.9-2 2-2h14c1.1 0 2 .9 2 2s-.9 2-2 2zm0-7H13c-1.1 0-2-.9-2-2s.9-2 2-2h14c1.1 0 2 .9 2 2s-.9 2-2 2z",
fill: "currentColor"
}))));
};
export default Userlike;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useChat","ClassNames","styles","container","zIndex","position","border","width","height","boxShadow","left","button","display","justifyContent","alignItems","minWidth","minHeight","padding","cursor","icon","fontSize","Userlike","_ref","_ref$color","color","_ref$backgroundColor","backgroundColor","_ref$position","_ref$vOffset","vOffset","_ref$hOffset","hOffset","_ref$style","style","_ref$containerClass","containerClass","_useChat","loadWhenIdle","_useChat2","_slicedToArray","state","loadChat","positionStyles","bottom","right","shapeStyle","borderRadius","createElement","className","_objectSpread","role","onClick","open","onMouseEnter","viewBox","fill","d"],"sources":["../../../src/components/Userlike/index.tsx"],"sourcesContent":["import React, { CSSProperties } from 'react'\n\nimport useChat from '../../hooks/useChat'\nimport { ProviderProps, ClassNames } from '../../types'\n\nconst styles: {\n  container: CSSProperties\n  button: CSSProperties\n  icon: CSSProperties\n} = {\n  container: {\n    zIndex: 2147483648, // one more than provider\n    position: 'fixed',\n    border: '0',\n    width: '64px',\n    height: '64px',\n    boxShadow: 'rgba(0, 0, 0, 0.24) 0px 8px 16px 0px',\n    left: 'auto'\n  },\n  button: {\n    position: 'relative',\n    display: 'flex',\n    justifyContent: 'center',\n    alignItems: 'center',\n    width: '64px',\n    minWidth: '64px',\n    height: '64px',\n    minHeight: '64px',\n    padding: '0',\n    cursor: 'pointer',\n    border: '0'\n  },\n  icon: {\n    fontSize: '40px'\n  }\n}\n\ninterface Props extends ProviderProps {\n  color?: string\n  backgroundColor?: string\n  position?: string\n  vOffset?: string\n  hOffset?: string\n  style?: string\n}\n\nconst Userlike = ({\n  color = 'white',\n  backgroundColor = '#0d8cff',\n  position = 'right',\n  vOffset = 'calc(0% + 20px)',\n  hOffset = 'calc(0% + 24px)',\n  style = 'round',\n  containerClass = ClassNames.container\n}: Props): JSX.Element | null => {\n  const [state, loadChat] = useChat({ loadWhenIdle: true })\n  const positionStyles = {\n    bottom: vOffset,\n    right: position === 'left' ? 'auto' : hOffset,\n    left: position === 'right' ? 'auto' : hOffset\n  }\n  const shapeStyle = {\n    borderRadius: style === 'round' ? '50%' : '0'\n  }\n\n  if (state === 'complete') {\n    return null\n  }\n\n  return (\n    <div\n      className={containerClass}\n      style={{ ...styles.container, ...positionStyles, ...shapeStyle }}\n    >\n      <button\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.button,\n          ...shapeStyle,\n          backgroundColor\n        }}\n      >\n        <svg\n          width=\"1em\"\n          height=\"1em\"\n          viewBox=\"0 0 40 40\"\n          fill=\"none\"\n          style={{ ...styles.icon, color }}\n        >\n          <path\n            d=\"M37.4 30.7c-.1-.5 0-.9.2-1.4 1.5-2.8 2.3-6 2.3-9.4C40 9 31 0 20 0 9 0 0 9 0 20s9 20 20 20c3.3 0 6.5-.9 9.4-2.3.4-.2.9-.3 1.4-.2l6.8 1.3c.7.1 1.3-.5 1.2-1.2l-1.4-6.9zM21 29h-8c-1.1 0-2-.9-2-2s.9-2 2-2h8c1.1 0 2 .9 2 2s-.9 2-2 2zm6-7H13c-1.1 0-2-.9-2-2s.9-2 2-2h14c1.1 0 2 .9 2 2s-.9 2-2 2zm0-7H13c-1.1 0-2-.9-2-2s.9-2 2-2h14c1.1 0 2 .9 2 2s-.9 2-2 2z\"\n            fill=\"currentColor\"\n          ></path>\n        </svg>\n      </button>\n    </div>\n  )\n}\n\nexport default Userlike\n"],"mappings":"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","ignoreList":[]}