UNPKG

botframework-webchat-component

Version:
156 lines (154 loc) 56.1 kB
"use strict"; 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; var _botframeworkWebchatApi = require("botframework-webchat-api"); var _classnames = _interopRequireDefault(require("classnames")); var _propTypes = _interopRequireDefault(require("prop-types")); var _react = _interopRequireWildcard(require("react")); var _useRefFrom = require("use-ref-from"); var _IconButton = _interopRequireDefault(require("../SendBox/IconButton")); var _useMakeThumbnail = _interopRequireDefault(require("../hooks/useMakeThumbnail")); var _useStyleToEmotionObject = _interopRequireDefault(require("../hooks/internal/useStyleToEmotionObject")); var _useFocus = _interopRequireDefault(require("../hooks/useFocus")); var _useStyleSet3 = _interopRequireDefault(require("../hooks/useStyleSet")); var _useSubmit = _interopRequireDefault(require("../providers/internal/SendBox/useSubmit")); var _AttachmentIcon = _interopRequireDefault(require("./Assets/AttachmentIcon")); 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 _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return exports; }; var exports = {}, Op = Object.prototype, hasOwn = Op.hasOwnProperty, $Symbol = "function" == typeof Symbol ? Symbol : {}, iteratorSymbol = $Symbol.iterator || "@@iterator", asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator", toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag"; function define(obj, key, value) { return Object.defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key]; } try { define({}, ""); } catch (err) { define = function define(obj, key, value) { return obj[key] = value; }; } function wrap(innerFn, outerFn, self, tryLocsList) { var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator, generator = Object.create(protoGenerator.prototype), context = new Context(tryLocsList || []); return generator._invoke = function (innerFn, self, context) { var state = "suspendedStart"; return function (method, arg) { if ("executing" === state) throw new Error("Generator is already running"); if ("completed" === state) { if ("throw" === method) throw arg; return doneResult(); } for (context.method = method, context.arg = arg;;) { var delegate = context.delegate; if (delegate) { var delegateResult = maybeInvokeDelegate(delegate, context); if (delegateResult) { if (delegateResult === ContinueSentinel) continue; return delegateResult; } } if ("next" === context.method) context.sent = context._sent = context.arg;else if ("throw" === context.method) { if ("suspendedStart" === state) throw state = "completed", context.arg; context.dispatchException(context.arg); } else "return" === context.method && context.abrupt("return", context.arg); state = "executing"; var record = tryCatch(innerFn, self, context); if ("normal" === record.type) { if (state = context.done ? "completed" : "suspendedYield", record.arg === ContinueSentinel) continue; return { value: record.arg, done: context.done }; } "throw" === record.type && (state = "completed", context.method = "throw", context.arg = record.arg); } }; }(innerFn, self, context), generator; } function tryCatch(fn, obj, arg) { try { return { type: "normal", arg: fn.call(obj, arg) }; } catch (err) { return { type: "throw", arg: err }; } } exports.wrap = wrap; var ContinueSentinel = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var IteratorPrototype = {}; define(IteratorPrototype, iteratorSymbol, function () { return this; }); var getProto = Object.getPrototypeOf, NativeIteratorPrototype = getProto && getProto(getProto(values([]))); NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype); var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype); function defineIteratorMethods(prototype) { ["next", "throw", "return"].forEach(function (method) { define(prototype, method, function (arg) { return this._invoke(method, arg); }); }); } function AsyncIterator(generator, PromiseImpl) { function invoke(method, arg, resolve, reject) { var record = tryCatch(generator[method], generator, arg); if ("throw" !== record.type) { var result = record.arg, value = result.value; return value && "object" == _typeof(value) && hasOwn.call(value, "__await") ? PromiseImpl.resolve(value.__await).then(function (value) { invoke("next", value, resolve, reject); }, function (err) { invoke("throw", err, resolve, reject); }) : PromiseImpl.resolve(value).then(function (unwrapped) { result.value = unwrapped, resolve(result); }, function (error) { return invoke("throw", error, resolve, reject); }); } reject(record.arg); } var previousPromise; this._invoke = function (method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); }; } function maybeInvokeDelegate(delegate, context) { var method = delegate.iterator[context.method]; if (undefined === method) { if (context.delegate = null, "throw" === context.method) { if (delegate.iterator.return && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method)) return ContinueSentinel; context.method = "throw", context.arg = new TypeError("The iterator does not provide a 'throw' method"); } return ContinueSentinel; } var record = tryCatch(method, delegate.iterator, context.arg); if ("throw" === record.type) return context.method = "throw", context.arg = record.arg, context.delegate = null, ContinueSentinel; var info = record.arg; return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, "return" !== context.method && (context.method = "next", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = "throw", context.arg = new TypeError("iterator result is not an object"), context.delegate = null, ContinueSentinel); } function pushTryEntry(locs) { var entry = { tryLoc: locs[0] }; 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry); } function resetTryEntry(entry) { var record = entry.completion || {}; record.type = "normal", delete record.arg, entry.completion = record; } function Context(tryLocsList) { this.tryEntries = [{ tryLoc: "root" }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0); } function values(iterable) { if (iterable) { var iteratorMethod = iterable[iteratorSymbol]; if (iteratorMethod) return iteratorMethod.call(iterable); if ("function" == typeof iterable.next) return iterable; if (!isNaN(iterable.length)) { var i = -1, next = function next() { for (; ++i < iterable.length;) { if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next; } return next.value = undefined, next.done = !0, next; }; return next.next = next; } } return { next: doneResult }; } function doneResult() { return { value: undefined, done: !0 }; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, define(Gp, "constructor", GeneratorFunctionPrototype), define(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, "GeneratorFunction"), exports.isGeneratorFunction = function (genFun) { var ctor = "function" == typeof genFun && genFun.constructor; return !!ctor && (ctor === GeneratorFunction || "GeneratorFunction" === (ctor.displayName || ctor.name)); }, exports.mark = function (genFun) { return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, "GeneratorFunction")), genFun.prototype = Object.create(Gp), genFun; }, exports.awrap = function (arg) { return { __await: arg }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () { return this; }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) { void 0 === PromiseImpl && (PromiseImpl = Promise); var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl); return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) { return result.done ? result.value : iter.next(); }); }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, "Generator"), define(Gp, iteratorSymbol, function () { return this; }), define(Gp, "toString", function () { return "[object Generator]"; }), exports.keys = function (object) { var keys = []; for (var key in object) { keys.push(key); } return keys.reverse(), function next() { for (; keys.length;) { var key = keys.pop(); if (key in object) return next.value = key, next.done = !1, next; } return next.done = !0, next; }; }, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) { if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = "next", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) { "t" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined); } }, stop: function stop() { this.done = !0; var rootRecord = this.tryEntries[0].completion; if ("throw" === rootRecord.type) throw rootRecord.arg; return this.rval; }, dispatchException: function dispatchException(exception) { if (this.done) throw exception; var context = this; function handle(loc, caught) { return record.type = "throw", record.arg = exception, context.next = loc, caught && (context.method = "next", context.arg = undefined), !!caught; } for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if ("root" === entry.tryLoc) return handle("end"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, "catchLoc"), hasFinally = hasOwn.call(entry, "finallyLoc"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error("try statement without catch or finally"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, "finallyLoc") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && ("break" === type || "continue" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = "next", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if ("throw" === record.type) throw record.arg; return "break" === record.type || "continue" === record.type ? this.next = record.arg : "return" === record.type ? (this.rval = this.arg = record.arg, this.method = "return", this.next = "end") : "normal" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, catch: function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if ("throw" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, "next" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; } function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); } function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); } function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } 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 useDisabled = _botframeworkWebchatApi.hooks.useDisabled, useSendBoxAttachments = _botframeworkWebchatApi.hooks.useSendBoxAttachments, useLocalizer = _botframeworkWebchatApi.hooks.useLocalizer, useStyleOptions = _botframeworkWebchatApi.hooks.useStyleOptions; var ROOT_STYLE = { '&.webchat__upload-button': { display: 'flex', overflow: 'hidden', position: 'relative', '& .webchat__upload-button--file-input': { height: 0, width: 0, opacity: 0, position: 'absolute', left: 0, top: 0 } } }; var PREVENT_DEFAULT_HANDLER = function PREVENT_DEFAULT_HANDLER(event) { return event.preventDefault(); }; var UploadButton = function UploadButton(_ref) { var className = _ref.className; var _useStyleOptions = useStyleOptions(), _useStyleOptions2 = _slicedToArray(_useStyleOptions, 1), _useStyleOptions2$ = _useStyleOptions2[0], sendAttachmentOn = _useStyleOptions2$.sendAttachmentOn, uploadAccept = _useStyleOptions2$.uploadAccept, uploadMultiple = _useStyleOptions2$.uploadMultiple; var _useStyleSet = (0, _useStyleSet3.default)(), _useStyleSet2 = _slicedToArray(_useStyleSet, 1), uploadButtonStyleSet = _useStyleSet2[0].uploadButton; var _useDisabled = useDisabled(), _useDisabled2 = _slicedToArray(_useDisabled, 1), disabled = _useDisabled2[0]; var _useSendBoxAttachment = useSendBoxAttachments(), _useSendBoxAttachment2 = _slicedToArray(_useSendBoxAttachment, 2), sendBoxAttachments = _useSendBoxAttachment2[0], setSendBoxAttachments = _useSendBoxAttachment2[1]; var focus = (0, _useFocus.default)(); var inputRef = (0, _react.useRef)(null); var localize = useLocalizer(); var makeThumbnail = (0, _useMakeThumbnail.default)(); var rootClassName = (0, _useStyleToEmotionObject.default)()(ROOT_STYLE) + ''; var submit = (0, _useSubmit.default)(); var sendAttachmentOnRef = (0, _useRefFrom.useRefFrom)(sendAttachmentOn); var uploadFileString = localize('TEXT_INPUT_UPLOAD_BUTTON_ALT'); var handleClick = (0, _react.useCallback)(function () { var _inputRef$current; return (_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 ? void 0 : _inputRef$current.click(); }, [inputRef]); var handleFileChange = (0, _react.useCallback)(function (_ref2) { var currentTarget = _ref2.currentTarget; // We should change the focus synchronously for accessibility reason. focus('sendBox'); // TODO: [P2] We should disable send button while we are creating thumbnails. // Otherwise, if the user click the send button too quickly, it will not attach any files. _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() { return _regeneratorRuntime().wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: _context.t0 = setSendBoxAttachments; _context.t1 = Object; _context.next = 4; return Promise.all(_toConsumableArray(currentTarget.files).map(function (blob) { return makeThumbnail(blob).then(function (thumbnailURL) { return { blob: blob, thumbnailURL: thumbnailURL }; }); })); case 4: _context.t2 = _context.sent; _context.t3 = _context.t1.freeze.call(_context.t1, _context.t2); (0, _context.t0)(_context.t3); sendAttachmentOnRef.current === 'attach' && submit(); case 8: case "end": return _context.stop(); } } }, _callee); }))(); }, [focus, makeThumbnail, sendAttachmentOnRef, setSendBoxAttachments, submit]); return /*#__PURE__*/_react.default.createElement("div", { className: (0, _classnames.default)(rootClassName, 'webchat__upload-button', uploadButtonStyleSet + '', className) }, /*#__PURE__*/_react.default.createElement("input", { accept: uploadAccept, "aria-disabled": disabled, "aria-hidden": "true", className: "webchat__upload-button--file-input", multiple: uploadMultiple, onChange: disabled ? undefined : handleFileChange, onClick: disabled ? PREVENT_DEFAULT_HANDLER : undefined, readOnly: disabled, ref: inputRef, role: "button", tabIndex: -1, type: "file" }), /*#__PURE__*/_react.default.createElement(_IconButton.default, { alt: uploadFileString, "aria-label": uploadFileString, disabled: disabled, onClick: handleClick }, /*#__PURE__*/_react.default.createElement(_AttachmentIcon.default, { checked: !!sendBoxAttachments.length }))); }; UploadButton.defaultProps = { className: undefined }; UploadButton.propTypes = { className: _propTypes.default.string }; var _default = UploadButton; exports.default = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_botframeworkWebchatApi","require","_classnames","_interopRequireDefault","_propTypes","_react","_interopRequireWildcard","_useRefFrom","_IconButton","_useMakeThumbnail","_useStyleToEmotionObject","_useFocus","_useStyleSet3","_useSubmit","_AttachmentIcon","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_regeneratorRuntime","exports","Op","hasOwn","$Symbol","Symbol","iteratorSymbol","iterator","asyncIteratorSymbol","asyncIterator","toStringTagSymbol","toStringTag","define","value","enumerable","configurable","writable","err","wrap","innerFn","outerFn","self","tryLocsList","protoGenerator","Generator","generator","create","context","Context","_invoke","state","method","arg","Error","doneResult","delegate","delegateResult","maybeInvokeDelegate","ContinueSentinel","sent","_sent","dispatchException","abrupt","record","tryCatch","type","done","fn","GeneratorFunction","GeneratorFunctionPrototype","IteratorPrototype","getProto","getPrototypeOf","NativeIteratorPrototype","values","Gp","defineIteratorMethods","forEach","AsyncIterator","PromiseImpl","invoke","resolve","reject","result","__await","then","unwrapped","error","previousPromise","callInvokeWithMethodAndArg","undefined","return","TypeError","info","resultName","next","nextLoc","pushTryEntry","locs","entry","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","push","resetTryEntry","completion","reset","iterable","iteratorMethod","isNaN","length","i","displayName","isGeneratorFunction","genFun","ctor","constructor","name","mark","setPrototypeOf","__proto__","awrap","async","Promise","iter","keys","object","reverse","pop","skipTempReset","prev","charAt","slice","stop","rootRecord","rval","exception","handle","loc","caught","hasCatch","hasFinally","finallyEntry","complete","finish","catch","_catch","thrown","delegateYield","_toConsumableArray","arr","_arrayWithoutHoles","_iterableToArray","_unsupportedIterableToArray","_nonIterableSpread","Array","from","isArray","_arrayLikeToArray","asyncGeneratorStep","gen","_next","_throw","_asyncToGenerator","args","arguments","apply","_slicedToArray","_arrayWithHoles","_iterableToArrayLimit","_nonIterableRest","o","minLen","n","toString","test","len","arr2","_i","_arr","_n","_d","_s","_e","useDisabled","hooks","useSendBoxAttachments","useLocalizer","useStyleOptions","ROOT_STYLE","display","overflow","position","height","width","opacity","left","top","PREVENT_DEFAULT_HANDLER","event","preventDefault","UploadButton","_ref","className","_useStyleOptions","_useStyleOptions2","_useStyleOptions2$","sendAttachmentOn","uploadAccept","uploadMultiple","_useStyleSet","useStyleSet","_useStyleSet2","uploadButtonStyleSet","uploadButton","_useDisabled","_useDisabled2","disabled","_useSendBoxAttachment","_useSendBoxAttachment2","sendBoxAttachments","setSendBoxAttachments","focus","useFocus","inputRef","useRef","localize","makeThumbnail","useMakeThumbnail","rootClassName","useStyleToEmotionObject","submit","useSubmit","sendAttachmentOnRef","useRefFrom","uploadFileString","handleClick","useCallback","_inputRef$current","current","click","handleFileChange","_ref2","currentTarget","_callee","_callee$","_context","t0","t1","all","files","map","blob","thumbnailURL","t2","t3","freeze","createElement","classNames","accept","multiple","onChange","onClick","readOnly","ref","role","tabIndex","alt","checked","defaultProps","propTypes","PropTypes","string","_default"],"sourceRoot":"component:///","sources":["../../src/SendBoxToolbar/UploadButton.tsx"],"sourcesContent":["import { hooks } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React, { useCallback, useRef, type FC, type FormEventHandler, type MouseEventHandler } from 'react';\nimport { useRefFrom } from 'use-ref-from';\n\nimport IconButton from '../SendBox/IconButton';\nimport useMakeThumbnail from '../hooks/useMakeThumbnail';\nimport useStyleToEmotionObject from '../hooks/internal/useStyleToEmotionObject';\nimport useFocus from '../hooks/useFocus';\nimport useStyleSet from '../hooks/useStyleSet';\nimport useSubmit from '../providers/internal/SendBox/useSubmit';\nimport AttachmentIcon from './Assets/AttachmentIcon';\n\nconst { useDisabled, useSendBoxAttachments, useLocalizer, useStyleOptions } = hooks;\n\nconst ROOT_STYLE = {\n  '&.webchat__upload-button': {\n    display: 'flex',\n    overflow: 'hidden',\n    position: 'relative',\n\n    '& .webchat__upload-button--file-input': {\n      height: 0,\n      width: 0,\n      opacity: 0,\n      position: 'absolute',\n      left: 0,\n      top: 0\n    }\n  }\n};\n\nconst PREVENT_DEFAULT_HANDLER = event => event.preventDefault();\n\ntype UploadButtonProps = {\n  className?: string;\n};\n\nconst UploadButton: FC<UploadButtonProps> = ({ className }) => {\n  const [{ sendAttachmentOn, uploadAccept, uploadMultiple }] = useStyleOptions();\n  const [{ uploadButton: uploadButtonStyleSet }] = useStyleSet();\n  const [disabled] = useDisabled();\n  const [sendBoxAttachments, setSendBoxAttachments] = useSendBoxAttachments();\n  const focus = useFocus();\n  const inputRef = useRef<HTMLInputElement>(null);\n  const localize = useLocalizer();\n  const makeThumbnail = useMakeThumbnail();\n  const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n  const submit = useSubmit();\n\n  const sendAttachmentOnRef = useRefFrom(sendAttachmentOn);\n  const uploadFileString = localize('TEXT_INPUT_UPLOAD_BUTTON_ALT');\n\n  const handleClick = useCallback<MouseEventHandler<HTMLButtonElement>>(() => inputRef.current?.click(), [inputRef]);\n\n  const handleFileChange = useCallback<FormEventHandler<HTMLInputElement>>(\n    ({ currentTarget }) => {\n      // We should change the focus synchronously for accessibility reason.\n      focus('sendBox');\n\n      // TODO: [P2] We should disable send button while we are creating thumbnails.\n      //            Otherwise, if the user click the send button too quickly, it will not attach any files.\n      (async function () {\n        setSendBoxAttachments(\n          Object.freeze(\n            await Promise.all(\n              [...currentTarget.files].map(blob => makeThumbnail(blob).then(thumbnailURL => ({ blob, thumbnailURL })))\n            )\n          )\n        );\n\n        sendAttachmentOnRef.current === 'attach' && submit();\n      })();\n    },\n    [focus, makeThumbnail, sendAttachmentOnRef, setSendBoxAttachments, submit]\n  );\n\n  return (\n    <div className={classNames(rootClassName, 'webchat__upload-button', uploadButtonStyleSet + '', className)}>\n      <input\n        accept={uploadAccept}\n        aria-disabled={disabled}\n        aria-hidden=\"true\"\n        className=\"webchat__upload-button--file-input\"\n        multiple={uploadMultiple}\n        onChange={disabled ? undefined : handleFileChange}\n        onClick={disabled ? PREVENT_DEFAULT_HANDLER : undefined}\n        readOnly={disabled}\n        ref={inputRef}\n        role=\"button\"\n        tabIndex={-1}\n        type=\"file\"\n      />\n      <IconButton alt={uploadFileString} aria-label={uploadFileString} disabled={disabled} onClick={handleClick}>\n        <AttachmentIcon checked={!!sendBoxAttachments.length} />\n      </IconButton>\n    </div>\n  );\n};\n\nUploadButton.defaultProps = {\n  className: undefined\n};\n\nUploadButton.propTypes = {\n  className: PropTypes.string\n};\n\nexport default UploadButton;\n"],"mappings":"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