UNPKG

botframework-webchat-component

Version:
336 lines (334 loc) 79.9 kB
"use strict"; 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 _createInstance = _interopRequireDefault(require("@emotion/css/create-instance")); var _botframeworkWebchatApi = require("botframework-webchat-api"); var _decorator = require("botframework-webchat-api/decorator"); var _botframeworkWebchatCore = require("botframework-webchat-core"); var _classnames = _interopRequireDefault(require("classnames")); var _markdownIt = _interopRequireDefault(require("markdown-it")); var _propTypes = _interopRequireDefault(require("prop-types")); var _react = _interopRequireWildcard(require("react")); var _reactSay = require("react-say"); var _createMiddleware = _interopRequireDefault(require("./Attachment/createMiddleware")); var _Dictation = _interopRequireDefault(require("./Dictation")); var _ErrorBox = _interopRequireDefault(require("./ErrorBox")); var _BypassSpeechSynthesisPonyfill = require("./hooks/internal/BypassSpeechSynthesisPonyfill"); var _UITracker = _interopRequireDefault(require("./hooks/internal/UITracker")); var _WebChatUIContext = _interopRequireDefault(require("./hooks/internal/WebChatUIContext")); var _useStyleSet3 = _interopRequireDefault(require("./hooks/useStyleSet")); var _createCoreMiddleware = _interopRequireDefault(require("./Middleware/Activity/createCoreMiddleware")); var _createCoreMiddleware2 = _interopRequireDefault(require("./Middleware/ActivityStatus/createCoreMiddleware")); var _createCoreMiddleware3 = _interopRequireDefault(require("./Middleware/AttachmentForScreenReader/createCoreMiddleware")); var _createCoreMiddleware4 = _interopRequireDefault(require("./Middleware/Avatar/createCoreMiddleware")); var _createCoreMiddleware5 = _interopRequireDefault(require("./Middleware/CardAction/createCoreMiddleware")); var _createScrollToEndButtonMiddleware = _interopRequireDefault(require("./Middleware/ScrollToEndButton/createScrollToEndButtonMiddleware")); var _createCoreMiddleware6 = _interopRequireDefault(require("./Middleware/Toast/createCoreMiddleware")); var _createCoreMiddleware7 = _interopRequireDefault(require("./Middleware/TypingIndicator/createCoreMiddleware")); var _ActivityTreeComposer = _interopRequireDefault(require("./providers/ActivityTree/ActivityTreeComposer")); var _SendBoxComposer = _interopRequireDefault(require("./providers/internal/SendBox/SendBoxComposer")); var _ModalDialogComposer = _interopRequireDefault(require("./providers/ModalDialog/ModalDialogComposer")); var _useTheme = _interopRequireDefault(require("./providers/Theme/useTheme")); var _createMiddleware2 = _interopRequireDefault(require("./SendBox/createMiddleware")); var _createMiddleware3 = _interopRequireDefault(require("./SendBoxToolbar/createMiddleware")); var _createStyleSet = _interopRequireDefault(require("./Styles/createStyleSet")); var _addTargetBlankToHyperlinksMarkdown = _interopRequireDefault(require("./Utils/addTargetBlankToHyperlinksMarkdown")); var _createCSSKey = _interopRequireDefault(require("./Utils/createCSSKey")); var _downscaleImageToDataURL = _interopRequireDefault(require("./Utils/downscaleImageToDataURL")); var _mapMap = _interopRequireDefault(require("./Utils/mapMap")); var _excluded = ["activityMiddleware", "activityStatusMiddleware", "attachmentForScreenReaderMiddleware", "attachmentMiddleware", "avatarMiddleware", "cardActionMiddleware", "children", "extraStyleSet", "renderMarkdown", "scrollToEndButtonMiddleware", "sendBoxMiddleware", "sendBoxToolbarMiddleware", "styleOptions", "styleSet", "suggestedActionsAccessKey", "toastMiddleware", "typingIndicatorMiddleware", "webSpeechPonyfillFactory"]; 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 _extends() { _extends = Object.assign ? Object.assign.bind() : 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); } 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 _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 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; } 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 useGetActivityByKey = _botframeworkWebchatApi.hooks.useGetActivityByKey, useReferenceGrammarID = _botframeworkWebchatApi.hooks.useReferenceGrammarID, useStyleOptions = _botframeworkWebchatApi.hooks.useStyleOptions; var node_env = undefined || "production"; var emotionPool = {}; function styleSetToEmotionObjects(styleToEmotionObject, styleSet) { return (0, _mapMap.default)(styleSet, function (style, key) { return key === 'options' ? style : styleToEmotionObject(style); }); } var ComposerCoreUI = /*#__PURE__*/(0, _react.memo)(function (_ref) { var children = _ref.children; var _useStyleSet = (0, _useStyleSet3.default)(), _useStyleSet2 = _slicedToArray(_useStyleSet, 1), cssCustomProperties = _useStyleSet2[0].cssCustomProperties; var dictationOnError = (0, _react.useCallback)(function (err) { console.error(err); }, []); return /*#__PURE__*/_react.default.createElement("div", { className: (0, _classnames.default)('webchat__css-custom-properties', cssCustomProperties) }, /*#__PURE__*/_react.default.createElement(_decorator.DecoratorComposer, null, /*#__PURE__*/_react.default.createElement(_ModalDialogComposer.default, null, /*#__PURE__*/_react.default.createElement(_SendBoxComposer.default, null, children, /*#__PURE__*/_react.default.createElement(_Dictation.default, { onError: dictationOnError }))))); }); ComposerCoreUI.displayName = 'ComposerCoreUI'; var ComposerCore = function ComposerCore(_ref2) { var children = _ref2.children, extraStyleSet = _ref2.extraStyleSet, nonce = _ref2.nonce, renderMarkdown = _ref2.renderMarkdown, styleSet = _ref2.styleSet, suggestedActionsAccessKey = _ref2.suggestedActionsAccessKey, webSpeechPonyfillFactory = _ref2.webSpeechPonyfillFactory; var _useState = (0, _react.useState)(), _useState2 = _slicedToArray(_useState, 2), dictateAbortable = _useState2[0], setDictateAbortable = _useState2[1]; var _useReferenceGrammarI = useReferenceGrammarID(), _useReferenceGrammarI2 = _slicedToArray(_useReferenceGrammarI, 1), referenceGrammarID = _useReferenceGrammarI2[0]; var _useStyleOptions = useStyleOptions(), _useStyleOptions2 = _slicedToArray(_useStyleOptions, 1), styleOptions = _useStyleOptions2[0]; var focusTranscriptCallbacksRef = (0, _react.useRef)([]); var internalMarkdownIt = (0, _react.useMemo)(function () { return new _markdownIt.default(); }, []); var scrollToCallbacksRef = (0, _react.useRef)([]); var scrollToEndCallbacksRef = (0, _react.useRef)([]); var internalRenderMarkdownInline = (0, _react.useMemo)(function () { return function (markdown) { var tree = internalMarkdownIt.parseInline(markdown); // TODO: Use "betterLink" plugin. // We should add rel="noopener noreferrer" and target="_blank" var patchedTree = (0, _addTargetBlankToHyperlinksMarkdown.default)(tree); return internalMarkdownIt.renderer.render(patchedTree); }; }, [internalMarkdownIt]); var styleToEmotionObject = (0, _react.useMemo)(function () { // Emotion doesn't hash with nonce. We need to provide the pooling mechanism. // 1. If 2 instances use different nonce, they should result in different hash; // 2. If 2 instances are being mounted, pooling will make sure we render only 1 set of <style> tags, instead of 2. var emotion = // Prefix "id-" to prevent object injection attack. emotionPool["id-".concat(nonce)] || (emotionPool["id-".concat(nonce)] = (0, _createInstance.default)({ key: "webchat--css-".concat((0, _createCSSKey.default)()), nonce: nonce })); return function (style) { return emotion.css(style); }; }, [nonce]); var patchedStyleSet = (0, _react.useMemo)(function () { return styleSetToEmotionObjects(styleToEmotionObject, _objectSpread(_objectSpread({}, styleSet || (0, _createStyleSet.default)(styleOptions)), extraStyleSet)); }, [extraStyleSet, styleOptions, styleSet, styleToEmotionObject]); var webSpeechPonyfill = (0, _react.useMemo)(function () { var ponyfill = webSpeechPonyfillFactory && webSpeechPonyfillFactory({ referenceGrammarID: referenceGrammarID }); var _ref3 = ponyfill || {}, speechSynthesis = _ref3.speechSynthesis, SpeechSynthesisUtterance = _ref3.SpeechSynthesisUtterance; return _objectSpread(_objectSpread({}, ponyfill), {}, { speechSynthesis: speechSynthesis || _BypassSpeechSynthesisPonyfill.speechSynthesis, SpeechSynthesisUtterance: SpeechSynthesisUtterance || _BypassSpeechSynthesisPonyfill.SpeechSynthesisUtterance }); }, [referenceGrammarID, webSpeechPonyfillFactory]); var scrollPositionObserversRef = (0, _react.useRef)([]); var dispatchScrollPosition = (0, _react.useCallback)(function (event) { return scrollPositionObserversRef.current.forEach(function (observer) { return observer(event); }); }, [scrollPositionObserversRef]); var observeScrollPosition = (0, _react.useCallback)(function (observer) { scrollPositionObserversRef.current = [].concat(_toConsumableArray(scrollPositionObserversRef.current), [observer]); return function () { scrollPositionObserversRef.current = scrollPositionObserversRef.current.filter(function (target) { return target !== observer; }); }; }, [scrollPositionObserversRef]); var transcriptFocusObserversRef = (0, _react.useRef)([]); var _useState3 = (0, _react.useState)(0), _useState4 = _slicedToArray(_useState3, 2), numTranscriptFocusObservers = _useState4[0], setNumTranscriptFocusObservers = _useState4[1]; var getActivityByKey = useGetActivityByKey(); var dispatchTranscriptFocusByActivityKey = (0, _react.useMemo)(function () { var prevActivityKey = Symbol(); return function (activityKey) { if (activityKey !== prevActivityKey) { prevActivityKey = activityKey; var event = { activity: getActivityByKey(activityKey) }; transcriptFocusObserversRef.current.forEach(function (observer) { return observer(event); }); } }; }, [getActivityByKey, transcriptFocusObserversRef]); var observeTranscriptFocus = (0, _react.useCallback)(function (observer) { transcriptFocusObserversRef.current = [].concat(_toConsumableArray(transcriptFocusObserversRef.current), [observer]); setNumTranscriptFocusObservers(transcriptFocusObserversRef.current.length); return function () { transcriptFocusObserversRef.current = transcriptFocusObserversRef.current.filter(function (target) { return target !== observer; }); setNumTranscriptFocusObservers(transcriptFocusObserversRef.current.length); }; }, [transcriptFocusObserversRef, setNumTranscriptFocusObservers]); var context = (0, _react.useMemo)(function () { return { dictateAbortable: dictateAbortable, dispatchScrollPosition: dispatchScrollPosition, dispatchTranscriptFocusByActivityKey: dispatchTranscriptFocusByActivityKey, focusTranscriptCallbacksRef: focusTranscriptCallbacksRef, internalMarkdownItState: [internalMarkdownIt], internalRenderMarkdownInline: internalRenderMarkdownInline, nonce: nonce, numTranscriptFocusObservers: numTranscriptFocusObservers, observeScrollPosition: observeScrollPosition, observeTranscriptFocus: observeTranscriptFocus, renderMarkdown: renderMarkdown, scrollToCallbacksRef: scrollToCallbacksRef, scrollToEndCallbacksRef: scrollToEndCallbacksRef, setDictateAbortable: setDictateAbortable, styleSet: patchedStyleSet, styleToEmotionObject: styleToEmotionObject, suggestedActionsAccessKey: suggestedActionsAccessKey, webSpeechPonyfill: webSpeechPonyfill }; }, [dictateAbortable, dispatchScrollPosition, dispatchTranscriptFocusByActivityKey, focusTranscriptCallbacksRef, internalMarkdownIt, internalRenderMarkdownInline, nonce, numTranscriptFocusObservers, observeScrollPosition, observeTranscriptFocus, patchedStyleSet, renderMarkdown, scrollToCallbacksRef, scrollToEndCallbacksRef, setDictateAbortable, styleToEmotionObject, suggestedActionsAccessKey, webSpeechPonyfill]); return /*#__PURE__*/_react.default.createElement(_reactSay.Composer, { ponyfill: webSpeechPonyfill }, /*#__PURE__*/_react.default.createElement(_WebChatUIContext.default.Provider, { value: context }, /*#__PURE__*/_react.default.createElement(ComposerCoreUI, null, children))); }; ComposerCore.defaultProps = { extraStyleSet: undefined, nonce: undefined, renderMarkdown: undefined, styleSet: undefined, suggestedActionsAccessKey: 'A a Å å', webSpeechPonyfillFactory: undefined }; ComposerCore.propTypes = { extraStyleSet: _propTypes.default.any, nonce: _propTypes.default.string, renderMarkdown: _propTypes.default.func, styleSet: _propTypes.default.any, suggestedActionsAccessKey: _propTypes.default.oneOfType([_propTypes.default.oneOf([false]), _propTypes.default.string]), webSpeechPonyfillFactory: _propTypes.default.func }; var Composer = function Composer(_ref4) { var activityMiddleware = _ref4.activityMiddleware, activityStatusMiddleware = _ref4.activityStatusMiddleware, attachmentForScreenReaderMiddleware = _ref4.attachmentForScreenReaderMiddleware, attachmentMiddleware = _ref4.attachmentMiddleware, avatarMiddleware = _ref4.avatarMiddleware, cardActionMiddleware = _ref4.cardActionMiddleware, children = _ref4.children, extraStyleSet = _ref4.extraStyleSet, renderMarkdown = _ref4.renderMarkdown, scrollToEndButtonMiddleware = _ref4.scrollToEndButtonMiddleware, sendBoxMiddlewareFromProps = _ref4.sendBoxMiddleware, sendBoxToolbarMiddlewareFromProps = _ref4.sendBoxToolbarMiddleware, styleOptions = _ref4.styleOptions, styleSet = _ref4.styleSet, suggestedActionsAccessKey = _ref4.suggestedActionsAccessKey, toastMiddleware = _ref4.toastMiddleware, typingIndicatorMiddleware = _ref4.typingIndicatorMiddleware, webSpeechPonyfillFactory = _ref4.webSpeechPonyfillFactory, composerProps = _objectWithoutProperties(_ref4, _excluded); var nonce = composerProps.nonce, onTelemetry = composerProps.onTelemetry; var theme = (0, _useTheme.default)(); var patchedActivityMiddleware = (0, _react.useMemo)(function () { return [].concat(_toConsumableArray((0, _botframeworkWebchatCore.singleToArray)(activityMiddleware)), _toConsumableArray(theme.activityMiddleware), _toConsumableArray((0, _createCoreMiddleware.default)())); }, [activityMiddleware, theme.activityMiddleware]); var patchedActivityStatusMiddleware = (0, _react.useMemo)(function () { return [].concat(_toConsumableArray((0, _botframeworkWebchatCore.singleToArray)(activityStatusMiddleware)), _toConsumableArray(theme.activityStatusMiddleware), _toConsumableArray((0, _createCoreMiddleware2.default)())); }, [activityStatusMiddleware, theme.activityStatusMiddleware]); var patchedAttachmentForScreenReaderMiddleware = (0, _react.useMemo)(function () { return [].concat(_toConsumableArray((0, _botframeworkWebchatCore.singleToArray)(attachmentForScreenReaderMiddleware)), _toConsumableArray(theme.attachmentForScreenReaderMiddleware), _toConsumableArray((0, _createCoreMiddleware3.default)())); }, [attachmentForScreenReaderMiddleware, theme.attachmentForScreenReaderMiddleware]); var patchedAttachmentMiddleware = (0, _react.useMemo)(function () { return [].concat(_toConsumableArray((0, _botframeworkWebchatCore.singleToArray)(attachmentMiddleware)), _toConsumableArray(theme.attachmentMiddleware), _toConsumableArray((0, _createMiddleware.default)())); }, [attachmentMiddleware, theme.attachmentMiddleware]); var patchedAvatarMiddleware = (0, _react.useMemo)(function () { return [].concat(_toConsumableArray((0, _botframeworkWebchatCore.singleToArray)(avatarMiddleware)), _toConsumableArray(theme.avatarMiddleware), _toConsumableArray((0, _createCoreMiddleware4.default)())); }, [avatarMiddleware, theme.avatarMiddleware]); var patchedCardActionMiddleware = (0, _react.useMemo)(function () { return [].concat(_toConsumableArray((0, _botframeworkWebchatCore.singleToArray)(cardActionMiddleware)), _toConsumableArray(theme.cardActionMiddleware), _toConsumableArray((0, _createCoreMiddleware5.default)())); }, [cardActionMiddleware, theme.cardActionMiddleware]); var patchedToastMiddleware = (0, _react.useMemo)(function () { return [].concat(_toConsumableArray((0, _botframeworkWebchatCore.singleToArray)(toastMiddleware)), _toConsumableArray(theme.toastMiddleware), _toConsumableArray((0, _createCoreMiddleware6.default)())); }, [toastMiddleware, theme.toastMiddleware]); var patchedTypingIndicatorMiddleware = (0, _react.useMemo)(function () { return [].concat(_toConsumableArray((0, _botframeworkWebchatCore.singleToArray)(typingIndicatorMiddleware)), _toConsumableArray(theme.typingIndicatorMiddleware), _toConsumableArray((0, _createCoreMiddleware7.default)())); }, [typingIndicatorMiddleware, theme.typingIndicatorMiddleware]); var defaultScrollToEndButtonMiddleware = (0, _react.useMemo)(function () { return (0, _createScrollToEndButtonMiddleware.default)(); }, []); var patchedScrollToEndButtonMiddleware = (0, _react.useMemo)(function () { return [].concat(_toConsumableArray((0, _botframeworkWebchatCore.singleToArray)(scrollToEndButtonMiddleware)), _toConsumableArray(theme.scrollToEndButtonMiddleware), _toConsumableArray(defaultScrollToEndButtonMiddleware)); }, [defaultScrollToEndButtonMiddleware, scrollToEndButtonMiddleware, theme.scrollToEndButtonMiddleware]); var patchedStyleOptions = (0, _react.useMemo)(function () { return _objectSpread(_objectSpread({}, theme.styleOptions), styleOptions); }, [styleOptions, theme.styleOptions]); var sendBoxMiddleware = (0, _react.useMemo)(function () { return Object.freeze([].concat(_toConsumableArray((0, _botframeworkWebchatApi.initSendBoxMiddleware)(sendBoxMiddlewareFromProps)), _toConsumableArray((0, _botframeworkWebchatApi.initSendBoxMiddleware)(theme.sendBoxMiddleware)), _toConsumableArray((0, _createMiddleware2.default)()))); }, [sendBoxMiddlewareFromProps, theme.sendBoxMiddleware]); var sendBoxToolbarMiddleware = (0, _react.useMemo)(function () { return Object.freeze([].concat(_toConsumableArray((0, _botframeworkWebchatApi.initSendBoxToolbarMiddleware)(sendBoxToolbarMiddlewareFromProps)), _toConsumableArray((0, _botframeworkWebchatApi.initSendBoxToolbarMiddleware)(theme.sendBoxToolbarMiddleware)), _toConsumableArray((0, _createMiddleware3.default)()))); }, [sendBoxToolbarMiddlewareFromProps, theme.sendBoxToolbarMiddleware]); return /*#__PURE__*/_react.default.createElement(_botframeworkWebchatApi.Composer, _extends({ activityMiddleware: patchedActivityMiddleware, activityStatusMiddleware: patchedActivityStatusMiddleware, attachmentForScreenReaderMiddleware: patchedAttachmentForScreenReaderMiddleware, attachmentMiddleware: patchedAttachmentMiddleware, avatarMiddleware: patchedAvatarMiddleware, cardActionMiddleware: patchedCardActionMiddleware, downscaleImageToDataURL: _downscaleImageToDataURL.default // Under dev server of create-react-app, "NODE_ENV" will be set to "development". , internalErrorBoxClass: node_env === 'development' ? _ErrorBox.default : undefined, nonce: nonce, scrollToEndButtonMiddleware: patchedScrollToEndButtonMiddleware, sendBoxMiddleware: sendBoxMiddleware, sendBoxToolbarMiddleware: sendBoxToolbarMiddleware, styleOptions: patchedStyleOptions, toastMiddleware: patchedToastMiddleware, typingIndicatorMiddleware: patchedTypingIndicatorMiddleware }, composerProps), /*#__PURE__*/_react.default.createElement(_ActivityTreeComposer.default, null, /*#__PURE__*/_react.default.createElement(ComposerCore, { extraStyleSet: extraStyleSet, nonce: nonce, renderMarkdown: renderMarkdown, styleSet: styleSet, suggestedActionsAccessKey: suggestedActionsAccessKey, webSpeechPonyfillFactory: webSpeechPonyfillFactory }, children, onTelemetry && /*#__PURE__*/_react.default.createElement(_UITracker.default, null)))); }; Composer.defaultProps = _objectSpread(_objectSpread(_objectSpread({}, _botframeworkWebchatApi.Composer.defaultProps), ComposerCore.defaultProps), {}, { children: undefined }); Composer.propTypes = _objectSpread(_objectSpread(_objectSpread({}, _botframeworkWebchatApi.Composer.propTypes), ComposerCore.propTypes), {}, { children: _propTypes.default.any }); var _default = Composer; exports.default = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_createInstance","_interopRequireDefault","require","_botframeworkWebchatApi","_decorator","_botframeworkWebchatCore","_classnames","_markdownIt","_propTypes","_react","_interopRequireWildcard","_reactSay","_createMiddleware","_Dictation","_ErrorBox","_BypassSpeechSynthesisPonyfill","_UITracker","_WebChatUIContext","_useStyleSet3","_createCoreMiddleware","_createCoreMiddleware2","_createCoreMiddleware3","_createCoreMiddleware4","_createCoreMiddleware5","_createScrollToEndButtonMiddleware","_createCoreMiddleware6","_createCoreMiddleware7","_ActivityTreeComposer","_SendBoxComposer","_ModalDialogComposer","_useTheme","_createMiddleware2","_createMiddleware3","_createStyleSet","_addTargetBlankToHyperlinksMarkdown","_createCSSKey","_downscaleImageToDataURL","_mapMap","_excluded","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","_toConsumableArray","arr","_arrayWithoutHoles","_iterableToArray","_unsupportedIterableToArray","_nonIterableSpread","TypeError","iter","Symbol","iterator","Array","from","isArray","_arrayLikeToArray","ownKeys","object","enumerableOnly","symbols","filter","sym","enumerable","push","_objectSpread","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","value","configurable","writable","_slicedToArray","_arrayWithHoles","_iterableToArrayLimit","_nonIterableRest","o","minLen","n","toString","slice","constructor","name","test","len","arr2","_i","_arr","_n","_d","_s","_e","next","done","err","useGetActivityByKey","hooks","useReferenceGrammarID","useStyleOptions","node_env","undefined","emotionPool","styleSetToEmotionObjects","styleToEmotionObject","styleSet","mapMap","style","ComposerCoreUI","memo","_ref","children","_useStyleSet","useStyleSet","_useStyleSet2","cssCustomProperties","dictationOnError","useCallback","console","error","createElement","className","classNames","DecoratorComposer","onError","displayName","ComposerCore","_ref2","extraStyleSet","nonce","renderMarkdown","suggestedActionsAccessKey","webSpeechPonyfillFactory","_useState","useState","_useState2","dictateAbortable","setDictateAbortable","_useReferenceGrammarI","_useReferenceGrammarI2","referenceGrammarID","_useStyleOptions","_useStyleOptions2","styleOptions","focusTranscriptCallbacksRef","useRef","internalMarkdownIt","useMemo","MarkdownIt","scrollToCallbacksRef","scrollToEndCallbacksRef","internalRenderMarkdownInline","markdown","tree","parseInline","patchedTree","addTargetBlankToHyperlinksMarkdown","renderer","render","emotion","concat","createEmotion","createCSSKey","css","patchedStyleSet","createStyleSet","webSpeechPonyfill","ponyfill","_ref3","speechSynthesis","SpeechSynthesisUtterance","bypassSpeechSynthesis","BypassSpeechSynthesisUtterance","scrollPositionObserversRef","dispatchScrollPosition","event","current","observer","observeScrollPosition","transcriptFocusObserversRef","_useState3","_useState4","numTranscriptFocusObservers","setNumTranscriptFocusObservers","getActivityByKey","dispatchTranscriptFocusByActivityKey","prevActivityKey","activityKey","activity","observeTranscriptFocus","context","internalMarkdownItState","Composer","Provider","defaultProps","propTypes","PropTypes","any","string","func","oneOfType","oneOf","_ref4","activityMiddleware","activityStatusMiddleware","attachmentForScreenReaderMiddleware","attachmentMiddleware","avatarMiddleware","cardActionMiddleware","scrollToEndButtonMiddleware","sendBoxMiddlewareFromProps","sendBoxMiddleware","sendBoxToolbarMiddlewareFromProps","sendBoxToolbarMiddleware","toastMiddleware","typingIndicatorMiddleware","composerProps","onTelemetry","theme","useTheme","patchedActivityMiddleware","singleToArray","createDefaultActivityMiddleware","patchedActivityStatusMiddleware","createDefaultActivityStatusMiddleware","patchedAttachmentForScreenReaderMiddleware","createDefaultAttachmentForScreenReaderMiddleware","patchedAttachmentMiddleware","createDefaultAttachmentMiddleware","patchedAvatarMiddleware","createDefaultAvatarMiddleware","patchedCardActionMiddleware","createDefaultCardActionMiddleware","patchedToastMiddleware","createDefaultToastMiddleware","patchedTypingIndicatorMiddleware","createDefaultTypingIndicatorMiddleware","defaultScrollToEndButtonMiddleware","createDefaultScrollToEndButtonMiddleware","patchedScrollToEndButtonMiddleware","patchedStyleOptions","freeze","initSendBoxMiddleware","createDefaultSendBoxMiddleware","initSendBoxToolbarMiddleware","createDefaultSendBoxToolbarMiddleware","downscaleImageToDataURL","internalErrorBoxClass","ErrorBox","APIComposer","_default","exports"],"sourceRoot":"component:///","sources":["../src/Composer.tsx"],"sourcesContent":["import createEmotion from '@emotion/css/create-instance';\nimport type {\n  ComposerProps as APIComposerProps,\n  SendBoxMiddleware,\n  SendBoxToolbarMiddleware\n} from 'botframework-webchat-api';\nimport {\n  Composer as APIComposer,\n  hooks,\n  initSendBoxMiddleware,\n  initSendBoxToolbarMiddleware,\n  WebSpeechPonyfillFactory\n} from 'botframework-webchat-api';\nimport { DecoratorComposer } from 'botframework-webchat-api/decorator';\nimport { singleToArray } from 'botframework-webchat-core';\nimport classNames from 'classnames';\nimport MarkdownIt from 'markdown-it';\nimport PropTypes from 'prop-types';\nimport React, { memo, useCallback, useMemo, useRef, useState, type ReactNode } from 'react';\nimport { Composer as SayComposer } from 'react-say';\n\nimport createDefaultAttachmentMiddleware from './Attachment/createMiddleware';\nimport Dictation from './Dictation';\nimport ErrorBox from './ErrorBox';\nimport {\n  speechSynthesis as bypassSpeechSynthesis,\n  SpeechSynthesisUtterance as BypassSpeechSynthesisUtterance\n} from './hooks/internal/BypassSpeechSynthesisPonyfill';\nimport UITracker from './hooks/internal/UITracker';\nimport WebChatUIContext from './hooks/internal/WebChatUIContext';\nimport useStyleSet from './hooks/useStyleSet';\nimport createDefaultActivityMiddleware from './Middleware/Activity/createCoreMiddleware';\nimport createDefaultActivityStatusMiddleware from './Middleware/ActivityStatus/createCoreMiddleware';\nimport createDefaultAttachmentForScreenReaderMiddleware from './Middleware/AttachmentForScreenReader/createCoreMiddleware';\nimport createDefaultAvatarMiddleware from './Middleware/Avatar/createCoreMiddleware';\nimport createDefaultCardActionMiddleware from './Middleware/CardAction/createCoreMiddleware';\nimport createDefaultScrollToEndButtonMiddleware from './Middleware/ScrollToEndButton/createScrollToEndButtonMiddleware';\nimport createDefaultToastMiddleware from './Middleware/Toast/createCoreMiddleware';\nimport createDefaultTypingIndicatorMiddleware from './Middleware/TypingIndicator/createCoreMiddleware';\nimport ActivityTreeComposer from './providers/ActivityTree/ActivityTreeComposer';\nimport SendBoxComposer from './providers/internal/SendBox/SendBoxComposer';\nimport ModalDialogComposer from './providers/ModalDialog/ModalDialogComposer';\nimport useTheme from './providers/Theme/useTheme';\nimport createDefaultSendBoxMiddleware from './SendBox/createMiddleware';\nimport createDefaultSendBoxToolbarMiddleware from './SendBoxToolbar/createMiddleware';\nimport createStyleSet from './Styles/createStyleSet';\nimport { type ContextOf } from './types/ContextOf';\nimport { type FocusTranscriptInit } from './types/internal/FocusTranscriptInit';\nimport addTargetBlankToHyperlinksMarkdown from './Utils/addTargetBlankToHyperlinksMarkdown';\nimport createCSSKey from './Utils/createCSSKey';\nimport downscaleImageToDataURL from './Utils/downscaleImageToDataURL';\nimport mapMap from './Utils/mapMap';\n\nconst { useGetActivityByKey, useReferenceGrammarID, useStyleOptions } = hooks;\n\nconst node_env = process.env.node_env || process.env.NODE_ENV;\n\nconst emotionPool = {};\n\nfunction styleSetToEmotionObjects(styleToEmotionObject, styleSet) {\n  return mapMap(styleSet, (style, key) => (key === 'options' ? style : styleToEmotionObject(style)));\n}\n\ntype ComposerCoreUIProps = Readonly<{ children?: ReactNode }>;\n\nconst ComposerCoreUI = memo(({ children }: ComposerCoreUIProps) => {\n  const [{ cssCustomProperties }] = useStyleSet();\n\n  const dictationOnError = useCallback(err => {\n    console.error(err);\n  }, []);\n\n  return (\n    <div className={classNames('webchat__css-custom-properties', cssCustomProperties)}>\n      <DecoratorComposer>\n        <ModalDialogComposer>\n          {/* When <SendBoxComposer> is finalized, it will be using an independent instance that lives inside <BasicSendBox>. */}\n          <SendBoxComposer>\n            {children}\n            <Dictation onError={dictationOnError} />\n          </SendBoxComposer>\n        </ModalDialogComposer>\n      </DecoratorComposer>\n    </div>\n  );\n});\n\nComposerCoreUI.displayName = 'ComposerCoreUI';\n\ntype ComposerCoreProps = Readonly<{\n  children?: ReactNode;\n  extraStyleSet?: any;\n  nonce?: string;\n  renderMarkdown?: (\n    markdown: string,\n    newLineOptions: { markdownRespectCRLF: boolean },\n    linkOptions: { externalLinkAlt: string }\n  ) => string;\n  styleSet?: any;\n  suggestedActionsAccessKey?: boolean | string;\n  webSpeechPonyfillFactory?: WebSpeechPonyfillFactory;\n}>;\n\nconst ComposerCore = ({\n  children,\n  extraStyleSet,\n  nonce,\n  renderMarkdown,\n  styleSet,\n  suggestedActionsAccessKey,\n  webSpeechPonyfillFactory\n}: ComposerCoreProps) => {\n  const [dictateAbortable, setDictateAbortable] = useState();\n  const [referenceGrammarID] = useReferenceGrammarID();\n  const [styleOptions] = useStyleOptions();\n  const focusTranscriptCallbacksRef = useRef<((init: FocusTranscriptInit) => Promise<void>)[]>([]);\n  const internalMarkdownIt = useMemo(() => new MarkdownIt(), []);\n  const scrollToCallbacksRef = useRef([]);\n  const scrollToEndCallbacksRef = useRef([]);\n\n  const internalRenderMarkdownInline = useMemo(\n    () => markdown => {\n      const tree = internalMarkdownIt.parseInline(markdown);\n\n      // TODO: Use \"betterLink\" plugin.\n      // We should add rel=\"noopener noreferrer\" and target=\"_blank\"\n      const patchedTree = addTargetBlankToHyperlinksMarkdown(tree);\n\n      return internalMarkdownIt.renderer.render(patchedTree);\n    },\n    [internalMarkdownIt]\n  );\n\n  const styleToEmotionObject = useMemo(() => {\n    // Emotion doesn't hash with nonce. We need to provide the pooling mechanism.\n    // 1. If 2 instances use different nonce, they should result in different hash;\n    // 2. If 2 instances are being mounted, pooling will make sure we render only 1 set of <style> tags, instead of 2.\n    const emotion =\n      // Prefix \"id-\" to prevent object injection attack.\n      emotionPool[`id-${nonce}`] ||\n      (emotionPool[`id-${nonce}`] = createEmotion({ key: `webchat--css-${createCSSKey()}`, nonce }));\n\n    return style => emotion.css(style);\n  }, [nonce]);\n\n  const patchedStyleSet = useMemo(\n    () =>\n      styleSetToEmotionObjects(styleToEmotionObject, {\n        ...(styleSet || createStyleSet(styleOptions)),\n        ...extraStyleSet\n      }),\n    [extraStyleSet, styleOptions, styleSet, styleToEmotionObject]\n  );\n\n  const webSpeechPonyfill = useMemo(() => {\n    const ponyfill = webSpeechPonyfillFactory && webSpeechPonyfillFactory({ referenceGrammarID });\n    const { speechSynthesis, SpeechSynthesisUtterance } = ponyfill || {};\n\n    return {\n      ...ponyfill,\n      speechSynthesis: speechSynthesis || bypassSpeechSynthesis,\n      SpeechSynthesisUtterance: SpeechSynthesisUtterance || BypassSpeechSynthesisUtterance\n    };\n  }, [referenceGrammarID, webSpeechPonyfillFactory]);\n\n  const scrollPositionObserversRef = useRef([]);\n\n  const dispatchScrollPosition = useCallback(\n    event => scrollPositionObserversRef.current.forEach(observer => observer(event)),\n    [scrollPositionObserversRef]\n  );\n\n  const observeScrollPosition = useCallback(\n    observer => {\n      scrollPositionObserversRef.current = [...scrollPositionObserversRef.current, observer];\n\n      return () => {\n        scrollPositionObserversRef.current = scrollPositionObserversRef.current.filter(target => target !== observer);\n      };\n    },\n    [scrollPositionObserversRef]\n  );\n\n  const transcriptFocusObserversRef = useRef([]);\n  const [numTranscriptFocusObservers, setNumTranscriptFocusObservers] = useState(0);\n\n  const getActivityByKey = useGetActivityByKey();\n\n  const dispatchTranscriptFocusByActivityKey = useMemo(() => {\n    let prevActivityKey: string | Symbol | undefined = Symbol();\n\n    return activityKey => {\n      if (activityKey !== prevActivityKey) {\n        prevActivityKey = activityKey;\n\n        const event = { activity: getActivityByKey(activityKey) };\n\n        transcriptFocusObserversRef.current.forEach(observer => observer(event));\n      }\n    };\n  }, [getActivityByKey, transcriptFocusObserversRef]);\n\n  const observeTranscriptFocus = useCallback(\n    observer => {\n      transcriptFocusObserversRef.current = [...transcriptFocusObserversRef.current, observer];\n      setNumTranscriptFocusObservers(transcriptFocusObserversRef.current.length);\n\n      return () => {\n        transcriptFocusObserversRef.current = transcriptFocusObserversRef.current.filter(target => target !== observer);\n        setNumTranscriptFocusObservers(transcriptFocusObserversRef.current.length);\n      };\n    },\n    [transcriptFocusObserversRef, setNumTranscriptFocusObservers]\n  );\n\n  const context = useMemo<ContextOf<typeof WebChatUIContext>>(\n    () => ({\n      dictateAbortable,\n      dispatchScrollPosition,\n      dispatchTranscriptFocusByActivityKey,\n      focusTranscriptCallbacksRef,\n      internalMarkdownItState: [internalMarkdownIt],\n      internalRenderMarkdownInline,\n      nonce,\n      numTranscriptFocusObservers,\n      observeScrollPosition,\n      observeTranscriptFocus,\n      renderMarkdown,\n      scrollToCallbacksRef,\n      scrollToEndCallbacksRef,\n      setDictateAbortable,\n      styleSet: patchedStyleSet,\n      styleToEmotionObject,\n      suggestedActionsAccessKey,\n      webSpeechPonyfill\n    }),\n    [\n      dictateAbortable,\n      dispatchScrollPosition,\n      dispatchTranscriptFocusByActivityKey,\n      focusTranscriptCallbacksRef,\n      internalMarkdownIt,\n      internalRenderMarkdownInline,\n      nonce,\n      numTranscriptFocusObservers,\n      observeScrollPosition,\n      observeTranscriptFocus,\n      patchedStyleSet,\n      renderMarkdown,\n      scrollToCallbacksRef,\n      scrollToEndCallbacksRef,\n      setDictateAbortable,\n      styleToEmotionObject,\n      suggestedActionsAccessKey,\n      webSpeechPonyfill\n    ]\n  );\n\n  return (\n    <SayComposer ponyfill={webSpeechPonyfill}>\n      <WebChatUIContext.Provider value={context}>\n        <ComposerCoreUI>{children}</ComposerCoreUI>\n      </WebChatUIContext.Provider>\n    </SayComposer>\n  );\n};\n\nComposerCore.defaultProps = {\n  extraStyleSet: undefined,\n  nonce: undefined,\n  renderMarkdown: undefined,\n  styleSet: undefined,\n  suggestedActionsAccessKey: 'A a Å å',\n  webSpeechPonyfillFactory: undefined\n};\n\nComposerCore.propTypes = {\n  extraStyleSet: PropTypes.any,\n  nonce: PropTypes.string,\n  renderMarkdown: PropTypes.func,\n  styleSet: PropTypes.any,\n  suggestedActionsAccessKey: PropTypes.oneOfType([PropTypes.oneOf([false]), PropTypes.string]),\n  webSpeechPonyfillFactory: PropTypes.func\n};\n\ntype ComposerProps = APIComposerProps & ComposerCoreProps;\n\nconst Composer = ({\n  activityMiddleware,\n  activityStatusMiddleware,\n  attachmentForScreenReaderMiddleware,\n  attachmentMiddleware,\n  avatarMiddleware,\n  cardActionMiddleware,\n  children,\n  extraStyleSet,\n  renderMarkdown,\n  scrollToEndButtonMiddleware,\n  sendBoxMiddleware: sendBoxMiddlewareFromProps,\n  sendBoxToolbarMiddleware: sendBoxToolbarMiddlewareFromProps,\n  styleOptions,\n  styleSet,\n  suggestedActionsAccessKey,\n  toastMiddleware,\n  typingIndicatorMiddleware,\n  webSpeechPonyfillFactory,\n  ...composerProps\n}: ComposerProps) => {\n  const { nonce, onTelemetry } = composerProps;\n  const theme = useTheme();\n\n  const patchedActivityMiddleware = useMemo(\n    () => [...singleToArray(activityMiddleware), ...theme.activityMiddleware, ...createDefaultActivityMiddleware()],\n    [activityMiddleware, theme.activityMiddleware]\n  );\n\n  const patchedActivityStatusMiddleware = useMemo(\n    () => [\n      ...singleToArray(activityStatusMiddleware),\n      ...theme.activityStatusMiddleware,\n      ...createDefaultActivityStatusMiddleware()\n    ],\n    [activityStatusMiddleware, theme.activityStatusMiddleware]\n  );\n\n  const patchedAttachmentForScreenReaderMiddleware = useMemo(\n    () => [\n      ...singleToArray(attachmentForScreenReaderMiddleware),\n      ...theme.attachmentForScreenReaderMiddleware,\n      ...createDefaultAttachmentForScreenReaderMiddleware()\n    ],\n    [attachmentForScreenReaderMiddleware, theme.attachmentForScreenReaderMiddleware]\n  );\n\n  const patchedAttachmentMiddleware = useMemo(\n    () => [\n      ...singleToArray(attachmentMiddleware),\n      ...theme.attachmentMiddleware,\n      ...createDefaultAttachmentMiddleware()\n    ],\n    [attachmentMiddleware, theme.attachmentMiddleware]\n  );\n\n  const patchedAvatarMiddleware = useMemo(\n    () => [...singleToArray(avatarMiddleware), ...theme.avatar