UNPKG

botframework-webchat-component

Version:
260 lines (202 loc) 28.7 kB
"use strict"; function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } Object.defineProperty(exports, "__esModule", { value: true }); exports.useMicrophoneButtonDisabled = useMicrophoneButtonDisabled; exports.useMicrophoneButtonClick = exports.connectMicrophoneButton = exports.default = void 0; var _botframeworkWebchatCore = require("botframework-webchat-core"); var _botframeworkWebchatApi = require("botframework-webchat-api"); var _classnames = _interopRequireDefault(require("classnames")); var _memoizeOne = _interopRequireDefault(require("memoize-one")); var _propTypes = _interopRequireDefault(require("prop-types")); var _react = _interopRequireWildcard(require("react")); var _connectToWebChat = _interopRequireDefault(require("../connectToWebChat")); var _IconButton = _interopRequireDefault(require("./IconButton")); var _MicrophoneIcon = _interopRequireDefault(require("./Assets/MicrophoneIcon")); var _useDictateAbortable3 = _interopRequireDefault(require("../hooks/useDictateAbortable")); var _useStyleSet3 = _interopRequireDefault(require("../hooks/useStyleSet")); var _useStyleToEmotionObject = _interopRequireDefault(require("../hooks/internal/useStyleToEmotionObject")); var _useWebSpeechPonyfill4 = _interopRequireDefault(require("../hooks/useWebSpeechPonyfill")); function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; } function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } var 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 } }; var connectMicrophoneButton = function connectMicrophoneButton() { var primeSpeechSynthesis = (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); } }); for (var _len = arguments.length, selectors = new Array(_len), _key = 0; _key < _len; _key++) { selectors[_key] = arguments[_key]; } return _connectToWebChat.default.apply(void 0, [function (_ref) { var disabled = _ref.disabled, dictateInterims = _ref.dictateInterims, dictateState = _ref.dictateState, language = _ref.language, setSendBox = _ref.setSendBox, startDictate = _ref.startDictate, stopDictate = _ref.stopDictate, stopSpeakingActivity = _ref.stopSpeakingActivity, _ref$webSpeechPonyfil = _ref.webSpeechPonyfill; _ref$webSpeechPonyfil = _ref$webSpeechPonyfil === void 0 ? {} : _ref$webSpeechPonyfil; var speechSynthesis = _ref$webSpeechPonyfil.speechSynthesis, SpeechSynthesisUtterance = _ref$webSpeechPonyfil.SpeechSynthesisUtterance; return { click: function click() { if (dictateState === DictateState.WILL_START) { stopSpeakingActivity(); } else if (dictateState === DictateState.DICTATING) { stopDictate(); setSendBox(dictateInterims.join(' ')); } else { stopSpeakingActivity(); startDictate(); } primeSpeechSynthesis(speechSynthesis, SpeechSynthesisUtterance); }, dictating: dictateState === DictateState.DICTATING, disabled: disabled || dictateState === DictateState.STARTING && dictateState === DictateState.STOPPING, language: language }; }].concat(selectors)); }; exports.connectMicrophoneButton = connectMicrophoneButton; var useMicrophoneButtonClick = function useMicrophoneButtonClick() { var _useSendBoxValue = useSendBoxValue(), _useSendBoxValue2 = _slicedToArray(_useSendBoxValue, 2), setSendBox = _useSendBoxValue2[1]; var _useShouldSpeakIncomi = useShouldSpeakIncomingActivity(), _useShouldSpeakIncomi2 = _slicedToArray(_useShouldSpeakIncomi, 2), setShouldSpeakIncomingActivity = _useShouldSpeakIncomi2[1]; var _useWebSpeechPonyfill = (0, _useWebSpeechPonyfill4.default)(), _useWebSpeechPonyfill2 = _slicedToArray(_useWebSpeechPonyfill, 1), _useWebSpeechPonyfill3 = _useWebSpeechPonyfill2[0]; _useWebSpeechPonyfill3 = _useWebSpeechPonyfill3 === void 0 ? {} : _useWebSpeechPonyfill3; var speechSynthesis = _useWebSpeechPonyfill3.speechSynthesis, SpeechSynthesisUtterance = _useWebSpeechPonyfill3.SpeechSynthesisUtterance; var _useDictateInterims = useDictateInterims(), _useDictateInterims2 = _slicedToArray(_useDictateInterims, 1), dictateInterims = _useDictateInterims2[0]; var _useDictateState = useDictateState(), _useDictateState2 = _slicedToArray(_useDictateState, 1), dictateState = _useDictateState2[0]; var startDictate = useStartDictate(); var stopDictate = useStopDictate(); var _useState = (0, _react.useState)(function () { return (0, _memoizeOne.default)(function (speechSynthesis, SpeechSynthesisUtterance) { if (speechSynthesis && SpeechSynthesisUtterance) { var utterance = new SpeechSynthesisUtterance(''); var _speechSynthesis$getV3 = speechSynthesis.getVoices(); var _speechSynthesis$getV4 = _slicedToArray(_speechSynthesis$getV3, 1); utterance.voice = _speechSynthesis$getV4[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]); }; exports.useMicrophoneButtonClick = useMicrophoneButtonClick; 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,"sources":["../../src/SendBox/MicrophoneButton.js"],"names":["DictateState","Constants","useDictateInterims","hooks","useDictateState","useDisabled","useLocalizer","useSendBoxValue","useShouldSpeakIncomingActivity","useStartDictate","useStopDictate","ROOT_STYLE","display","color","height","left","overflow","position","top","whiteSpace","width","connectMicrophoneButton","primeSpeechSynthesis","speechSynthesis","SpeechSynthesisUtterance","utterance","getVoices","voice","speak","selectors","connectToWebChat","disabled","dictateInterims","dictateState","language","setSendBox","startDictate","stopDictate","stopSpeakingActivity","webSpeechPonyfill","click","WILL_START","DICTATING","join","dictating","STARTING","STOPPING","useMicrophoneButtonClick","setShouldSpeakIncomingActivity","useMicrophoneButtonDisabled","abortable","MicrophoneButton","className","microphoneButtonStyleSet","microphoneButton","localize","rootClassName","defaultProps","propTypes","PropTypes","string"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["// This is required for aria-controls.\n/* eslint react/forbid-dom-props: \"off\" */\n\nimport { Constants } from 'botframework-webchat-core';\nimport { hooks } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport memoize from 'memoize-one';\nimport PropTypes from 'prop-types';\nimport React, { useCallback, useState } from 'react';\n\nimport connectToWebChat from '../connectToWebChat';\nimport IconButton from './IconButton';\nimport MicrophoneIcon from './Assets/MicrophoneIcon';\nimport useDictateAbortable from '../hooks/useDictateAbortable';\nimport useStyleSet from '../hooks/useStyleSet';\nimport useStyleToEmotionObject from '../hooks/internal/useStyleToEmotionObject';\nimport useWebSpeechPonyfill from '../hooks/useWebSpeechPonyfill';\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\nconst connectMicrophoneButton = (...selectors) => {\n  const primeSpeechSynthesis = 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  return connectToWebChat(\n    ({\n      disabled,\n      dictateInterims,\n      dictateState,\n      language,\n      setSendBox,\n      startDictate,\n      stopDictate,\n      stopSpeakingActivity,\n      webSpeechPonyfill: { speechSynthesis, SpeechSynthesisUtterance } = {}\n    }) => ({\n      click: () => {\n        if (dictateState === DictateState.WILL_START) {\n          stopSpeakingActivity();\n        } else if (dictateState === DictateState.DICTATING) {\n          stopDictate();\n          setSendBox(dictateInterims.join(' '));\n        } else {\n          stopSpeakingActivity();\n          startDictate();\n        }\n\n        primeSpeechSynthesis(speechSynthesis, SpeechSynthesisUtterance);\n      },\n      dictating: dictateState === DictateState.DICTATING,\n      disabled: disabled || (dictateState === DictateState.STARTING && dictateState === DictateState.STOPPING),\n      language\n    }),\n    ...selectors\n  );\n};\n\nconst useMicrophoneButtonClick = () => {\n  const [, setSendBox] = useSendBoxValue();\n  const [, setShouldSpeakIncomingActivity] = useShouldSpeakIncomingActivity();\n  const [{ speechSynthesis, SpeechSynthesisUtterance } = {}] = useWebSpeechPonyfill();\n  const [dictateInterims] = useDictateInterims();\n  const [dictateState] = useDictateState();\n  const startDictate = useStartDictate();\n  const stopDictate = useStopDictate();\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() {\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\nconst MicrophoneButton = ({ 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 { connectMicrophoneButton, useMicrophoneButtonClick, useMicrophoneButtonDisabled };\n"]}