UNPKG

botframework-webchat-component

Version:
160 lines (124 loc) 16.6 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.useSendBoxSpeechInterimsVisible = useSendBoxSpeechInterimsVisible; exports.default = void 0; var _botframeworkWebchatCore = require("botframework-webchat-core"); var _botframeworkWebchatApi = require("botframework-webchat-api"); var _classnames = _interopRequireDefault(require("classnames")); var _propTypes = _interopRequireDefault(require("prop-types")); var _react = _interopRequireDefault(require("react")); var _DictationInterims = _interopRequireDefault(require("./SendBox/DictationInterims")); var _MicrophoneButton = _interopRequireDefault(require("./SendBox/MicrophoneButton")); var _SendButton = _interopRequireDefault(require("./SendBox/SendButton")); var _SuggestedActions = _interopRequireDefault(require("./SendBox/SuggestedActions")); var _TextBox = _interopRequireDefault(require("./SendBox/TextBox")); var _UploadButton = _interopRequireDefault(require("./SendBox/UploadButton")); var _useStyleSet3 = _interopRequireDefault(require("./hooks/useStyleSet")); var _useStyleToEmotionObject = _interopRequireDefault(require("./hooks/internal/useStyleToEmotionObject")); var _useWebSpeechPonyfill4 = _interopRequireDefault(require("./hooks/useWebSpeechPonyfill")); 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 _Constants$DictateSta = _botframeworkWebchatCore.Constants.DictateState, DICTATING = _Constants$DictateSta.DICTATING, STARTING = _Constants$DictateSta.STARTING; var useActivities = _botframeworkWebchatApi.hooks.useActivities, useDirection = _botframeworkWebchatApi.hooks.useDirection, useDictateState = _botframeworkWebchatApi.hooks.useDictateState, useStyleOptions = _botframeworkWebchatApi.hooks.useStyleOptions; var ROOT_STYLE = { '&.webchat__send-box': { '& .webchat__send-box__button': { flexShrink: 0 }, '& .webchat__send-box__dictation-interims': { flex: 10000 }, '& .webchat__send-box__main': { display: 'flex' }, '& .webchat__send-box__microphone-button': { flex: 1 }, '& .webchat__send-box__text-box': { flex: 10000 } } }; // TODO: [P3] We should consider exposing core/src/definitions and use it instead function activityIsSpeakingOrQueuedToSpeak(_ref) { var _ref$channelData = _ref.channelData; _ref$channelData = _ref$channelData === void 0 ? {} : _ref$channelData; var speak = _ref$channelData.speak; return !!speak; } function useSendBoxSpeechInterimsVisible() { var _useActivities = useActivities(), _useActivities2 = _slicedToArray(_useActivities, 1), activities = _useActivities2[0]; var _useDictateState = useDictateState(), _useDictateState2 = _slicedToArray(_useDictateState, 1), dictateState = _useDictateState2[0]; return [(dictateState === STARTING || dictateState === DICTATING) && !activities.filter(activityIsSpeakingOrQueuedToSpeak).length]; } var BasicSendBox = function BasicSendBox(_ref2) { var className = _ref2.className; var _useStyleOptions = useStyleOptions(), _useStyleOptions2 = _slicedToArray(_useStyleOptions, 1), _useStyleOptions2$ = _useStyleOptions2[0], hideUploadButton = _useStyleOptions2$.hideUploadButton, sendBoxButtonAlignment = _useStyleOptions2$.sendBoxButtonAlignment; var _useStyleSet = (0, _useStyleSet3.default)(), _useStyleSet2 = _slicedToArray(_useStyleSet, 1), sendBoxStyleSet = _useStyleSet2[0].sendBox; var _useWebSpeechPonyfill = (0, _useWebSpeechPonyfill4.default)(), _useWebSpeechPonyfill2 = _slicedToArray(_useWebSpeechPonyfill, 1), _useWebSpeechPonyfill3 = _useWebSpeechPonyfill2[0]; _useWebSpeechPonyfill3 = _useWebSpeechPonyfill3 === void 0 ? {} : _useWebSpeechPonyfill3; var SpeechRecognition = _useWebSpeechPonyfill3.SpeechRecognition; var _useDirection = useDirection(), _useDirection2 = _slicedToArray(_useDirection, 1), direction = _useDirection2[0]; var _useSendBoxSpeechInte = useSendBoxSpeechInterimsVisible(), _useSendBoxSpeechInte2 = _slicedToArray(_useSendBoxSpeechInte, 1), speechInterimsVisible = _useSendBoxSpeechInte2[0]; var styleToEmotionObject = (0, _useStyleToEmotionObject.default)(); var rootClassName = styleToEmotionObject(ROOT_STYLE) + ''; var supportSpeechRecognition = !!SpeechRecognition; var buttonClassName = (0, _classnames.default)('webchat__send-box__button', { 'webchat__send-box__button--align-bottom': sendBoxButtonAlignment === 'bottom', 'webchat__send-box__button--align-stretch': sendBoxButtonAlignment !== 'bottom' && sendBoxButtonAlignment !== 'top', 'webchat__send-box__button--align-top': sendBoxButtonAlignment === 'top' }); return /*#__PURE__*/_react.default.createElement("div", { className: (0, _classnames.default)('webchat__send-box', sendBoxStyleSet + '', rootClassName + '', (className || '') + ''), dir: direction, role: "form" }, /*#__PURE__*/_react.default.createElement(_SuggestedActions.default, null), /*#__PURE__*/_react.default.createElement("div", { className: "webchat__send-box__main" }, !hideUploadButton && /*#__PURE__*/_react.default.createElement(_UploadButton.default, { className: buttonClassName }), speechInterimsVisible ? /*#__PURE__*/_react.default.createElement(_DictationInterims.default, { className: "webchat__send-box__dictation-interims" }) : /*#__PURE__*/_react.default.createElement(_TextBox.default, { className: "webchat__send-box__text-box" }), supportSpeechRecognition ? /*#__PURE__*/_react.default.createElement(_MicrophoneButton.default, { className: (0, _classnames.default)(buttonClassName, 'webchat__send-box__microphone-button') }) : /*#__PURE__*/_react.default.createElement(_SendButton.default, { className: buttonClassName }))); }; BasicSendBox.defaultProps = { className: '' }; BasicSendBox.propTypes = { className: _propTypes.default.string }; var _default = BasicSendBox; exports.default = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/BasicSendBox.js"],"names":["Constants","DictateState","DICTATING","STARTING","useActivities","hooks","useDirection","useDictateState","useStyleOptions","ROOT_STYLE","flexShrink","flex","display","activityIsSpeakingOrQueuedToSpeak","channelData","speak","useSendBoxSpeechInterimsVisible","activities","dictateState","filter","length","BasicSendBox","className","hideUploadButton","sendBoxButtonAlignment","sendBoxStyleSet","sendBox","SpeechRecognition","direction","speechInterimsVisible","styleToEmotionObject","rootClassName","supportSpeechRecognition","buttonClassName","defaultProps","propTypes","PropTypes","string"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["import { Constants } from 'botframework-webchat-core';\nimport { hooks } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React from 'react';\n\nimport DictationInterims from './SendBox/DictationInterims';\nimport MicrophoneButton from './SendBox/MicrophoneButton';\nimport SendButton from './SendBox/SendButton';\nimport SuggestedActions from './SendBox/SuggestedActions';\nimport TextBox from './SendBox/TextBox';\nimport UploadButton from './SendBox/UploadButton';\nimport useStyleSet from './hooks/useStyleSet';\nimport useStyleToEmotionObject from './hooks/internal/useStyleToEmotionObject';\nimport useWebSpeechPonyfill from './hooks/useWebSpeechPonyfill';\n\nconst {\n  DictateState: { DICTATING, STARTING }\n} = Constants;\n\nconst { useActivities, useDirection, useDictateState, useStyleOptions } = hooks;\n\nconst ROOT_STYLE = {\n  '&.webchat__send-box': {\n    '& .webchat__send-box__button': { flexShrink: 0 },\n    '& .webchat__send-box__dictation-interims': { flex: 10000 },\n    '& .webchat__send-box__main': { display: 'flex' },\n    '& .webchat__send-box__microphone-button': { flex: 1 },\n    '& .webchat__send-box__text-box': { flex: 10000 }\n  }\n};\n\n// TODO: [P3] We should consider exposing core/src/definitions and use it instead\nfunction activityIsSpeakingOrQueuedToSpeak({ channelData: { speak } = {} }) {\n  return !!speak;\n}\n\nfunction useSendBoxSpeechInterimsVisible() {\n  const [activities] = useActivities();\n  const [dictateState] = useDictateState();\n\n  return [\n    (dictateState === STARTING || dictateState === DICTATING) &&\n      !activities.filter(activityIsSpeakingOrQueuedToSpeak).length\n  ];\n}\n\nconst BasicSendBox = ({ className }) => {\n  const [{ hideUploadButton, sendBoxButtonAlignment }] = useStyleOptions();\n  const [{ sendBox: sendBoxStyleSet }] = useStyleSet();\n  const [{ SpeechRecognition } = {}] = useWebSpeechPonyfill();\n  const [direction] = useDirection();\n  const [speechInterimsVisible] = useSendBoxSpeechInterimsVisible();\n  const styleToEmotionObject = useStyleToEmotionObject();\n\n  const rootClassName = styleToEmotionObject(ROOT_STYLE) + '';\n\n  const supportSpeechRecognition = !!SpeechRecognition;\n\n  const buttonClassName = classNames('webchat__send-box__button', {\n    'webchat__send-box__button--align-bottom': sendBoxButtonAlignment === 'bottom',\n    'webchat__send-box__button--align-stretch': sendBoxButtonAlignment !== 'bottom' && sendBoxButtonAlignment !== 'top',\n    'webchat__send-box__button--align-top': sendBoxButtonAlignment === 'top'\n  });\n\n  return (\n    <div\n      className={classNames('webchat__send-box', sendBoxStyleSet + '', rootClassName + '', (className || '') + '')}\n      dir={direction}\n      role=\"form\"\n    >\n      <SuggestedActions />\n      <div className=\"webchat__send-box__main\">\n        {!hideUploadButton && <UploadButton className={buttonClassName} />}\n        {speechInterimsVisible ? (\n          <DictationInterims className=\"webchat__send-box__dictation-interims\" />\n        ) : (\n          <TextBox className=\"webchat__send-box__text-box\" />\n        )}\n        {supportSpeechRecognition ? (\n          <MicrophoneButton className={classNames(buttonClassName, 'webchat__send-box__microphone-button')} />\n        ) : (\n          <SendButton className={buttonClassName} />\n        )}\n      </div>\n    </div>\n  );\n};\n\nBasicSendBox.defaultProps = {\n  className: ''\n};\n\nBasicSendBox.propTypes = {\n  className: PropTypes.string\n};\n\nexport default BasicSendBox;\n\nexport { useSendBoxSpeechInterimsVisible };\n"]}