UNPKG

botframework-webchat-component

Version:
90 lines (85 loc) 18 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _botframeworkWebchatApi = require("botframework-webchat-api"); var _react = require("react"); var _SendStatus = require("../../types/internal/SendStatus"); var _isPresentational = _interopRequireDefault(require("./isPresentational")); var _usePrevious = _interopRequireDefault(require("../../hooks/internal/usePrevious")); var _useQueueStaticElement = _interopRequireDefault(require("../../providers/LiveRegionTwin/useQueueStaticElement")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; } 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 useGetActivityByKey = _botframeworkWebchatApi.hooks.useGetActivityByKey, useLocalizer = _botframeworkWebchatApi.hooks.useLocalizer, useSendStatusByActivityKey = _botframeworkWebchatApi.hooks.useSendStatusByActivityKey; /** * React component to on-demand narrate "Failed to send message" at the end of the live region. * * We cannot narrate "failed to send message" next to the activity. At the time when the activity is being sent, * the activity is also queued to the screen reader. And at that moment, we not yet know if the activity can be sent or not. * * We only know when the activity was failed to send at a later time. * * Thus, we need to use a live region "footnote" to indicate the message was failed to send. */ var LiveRegionSendFailed = function LiveRegionSendFailed() { var _useSendStatusByActiv = useSendStatusByActivityKey(), _useSendStatusByActiv2 = _slicedToArray(_useSendStatusByActiv, 1), sendStatusByActivityKey = _useSendStatusByActiv2[0]; var getActivityByKey = useGetActivityByKey(); var localize = useLocalizer(); var queueStaticElement = (0, _useQueueStaticElement.default)(); /** * List of keys of outgoing and non-presentational activities that are failed to send. * * Activities which are presentational, such as `event` or `typing`, are ignored to reduce confusions. * "Failed to send message" should not be narrated for presentational activities. */ var activityKeysOfSendFailed = (0, _react.useMemo)(function () { return Array.from(sendStatusByActivityKey).reduce(function (activityKeysOfSendFailed, _ref) { var _ref2 = _slicedToArray(_ref, 2), key = _ref2[0], sendStatus = _ref2[1]; return sendStatus === _SendStatus.SEND_FAILED && !(0, _isPresentational.default)(getActivityByKey(key)) ? activityKeysOfSendFailed.add(key) : activityKeysOfSendFailed; }, new Set()); }, [getActivityByKey, sendStatusByActivityKey]); /** Returns localized "Failed to send message." */ var liveRegionSendFailedAlt = localize('TRANSCRIPT_LIVE_REGION_SEND_FAILED_ALT'); var prevActivityKeysOfSendFailed = (0, _usePrevious.default)(activityKeysOfSendFailed); /** True, if one or more non-presentational activities start appears as "send failed", otherwise, false. */ var hasNewSendFailed = (0, _react.useMemo)(function () { if (activityKeysOfSendFailed === prevActivityKeysOfSendFailed) { return false; } var _iterator = _createForOfIteratorHelper(activityKeysOfSendFailed.keys()), _step; try { for (_iterator.s(); !(_step = _iterator.n()).done;) { var key = _step.value; if (!prevActivityKeysOfSendFailed.has(key)) { return true; } } } catch (err) { _iterator.e(err); } finally { _iterator.f(); } return false; }, [activityKeysOfSendFailed, prevActivityKeysOfSendFailed]); (0, _react.useEffect)(function () { hasNewSendFailed && queueStaticElement(liveRegionSendFailedAlt); }, [hasNewSendFailed, liveRegionSendFailedAlt, queueStaticElement]); return null; }; var _default = LiveRegionSendFailed; exports.default = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_botframeworkWebchatApi","require","_react","_SendStatus","_isPresentational","_interopRequireDefault","_usePrevious","_useQueueStaticElement","obj","__esModule","default","_createForOfIteratorHelper","o","allowArrayLike","it","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","i","F","s","n","done","value","e","_e2","f","TypeError","normalCompletion","didErr","err","call","step","next","_e3","return","_slicedToArray","arr","_arrayWithHoles","_iterableToArrayLimit","_nonIterableRest","minLen","_arrayLikeToArray","Object","prototype","toString","slice","constructor","name","from","test","len","arr2","_i","_arr","_n","_d","_s","_e","push","useGetActivityByKey","hooks","useLocalizer","useSendStatusByActivityKey","LiveRegionSendFailed","_useSendStatusByActiv","_useSendStatusByActiv2","sendStatusByActivityKey","getActivityByKey","localize","queueStaticElement","useQueueStaticElement","activityKeysOfSendFailed","useMemo","reduce","_ref","_ref2","key","sendStatus","SEND_FAILED","isPresentational","add","Set","liveRegionSendFailedAlt","prevActivityKeysOfSendFailed","usePrevious","hasNewSendFailed","_iterator","keys","_step","has","useEffect","_default","exports"],"sourceRoot":"component:///","sources":["../../../src/Transcript/LiveRegion/SendFailed.tsx"],"sourcesContent":["import { hooks } from 'botframework-webchat-api';\nimport { useEffect, useMemo } from 'react';\nimport type { VFC } from 'react';\n\nimport { SEND_FAILED } from '../../types/internal/SendStatus';\nimport isPresentational from './isPresentational';\nimport usePrevious from '../../hooks/internal/usePrevious';\nimport useQueueStaticElement from '../../providers/LiveRegionTwin/useQueueStaticElement';\n\nconst { useGetActivityByKey, useLocalizer, useSendStatusByActivityKey } = hooks;\n\n/**\n * React component to on-demand narrate \"Failed to send message\" at the end of the live region.\n *\n * We cannot narrate \"failed to send message\" next to the activity. At the time when the activity is being sent,\n * the activity is also queued to the screen reader. And at that moment, we not yet know if the activity can be sent or not.\n *\n * We only know when the activity was failed to send at a later time.\n *\n * Thus, we need to use a live region \"footnote\" to indicate the message was failed to send.\n */\nconst LiveRegionSendFailed: VFC<{}> = () => {\n  const [sendStatusByActivityKey] = useSendStatusByActivityKey();\n  const getActivityByKey = useGetActivityByKey();\n  const localize = useLocalizer();\n  const queueStaticElement = useQueueStaticElement();\n\n  /**\n   * List of keys of outgoing and non-presentational activities that are failed to send.\n   *\n   * Activities which are presentational, such as `event` or `typing`, are ignored to reduce confusions.\n   * \"Failed to send message\" should not be narrated for presentational activities.\n   */\n  const activityKeysOfSendFailed = useMemo<Set<string>>(\n    () =>\n      Array.from(sendStatusByActivityKey).reduce(\n        (activityKeysOfSendFailed, [key, sendStatus]) =>\n          sendStatus === SEND_FAILED && !isPresentational(getActivityByKey(key))\n            ? activityKeysOfSendFailed.add(key)\n            : activityKeysOfSendFailed,\n        new Set<string>()\n      ),\n    [getActivityByKey, sendStatusByActivityKey]\n  );\n\n  /** Returns localized \"Failed to send message.\" */\n  const liveRegionSendFailedAlt = localize('TRANSCRIPT_LIVE_REGION_SEND_FAILED_ALT');\n\n  const prevActivityKeysOfSendFailed = usePrevious(activityKeysOfSendFailed);\n\n  /** True, if one or more non-presentational activities start appears as \"send failed\", otherwise, false. */\n  const hasNewSendFailed = useMemo<boolean>(() => {\n    if (activityKeysOfSendFailed === prevActivityKeysOfSendFailed) {\n      return false;\n    }\n\n    for (const key of activityKeysOfSendFailed.keys()) {\n      if (!prevActivityKeysOfSendFailed.has(key)) {\n        return true;\n      }\n    }\n\n    return false;\n  }, [activityKeysOfSendFailed, prevActivityKeysOfSendFailed]);\n\n  useEffect(() => {\n    hasNewSendFailed && queueStaticElement(liveRegionSendFailedAlt);\n  }, [hasNewSendFailed, liveRegionSendFailedAlt, queueStaticElement]);\n\n  return null;\n};\n\nexport default LiveRegionSendFailed;\n"],"mappings":";;;;;;AAAA,IAAAA,uBAAA,GAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA;AAGA,IAAAE,WAAA,GAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAC,sBAAA,CAAAJ,OAAA;AACA,IAAAK,YAAA,GAAAD,sBAAA,CAAAJ,OAAA;AACA,IAAAM,sBAAA,GAAAF,sBAAA,CAAAJ,OAAA;AAAyF,SAAAI,uBAAAG,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAAA,SAAAG,2BAAAC,CAAA,EAAAC,cAAA,QAAAC,EAAA,UAAAC,MAAA,oBAAAH,CAAA,CAAAG,MAAA,CAAAC,QAAA,KAAAJ,CAAA,qBAAAE,EAAA,QAAAG,KAAA,CAAAC,OAAA,CAAAN,CAAA,MAAAE,EAAA,GAAAK,2BAAA,CAAAP,CAAA,MAAAC,cAAA,IAAAD,CAAA,WAAAA,CAAA,CAAAQ,MAAA,qBAAAN,EAAA,EAAAF,CAAA,GAAAE,EAAA,MAAAO,CAAA,UAAAC,CAAA,YAAAA,EAAA,eAAAC,CAAA,EAAAD,CAAA,EAAAE,CAAA,WAAAA,EAAA,QAAAH,CAAA,IAAAT,CAAA,CAAAQ,MAAA,WAAAK,IAAA,mBAAAA,IAAA,SAAAC,KAAA,EAAAd,CAAA,CAAAS,CAAA,UAAAM,CAAA,WAAAA,EAAAC,GAAA,UAAAA,GAAA,KAAAC,CAAA,EAAAP,CAAA,gBAAAQ,SAAA,iJAAAC,gBAAA,SAAAC,MAAA,UAAAC,GAAA,WAAAV,CAAA,WAAAA,EAAA,IAAAT,EAAA,GAAAA,EAAA,CAAAoB,IAAA,CAAAtB,CAAA,MAAAY,CAAA,WAAAA,EAAA,QAAAW,IAAA,GAAArB,EAAA,CAAAsB,IAAA,IAAAL,gBAAA,GAAAI,IAAA,CAAAV,IAAA,SAAAU,IAAA,KAAAR,CAAA,WAAAA,EAAAU,GAAA,IAAAL,MAAA,SAAAC,GAAA,GAAAI,GAAA,KAAAR,CAAA,WAAAA,EAAA,eAAAE,gBAAA,IAAAjB,EAAA,CAAAwB,MAAA,UAAAxB,EAAA,CAAAwB,MAAA,oBAAAN,MAAA,QAAAC,GAAA;AAAA,SAAAM,eAAAC,GAAA,EAAAnB,CAAA,WAAAoB,eAAA,CAAAD,GAAA,KAAAE,qBAAA,CAAAF,GAAA,EAAAnB,CAAA,KAAAF,2BAAA,CAAAqB,GAAA,EAAAnB,CAAA,KAAAsB,gBAAA;AAAA,SAAAA,iBAAA,cAAAb,SAAA;AAAA,SAAAX,4BAAAP,CAAA,EAAAgC,MAAA,SAAAhC,CAAA,qBAAAA,CAAA,sBAAAiC,iBAAA,CAAAjC,CAAA,EAAAgC,MAAA,OAAApB,CAAA,GAAAsB,MAAA,CAAAC,SAAA,CAAAC,QAAA,CAAAd,IAAA,CAAAtB,CAAA,EAAAqC,KAAA,aAAAzB,CAAA,iBAAAZ,CAAA,CAAAsC,WAAA,EAAA1B,CAAA,GAAAZ,CAAA,CAAAsC,WAAA,CAAAC,IAAA,MAAA3B,CAAA,cAAAA,CAAA,mBAAAP,KAAA,CAAAmC,IAAA,CAAAxC,CAAA,OAAAY,CAAA,+DAAA6B,IAAA,CAAA7B,CAAA,UAAAqB,iBAAA,CAAAjC,CAAA,EAAAgC,MAAA;AAAA,SAAAC,kBAAAL,GAAA,EAAAc,GAAA,QAAAA,GAAA,YAAAA,GAAA,GAAAd,GAAA,CAAApB,MAAA,EAAAkC,GAAA,GAAAd,GAAA,CAAApB,MAAA,WAAAC,CAAA,MAAAkC,IAAA,OAAAtC,KAAA,CAAAqC,GAAA,GAAAjC,CAAA,GAAAiC,GAAA,EAAAjC,CAAA,MAAAkC,IAAA,CAAAlC,CAAA,IAAAmB,GAAA,CAAAnB,CAAA,YAAAkC,IAAA;AAAA,SAAAb,sBAAAF,GAAA,EAAAnB,CAAA,QAAAmC,EAAA,GAAAhB,GAAA,yBAAAzB,MAAA,oBAAAyB,GAAA,CAAAzB,MAAA,CAAAC,QAAA,KAAAwB,GAAA,oBAAAgB,EAAA,sBAAAC,IAAA,WAAAC,EAAA,aAAAC,EAAA,cAAAC,EAAA,EAAAC,EAAA,aAAAL,EAAA,GAAAA,EAAA,CAAAtB,IAAA,CAAAM,GAAA,KAAAkB,EAAA,IAAAE,EAAA,GAAAJ,EAAA,CAAApB,IAAA,IAAAX,IAAA,GAAAiC,EAAA,WAAAD,IAAA,CAAAK,IAAA,CAAAF,EAAA,CAAAlC,KAAA,OAAAL,CAAA,IAAAoC,IAAA,CAAArC,MAAA,KAAAC,CAAA,oBAAAY,GAAA,IAAA0B,EAAA,SAAAE,EAAA,GAAA5B,GAAA,yBAAAyB,EAAA,IAAAF,EAAA,oBAAAA,EAAA,8BAAAG,EAAA,QAAAE,EAAA,aAAAJ,IAAA;AAAA,SAAAhB,gBAAAD,GAAA,QAAAvB,KAAA,CAAAC,OAAA,CAAAsB,GAAA,UAAAA,GAAA;AAEzF,IAAQuB,mBAAmB,GAA+CC,6BAAK,CAAvED,mBAAmB;EAAEE,YAAY,GAAiCD,6BAAK,CAAlDC,YAAY;EAAEC,0BAA0B,GAAKF,6BAAK,CAApCE,0BAA0B;;AAErE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAMC,oBAA6B,GAAG,SAAhCA,oBAA6BA,CAAA,EAAS;EAC1C,IAAAC,qBAAA,GAAkCF,0BAA0B,CAAC,CAAC;IAAAG,sBAAA,GAAA9B,cAAA,CAAA6B,qBAAA;IAAvDE,uBAAuB,GAAAD,sBAAA;EAC9B,IAAME,gBAAgB,GAAGR,mBAAmB,CAAC,CAAC;EAC9C,IAAMS,QAAQ,GAAGP,YAAY,CAAC,CAAC;EAC/B,IAAMQ,kBAAkB,GAAG,IAAAC,8BAAqB,EAAC,CAAC;;EAElD;AACF;AACA;AACA;AACA;AACA;EACE,IAAMC,wBAAwB,GAAG,IAAAC,cAAO,EACtC;IAAA,OACE3D,KAAK,CAACmC,IAAI,CAACkB,uBAAuB,CAAC,CAACO,MAAM,CACxC,UAACF,wBAAwB,EAAAG,IAAA;MAAA,IAAAC,KAAA,GAAAxC,cAAA,CAAAuC,IAAA;QAAGE,GAAG,GAAAD,KAAA;QAAEE,UAAU,GAAAF,KAAA;MAAA,OACzCE,UAAU,KAAKC,uBAAW,IAAI,CAAC,IAAAC,yBAAgB,EAACZ,gBAAgB,CAACS,GAAG,CAAC,CAAC,GAClEL,wBAAwB,CAACS,GAAG,CAACJ,GAAG,CAAC,GACjCL,wBAAwB;IAAA,GAC9B,IAAIU,GAAG,CAAS,CAClB,CAAC;EAAA,GACH,CAACd,gBAAgB,EAAED,uBAAuB,CAC5C,CAAC;;EAED;EACA,IAAMgB,uBAAuB,GAAGd,QAAQ,CAAC,wCAAwC,CAAC;EAElF,IAAMe,4BAA4B,GAAG,IAAAC,oBAAW,EAACb,wBAAwB,CAAC;;EAE1E;EACA,IAAMc,gBAAgB,GAAG,IAAAb,cAAO,EAAU,YAAM;IAC9C,IAAID,wBAAwB,KAAKY,4BAA4B,EAAE;MAC7D,OAAO,KAAK;IACd;IAAC,IAAAG,SAAA,GAAA/E,0BAAA,CAEiBgE,wBAAwB,CAACgB,IAAI,CAAC,CAAC;MAAAC,KAAA;IAAA;MAAjD,KAAAF,SAAA,CAAAnE,CAAA,MAAAqE,KAAA,GAAAF,SAAA,CAAAlE,CAAA,IAAAC,IAAA,GAAmD;QAAA,IAAxCuD,GAAG,GAAAY,KAAA,CAAAlE,KAAA;QACZ,IAAI,CAAC6D,4BAA4B,CAACM,GAAG,CAACb,GAAG,CAAC,EAAE;UAC1C,OAAO,IAAI;QACb;MACF;IAAC,SAAA/C,GAAA;MAAAyD,SAAA,CAAA/D,CAAA,CAAAM,GAAA;IAAA;MAAAyD,SAAA,CAAA7D,CAAA;IAAA;IAED,OAAO,KAAK;EACd,CAAC,EAAE,CAAC8C,wBAAwB,EAAEY,4BAA4B,CAAC,CAAC;EAE5D,IAAAO,gBAAS,EAAC,YAAM;IACdL,gBAAgB,IAAIhB,kBAAkB,CAACa,uBAAuB,CAAC;EACjE,CAAC,EAAE,CAACG,gBAAgB,EAAEH,uBAAuB,EAAEb,kBAAkB,CAAC,CAAC;EAEnE,OAAO,IAAI;AACb,CAAC;AAAC,IAAAsB,QAAA,GAEa5B,oBAAoB;AAAA6B,OAAA,CAAAtF,OAAA,GAAAqF,QAAA"}