botframework-webchat-component
Version:
React component of botframework-webchat
277 lines (222 loc) • 25.5 kB
JavaScript
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.connectUploadButton = 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 _AttachmentIcon = _interopRequireDefault(require("./Assets/AttachmentIcon"));
var _connectToWebChat = _interopRequireDefault(require("../connectToWebChat"));
var _index = _interopRequireDefault(require("../Utils/downscaleImageToDataURL/index"));
var _IconButton = _interopRequireDefault(require("./IconButton"));
var _useSendFiles = _interopRequireDefault(require("../hooks/useSendFiles"));
var _useStyleSet3 = _interopRequireDefault(require("../hooks/useStyleSet"));
var _useStyleToEmotionObject = _interopRequireDefault(require("../hooks/internal/useStyleToEmotionObject"));
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; }
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
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); }); }; }
var useDisabled = _botframeworkWebchatApi.hooks.useDisabled,
useLocalizer = _botframeworkWebchatApi.hooks.useLocalizer;
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();
};
function makeThumbnail(_x, _x2, _x3, _x4, _x5) {
return _makeThumbnail.apply(this, arguments);
}
function _makeThumbnail() {
_makeThumbnail = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee3(file, width, height, contentType, quality) {
return regeneratorRuntime.wrap(function _callee3$(_context3) {
while (1) {
switch (_context3.prev = _context3.next) {
case 0:
if (!/\.(gif|jpe?g|png)$/i.test(file.name)) {
_context3.next = 10;
break;
}
_context3.prev = 1;
_context3.next = 4;
return (0, _index.default)(file, width, height, contentType, quality);
case 4:
return _context3.abrupt("return", _context3.sent);
case 7:
_context3.prev = 7;
_context3.t0 = _context3["catch"](1);
console.warn("Web Chat: Failed to downscale image due to ".concat(_context3.t0, "."));
case 10:
case "end":
return _context3.stop();
}
}
}, _callee3, null, [[1, 7]]);
}));
return _makeThumbnail.apply(this, arguments);
}
var connectUploadButton = function connectUploadButton() {
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,
language = _ref.language,
_sendFiles = _ref.sendFiles,
_ref$styleSet$options = _ref.styleSet.options,
enableUploadThumbnail = _ref$styleSet$options.enableUploadThumbnail,
uploadThumbnailContentType = _ref$styleSet$options.uploadThumbnailContentType,
uploadThumbnailHeight = _ref$styleSet$options.uploadThumbnailHeight,
uploadThumbnailQuality = _ref$styleSet$options.uploadThumbnailQuality,
uploadThumbnailWidth = _ref$styleSet$options.uploadThumbnailWidth;
return {
disabled: disabled,
language: language,
sendFiles: function () {
var _sendFiles2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2(files) {
return regeneratorRuntime.wrap(function _callee2$(_context2) {
while (1) {
switch (_context2.prev = _context2.next) {
case 0:
if (!(files && files.length)) {
_context2.next = 6;
break;
}
_context2.t0 = _sendFiles;
_context2.next = 4;
return Promise.all([].map.call(files, /*#__PURE__*/function () {
var _ref2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(file) {
return regeneratorRuntime.wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
_context.t0 = _objectSpread;
_context.t1 = {
name: file.name,
size: file.size,
url: window.URL.createObjectURL(file)
};
_context.t2 = enableUploadThumbnail;
if (!_context.t2) {
_context.next = 8;
break;
}
_context.next = 6;
return makeThumbnail(file, uploadThumbnailWidth, uploadThumbnailHeight, uploadThumbnailContentType, uploadThumbnailQuality);
case 6:
_context.t3 = _context.sent;
_context.t2 = {
thumbnail: _context.t3
};
case 8:
_context.t4 = _context.t2;
return _context.abrupt("return", (0, _context.t0)(_context.t1, _context.t4));
case 10:
case "end":
return _context.stop();
}
}
}, _callee);
}));
return function (_x7) {
return _ref2.apply(this, arguments);
};
}()));
case 4:
_context2.t1 = _context2.sent;
(0, _context2.t0)(_context2.t1);
case 6:
case "end":
return _context2.stop();
}
}
}, _callee2);
}));
function sendFiles(_x6) {
return _sendFiles2.apply(this, arguments);
}
return sendFiles;
}()
};
}].concat(selectors));
};
exports.connectUploadButton = connectUploadButton;
var UploadButton = function UploadButton(_ref3) {
var className = _ref3.className;
var _useStyleSet = (0, _useStyleSet3.default)(),
_useStyleSet2 = _slicedToArray(_useStyleSet, 1),
uploadButtonStyleSet = _useStyleSet2[0].uploadButton;
var _useDisabled = useDisabled(),
_useDisabled2 = _slicedToArray(_useDisabled, 1),
disabled = _useDisabled2[0];
var inputRef = (0, _react.useRef)();
var localize = useLocalizer();
var rootClassName = (0, _useStyleToEmotionObject.default)()(ROOT_STYLE) + '';
var sendFiles = (0, _useSendFiles.default)();
var current = inputRef.current;
var uploadFileString = localize('TEXT_INPUT_UPLOAD_BUTTON_ALT');
var handleClick = (0, _react.useCallback)(function () {
current && current.click();
}, [current]);
var handleFileChange = (0, _react.useCallback)(function (_ref4) {
var files = _ref4.target.files;
sendFiles(files);
if (current) {
current.value = null;
}
}, [current, sendFiles]);
return /*#__PURE__*/_react.default.createElement("div", {
className: (0, _classnames.default)(rootClassName, 'webchat__upload-button', uploadButtonStyleSet + '', className)
}, /*#__PURE__*/_react.default.createElement("input", {
"aria-disabled": disabled,
"aria-hidden": "true",
className: "webchat__upload-button--file-input",
multiple: true,
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, null)));
};
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,"sources":["../../src/SendBox/UploadButton.js"],"names":["useDisabled","hooks","useLocalizer","ROOT_STYLE","display","overflow","position","height","width","opacity","left","top","PREVENT_DEFAULT_HANDLER","event","preventDefault","makeThumbnail","file","contentType","quality","test","name","console","warn","connectUploadButton","selectors","connectToWebChat","disabled","language","sendFiles","styleSet","options","enableUploadThumbnail","uploadThumbnailContentType","uploadThumbnailHeight","uploadThumbnailQuality","uploadThumbnailWidth","files","length","Promise","all","map","call","size","url","window","URL","createObjectURL","thumbnail","UploadButton","className","uploadButtonStyleSet","uploadButton","inputRef","localize","rootClassName","current","uploadFileString","handleClick","click","handleFileChange","target","value","undefined","defaultProps","propTypes","PropTypes","string"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["import { hooks } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React, { useCallback, useRef } from 'react';\n\nimport AttachmentIcon from './Assets/AttachmentIcon';\nimport connectToWebChat from '../connectToWebChat';\nimport downscaleImageToDataURL from '../Utils/downscaleImageToDataURL/index';\nimport IconButton from './IconButton';\nimport useSendFiles from '../hooks/useSendFiles';\nimport useStyleSet from '../hooks/useStyleSet';\nimport useStyleToEmotionObject from '../hooks/internal/useStyleToEmotionObject';\n\nconst { useDisabled, useLocalizer } = 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\nasync function makeThumbnail(file, width, height, contentType, quality) {\n  if (/\\.(gif|jpe?g|png)$/iu.test(file.name)) {\n    try {\n      return await downscaleImageToDataURL(file, width, height, contentType, quality);\n    } catch (error) {\n      console.warn(`Web Chat: Failed to downscale image due to ${error}.`);\n    }\n  }\n}\n\nconst connectUploadButton = (...selectors) =>\n  connectToWebChat(\n    ({\n      disabled,\n      language,\n      sendFiles,\n      styleSet: {\n        options: {\n          enableUploadThumbnail,\n          uploadThumbnailContentType,\n          uploadThumbnailHeight,\n          uploadThumbnailQuality,\n          uploadThumbnailWidth\n        }\n      }\n    }) => ({\n      disabled,\n      language,\n      sendFiles: async files => {\n        if (files && files.length) {\n          // TODO: [P3] We need to find revokeObjectURL on the UI side\n          //       Redux store should not know about the browser environment\n          //       One fix is to use ArrayBuffer instead of object URL, but that would requires change to DirectLineJS\n          sendFiles(\n            await Promise.all(\n              [].map.call(files, async file => ({\n                name: file.name,\n                size: file.size,\n                url: window.URL.createObjectURL(file),\n                ...(enableUploadThumbnail && {\n                  thumbnail: await makeThumbnail(\n                    file,\n                    uploadThumbnailWidth,\n                    uploadThumbnailHeight,\n                    uploadThumbnailContentType,\n                    uploadThumbnailQuality\n                  )\n                })\n              }))\n            )\n          );\n        }\n      }\n    }),\n    ...selectors\n  );\n\nconst UploadButton = ({ className }) => {\n  const [{ uploadButton: uploadButtonStyleSet }] = useStyleSet();\n  const [disabled] = useDisabled();\n  const inputRef = useRef();\n  const localize = useLocalizer();\n  const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n  const sendFiles = useSendFiles();\n\n  const { current } = inputRef;\n  const uploadFileString = localize('TEXT_INPUT_UPLOAD_BUTTON_ALT');\n\n  const handleClick = useCallback(() => {\n    current && current.click();\n  }, [current]);\n\n  const handleFileChange = useCallback(\n    ({ target: { files } }) => {\n      sendFiles(files);\n\n      if (current) {\n        current.value = null;\n      }\n    },\n    [current, sendFiles]\n  );\n\n  return (\n    <div className={classNames(rootClassName, 'webchat__upload-button', uploadButtonStyleSet + '', className)}>\n      <input\n        aria-disabled={disabled}\n        aria-hidden=\"true\"\n        className=\"webchat__upload-button--file-input\"\n        multiple={true}\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 />\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\nexport { connectUploadButton };\n"]}
;