botframework-webchat-component
Version:
React component of botframework-webchat
160 lines (157 loc) • 30.2 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;
exports.useMicrophoneButtonClick = useMicrophoneButtonClick;
exports.useMicrophoneButtonDisabled = useMicrophoneButtonDisabled;
var _botframeworkWebchatApi = require("botframework-webchat-api");
var _botframeworkWebchatCore = require("botframework-webchat-core");
var _classnames = _interopRequireDefault(require("classnames"));
var _memoizeOne = _interopRequireDefault(require("memoize-one"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _react = _interopRequireWildcard(require("react"));
var _useStyleToEmotionObject = _interopRequireDefault(require("../hooks/internal/useStyleToEmotionObject"));
var _useDictateAbortable3 = _interopRequireDefault(require("../hooks/useDictateAbortable"));
var _useStyleSet3 = _interopRequireDefault(require("../hooks/useStyleSet"));
var _useWebSpeechPonyfill3 = _interopRequireDefault(require("../hooks/useWebSpeechPonyfill"));
var _MicrophoneIcon = _interopRequireDefault(require("./Assets/MicrophoneIcon"));
var _IconButton = _interopRequireDefault(require("./IconButton"));
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; } // This is required for aria-controls.
/* eslint react/forbid-dom-props: "off" */
var DictateState = _botframeworkWebchatCore.Constants.DictateState;
var useDictateInterims = _botframeworkWebchatApi.hooks.useDictateInterims,
useDictateState = _botframeworkWebchatApi.hooks.useDictateState,
useDisabled = _botframeworkWebchatApi.hooks.useDisabled,
useLocalizer = _botframeworkWebchatApi.hooks.useLocalizer,
useSendBoxValue = _botframeworkWebchatApi.hooks.useSendBoxValue,
useShouldSpeakIncomingActivity = _botframeworkWebchatApi.hooks.useShouldSpeakIncomingActivity,
useStartDictate = _botframeworkWebchatApi.hooks.useStartDictate,
useStopDictate = _botframeworkWebchatApi.hooks.useStopDictate;
var ROOT_STYLE = {
display: 'flex',
// .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
'& > .sr-only': {
color: 'transparent',
height: 1,
left: -10000,
overflow: 'hidden',
position: 'absolute',
top: 0,
whiteSpace: 'nowrap',
width: 1
}
};
function useMicrophoneButtonClick() {
var _useSendBoxValue = useSendBoxValue(),
_useSendBoxValue2 = _slicedToArray(_useSendBoxValue, 2),
setSendBox = _useSendBoxValue2[1];
var _useShouldSpeakIncomi = useShouldSpeakIncomingActivity(),
_useShouldSpeakIncomi2 = _slicedToArray(_useShouldSpeakIncomi, 2),
setShouldSpeakIncomingActivity = _useShouldSpeakIncomi2[1];
var _useDictateInterims = useDictateInterims(),
_useDictateInterims2 = _slicedToArray(_useDictateInterims, 1),
dictateInterims = _useDictateInterims2[0];
var _useDictateState = useDictateState(),
_useDictateState2 = _slicedToArray(_useDictateState, 1),
dictateState = _useDictateState2[0];
var _useWebSpeechPonyfill = (0, _useWebSpeechPonyfill3.default)(),
_useWebSpeechPonyfill2 = _slicedToArray(_useWebSpeechPonyfill, 1),
webSpeechPonyfill = _useWebSpeechPonyfill2[0];
var startDictate = useStartDictate();
var stopDictate = useStopDictate();
var _ref = webSpeechPonyfill || {},
speechSynthesis = _ref.speechSynthesis,
SpeechSynthesisUtterance = _ref.SpeechSynthesisUtterance;
var _useState = (0, _react.useState)(function () {
return (0, _memoizeOne.default)(function (speechSynthesis, SpeechSynthesisUtterance) {
if (speechSynthesis && SpeechSynthesisUtterance) {
var utterance = new SpeechSynthesisUtterance('');
var _speechSynthesis$getV = speechSynthesis.getVoices();
var _speechSynthesis$getV2 = _slicedToArray(_speechSynthesis$getV, 1);
utterance.voice = _speechSynthesis$getV2[0];
speechSynthesis.speak(utterance);
}
});
}),
_useState2 = _slicedToArray(_useState, 1),
primeSpeechSynthesis = _useState2[0];
// TODO: [P2] We should revisit this function later
// The click() logic seems local to the component, but may not be generalized across all implementations.
return (0, _react.useCallback)(function () {
if (dictateState === DictateState.WILL_START) {
setShouldSpeakIncomingActivity(false);
} else if (dictateState === DictateState.DICTATING) {
stopDictate();
setSendBox(dictateInterims.join(' '));
} else {
setShouldSpeakIncomingActivity(false);
startDictate();
}
primeSpeechSynthesis(speechSynthesis, SpeechSynthesisUtterance);
}, [dictateInterims, dictateState, primeSpeechSynthesis, setSendBox, setShouldSpeakIncomingActivity, speechSynthesis, SpeechSynthesisUtterance, startDictate, stopDictate]);
}
function useMicrophoneButtonDisabled() {
var _useDictateAbortable = (0, _useDictateAbortable3.default)(),
_useDictateAbortable2 = _slicedToArray(_useDictateAbortable, 1),
abortable = _useDictateAbortable2[0];
var _useDictateState3 = useDictateState(),
_useDictateState4 = _slicedToArray(_useDictateState3, 1),
dictateState = _useDictateState4[0];
var _useDisabled = useDisabled(),
_useDisabled2 = _slicedToArray(_useDisabled, 1),
disabled = _useDisabled2[0];
return [disabled || dictateState === DictateState.STARTING || dictateState === DictateState.STOPPING || dictateState === DictateState.DICTATING && !abortable];
}
var MicrophoneButton = function MicrophoneButton(_ref2) {
var className = _ref2.className;
var _useStyleSet = (0, _useStyleSet3.default)(),
_useStyleSet2 = _slicedToArray(_useStyleSet, 1),
microphoneButtonStyleSet = _useStyleSet2[0].microphoneButton;
var _useDictateState5 = useDictateState(),
_useDictateState6 = _slicedToArray(_useDictateState5, 1),
dictateState = _useDictateState6[0];
var _useMicrophoneButtonD = useMicrophoneButtonDisabled(),
_useMicrophoneButtonD2 = _slicedToArray(_useMicrophoneButtonD, 1),
disabled = _useMicrophoneButtonD2[0];
var click = useMicrophoneButtonClick();
var localize = useLocalizer();
var rootClassName = (0, _useStyleToEmotionObject.default)()(ROOT_STYLE) + '';
var dictating = dictateState === DictateState.DICTATING;
return /*#__PURE__*/_react.default.createElement("div", {
"aria-controls": "webchatSendBoxMicrophoneButton",
className: (0, _classnames.default)('webchat__microphone-button', {
'webchat__microphone-button--dictating': dictating
}, microphoneButtonStyleSet + '', rootClassName, (className || '') + '')
}, /*#__PURE__*/_react.default.createElement(_IconButton.default, {
alt: localize('TEXT_INPUT_SPEAK_BUTTON_ALT'),
className: "webchat__microphone-button__button",
disabled: disabled,
onClick: click
}, /*#__PURE__*/_react.default.createElement(_MicrophoneIcon.default, {
className: "webchat__microphone-button__icon"
})), /*#__PURE__*/_react.default.createElement("div", {
"aria-live": "polite",
className: "sr-only",
id: "webchatSendBoxMicrophoneButton",
role: "status"
}, localize(dictating ? 'SPEECH_INPUT_MICROPHONE_BUTTON_OPEN_ALT' : 'SPEECH_INPUT_MICROPHONE_BUTTON_CLOSE_ALT')));
};
MicrophoneButton.defaultProps = {
className: ''
};
MicrophoneButton.propTypes = {
className: _propTypes.default.string
};
var _default = MicrophoneButton;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_botframeworkWebchatApi","require","_botframeworkWebchatCore","_classnames","_interopRequireDefault","_memoizeOne","_propTypes","_react","_interopRequireWildcard","_useStyleToEmotionObject","_useDictateAbortable3","_useStyleSet3","_useWebSpeechPonyfill3","_MicrophoneIcon","_IconButton","_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","DictateState","Constants","useDictateInterims","hooks","useDictateState","useDisabled","useLocalizer","useSendBoxValue","useShouldSpeakIncomingActivity","useStartDictate","useStopDictate","ROOT_STYLE","display","color","height","left","overflow","position","top","whiteSpace","width","useMicrophoneButtonClick","_useSendBoxValue","_useSendBoxValue2","setSendBox","_useShouldSpeakIncomi","_useShouldSpeakIncomi2","setShouldSpeakIncomingActivity","_useDictateInterims","_useDictateInterims2","dictateInterims","_useDictateState","_useDictateState2","dictateState","_useWebSpeechPonyfill","useWebSpeechPonyfill","_useWebSpeechPonyfill2","webSpeechPonyfill","startDictate","stopDictate","_ref","speechSynthesis","SpeechSynthesisUtterance","_useState","useState","memoize","utterance","_speechSynthesis$getV","getVoices","_speechSynthesis$getV2","voice","speak","_useState2","primeSpeechSynthesis","useCallback","WILL_START","DICTATING","join","useMicrophoneButtonDisabled","_useDictateAbortable","useDictateAbortable","_useDictateAbortable2","abortable","_useDictateState3","_useDictateState4","_useDisabled","_useDisabled2","disabled","STARTING","STOPPING","MicrophoneButton","_ref2","className","_useStyleSet","useStyleSet","_useStyleSet2","microphoneButtonStyleSet","microphoneButton","_useDictateState5","_useDictateState6","_useMicrophoneButtonD","_useMicrophoneButtonD2","click","localize","rootClassName","useStyleToEmotionObject","dictating","createElement","classNames","alt","onClick","id","role","defaultProps","propTypes","PropTypes","string","_default","exports"],"sourceRoot":"component:///","sources":["../../src/SendBox/MicrophoneButton.tsx"],"sourcesContent":["// This is required for aria-controls.\n/* eslint react/forbid-dom-props: \"off\" */\n\nimport { hooks } from 'botframework-webchat-api';\nimport { Constants } from 'botframework-webchat-core';\nimport classNames from 'classnames';\nimport memoize from 'memoize-one';\nimport PropTypes from 'prop-types';\nimport React, { FC, useCallback, useState } from 'react';\n\nimport useStyleToEmotionObject from '../hooks/internal/useStyleToEmotionObject';\nimport useDictateAbortable from '../hooks/useDictateAbortable';\nimport useStyleSet from '../hooks/useStyleSet';\nimport useWebSpeechPonyfill from '../hooks/useWebSpeechPonyfill';\nimport MicrophoneIcon from './Assets/MicrophoneIcon';\nimport IconButton from './IconButton';\n\nconst { DictateState } = Constants;\n\nconst {\n  useDictateInterims,\n  useDictateState,\n  useDisabled,\n  useLocalizer,\n  useSendBoxValue,\n  useShouldSpeakIncomingActivity,\n  useStartDictate,\n  useStopDictate\n} = hooks;\n\nconst ROOT_STYLE = {\n  display: 'flex',\n\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\n  '& > .sr-only': {\n    color: 'transparent',\n    height: 1,\n    left: -10000,\n    overflow: 'hidden',\n    position: 'absolute',\n    top: 0,\n    whiteSpace: 'nowrap',\n    width: 1\n  }\n};\n\nfunction useMicrophoneButtonClick(): () => void {\n  const [, setSendBox] = useSendBoxValue();\n  const [, setShouldSpeakIncomingActivity] = useShouldSpeakIncomingActivity();\n  const [dictateInterims] = useDictateInterims();\n  const [dictateState] = useDictateState();\n  const [webSpeechPonyfill] = useWebSpeechPonyfill();\n  const startDictate = useStartDictate();\n  const stopDictate = useStopDictate();\n\n  const { speechSynthesis, SpeechSynthesisUtterance } = webSpeechPonyfill || {};\n\n  const [primeSpeechSynthesis] = useState(() =>\n    memoize((speechSynthesis, SpeechSynthesisUtterance) => {\n      if (speechSynthesis && SpeechSynthesisUtterance) {\n        const utterance = new SpeechSynthesisUtterance('');\n\n        [utterance.voice] = speechSynthesis.getVoices();\n        speechSynthesis.speak(utterance);\n      }\n    })\n  );\n\n  // TODO: [P2] We should revisit this function later\n  //       The click() logic seems local to the component, but may not be generalized across all implementations.\n  return useCallback(() => {\n    if (dictateState === DictateState.WILL_START) {\n      setShouldSpeakIncomingActivity(false);\n    } else if (dictateState === DictateState.DICTATING) {\n      stopDictate();\n      setSendBox(dictateInterims.join(' '));\n    } else {\n      setShouldSpeakIncomingActivity(false);\n      startDictate();\n    }\n\n    primeSpeechSynthesis(speechSynthesis, SpeechSynthesisUtterance);\n  }, [\n    dictateInterims,\n    dictateState,\n    primeSpeechSynthesis,\n    setSendBox,\n    setShouldSpeakIncomingActivity,\n    speechSynthesis,\n    SpeechSynthesisUtterance,\n    startDictate,\n    stopDictate\n  ]);\n}\n\nfunction useMicrophoneButtonDisabled(): [boolean] {\n  const [abortable] = useDictateAbortable();\n  const [dictateState] = useDictateState();\n  const [disabled] = useDisabled();\n\n  return [\n    disabled ||\n      dictateState === DictateState.STARTING ||\n      dictateState === DictateState.STOPPING ||\n      (dictateState === DictateState.DICTATING && !abortable)\n  ];\n}\n\ntype MicrophoneButtonProps = {\n  className?: string;\n};\n\nconst MicrophoneButton: FC<MicrophoneButtonProps> = ({ className }) => {\n  const [{ microphoneButton: microphoneButtonStyleSet }] = useStyleSet();\n  const [dictateState] = useDictateState();\n  const [disabled] = useMicrophoneButtonDisabled();\n  const click = useMicrophoneButtonClick();\n  const localize = useLocalizer();\n  const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n\n  const dictating = dictateState === DictateState.DICTATING;\n\n  return (\n    <div\n      aria-controls=\"webchatSendBoxMicrophoneButton\"\n      className={classNames(\n        'webchat__microphone-button',\n        { 'webchat__microphone-button--dictating': dictating },\n        microphoneButtonStyleSet + '',\n        rootClassName,\n        (className || '') + ''\n      )}\n    >\n      <IconButton\n        alt={localize('TEXT_INPUT_SPEAK_BUTTON_ALT')}\n        className=\"webchat__microphone-button__button\"\n        disabled={disabled}\n        onClick={click}\n      >\n        <MicrophoneIcon className=\"webchat__microphone-button__icon\" />\n      </IconButton>\n      <div aria-live=\"polite\" className=\"sr-only\" id=\"webchatSendBoxMicrophoneButton\" role=\"status\">\n        {localize(dictating ? 'SPEECH_INPUT_MICROPHONE_BUTTON_OPEN_ALT' : 'SPEECH_INPUT_MICROPHONE_BUTTON_CLOSE_ALT')}\n      </div>\n    </div>\n  );\n};\n\nMicrophoneButton.defaultProps = {\n  className: ''\n};\n\nMicrophoneButton.propTypes = {\n  className: PropTypes.string\n};\n\nexport default MicrophoneButton;\n\nexport { useMicrophoneButtonClick, useMicrophoneButtonDisabled };\n"],"mappings":"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"}
;