botframework-webchat-component
Version:
React component of botframework-webchat
207 lines (173 loc) • 23.4 kB
JavaScript
;
function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _botframeworkWebchatApi = require("botframework-webchat-api");
var _classnames = _interopRequireDefault(require("classnames"));
var _react = _interopRequireWildcard(require("react"));
var _CollapseIcon = _interopRequireDefault(require("./Toast/CollapseIcon"));
var _ExpandIcon = _interopRequireDefault(require("./Toast/ExpandIcon"));
var _NotificationIcon = _interopRequireDefault(require("./Toast/NotificationIcon"));
var _randomId = _interopRequireDefault(require("./Utils/randomId"));
var _useStyleSet3 = _interopRequireDefault(require("./hooks/useStyleSet"));
var _useStyleToEmotionObject = _interopRequireDefault(require("./hooks/internal/useStyleToEmotionObject"));
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _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(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
var useDebouncedNotifications = _botframeworkWebchatApi.hooks.useDebouncedNotifications,
useLocalizer = _botframeworkWebchatApi.hooks.useLocalizer,
useRenderToast = _botframeworkWebchatApi.hooks.useRenderToast;
var ROOT_STYLE = {
display: 'flex',
flexDirection: 'column',
'& .webchat__toaster__header': {
display: 'flex',
flexShrink: 0
},
'& .webchat__toaster__expandText': {
flex: 1
},
'& .webchat__toaster__list': {
display: 'block',
listStyleType: 'none'
}
};
var LEVEL_AS_NUMBER = {
error: 1,
warn: 2,
info: 3,
success: 4
};
function getLevelAsNumber(level) {
return LEVEL_AS_NUMBER[level] || 5;
}
function compareLevel(x, y) {
return getLevelAsNumber(x) - getLevelAsNumber(y);
}
function sortNotifications(map) {
return Object.values(map) // We want the order reversed, most recent on top.
.sort(function (_ref, _ref2) {
var x = _ref.timestamp;
var y = _ref2.timestamp;
return y - x;
});
}
var PASSTHRU_FN = function PASSTHRU_FN(value) {
return value;
};
var TOAST_ACCORDION_IDS = {
two: 'TOAST_ACCORDION_TWO',
few: 'TOAST_ACCORDION_FEW',
many: 'TOAST_ACCORDION_MANY',
other: 'TOAST_ACCORDION_OTHER'
};
var BasicToaster = function BasicToaster() {
var instanceId = (0, _react.useMemo)(_randomId.default, []);
var _useStyleSet = (0, _useStyleSet3.default)(),
_useStyleSet2 = _slicedToArray(_useStyleSet, 1),
toasterStyleSet = _useStyleSet2[0].toaster;
var _useDebouncedNotifica = useDebouncedNotifications(),
_useDebouncedNotifica2 = _slicedToArray(_useDebouncedNotifica, 1),
debouncedNotifications = _useDebouncedNotifica2[0];
var _useState = (0, _react.useState)(false),
_useState2 = _slicedToArray(_useState, 2),
expanded = _useState2[0],
setExpanded = _useState2[1];
var localizeWithPlural = useLocalizer({
plural: true
});
var renderToast = useRenderToast();
var rootClassName = (0, _useStyleToEmotionObject.default)()(ROOT_STYLE) + '';
var handleToggleExpand = (0, _react.useCallback)(function () {
return setExpanded(!expanded);
}, [expanded, setExpanded]);
var sortedNotifications = (0, _react.useMemo)(function () {
return sortNotifications(debouncedNotifications);
}, [debouncedNotifications]);
var sortedNotificationsWithChildren = (0, _react.useMemo)(function () {
return sortedNotifications.map(function (notification) {
var children = renderToast({
notification: notification
});
return children && {
children: children,
notification: notification
};
}).filter(PASSTHRU_FN);
}, [renderToast, sortedNotifications]);
var expandable = sortedNotificationsWithChildren.length > 1;
var _sortedNotificationsW = sortedNotificationsWithChildren.map(function (_ref3) {
var level = _ref3.notification.level;
return level;
}).sort(compareLevel),
_sortedNotificationsW2 = _slicedToArray(_sortedNotificationsW, 1),
highestLevel = _sortedNotificationsW2[0];
var expandableElementId = (0, _react.useMemo)(function () {
return !expandable || expanded ? "webchat__toaster__list__".concat(instanceId) : undefined;
}, [expandable, expanded, instanceId]);
var headerElementId = (0, _react.useMemo)(function () {
return expandable ? "webchat__toaster__header__".concat(instanceId) : undefined;
}, [expandable, instanceId]);
(0, _react.useEffect)(function () {
!expandable && setExpanded(false);
}, [expandable]);
return /*#__PURE__*/_react.default.createElement("div", {
"aria-labelledby": headerElementId,
"aria-live": "polite",
"aria-relevant": "all",
className: (0, _classnames.default)('webchat__toaster', {
'webchat__toaster--expandable': expandable,
'webchat__toaster--expanded': expanded,
'webchat__toaster--error': highestLevel === 'error',
'webchat__toaster--info': highestLevel === 'info',
'webchat__toaster--success': highestLevel === 'success',
'webchat__toaster--warn': highestLevel === 'warn'
}, rootClassName, toasterStyleSet + ''),
role: "log"
}, expandable && /*#__PURE__*/_react.default.createElement("button", {
"aria-controls": expandableElementId,
"aria-expanded": expanded,
className: "webchat__toaster__header",
id: headerElementId,
onClick: handleToggleExpand,
type: "button"
}, /*#__PURE__*/_react.default.createElement("div", {
"aria-hidden": true,
className: "webchat__toaster__expandLevelIconBox"
}, /*#__PURE__*/_react.default.createElement(_NotificationIcon.default, {
className: "webchat__toaster__expandLevelIcon",
level: highestLevel
})), /*#__PURE__*/_react.default.createElement("div", {
className: "webchat__toaster__expandText"
}, localizeWithPlural(TOAST_ACCORDION_IDS, sortedNotificationsWithChildren.length)), /*#__PURE__*/_react.default.createElement("div", {
"aria-hidden": true,
className: "webchat__toaster__expandIcon"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "webchat__toaster__expandIconFocus"
}, expanded ? /*#__PURE__*/_react.default.createElement(_CollapseIcon.default, null) : /*#__PURE__*/_react.default.createElement(_ExpandIcon.default, null)))), (!expandable || expanded) && /*#__PURE__*/_react.default.createElement("ul", {
"aria-labelledby": headerElementId,
className: "webchat__toaster__list",
id: expandableElementId,
role: "region"
}, sortedNotificationsWithChildren.map(function (_ref4) {
var children = _ref4.children,
id = _ref4.notification.id;
return /*#__PURE__*/_react.default.createElement("li", {
"aria-atomic": true,
className: "webchat__toaster__listItem",
key: id,
role: "none"
}, children);
})));
};
var _default = BasicToaster;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/BasicToaster.js"],"names":["useDebouncedNotifications","hooks","useLocalizer","useRenderToast","ROOT_STYLE","display","flexDirection","flexShrink","flex","listStyleType","LEVEL_AS_NUMBER","error","warn","info","success","getLevelAsNumber","level","compareLevel","x","y","sortNotifications","map","Object","values","sort","timestamp","PASSTHRU_FN","value","TOAST_ACCORDION_IDS","two","few","many","other","BasicToaster","instanceId","randomId","toasterStyleSet","toaster","debouncedNotifications","expanded","setExpanded","localizeWithPlural","plural","renderToast","rootClassName","handleToggleExpand","sortedNotifications","sortedNotificationsWithChildren","notification","children","filter","expandable","length","highestLevel","expandableElementId","undefined","headerElementId","id"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["/* eslint no-magic-numbers: [\"error\", { \"ignore\": [0, 1, 2, 3, 4, 5] }] */\n/* eslint react/forbid-dom-props: \"off\" */\n\nimport { hooks } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\n\nimport CollapseIcon from './Toast/CollapseIcon';\nimport ExpandIcon from './Toast/ExpandIcon';\nimport NotificationIcon from './Toast/NotificationIcon';\nimport randomId from './Utils/randomId';\nimport useStyleSet from './hooks/useStyleSet';\nimport useStyleToEmotionObject from './hooks/internal/useStyleToEmotionObject';\n\nconst { useDebouncedNotifications, useLocalizer, useRenderToast } = hooks;\n\nconst ROOT_STYLE = {\n  display: 'flex',\n  flexDirection: 'column',\n\n  '& .webchat__toaster__header': {\n    display: 'flex',\n    flexShrink: 0\n  },\n\n  '& .webchat__toaster__expandText': {\n    flex: 1\n  },\n\n  '& .webchat__toaster__list': {\n    display: 'block',\n    listStyleType: 'none'\n  }\n};\n\nconst LEVEL_AS_NUMBER = {\n  error: 1,\n  warn: 2,\n  info: 3,\n  success: 4\n};\n\nfunction getLevelAsNumber(level) {\n  return LEVEL_AS_NUMBER[level] || 5;\n}\n\nfunction compareLevel(x, y) {\n  return getLevelAsNumber(x) - getLevelAsNumber(y);\n}\n\nfunction sortNotifications(map) {\n  return (\n    Object.values(map)\n      // We want the order reversed, most recent on top.\n      .sort(({ timestamp: x }, { timestamp: y }) => y - x)\n  );\n}\n\nconst PASSTHRU_FN = value => value;\nconst TOAST_ACCORDION_IDS = {\n  two: 'TOAST_ACCORDION_TWO',\n  few: 'TOAST_ACCORDION_FEW',\n  many: 'TOAST_ACCORDION_MANY',\n  other: 'TOAST_ACCORDION_OTHER'\n};\n\nconst BasicToaster = () => {\n  const instanceId = useMemo(randomId, []);\n  const [{ toaster: toasterStyleSet }] = useStyleSet();\n  const [debouncedNotifications] = useDebouncedNotifications();\n  const [expanded, setExpanded] = useState(false);\n  const localizeWithPlural = useLocalizer({ plural: true });\n  const renderToast = useRenderToast();\n  const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n\n  const handleToggleExpand = useCallback(() => setExpanded(!expanded), [expanded, setExpanded]);\n  const sortedNotifications = useMemo(() => sortNotifications(debouncedNotifications), [debouncedNotifications]);\n  const sortedNotificationsWithChildren = useMemo(\n    () =>\n      sortedNotifications\n        .map(notification => {\n          const children = renderToast({ notification });\n\n          return children && { children, notification };\n        })\n        .filter(PASSTHRU_FN),\n    [renderToast, sortedNotifications]\n  );\n\n  const expandable = sortedNotificationsWithChildren.length > 1;\n  const [highestLevel] = sortedNotificationsWithChildren.map(({ notification: { level } }) => level).sort(compareLevel);\n\n  const expandableElementId = useMemo(\n    () => (!expandable || expanded ? `webchat__toaster__list__${instanceId}` : undefined),\n    [expandable, expanded, instanceId]\n  );\n  const headerElementId = useMemo(() => (expandable ? `webchat__toaster__header__${instanceId}` : undefined), [\n    expandable,\n    instanceId\n  ]);\n\n  useEffect(() => {\n    !expandable && setExpanded(false);\n  }, [expandable]);\n\n  return (\n    <div\n      aria-labelledby={headerElementId}\n      aria-live=\"polite\"\n      aria-relevant=\"all\"\n      className={classNames(\n        'webchat__toaster',\n        {\n          'webchat__toaster--expandable': expandable,\n          'webchat__toaster--expanded': expanded,\n          'webchat__toaster--error': highestLevel === 'error',\n          'webchat__toaster--info': highestLevel === 'info',\n          'webchat__toaster--success': highestLevel === 'success',\n          'webchat__toaster--warn': highestLevel === 'warn'\n        },\n        rootClassName,\n        toasterStyleSet + ''\n      )}\n      role=\"log\"\n    >\n      {expandable && (\n        <button\n          aria-controls={expandableElementId}\n          aria-expanded={expanded}\n          className=\"webchat__toaster__header\"\n          id={headerElementId}\n          onClick={handleToggleExpand}\n          type=\"button\"\n        >\n          <div aria-hidden={true} className=\"webchat__toaster__expandLevelIconBox\">\n            <NotificationIcon className=\"webchat__toaster__expandLevelIcon\" level={highestLevel} />\n          </div>\n          <div className=\"webchat__toaster__expandText\">\n            {localizeWithPlural(TOAST_ACCORDION_IDS, sortedNotificationsWithChildren.length)}\n          </div>\n          <div aria-hidden={true} className=\"webchat__toaster__expandIcon\">\n            <div className=\"webchat__toaster__expandIconFocus\">{expanded ? <CollapseIcon /> : <ExpandIcon />}</div>\n          </div>\n        </button>\n      )}\n      {(!expandable || expanded) && (\n        <ul aria-labelledby={headerElementId} className=\"webchat__toaster__list\" id={expandableElementId} role=\"region\">\n          {sortedNotificationsWithChildren.map(({ children, notification: { id } }) => (\n            <li aria-atomic={true} className=\"webchat__toaster__listItem\" key={id} role=\"none\">\n              {children}\n            </li>\n          ))}\n        </ul>\n      )}\n    </div>\n  );\n};\n\nexport default BasicToaster;\n"]}