UNPKG

botframework-webchat-component

Version:
186 lines (149 loc) 20.9 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.default = void 0; var _reactDictateButton = require("react-dictate-button"); var _botframeworkWebchatCore = require("botframework-webchat-core"); var _botframeworkWebchatApi = require("botframework-webchat-api"); var _propTypes = _interopRequireDefault(require("prop-types")); var _react = _interopRequireWildcard(require("react")); var _useSettableDictateAbortable = _interopRequireDefault(require("./hooks/internal/useSettableDictateAbortable")); var _useWebSpeechPonyfill4 = _interopRequireDefault(require("./hooks/useWebSpeechPonyfill")); var _useSetDictateState = _interopRequireDefault(require("botframework-webchat-api/lib/hooks/internal/useSetDictateState")); 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 useActivities = _botframeworkWebchatApi.hooks.useActivities, useDictateInterims = _botframeworkWebchatApi.hooks.useDictateInterims, useDictateState = _botframeworkWebchatApi.hooks.useDictateState, useDisabled = _botframeworkWebchatApi.hooks.useDisabled, useEmitTypingIndicator = _botframeworkWebchatApi.hooks.useEmitTypingIndicator, useLanguage = _botframeworkWebchatApi.hooks.useLanguage, useSendBoxValue = _botframeworkWebchatApi.hooks.useSendBoxValue, useSendTypingIndicator = _botframeworkWebchatApi.hooks.useSendTypingIndicator, useShouldSpeakIncomingActivity = _botframeworkWebchatApi.hooks.useShouldSpeakIncomingActivity, useStopDictate = _botframeworkWebchatApi.hooks.useStopDictate, useSubmitSendBox = _botframeworkWebchatApi.hooks.useSubmitSendBox; var _Constants$DictateSta = _botframeworkWebchatCore.Constants.DictateState, DICTATING = _Constants$DictateSta.DICTATING, IDLE = _Constants$DictateSta.IDLE, STARTING = _Constants$DictateSta.STARTING; var Dictation = function Dictation(_ref) { var onError = _ref.onError; var _useSettableDictateAb = (0, _useSettableDictateAbortable.default)(), _useSettableDictateAb2 = _slicedToArray(_useSettableDictateAb, 2), setDictateAbortable = _useSettableDictateAb2[1]; var _useDictateInterims = useDictateInterims(), _useDictateInterims2 = _slicedToArray(_useDictateInterims, 2), setDictateInterims = _useDictateInterims2[1]; 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 SpeechGrammarList = _useWebSpeechPonyfill3.SpeechGrammarList, SpeechRecognition = _useWebSpeechPonyfill3.SpeechRecognition; var _useActivities = useActivities(), _useActivities2 = _slicedToArray(_useActivities, 1), activities = _useActivities2[0]; var _useDictateState = useDictateState(), _useDictateState2 = _slicedToArray(_useDictateState, 1), dictateState = _useDictateState2[0]; var _useDisabled = useDisabled(), _useDisabled2 = _slicedToArray(_useDisabled, 1), disabled = _useDisabled2[0]; var _useSendTypingIndicat = useSendTypingIndicator(), _useSendTypingIndicat2 = _slicedToArray(_useSendTypingIndicat, 1), sendTypingIndicator = _useSendTypingIndicat2[0]; var _useLanguage = useLanguage('speech'), _useLanguage2 = _slicedToArray(_useLanguage, 1), speechLanguage = _useLanguage2[0]; var emitTypingIndicator = useEmitTypingIndicator(); var setDictateState = (0, _useSetDictateState.default)(); var stopDictate = useStopDictate(); var submitSendBox = useSubmitSendBox(); var numSpeakingActivities = (0, _react.useMemo)(function () { return activities.filter(function (_ref2) { var _ref2$channelData = _ref2.channelData; _ref2$channelData = _ref2$channelData === void 0 ? {} : _ref2$channelData; var speak = _ref2$channelData.speak; return speak; }).length; }, [activities]); var handleDictate = (0, _react.useCallback)(function (_ref3) { var _ref3$result = _ref3.result; _ref3$result = _ref3$result === void 0 ? {} : _ref3$result; var confidence = _ref3$result.confidence, transcript = _ref3$result.transcript; if (dictateState === DICTATING || dictateState === STARTING) { setDictateInterims([]); setDictateState(IDLE); stopDictate(); if (transcript) { setSendBox(transcript); submitSendBox('speech', { channelData: { speech: { alternatives: [{ confidence: confidence, transcript: transcript }] } } }); setShouldSpeakIncomingActivity(true); } } }, [dictateState, setDictateInterims, setDictateState, stopDictate, setSendBox, submitSendBox, setShouldSpeakIncomingActivity]); var handleDictating = (0, _react.useCallback)(function (_ref4) { var abortable = _ref4.abortable, _ref4$results = _ref4.results, results = _ref4$results === void 0 ? [] : _ref4$results; if (dictateState === DICTATING || dictateState === STARTING) { var interims = results.map(function (_ref5) { var transcript = _ref5.transcript; return transcript; }); setDictateAbortable(abortable); setDictateInterims(interims); setDictateState(DICTATING); sendTypingIndicator && emitTypingIndicator(); } }, [dictateState, emitTypingIndicator, sendTypingIndicator, setDictateAbortable, setDictateInterims, setDictateState]); var handleError = (0, _react.useCallback)(function (event) { dictateState !== IDLE && setDictateState(IDLE); (dictateState === DICTATING || dictateState === STARTING) && stopDictate(); onError && onError(event); }, [dictateState, onError, setDictateState, stopDictate]); return /*#__PURE__*/_react.default.createElement(_reactDictateButton.Composer, { lang: speechLanguage, onDictate: handleDictate, onError: handleError, onProgress: handleDictating, speechGrammarList: SpeechGrammarList, speechRecognition: SpeechRecognition, started: !disabled && (dictateState === STARTING || dictateState === DICTATING) && !numSpeakingActivities }); }; Dictation.defaultProps = { onError: undefined }; Dictation.propTypes = { onError: _propTypes.default.func }; var _default = Dictation; exports.default = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Dictation.js"],"names":["useActivities","hooks","useDictateInterims","useDictateState","useDisabled","useEmitTypingIndicator","useLanguage","useSendBoxValue","useSendTypingIndicator","useShouldSpeakIncomingActivity","useStopDictate","useSubmitSendBox","Constants","DictateState","DICTATING","IDLE","STARTING","Dictation","onError","setDictateAbortable","setDictateInterims","setSendBox","setShouldSpeakIncomingActivity","SpeechGrammarList","SpeechRecognition","activities","dictateState","disabled","sendTypingIndicator","speechLanguage","emitTypingIndicator","setDictateState","stopDictate","submitSendBox","numSpeakingActivities","filter","channelData","speak","length","handleDictate","result","confidence","transcript","speech","alternatives","handleDictating","abortable","results","interims","map","handleError","event","defaultProps","undefined","propTypes","PropTypes","func"],"mappings":";;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AAGA;;;;;;;;;;;;;;;;;;;;IAGEA,a,GAWEC,6B,CAXFD,a;IACAE,kB,GAUED,6B,CAVFC,kB;IACAC,e,GASEF,6B,CATFE,e;IACAC,W,GAQEH,6B,CARFG,W;IACAC,sB,GAOEJ,6B,CAPFI,sB;IACAC,W,GAMEL,6B,CANFK,W;IACAC,e,GAKEN,6B,CALFM,e;IACAC,sB,GAIEP,6B,CAJFO,sB;IACAC,8B,GAGER,6B,CAHFQ,8B;IACAC,c,GAEET,6B,CAFFS,c;IACAC,gB,GACEV,6B,CADFU,gB;4BAKEC,kC,CADFC,Y;IAAgBC,S,yBAAAA,S;IAAWC,I,yBAAAA,I;IAAMC,Q,yBAAAA,Q;;AAGnC,IAAMC,SAAS,GAAG,SAAZA,SAAY,OAAiB;AAAA,MAAdC,OAAc,QAAdA,OAAc;;AAAA,8BACD,2CADC;AAAA;AAAA,MACxBC,mBADwB;;AAAA,4BAEFjB,kBAAkB,EAFhB;AAAA;AAAA,MAExBkB,kBAFwB;;AAAA,yBAGVb,eAAe,EAHL;AAAA;AAAA,MAGxBc,UAHwB;;AAAA,8BAIUZ,8BAA8B,EAJxC;AAAA;AAAA,MAIxBa,8BAJwB;;AAAA,8BAKuB,qCALvB;AAAA;AAAA;;AAAA,+DAKiB,EALjB;AAAA,MAKxBC,iBALwB,0BAKxBA,iBALwB;AAAA,MAKLC,iBALK,0BAKLA,iBALK;;AAAA,uBAMZxB,aAAa,EAND;AAAA;AAAA,MAM1ByB,UAN0B;;AAAA,yBAOVtB,eAAe,EAPL;AAAA;AAAA,MAO1BuB,YAP0B;;AAAA,qBAQdtB,WAAW,EARG;AAAA;AAAA,MAQ1BuB,QAR0B;;AAAA,8BASHnB,sBAAsB,EATnB;AAAA;AAAA,MAS1BoB,mBAT0B;;AAAA,qBAURtB,WAAW,CAAC,QAAD,CAVH;AAAA;AAAA,MAU1BuB,cAV0B;;AAWjC,MAAMC,mBAAmB,GAAGzB,sBAAsB,EAAlD;AACA,MAAM0B,eAAe,GAAG,kCAAxB;AACA,MAAMC,WAAW,GAAGtB,cAAc,EAAlC;AACA,MAAMuB,aAAa,GAAGtB,gBAAgB,EAAtC;AAEA,MAAMuB,qBAAqB,GAAG,oBAAQ;AAAA,WAAMT,UAAU,CAACU,MAAX,CAAkB;AAAA,oCAAGC,WAAH;AAAA,yDAA4B,EAA5B;AAAA,UAAkBC,KAAlB,qBAAkBA,KAAlB;AAAA,aAAqCA,KAArC;AAAA,KAAlB,EAA8DC,MAApE;AAAA,GAAR,EAAoF,CAChHb,UADgH,CAApF,CAA9B;AAIA,MAAMc,aAAa,GAAG,wBACpB,iBAAiD;AAAA,6BAA9CC,MAA8C;AAAA,6CAAT,EAAS;AAAA,QAApCC,UAAoC,gBAApCA,UAAoC;AAAA,QAAxBC,UAAwB,gBAAxBA,UAAwB;;AAC/C,QAAIhB,YAAY,KAAKZ,SAAjB,IAA8BY,YAAY,KAAKV,QAAnD,EAA6D;AAC3DI,MAAAA,kBAAkB,CAAC,EAAD,CAAlB;AACAW,MAAAA,eAAe,CAAChB,IAAD,CAAf;AACAiB,MAAAA,WAAW;;AAEX,UAAIU,UAAJ,EAAgB;AACdrB,QAAAA,UAAU,CAACqB,UAAD,CAAV;AACAT,QAAAA,aAAa,CAAC,QAAD,EAAW;AAAEG,UAAAA,WAAW,EAAE;AAAEO,YAAAA,MAAM,EAAE;AAAEC,cAAAA,YAAY,EAAE,CAAC;AAAEH,gBAAAA,UAAU,EAAVA,UAAF;AAAcC,gBAAAA,UAAU,EAAVA;AAAd,eAAD;AAAhB;AAAV;AAAf,SAAX,CAAb;AACApB,QAAAA,8BAA8B,CAAC,IAAD,CAA9B;AACD;AACF;AACF,GAbmB,EAcpB,CACEI,YADF,EAEEN,kBAFF,EAGEW,eAHF,EAIEC,WAJF,EAKEX,UALF,EAMEY,aANF,EAOEX,8BAPF,CAdoB,CAAtB;AAyBA,MAAMuB,eAAe,GAAG,wBACtB,iBAAiC;AAAA,QAA9BC,SAA8B,SAA9BA,SAA8B;AAAA,8BAAnBC,OAAmB;AAAA,QAAnBA,OAAmB,8BAAT,EAAS;;AAC/B,QAAIrB,YAAY,KAAKZ,SAAjB,IAA8BY,YAAY,KAAKV,QAAnD,EAA6D;AAC3D,UAAMgC,QAAQ,GAAGD,OAAO,CAACE,GAAR,CAAY;AAAA,YAAGP,UAAH,SAAGA,UAAH;AAAA,eAAoBA,UAApB;AAAA,OAAZ,CAAjB;AAEAvB,MAAAA,mBAAmB,CAAC2B,SAAD,CAAnB;AACA1B,MAAAA,kBAAkB,CAAC4B,QAAD,CAAlB;AACAjB,MAAAA,eAAe,CAACjB,SAAD,CAAf;AACAc,MAAAA,mBAAmB,IAAIE,mBAAmB,EAA1C;AACD;AACF,GAVqB,EAWtB,CAACJ,YAAD,EAAeI,mBAAf,EAAoCF,mBAApC,EAAyDT,mBAAzD,EAA8EC,kBAA9E,EAAkGW,eAAlG,CAXsB,CAAxB;AAcA,MAAMmB,WAAW,GAAG,wBAClB,UAAAC,KAAK,EAAI;AACPzB,IAAAA,YAAY,KAAKX,IAAjB,IAAyBgB,eAAe,CAAChB,IAAD,CAAxC;AACA,KAACW,YAAY,KAAKZ,SAAjB,IAA8BY,YAAY,KAAKV,QAAhD,KAA6DgB,WAAW,EAAxE;AAEAd,IAAAA,OAAO,IAAIA,OAAO,CAACiC,KAAD,CAAlB;AACD,GANiB,EAOlB,CAACzB,YAAD,EAAeR,OAAf,EAAwBa,eAAxB,EAAyCC,WAAzC,CAPkB,CAApB;AAUA,sBACE,6BAAC,4BAAD;AACE,IAAA,IAAI,EAAEH,cADR;AAEE,IAAA,SAAS,EAAEU,aAFb;AAGE,IAAA,OAAO,EAAEW,WAHX;AAIE,IAAA,UAAU,EAAEL,eAJd;AAKE,IAAA,iBAAiB,EAAEtB,iBALrB;AAME,IAAA,iBAAiB,EAAEC,iBANrB;AAOE,IAAA,OAAO,EAAE,CAACG,QAAD,KAAcD,YAAY,KAAKV,QAAjB,IAA6BU,YAAY,KAAKZ,SAA5D,KAA0E,CAACoB;AAPtF,IADF;AAWD,CAhFD;;AAkFAjB,SAAS,CAACmC,YAAV,GAAyB;AACvBlC,EAAAA,OAAO,EAAEmC;AADc,CAAzB;AAIApC,SAAS,CAACqC,SAAV,GAAsB;AACpBpC,EAAAA,OAAO,EAAEqC,mBAAUC;AADC,CAAtB;eAIevC,S","sourceRoot":"component:///","sourcesContent":["import { Composer as DictateComposer } from 'react-dictate-button';\nimport { Constants } from 'botframework-webchat-core';\nimport { hooks } from 'botframework-webchat-api';\nimport PropTypes from 'prop-types';\nimport React, { useCallback, useMemo } from 'react';\n\nimport useSettableDictateAbortable from './hooks/internal/useSettableDictateAbortable';\nimport useWebSpeechPonyfill from './hooks/useWebSpeechPonyfill';\n\n// TODO: [P1] #3350 No /lib/, we need to move setDictateState from bf-wc-core (Redux) to React Context.\nimport useSetDictateState from 'botframework-webchat-api/lib/hooks/internal/useSetDictateState';\n\nconst {\n  useActivities,\n  useDictateInterims,\n  useDictateState,\n  useDisabled,\n  useEmitTypingIndicator,\n  useLanguage,\n  useSendBoxValue,\n  useSendTypingIndicator,\n  useShouldSpeakIncomingActivity,\n  useStopDictate,\n  useSubmitSendBox\n} = hooks;\n\nconst {\n  DictateState: { DICTATING, IDLE, STARTING }\n} = Constants;\n\nconst Dictation = ({ onError }) => {\n  const [, setDictateAbortable] = useSettableDictateAbortable();\n  const [, setDictateInterims] = useDictateInterims();\n  const [, setSendBox] = useSendBoxValue();\n  const [, setShouldSpeakIncomingActivity] = useShouldSpeakIncomingActivity();\n  const [{ SpeechGrammarList, SpeechRecognition } = {}] = useWebSpeechPonyfill();\n  const [activities] = useActivities();\n  const [dictateState] = useDictateState();\n  const [disabled] = useDisabled();\n  const [sendTypingIndicator] = useSendTypingIndicator();\n  const [speechLanguage] = useLanguage('speech');\n  const emitTypingIndicator = useEmitTypingIndicator();\n  const setDictateState = useSetDictateState();\n  const stopDictate = useStopDictate();\n  const submitSendBox = useSubmitSendBox();\n\n  const numSpeakingActivities = useMemo(() => activities.filter(({ channelData: { speak } = {} }) => speak).length, [\n    activities\n  ]);\n\n  const handleDictate = useCallback(\n    ({ result: { confidence, transcript } = {} }) => {\n      if (dictateState === DICTATING || dictateState === STARTING) {\n        setDictateInterims([]);\n        setDictateState(IDLE);\n        stopDictate();\n\n        if (transcript) {\n          setSendBox(transcript);\n          submitSendBox('speech', { channelData: { speech: { alternatives: [{ confidence, transcript }] } } });\n          setShouldSpeakIncomingActivity(true);\n        }\n      }\n    },\n    [\n      dictateState,\n      setDictateInterims,\n      setDictateState,\n      stopDictate,\n      setSendBox,\n      submitSendBox,\n      setShouldSpeakIncomingActivity\n    ]\n  );\n\n  const handleDictating = useCallback(\n    ({ abortable, results = [] }) => {\n      if (dictateState === DICTATING || dictateState === STARTING) {\n        const interims = results.map(({ transcript }) => transcript);\n\n        setDictateAbortable(abortable);\n        setDictateInterims(interims);\n        setDictateState(DICTATING);\n        sendTypingIndicator && emitTypingIndicator();\n      }\n    },\n    [dictateState, emitTypingIndicator, sendTypingIndicator, setDictateAbortable, setDictateInterims, setDictateState]\n  );\n\n  const handleError = useCallback(\n    event => {\n      dictateState !== IDLE && setDictateState(IDLE);\n      (dictateState === DICTATING || dictateState === STARTING) && stopDictate();\n\n      onError && onError(event);\n    },\n    [dictateState, onError, setDictateState, stopDictate]\n  );\n\n  return (\n    <DictateComposer\n      lang={speechLanguage}\n      onDictate={handleDictate}\n      onError={handleError}\n      onProgress={handleDictating}\n      speechGrammarList={SpeechGrammarList}\n      speechRecognition={SpeechRecognition}\n      started={!disabled && (dictateState === STARTING || dictateState === DICTATING) && !numSpeakingActivities}\n    />\n  );\n};\n\nDictation.defaultProps = {\n  onError: undefined\n};\n\nDictation.propTypes = {\n  onError: PropTypes.func\n};\n\nexport default Dictation;\n"]}