botframework-webchat-component
Version:
React component of botframework-webchat
139 lines (114 loc) • 15.2 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 _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"]}
;