UNPKG

botframework-webchat-component

Version:
139 lines (114 loc) 15.2 kB
"use strict"; 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 _ScreenReaderText = _interopRequireDefault(require("../ScreenReaderText")); 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) { 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 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 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); 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", { "aria-hidden": true, className: (0, _classnames.default)('webchat__fileContent', rootClassName, fileContentStyleSet + '', (className || '') + '') }, /*#__PURE__*/_react.default.createElement(_ScreenReaderText.default, { text: alt }), href ? /*#__PURE__*/_react.default.createElement("a", { "aria-hidden": true, 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,"sources":["../../src/Attachment/FileContent.js"],"names":["useByteFormatter","hooks","useDirection","useLocalizer","ROOT_STYLE","display","flex","flexDirection","FileContentBadge","downloadIcon","fileName","size","direction","formatByte","localizedSize","defaultProps","undefined","propTypes","PropTypes","bool","string","isRequired","number","FileContent","className","href","fileContentStyleSet","fileContent","localize","localizeBytes","rootClassName","alt"],"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 from 'react';\n\nimport DownloadIcon from './Assets/DownloadIcon';\nimport ScreenReaderText from '../ScreenReaderText';\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 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\nconst FileContent = ({ 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  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      aria-hidden={true}\n      className={classNames('webchat__fileContent', rootClassName, fileContentStyleSet + '', (className || '') + '')}\n    >\n      <ScreenReaderText text={alt} />\n      {href ? (\n        <a\n          aria-hidden={true}\n          className=\"webchat__fileContent__buttonLink\"\n          download={fileName}\n          href={href}\n          rel=\"noopener noreferrer\"\n          target=\"_blank\"\n        >\n          {/* Although nested, Chrome v75 does not respect the above aria-hidden and makes the below aria-hidden in FileContentBadge necessary */}\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"]}