botframework-webchat-component
Version:
React component of botframework-webchat
120 lines (119 loc) • 19.7 kB
JavaScript
;
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 = _interopRequireDefault(require("react"));
var _DownloadIcon = _interopRequireDefault(require("./Assets/DownloadIcon"));
var _useStyleSet3 = _interopRequireDefault(require("../hooks/useStyleSet"));
var _useStyleToEmotionObject = _interopRequireDefault(require("../hooks/internal/useStyleToEmotionObject"));
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) { 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 useByteFormatter = _botframeworkWebchatApi.hooks.useByteFormatter,
useDirection = _botframeworkWebchatApi.hooks.useDirection,
useLocalizer = _botframeworkWebchatApi.hooks.useLocalizer;
var ROOT_STYLE = {
display: 'flex',
'& .webchat__fileContent__buttonLink': {
display: 'flex',
flex: 1
},
'& .webchat__fileContent__badge': {
display: 'flex',
flex: 1,
flexDirection: 'column'
}
};
var ALLOWED_PROTOCOLS = ['blob:', 'data:', 'http:', 'https:'];
function isAllowedProtocol(url) {
try {
return ALLOWED_PROTOCOLS.includes(new URL(url).protocol);
} catch (err) {
return false;
}
}
var FileContentBadge = function FileContentBadge(_ref) {
var downloadIcon = _ref.downloadIcon,
fileName = _ref.fileName,
size = _ref.size;
var _useDirection = useDirection(),
_useDirection2 = _slicedToArray(_useDirection, 1),
direction = _useDirection2[0];
var formatByte = useByteFormatter();
var localizedSize = typeof size === 'number' && formatByte(size);
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
"aria-hidden": true,
className: "webchat__fileContent__badge"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "webchat__fileContent__fileName"
}, fileName), !!localizedSize && /*#__PURE__*/_react.default.createElement("div", {
className: "webchat__fileContent__size"
}, localizedSize)), downloadIcon && /*#__PURE__*/_react.default.createElement(_DownloadIcon.default, {
className: (0, _classnames.default)('webchat__fileContent__downloadIcon', direction === 'rtl' && 'webchat__fileContent__downloadIcon--rtl'),
size: 1.5
}));
};
FileContentBadge.defaultProps = {
downloadIcon: false,
size: undefined
};
FileContentBadge.propTypes = {
downloadIcon: _propTypes.default.bool,
fileName: _propTypes.default.string.isRequired,
size: _propTypes.default.number
};
var FileContent = function FileContent(_ref2) {
var className = _ref2.className,
href = _ref2.href,
fileName = _ref2.fileName,
size = _ref2.size;
var _useStyleSet = (0, _useStyleSet3.default)(),
_useStyleSet2 = _slicedToArray(_useStyleSet, 1),
fileContentStyleSet = _useStyleSet2[0].fileContent;
var localize = useLocalizer();
var localizeBytes = useByteFormatter();
var rootClassName = (0, _useStyleToEmotionObject.default)()(ROOT_STYLE) + '';
var localizedSize = typeof size === 'number' && localizeBytes(size);
href = href && isAllowedProtocol(href) ? href : undefined;
var alt = localize(href ? localizedSize ? 'FILE_CONTENT_DOWNLOADABLE_WITH_SIZE_ALT' : 'FILE_CONTENT_DOWNLOADABLE_ALT' : localizedSize ? 'FILE_CONTENT_WITH_SIZE_ALT' : 'FILE_CONTENT_ALT', fileName, localizedSize);
return /*#__PURE__*/_react.default.createElement("div", {
className: (0, _classnames.default)('webchat__fileContent', rootClassName, fileContentStyleSet + '', (className || '') + '')
}, href ? /*#__PURE__*/_react.default.createElement("a", {
"aria-label": alt,
className: "webchat__fileContent__buttonLink",
download: fileName,
href: href,
rel: "noopener noreferrer",
target: "_blank"
}, /*#__PURE__*/_react.default.createElement(FileContentBadge, {
downloadIcon: true,
fileName: fileName,
size: size
})) : /*#__PURE__*/_react.default.createElement(FileContentBadge, {
downloadIcon: false,
fileName: fileName,
size: size
}));
};
FileContent.defaultProps = {
className: '',
href: undefined,
size: undefined
};
FileContent.propTypes = {
className: _propTypes.default.string,
fileName: _propTypes.default.string.isRequired,
href: _propTypes.default.string,
size: _propTypes.default.number
};
var _default = FileContent;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_botframeworkWebchatApi","require","_classnames","_interopRequireDefault","_propTypes","_react","_DownloadIcon","_useStyleSet3","_useStyleToEmotionObject","obj","__esModule","default","_slicedToArray","arr","i","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","TypeError","o","minLen","_arrayLikeToArray","n","Object","prototype","toString","call","slice","constructor","name","Array","from","test","len","length","arr2","_i","Symbol","iterator","_arr","_n","_d","_s","_e","next","done","push","value","err","isArray","useByteFormatter","hooks","useDirection","useLocalizer","ROOT_STYLE","display","flex","flexDirection","ALLOWED_PROTOCOLS","isAllowedProtocol","url","includes","URL","protocol","FileContentBadge","_ref","downloadIcon","fileName","size","_useDirection","_useDirection2","direction","formatByte","localizedSize","createElement","Fragment","className","classNames","defaultProps","undefined","propTypes","PropTypes","bool","string","isRequired","number","FileContent","_ref2","href","_useStyleSet","useStyleSet","_useStyleSet2","fileContentStyleSet","fileContent","localize","localizeBytes","rootClassName","useStyleToEmotionObject","alt","download","rel","target","_default","exports"],"sourceRoot":"component:///","sources":["../../src/Attachment/FileContent.tsx"],"sourcesContent":["import { hooks } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React, { FC } from 'react';\n\nimport DownloadIcon from './Assets/DownloadIcon';\nimport useStyleSet from '../hooks/useStyleSet';\nimport useStyleToEmotionObject from '../hooks/internal/useStyleToEmotionObject';\n\nconst { useByteFormatter, useDirection, useLocalizer } = hooks;\n\nconst ROOT_STYLE = {\n  display: 'flex',\n\n  '& .webchat__fileContent__buttonLink': {\n    display: 'flex',\n    flex: 1\n  },\n\n  '& .webchat__fileContent__badge': {\n    display: 'flex',\n    flex: 1,\n    flexDirection: 'column'\n  }\n};\n\nconst ALLOWED_PROTOCOLS = ['blob:', 'data:', 'http:', 'https:'];\n\nfunction isAllowedProtocol(url) {\n  try {\n    return ALLOWED_PROTOCOLS.includes(new URL(url).protocol);\n  } catch (err) {\n    return false;\n  }\n}\n\nconst FileContentBadge = ({ downloadIcon, fileName, size }) => {\n  const [direction] = useDirection();\n  const formatByte = useByteFormatter();\n\n  const localizedSize = typeof size === 'number' && formatByte(size);\n\n  return (\n    <React.Fragment>\n      <div aria-hidden={true} className=\"webchat__fileContent__badge\">\n        <div className=\"webchat__fileContent__fileName\">{fileName}</div>\n        {!!localizedSize && <div className=\"webchat__fileContent__size\">{localizedSize}</div>}\n      </div>\n      {downloadIcon && (\n        <DownloadIcon\n          className={classNames(\n            'webchat__fileContent__downloadIcon',\n            direction === 'rtl' && 'webchat__fileContent__downloadIcon--rtl'\n          )}\n          size={1.5}\n        />\n      )}\n    </React.Fragment>\n  );\n};\n\nFileContentBadge.defaultProps = {\n  downloadIcon: false,\n  size: undefined\n};\n\nFileContentBadge.propTypes = {\n  downloadIcon: PropTypes.bool,\n  fileName: PropTypes.string.isRequired,\n  size: PropTypes.number\n};\n\ntype FileContentProps = {\n  className?: string;\n  fileName: string;\n  href?: string;\n  size?: number;\n};\n\nconst FileContent: FC<FileContentProps> = ({ className, href, fileName, size }) => {\n  const [{ fileContent: fileContentStyleSet }] = useStyleSet();\n  const localize = useLocalizer();\n  const localizeBytes = useByteFormatter();\n  const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n\n  const localizedSize = typeof size === 'number' && localizeBytes(size);\n\n  href = href && isAllowedProtocol(href) ? href : undefined;\n\n  const alt = localize(\n    href\n      ? localizedSize\n        ? 'FILE_CONTENT_DOWNLOADABLE_WITH_SIZE_ALT'\n        : 'FILE_CONTENT_DOWNLOADABLE_ALT'\n      : localizedSize\n        ? 'FILE_CONTENT_WITH_SIZE_ALT'\n        : 'FILE_CONTENT_ALT',\n    fileName,\n    localizedSize\n  );\n\n  return (\n    <div\n      className={classNames('webchat__fileContent', rootClassName, fileContentStyleSet + '', (className || '') + '')}\n    >\n      {href ? (\n        <a\n          aria-label={alt}\n          className=\"webchat__fileContent__buttonLink\"\n          download={fileName}\n          href={href}\n          rel=\"noopener noreferrer\"\n          target=\"_blank\"\n        >\n          <FileContentBadge downloadIcon={true} fileName={fileName} size={size} />\n        </a>\n      ) : (\n        <FileContentBadge downloadIcon={false} fileName={fileName} size={size} />\n      )}\n    </div>\n  );\n};\n\nFileContent.defaultProps = {\n  className: '',\n  href: undefined,\n  size: undefined\n};\n\nFileContent.propTypes = {\n  className: PropTypes.string,\n  fileName: PropTypes.string.isRequired,\n  href: PropTypes.string,\n  size: PropTypes.number\n};\n\nexport default FileContent;\n"],"mappings":"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"}