botframework-webchat-component
Version:
React component of botframework-webchat
145 lines (141 loc) • 29.3 kB
JavaScript
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _botframeworkWebchatApi = require("botframework-webchat-api");
var _propTypes = _interopRequireDefault(require("prop-types"));
var _react = _interopRequireWildcard(require("react"));
var _LiveRegionTwinContainer = _interopRequireDefault(require("./private/LiveRegionTwinContainer"));
var _Context = _interopRequireDefault(require("./private/Context"));
var _useValueRef = _interopRequireDefault(require("../../hooks/internal/useValueRef"));
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && 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 _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
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) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_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 usePonyfill = _botframeworkWebchatApi.hooks.usePonyfill;
var DEFAULT_ARIA_LIVE = 'polite';
var DEFAULT_FADE_AFTER = 1000;
/**
* Live region twin is an UI component for queueing texts or elements to the screen reader using
* a container element with `aria-live` attribute set.
*
* After the text is rendered and queued, it will be removed to reduce burden on the DOM tree.
* Currently, we assume the assistive technologies should pick up the text within 1 second of rendering.
* This value is configurable.
*
* By default, the live region is visible. If is is not desirable, the caller can use `className` prop to
* hide its visuals.
*/
var LiveRegionTwinComposer = function LiveRegionTwinComposer(_ref) {
var ariaLabel = _ref['aria-label'],
_ref$ariaLive = _ref['aria-live'],
ariaLive = _ref$ariaLive === void 0 ? DEFAULT_ARIA_LIVE : _ref$ariaLive,
ariaRoleDescription = _ref['aria-roledescription'],
children = _ref.children,
className = _ref.className,
_ref$fadeAfter = _ref.fadeAfter,
fadeAfter = _ref$fadeAfter === void 0 ? DEFAULT_FADE_AFTER : _ref$fadeAfter,
role = _ref.role,
textElementClassName = _ref.textElementClassName;
var _usePonyfill = usePonyfill(),
_usePonyfill2 = _slicedToArray(_usePonyfill, 1),
_usePonyfill2$ = _usePonyfill2[0],
clearTimeout = _usePonyfill2$.clearTimeout,
setTimeout = _usePonyfill2$.setTimeout;
var _useState = (0, _react.useState)([]),
_useState2 = _slicedToArray(_useState, 2),
staticElementEntries = _useState2[0],
setStaticElementEntries = _useState2[1];
var fadeAfterRef = (0, _useValueRef.default)(fadeAfter);
var markAllAsRenderedTimeoutIdRef = (0, _react.useRef)();
var nextKeyRef = (0, _react.useRef)(1);
var staticElementEntriesRef = (0, _useValueRef.default)(staticElementEntries);
// This function is called by an effect hook `useMarkAllAsRenderedEffect`, it must be designed with converging in mind.
// To prevent infinite render loop, after multiple calls to this function, it should eventually no-op.
var markAllAsRendered = (0, _react.useCallback)(function () {
if (!staticElementEntriesRef.current.length) {
// Nothing to remove.
return;
}
// When removing each element one-by-one based on an individual timeout, Narrator would narrate them twice occasionally.
// Possibly it think some elements that is not removed during the current cycle, are new elements and queued them twice.
// Thus, we are removing all at once to prevent bugs in Narrator.
markAllAsRenderedTimeoutIdRef.current && clearTimeout(markAllAsRenderedTimeoutIdRef.current);
markAllAsRenderedTimeoutIdRef.current = setTimeout(function () {
// We are playing safe by using value ref to check its length here.
// If we are certain that `setStaticElements(emptyArray => emptyArray)` is a no-op,
// we could replace it with just the setter function.
staticElementEntriesRef.current.length && setStaticElementEntries([]);
}, fadeAfterRef.current);
}, [clearTimeout, fadeAfterRef, markAllAsRenderedTimeoutIdRef, setStaticElementEntries, setTimeout, staticElementEntriesRef]);
// When this component is unmounting, make sure all future `setTimeout` are cleared and should not be fired.
(0, _react.useEffect)(function () {
return function () {
return markAllAsRenderedTimeoutIdRef.current && clearTimeout(markAllAsRenderedTimeoutIdRef.current);
};
}, [clearTimeout, markAllAsRenderedTimeoutIdRef]);
var queueStaticElement = (0, _react.useCallback)(function (element) {
var key = nextKeyRef.current;
nextKeyRef.current = nextKeyRef.current + 1;
setStaticElementEntries(function (entries) {
return [].concat(_toConsumableArray(entries), [{
element: element,
key: key
}]);
});
}, [nextKeyRef, setStaticElementEntries]);
var staticElementEntriesState = (0, _react.useMemo)(function () {
return Object.freeze([Object.freeze(staticElementEntries)]);
}, [staticElementEntries]);
var context = (0, _react.useMemo)(function () {
return {
markAllAsRendered: markAllAsRendered,
queueStaticElement: queueStaticElement,
staticElementEntriesState: staticElementEntriesState
};
}, [markAllAsRendered, queueStaticElement, staticElementEntriesState]);
return /*#__PURE__*/_react.default.createElement(_Context.default.Provider, {
value: context
}, /*#__PURE__*/_react.default.createElement(_LiveRegionTwinContainer.default, {
"aria-label": ariaLabel,
"aria-live": ariaLive,
"aria-roledescription": ariaRoleDescription,
className: className,
role: role,
textElementClassName: textElementClassName
}), children);
};
LiveRegionTwinComposer.defaultProps = {
'aria-label': undefined,
'aria-live': DEFAULT_ARIA_LIVE,
'aria-roledescription': undefined,
children: undefined,
className: undefined,
fadeAfter: DEFAULT_FADE_AFTER,
role: undefined,
textElementClassName: undefined
};
LiveRegionTwinComposer.propTypes = {
'aria-label': _propTypes.default.string,
'aria-live': _propTypes.default.oneOf(['assertive', 'polite']),
'aria-roledescription': _propTypes.default.string,
children: _propTypes.default.any,
className: _propTypes.default.string,
fadeAfter: _propTypes.default.number,
role: _propTypes.default.string,
textElementClassName: _propTypes.default.string
};
var _default = LiveRegionTwinComposer;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_botframeworkWebchatApi","require","_propTypes","_interopRequireDefault","_react","_interopRequireWildcard","_LiveRegionTwinContainer","_Context","_useValueRef","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_toConsumableArray","arr","_arrayWithoutHoles","_iterableToArray","_unsupportedIterableToArray","_nonIterableSpread","TypeError","iter","Symbol","iterator","Array","from","isArray","_arrayLikeToArray","_slicedToArray","i","_arrayWithHoles","_iterableToArrayLimit","_nonIterableRest","o","minLen","n","toString","slice","constructor","name","test","len","length","arr2","_i","_arr","_n","_d","_s","_e","next","done","push","value","err","usePonyfill","hooks","DEFAULT_ARIA_LIVE","DEFAULT_FADE_AFTER","LiveRegionTwinComposer","_ref","ariaLabel","_ref$ariaLive","ariaLive","ariaRoleDescription","children","className","_ref$fadeAfter","fadeAfter","role","textElementClassName","_usePonyfill","_usePonyfill2","_usePonyfill2$","clearTimeout","setTimeout","_useState","useState","_useState2","staticElementEntries","setStaticElementEntries","fadeAfterRef","useValueRef","markAllAsRenderedTimeoutIdRef","useRef","nextKeyRef","staticElementEntriesRef","markAllAsRendered","useCallback","current","useEffect","queueStaticElement","element","entries","concat","staticElementEntriesState","useMemo","freeze","context","createElement","Provider","defaultProps","undefined","propTypes","PropTypes","string","oneOf","any","number","_default","exports"],"sourceRoot":"component:///","sources":["../../../src/providers/LiveRegionTwin/LiveRegionTwinComposer.tsx"],"sourcesContent":["import { hooks } from 'botframework-webchat-api';\nimport PropTypes from 'prop-types';\nimport React, { useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\nimport type { FC, PropsWithChildren } from 'react';\n\nimport LiveRegionTwinContainer from './private/LiveRegionTwinContainer';\nimport LiveRegionTwinContext from './private/Context';\nimport useValueRef from '../../hooks/internal/useValueRef';\n\nimport type { StaticElement, StaticElementEntry } from './private/types';\n\nconst { usePonyfill } = hooks;\n\nconst DEFAULT_ARIA_LIVE = 'polite';\nconst DEFAULT_FADE_AFTER = 1000;\n\ntype LiveRegionTwinComposerProps = PropsWithChildren<{\n  /** Optional \"aria-label\" attribute for the live region twin container. */\n  'aria-label'?: string;\n\n  /** \"aria-live\" attribute for the live region twin container, defaults to `'polite'`. */\n  'aria-live'?: 'assertive' | 'polite';\n\n  /** Optional \"aria-roledescription\" attribute for the live region twin container. */\n  'aria-roledescription'?: string;\n\n  /** Optional \"className\" attribute for the live region twin container. */\n  className?: string;\n\n  /**\n   * Static elements will fade out after this timeout value specified in milliseconds, defaults to `1000`.\n   *\n   * When lowering this value, make sure screen reader can continue to pick up new static elements before fading out.\n   *\n   * If this prop is updated, it will be reflected in next queueing elements.\n   */\n  fadeAfter?: number;\n\n  /** Optional \"role\" attribute for the live region twin container. */\n  role?: string;\n\n  /** Optional \"className\" attribute for static text element. */\n  textElementClassName?: string;\n}>;\n\n/**\n * Live region twin is an UI component for queueing texts or elements to the screen reader using\n * a container element with `aria-live` attribute set.\n *\n * After the text is rendered and queued, it will be removed to reduce burden on the DOM tree.\n * Currently, we assume the assistive technologies should pick up the text within 1 second of rendering.\n * This value is configurable.\n *\n * By default, the live region is visible. If is is not desirable, the caller can use `className` prop to\n * hide its visuals.\n */\nconst LiveRegionTwinComposer: FC<LiveRegionTwinComposerProps> = ({\n  'aria-label': ariaLabel,\n  'aria-live': ariaLive = DEFAULT_ARIA_LIVE,\n  'aria-roledescription': ariaRoleDescription,\n  children,\n  className,\n  fadeAfter = DEFAULT_FADE_AFTER,\n  role,\n  textElementClassName\n}) => {\n  const [{ clearTimeout, setTimeout }] = usePonyfill();\n  const [staticElementEntries, setStaticElementEntries] = useState<StaticElementEntry[]>([]);\n  const fadeAfterRef = useValueRef(fadeAfter);\n  const markAllAsRenderedTimeoutIdRef = useRef<any>();\n  const nextKeyRef = useRef<number>(1);\n\n  const staticElementEntriesRef = useValueRef(staticElementEntries);\n\n  // This function is called by an effect hook `useMarkAllAsRenderedEffect`, it must be designed with converging in mind.\n  // To prevent infinite render loop, after multiple calls to this function, it should eventually no-op.\n  const markAllAsRendered = useCallback<() => void>(() => {\n    if (!staticElementEntriesRef.current.length) {\n      // Nothing to remove.\n      return;\n    }\n\n    // When removing each element one-by-one based on an individual timeout, Narrator would narrate them twice occasionally.\n    // Possibly it think some elements that is not removed during the current cycle, are new elements and queued them twice.\n    // Thus, we are removing all at once to prevent bugs in Narrator.\n    markAllAsRenderedTimeoutIdRef.current && clearTimeout(markAllAsRenderedTimeoutIdRef.current);\n\n    markAllAsRenderedTimeoutIdRef.current = setTimeout(() => {\n      // We are playing safe by using value ref to check its length here.\n      // If we are certain that `setStaticElements(emptyArray => emptyArray)` is a no-op,\n      // we could replace it with just the setter function.\n      staticElementEntriesRef.current.length && setStaticElementEntries([]);\n    }, fadeAfterRef.current);\n  }, [\n    clearTimeout,\n    fadeAfterRef,\n    markAllAsRenderedTimeoutIdRef,\n    setStaticElementEntries,\n    setTimeout,\n    staticElementEntriesRef\n  ]);\n\n  // When this component is unmounting, make sure all future `setTimeout` are cleared and should not be fired.\n  useEffect(\n    () => () => markAllAsRenderedTimeoutIdRef.current && clearTimeout(markAllAsRenderedTimeoutIdRef.current),\n    [clearTimeout, markAllAsRenderedTimeoutIdRef]\n  );\n\n  const queueStaticElement = useCallback<(staticElement: StaticElement) => void>(\n    (element: StaticElement): void => {\n      const key = nextKeyRef.current;\n\n      nextKeyRef.current = nextKeyRef.current + 1;\n\n      setStaticElementEntries(entries => [...entries, { element, key }]);\n    },\n    [nextKeyRef, setStaticElementEntries]\n  );\n\n  const staticElementEntriesState = useMemo<readonly [readonly StaticElementEntry[]]>(\n    () => Object.freeze([Object.freeze(staticElementEntries)]) as readonly [readonly StaticElementEntry[]],\n    [staticElementEntries]\n  );\n\n  const context = useMemo(\n    () => ({\n      markAllAsRendered,\n      queueStaticElement,\n      staticElementEntriesState\n    }),\n    [markAllAsRendered, queueStaticElement, staticElementEntriesState]\n  );\n\n  return (\n    <LiveRegionTwinContext.Provider value={context}>\n      <LiveRegionTwinContainer\n        aria-label={ariaLabel}\n        aria-live={ariaLive}\n        aria-roledescription={ariaRoleDescription}\n        className={className}\n        role={role}\n        textElementClassName={textElementClassName}\n      />\n      {children}\n    </LiveRegionTwinContext.Provider>\n  );\n};\n\nLiveRegionTwinComposer.defaultProps = {\n  'aria-label': undefined,\n  'aria-live': DEFAULT_ARIA_LIVE,\n  'aria-roledescription': undefined,\n  children: undefined,\n  className: undefined,\n  fadeAfter: DEFAULT_FADE_AFTER,\n  role: undefined,\n  textElementClassName: undefined\n};\n\nLiveRegionTwinComposer.propTypes = {\n  'aria-label': PropTypes.string,\n  'aria-live': PropTypes.oneOf(['assertive', 'polite']),\n  'aria-roledescription': PropTypes.string,\n  children: PropTypes.any,\n  className: PropTypes.string,\n  fadeAfter: PropTypes.number,\n  role: PropTypes.string,\n  textElementClassName: PropTypes.string\n};\n\nexport default LiveRegionTwinComposer;\n"],"mappings":"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"}
;