botframework-webchat-component
Version:
React component of botframework-webchat
161 lines (154 loc) • 32.5 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 _classnames = _interopRequireDefault(require("classnames"));
var _react = _interopRequireWildcard(require("react"));
var _useRefFrom = require("use-ref-from");
var _useStyleToEmotionObject = _interopRequireDefault(require("../../../hooks/internal/useStyleToEmotionObject"));
var _useUniqueId = _interopRequireDefault(require("../../../hooks/internal/useUniqueId"));
var _useFocus = _interopRequireDefault(require("../../../hooks/useFocus"));
var _useScrollToEnd = _interopRequireDefault(require("../../../hooks/useScrollToEnd"));
var _Context = _interopRequireDefault(require("./private/Context"));
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 _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 useConnectivityStatus = _botframeworkWebchatApi.hooks.useConnectivityStatus,
useLocalizer = _botframeworkWebchatApi.hooks.useLocalizer,
usePonyfill = _botframeworkWebchatApi.hooks.usePonyfill,
useSendBoxAttachments = _botframeworkWebchatApi.hooks.useSendBoxAttachments,
useSendBoxValue = _botframeworkWebchatApi.hooks.useSendBoxValue,
useSubmitSendBox = _botframeworkWebchatApi.hooks.useSubmitSendBox;
var SUBMIT_ERROR_MESSAGE_STYLE = {
'&.webchat__submit-error-message': {
// .sr-only - This component is intended to be invisible to the visual Web Chat user, but read by the AT when using a screen reader
color: 'transparent',
height: 1,
overflow: 'hidden',
position: 'absolute',
// We need to set top: 0, otherwise, it will repro:
// - Run NVDA
// - Make the transcript long enough to show the scrollbar
// - Press SHIFT-TAB, focus on upload button
// - Press up arrow multiple times
top: 0,
whiteSpace: 'nowrap',
width: 1
}
};
// False positive: we are using `setTimeout` as a type.
// eslint-disable-next-line no-restricted-globals
var TIME_TO_QUEUE_ERROR_MESSAGE = 500;
var TIME_TO_RESET_ERROR_MESSAGE = 50;
// This component is marked as internal because it is not fully implemented and is not ready to be consumed publicly.
// When it is done, it should provide and replace all the functionalities we did in Redux, including but not limited to:
// - Speech interims
// - Maintain text box value
// - Multiple <SendBoxComposer> in a single Web Chat instance
// - Web devs should be able to put an individual send box instance into an activity
// - The send box instance in the activity, should be separated from the bottommost send box
// - The valued typed inside the activity, should be separated from the value typed into the bottommost send box
// In the old days, we use Redux to keep the send box state.
// However, when web devs put 2 send box on their page, it makes things complex because both send boxes will interact with each other.
// We would rather have them separate. If web devs want them to interact with each other, they will do the wiring themselves.
// TODO: [P2] Complete this component.
var SendBoxComposer = function SendBoxComposer(_ref) {
var children = _ref.children;
var _usePonyfill = usePonyfill(),
_usePonyfill2 = _slicedToArray(_usePonyfill, 1),
_usePonyfill2$ = _usePonyfill2[0],
clearTimeout = _usePonyfill2$.clearTimeout,
setTimeout = _usePonyfill2$.setTimeout;
var _useSendBoxAttachment = useSendBoxAttachments(),
_useSendBoxAttachment2 = _slicedToArray(_useSendBoxAttachment, 1),
attachments = _useSendBoxAttachment2[0];
var _useConnectivityStatu = useConnectivityStatus(),
_useConnectivityStatu2 = _slicedToArray(_useConnectivityStatu, 1),
connectivityStatus = _useConnectivityStatu2[0];
var _useState = (0, _react.useState)(false),
_useState2 = _slicedToArray(_useState, 2),
error = _useState2[0],
setError = _useState2[1];
var _useSendBoxValue = useSendBoxValue(),
_useSendBoxValue2 = _slicedToArray(_useSendBoxValue, 1),
sendBoxValue = _useSendBoxValue2[0];
var apiSubmitSendBox = useSubmitSendBox();
var focus = (0, _useFocus.default)();
var localize = useLocalizer();
var scrollToEnd = (0, _useScrollToEnd.default)();
var styleToEmotionObject = (0, _useStyleToEmotionObject.default)();
var submitErrorMessageId = (0, _useUniqueId.default)('webchat__send-box__error-message-id');
var timeoutRef = (0, _react.useRef)(undefined);
var errorMessageStringMap = (0, _react.useMemo)(function () {
return Object.freeze(new Map().set('empty', localize('SEND_BOX_IS_EMPTY_TOOLTIP_ALT'))
// TODO: [P0] We should add a new string for "Cannot send message while offline."
.set('offline', localize('CONNECTIVITY_STATUS_ALT_FATAL')));
}, [localize]);
var focusRef = (0, _useRefFrom.useRefFrom)(focus);
var scrollToEndRef = (0, _useRefFrom.useRefFrom)(scrollToEnd);
var setErrorRef = (0, _react.useRef)(setError);
var submitErrorMessageClassName = styleToEmotionObject(SUBMIT_ERROR_MESSAGE_STYLE) + '';
var submitErrorMessageIdState = (0, _react.useMemo)(function () {
return Object.freeze([error ? submitErrorMessageId : undefined]);
}, [error, submitErrorMessageId]);
setErrorRef.current = setError;
var submitErrorRef = (0, _useRefFrom.useRefFrom)(connectivityStatus !== 'connected' && connectivityStatus !== 'reconnected' ? 'offline' : !sendBoxValue && !attachments.length ? 'empty' : undefined);
var submit = (0, _react.useCallback)(function () {
var _focusRef$current;
var _ref2 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
setFocus = _ref2.setFocus;
(setFocus === 'main' || setFocus === 'sendBox' || setFocus === 'sendBoxWithoutKeyboard') && ((_focusRef$current = focusRef.current) === null || _focusRef$current === void 0 ? void 0 : _focusRef$current.call(focusRef, setFocus === 'main' || setFocus === 'sendBox' ? setFocus : 'sendBoxWithoutKeyboard'));
var submitError = submitErrorRef.current;
if (submitError) {
var _setErrorRef$current;
timeoutRef.current && timeoutRef.current.forEach(clearTimeout);
(_setErrorRef$current = setErrorRef.current) === null || _setErrorRef$current === void 0 ? void 0 : _setErrorRef$current.call(setErrorRef, false);
timeoutRef.current = Object.freeze([setTimeout(function () {
var _setErrorRef$current2;
return (_setErrorRef$current2 = setErrorRef.current) === null || _setErrorRef$current2 === void 0 ? void 0 : _setErrorRef$current2.call(setErrorRef, submitError);
}, TIME_TO_RESET_ERROR_MESSAGE), setTimeout(function () {
var _setErrorRef$current3;
return (_setErrorRef$current3 = setErrorRef.current) === null || _setErrorRef$current3 === void 0 ? void 0 : _setErrorRef$current3.call(setErrorRef, false);
}, TIME_TO_QUEUE_ERROR_MESSAGE)]);
} else {
var _scrollToEndRef$curre;
(_scrollToEndRef$curre = scrollToEndRef.current) === null || _scrollToEndRef$curre === void 0 ? void 0 : _scrollToEndRef$curre.call(scrollToEndRef);
apiSubmitSendBox();
}
}, [apiSubmitSendBox, clearTimeout, focusRef, scrollToEndRef, setErrorRef, setTimeout, submitErrorRef, timeoutRef]);
(0, _react.useEffect)(
// Prevent `setTimeout()` from firing after unmount.
function () {
return function () {
setErrorRef.current = undefined;
};
}, [setErrorRef]);
var context = (0, _react.useMemo)(function () {
return {
submit: submit,
submitErrorMessageIdState: submitErrorMessageIdState
};
}, [submit, submitErrorMessageIdState]);
return /*#__PURE__*/_react.default.createElement(_Context.default.Provider, {
value: context
}, children, /*#__PURE__*/_react.default.createElement("span", {
className: (0, _classnames.default)('webchat__submit-error-message', submitErrorMessageClassName)
// "id" is required for "aria-errormessage" as IDREF.
// eslint-disable-next-line react/forbid-dom-props
,
id: submitErrorMessageId,
role: "alert"
}, error ? errorMessageStringMap.get(error) : ''));
};
var _default = SendBoxComposer;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_botframeworkWebchatApi","require","_classnames","_interopRequireDefault","_react","_interopRequireWildcard","_useRefFrom","_useStyleToEmotionObject","_useUniqueId","_useFocus","_useScrollToEnd","_Context","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_slicedToArray","arr","i","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","TypeError","o","minLen","_arrayLikeToArray","n","toString","slice","constructor","name","Array","from","test","len","length","arr2","_i","Symbol","iterator","_arr","_n","_d","_s","_e","next","done","push","value","err","isArray","useConnectivityStatus","hooks","useLocalizer","usePonyfill","useSendBoxAttachments","useSendBoxValue","useSubmitSendBox","SUBMIT_ERROR_MESSAGE_STYLE","color","height","overflow","position","top","whiteSpace","width","TIME_TO_QUEUE_ERROR_MESSAGE","TIME_TO_RESET_ERROR_MESSAGE","SendBoxComposer","_ref","children","_usePonyfill","_usePonyfill2","_usePonyfill2$","clearTimeout","setTimeout","_useSendBoxAttachment","_useSendBoxAttachment2","attachments","_useConnectivityStatu","_useConnectivityStatu2","connectivityStatus","_useState","useState","_useState2","error","setError","_useSendBoxValue","_useSendBoxValue2","sendBoxValue","apiSubmitSendBox","focus","useFocus","localize","scrollToEnd","useScrollToEnd","styleToEmotionObject","useStyleToEmotionObject","submitErrorMessageId","useUniqueId","timeoutRef","useRef","undefined","errorMessageStringMap","useMemo","freeze","Map","focusRef","useRefFrom","scrollToEndRef","setErrorRef","submitErrorMessageClassName","submitErrorMessageIdState","current","submitErrorRef","submit","useCallback","_focusRef$current","_ref2","arguments","setFocus","submitError","_setErrorRef$current","forEach","_setErrorRef$current2","_setErrorRef$current3","_scrollToEndRef$curre","useEffect","context","createElement","Provider","className","classNames","id","role","_default","exports"],"sourceRoot":"component:///","sources":["../../../../src/providers/internal/SendBox/SendBoxComposer.tsx"],"sourcesContent":["import { hooks } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport React, { useCallback, useEffect, useMemo, useRef, useState, type PropsWithChildren } from 'react';\nimport { useRefFrom } from 'use-ref-from';\n\nimport useStyleToEmotionObject from '../../../hooks/internal/useStyleToEmotionObject';\nimport useUniqueId from '../../../hooks/internal/useUniqueId';\nimport useFocus from '../../../hooks/useFocus';\nimport useScrollToEnd from '../../../hooks/useScrollToEnd';\nimport SendBoxContext from './private/Context';\nimport { type ContextType, type SendError } from './private/types';\n\nconst { useConnectivityStatus, useLocalizer, usePonyfill, useSendBoxAttachments, useSendBoxValue, useSubmitSendBox } =\n  hooks;\n\nconst SUBMIT_ERROR_MESSAGE_STYLE = {\n  '&.webchat__submit-error-message': {\n    // .sr-only - This component is intended to be invisible to the visual Web Chat user, but read by the AT when using a screen reader\n    color: 'transparent',\n    height: 1,\n    overflow: 'hidden',\n    position: 'absolute',\n    // We need to set top: 0, otherwise, it will repro:\n    // - Run NVDA\n    // - Make the transcript long enough to show the scrollbar\n    // - Press SHIFT-TAB, focus on upload button\n    // - Press up arrow multiple times\n    top: 0,\n    whiteSpace: 'nowrap',\n    width: 1\n  }\n};\n\n// False positive: we are using `setTimeout` as a type.\n// eslint-disable-next-line no-restricted-globals\ntype Timeout = ReturnType<typeof setTimeout>;\n\nconst TIME_TO_QUEUE_ERROR_MESSAGE = 500;\nconst TIME_TO_RESET_ERROR_MESSAGE = 50;\n\n// This component is marked as internal because it is not fully implemented and is not ready to be consumed publicly.\n// When it is done, it should provide and replace all the functionalities we did in Redux, including but not limited to:\n\n// - Speech interims\n// - Maintain text box value\n// - Multiple <SendBoxComposer> in a single Web Chat instance\n//    - Web devs should be able to put an individual send box instance into an activity\n//    - The send box instance in the activity, should be separated from the bottommost send box\n//    - The valued typed inside the activity, should be separated from the value typed into the bottommost send box\n\n// In the old days, we use Redux to keep the send box state.\n// However, when web devs put 2 send box on their page, it makes things complex because both send boxes will interact with each other.\n// We would rather have them separate. If web devs want them to interact with each other, they will do the wiring themselves.\n\ntype ErrorMessageStringMap = ReadonlyMap<SendError, string>;\n\n// TODO: [P2] Complete this component.\nconst SendBoxComposer = ({ children }: PropsWithChildren<{}>) => {\n  const [{ clearTimeout, setTimeout }] = usePonyfill();\n  const [attachments] = useSendBoxAttachments();\n  const [connectivityStatus] = useConnectivityStatus();\n  const [error, setError] = useState<SendError | false>(false);\n  const [sendBoxValue] = useSendBoxValue();\n  const apiSubmitSendBox = useSubmitSendBox();\n  const focus = useFocus();\n  const localize = useLocalizer();\n  const scrollToEnd = useScrollToEnd();\n  const styleToEmotionObject = useStyleToEmotionObject();\n  const submitErrorMessageId = useUniqueId('webchat__send-box__error-message-id');\n  const timeoutRef = useRef<readonly [Timeout, Timeout] | undefined>(undefined);\n\n  const errorMessageStringMap = useMemo<ErrorMessageStringMap>(\n    () =>\n      Object.freeze(\n        new Map<SendError, string>()\n          .set('empty', localize('SEND_BOX_IS_EMPTY_TOOLTIP_ALT'))\n          // TODO: [P0] We should add a new string for \"Cannot send message while offline.\"\n          .set('offline', localize('CONNECTIVITY_STATUS_ALT_FATAL'))\n      ),\n    [localize]\n  );\n  const focusRef = useRefFrom(focus);\n  const scrollToEndRef = useRefFrom(scrollToEnd);\n  const setErrorRef = useRef<typeof setError | undefined>(setError);\n  const submitErrorMessageClassName = styleToEmotionObject(SUBMIT_ERROR_MESSAGE_STYLE) + '';\n  const submitErrorMessageIdState = useMemo<readonly [string | undefined]>(\n    () => Object.freeze([error ? submitErrorMessageId : undefined]) as readonly [string | undefined],\n    [error, submitErrorMessageId]\n  );\n\n  setErrorRef.current = setError;\n\n  const submitErrorRef = useRefFrom<'empty' | 'offline' | undefined>(\n    connectivityStatus !== 'connected' && connectivityStatus !== 'reconnected'\n      ? 'offline'\n      : !sendBoxValue && !attachments.length\n        ? 'empty'\n        : undefined\n  );\n\n  const submit = useCallback<ContextType['submit']>(\n    ({ setFocus } = {}) => {\n      (setFocus === 'main' || setFocus === 'sendBox' || setFocus === 'sendBoxWithoutKeyboard') &&\n        focusRef.current?.(setFocus === 'main' || setFocus === 'sendBox' ? setFocus : 'sendBoxWithoutKeyboard');\n\n      const { current: submitError } = submitErrorRef;\n\n      if (submitError) {\n        timeoutRef.current && timeoutRef.current.forEach(clearTimeout);\n\n        setErrorRef.current?.(false);\n\n        timeoutRef.current = Object.freeze([\n          setTimeout(() => setErrorRef.current?.(submitError), TIME_TO_RESET_ERROR_MESSAGE),\n          setTimeout(() => setErrorRef.current?.(false), TIME_TO_QUEUE_ERROR_MESSAGE)\n        ]) as readonly [Timeout, Timeout];\n      } else {\n        scrollToEndRef.current?.();\n        apiSubmitSendBox();\n      }\n    },\n    [apiSubmitSendBox, clearTimeout, focusRef, scrollToEndRef, setErrorRef, setTimeout, submitErrorRef, timeoutRef]\n  );\n\n  useEffect(\n    // Prevent `setTimeout()` from firing after unmount.\n    () => () => {\n      setErrorRef.current = undefined;\n    },\n    [setErrorRef]\n  );\n\n  const context = useMemo(\n    () => ({\n      submit,\n      submitErrorMessageIdState\n    }),\n    [submit, submitErrorMessageIdState]\n  );\n\n  return (\n    <SendBoxContext.Provider value={context}>\n      {children}\n      <span\n        className={classNames('webchat__submit-error-message', submitErrorMessageClassName)}\n        // \"id\" is required for \"aria-errormessage\" as IDREF.\n        // eslint-disable-next-line react/forbid-dom-props\n        id={submitErrorMessageId}\n        role=\"alert\"\n      >\n        {error ? errorMessageStringMap.get(error) : ''}\n      </span>\n    </SendBoxContext.Provider>\n  );\n};\n\nexport default SendBoxComposer;\n"],"mappings":"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"}