UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

304 lines (243 loc) 39.2 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); Object.defineProperty(exports, "__esModule", { value: true }); exports.FileUpload = exports["default"] = exports.WarningMsg = void 0; var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _reactIntl = require("react-intl"); var _uploadButton = _interopRequireDefault(require("./upload-button")); var _icons = require("../icons"); var _fileUploadProgress = _interopRequireDefault(require("./file-upload-progress")); var _fileDrop = _interopRequireDefault(require("./file-drop")); var _utils = require("../../../utils/utils"); var _userGuides = require("../../../constants/user-guides"); var _reactMarkdown = _interopRequireDefault(require("react-markdown")); var _mediaBreakpoints = require("../../../styles/media-breakpoints"); var _localization = require("../../../localization"); var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12, _templateObject13, _templateObject14, _templateObject15, _templateObject16, _templateObject17, _templateObject18; function _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; } 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 _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } /** @typedef {import('./file-upload').FileUploadProps} FileUploadProps */ var fileIconColor = '#D3D8E0'; var LinkRenderer = function LinkRenderer(props) { return /*#__PURE__*/_react["default"].createElement("a", { href: props.href, target: "_blank", rel: "noopener noreferrer" }, props.children); }; var StyledUploadMessage = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-size: 14px;\n margin-bottom: 12px;\n\n ", ";\n"])), function (props) { return props.theme.textColorLT; }, _mediaBreakpoints.media.portable(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: 12px;\n "])))); var WarningMsg = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n margin-top: 10px;\n color: ", ";\n font-weight: 500;\n"])), function (props) { return props.theme.errorColor; }); exports.WarningMsg = WarningMsg; var StyledFileDrop = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: white;\n border-radius: 4px;\n border-style: ", ";\n border-width: 1px;\n border-color: ", ";\n text-align: center;\n width: 100%;\n padding: 48px 8px 0;\n height: 360px;\n\n .file-upload-or {\n color: ", ";\n padding-right: 4px;\n }\n\n .file-type-row {\n opacity: 0.5;\n }\n ", ";\n"])), function (props) { return props.dragOver ? 'solid' : 'dashed'; }, function (props) { return props.dragOver ? props.theme.textColorLT : props.theme.subtextColorLT; }, function (props) { return props.theme.linkBtnColor; }, _mediaBreakpoints.media.portable(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 16px 4px 0;\n "])))); var MsgWrapper = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-size: 20px;\n height: 36px;\n"])), function (props) { return props.theme.modalTitleColor; }); var StyledDragNDropIcon = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n margin-bottom: 48px;\n\n ", ";\n ", ";\n"])), fileIconColor, _mediaBreakpoints.media.portable(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 16px;\n "]))), _mediaBreakpoints.media.palm(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 8px;\n "])))); var StyledFileTypeFow = _styledComponents["default"].div(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 24px;\n ", ";\n ", ";\n"])), _mediaBreakpoints.media.portable(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 16px;\n "]))), _mediaBreakpoints.media.palm(_templateObject12 || (_templateObject12 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 8px;\n "])))); var StyledFileUpload = _styledComponents["default"].div(_templateObject13 || (_templateObject13 = (0, _taggedTemplateLiteral2["default"])(["\n .file-drop {\n position: relative;\n }\n"]))); var StyledMessage = _styledComponents["default"].div(_templateObject14 || (_templateObject14 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: center;\n align-items: center;\n margin-bottom: 32px;\n\n .loading-action {\n margin-right: 10px;\n }\n .loading-spinner {\n margin-left: 10px;\n }\n"]))); var StyledDragFileWrapper = _styledComponents["default"].div(_templateObject15 || (_templateObject15 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 32px;\n ", ";\n ", ";\n"])), _mediaBreakpoints.media.portable(_templateObject16 || (_templateObject16 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 24px;\n "]))), _mediaBreakpoints.media.portable(_templateObject17 || (_templateObject17 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 16px;\n "])))); var StyledDisclaimer = (0, _styledComponents["default"])(StyledMessage)(_templateObject18 || (_templateObject18 = (0, _taggedTemplateLiteral2["default"])(["\n margin: 0 auto;\n"]))); function FileUploadFactory() { /** @augments {Component<FileUploadProps>} */ var FileUpload = /*#__PURE__*/function (_Component) { (0, _inherits2["default"])(FileUpload, _Component); var _super = _createSuper(FileUpload); function FileUpload() { var _this; (0, _classCallCheck2["default"])(this, FileUpload); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _super.call.apply(_super, [this].concat(args)); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", { dragOver: false, fileLoading: false, files: [], errorFiles: [] }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "frame", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_isValidFileType", function (filename) { var _this$props$fileExten = _this.props.fileExtensions, fileExtensions = _this$props$fileExten === void 0 ? [] : _this$props$fileExten; var fileExt = fileExtensions.find(function (ext) { return filename.endsWith(ext); }); return Boolean(fileExt); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_handleFileInput", function (fileList, event) { if (event) { event.stopPropagation(); } var files = (0, _toConsumableArray2["default"])(fileList).filter(Boolean); var _this$props$disableEx = _this.props.disableExtensionFilter, disableExtensionFilter = _this$props$disableEx === void 0 ? false : _this$props$disableEx; // TODO - move this code out of the component var filesToLoad = []; var errorFiles = []; var _iterator = _createForOfIteratorHelper(files), _step; try { for (_iterator.s(); !(_step = _iterator.n()).done;) { var file = _step.value; if (disableExtensionFilter || _this._isValidFileType(file.name)) { filesToLoad.push(file); } else { errorFiles.push(file.name); } } } catch (err) { _iterator.e(err); } finally { _iterator.f(); } var nextState = { files: filesToLoad, errorFiles: errorFiles, dragOver: false }; _this.setState(nextState, function () { return nextState.files.length ? _this.props.onFileUpload(nextState.files) : null; }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_toggleDragState", function (newState) { _this.setState({ dragOver: newState }); }); return _this; } (0, _createClass2["default"])(FileUpload, [{ key: "render", value: function render() { var _this2 = this; var _this$state = this.state, dragOver = _this$state.dragOver, files = _this$state.files, errorFiles = _this$state.errorFiles; var _this$props = this.props, fileLoading = _this$props.fileLoading, fileLoadingProgress = _this$props.fileLoadingProgress, theme = _this$props.theme, intl = _this$props.intl; var _this$props2 = this.props, _this$props2$fileExte = _this$props2.fileExtensions, fileExtensions = _this$props2$fileExte === void 0 ? [] : _this$props2$fileExte, _this$props2$fileForm = _this$props2.fileFormatNames, fileFormatNames = _this$props2$fileForm === void 0 ? [] : _this$props2$fileForm; return /*#__PURE__*/_react["default"].createElement(StyledFileUpload, { className: "file-uploader", ref: this.frame }, _fileDrop["default"] ? /*#__PURE__*/_react["default"].createElement(_fileDrop["default"], { frame: this.frame.current || document, onDragOver: function onDragOver() { return _this2._toggleDragState(true); }, onDragLeave: function onDragLeave() { return _this2._toggleDragState(false); }, onDrop: this._handleFileInput, className: "file-uploader__file-drop" }, /*#__PURE__*/_react["default"].createElement(StyledUploadMessage, { className: "file-upload__message" }, /*#__PURE__*/_react["default"].createElement(_reactMarkdown["default"], { source: "".concat(intl.formatMessage({ id: 'fileUploader.configUploadMessage' }, { fileFormatNames: fileFormatNames.map(function (format) { return "**".concat(format, "**"); }).join(', ') }), "(").concat(_userGuides.GUIDES_FILE_FORMAT_DOC, ")."), renderers: { link: LinkRenderer } })), /*#__PURE__*/_react["default"].createElement(StyledFileDrop, { dragOver: dragOver }, /*#__PURE__*/_react["default"].createElement(StyledFileTypeFow, { className: "file-type-row" }, fileExtensions.map(function (ext) { return /*#__PURE__*/_react["default"].createElement(_icons.FileType, { key: ext, ext: ext, height: "50px", fontSize: "9px" }); })), fileLoading ? /*#__PURE__*/_react["default"].createElement(_fileUploadProgress["default"], { fileLoadingProgress: fileLoadingProgress, theme: theme }) : /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("div", { style: { opacity: dragOver ? 0.5 : 1 }, className: "file-upload-display-message" }, /*#__PURE__*/_react["default"].createElement(StyledDragNDropIcon, null, /*#__PURE__*/_react["default"].createElement(_icons.DragNDrop, { height: "44px" })), errorFiles.length ? /*#__PURE__*/_react["default"].createElement(WarningMsg, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'fileUploader.fileNotSupported', values: { errorFiles: errorFiles.join(', ') } })) : null), !files.length ? /*#__PURE__*/_react["default"].createElement(StyledDragFileWrapper, null, /*#__PURE__*/_react["default"].createElement(MsgWrapper, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'fileUploader.message' })), /*#__PURE__*/_react["default"].createElement("span", { className: "file-upload-or" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'fileUploader.or' })), /*#__PURE__*/_react["default"].createElement(_uploadButton["default"], { onUpload: this._handleFileInput }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'fileUploader.browseFiles' }))) : null, /*#__PURE__*/_react["default"].createElement(StyledDisclaimer, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'fileUploader.disclaimer' }))))) : null, /*#__PURE__*/_react["default"].createElement(WarningMsg, null, (0, _utils.isChrome)() ? /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'fileUploader.chromeMessage' }) : '')); } }], [{ key: "getDerivedStateFromProps", value: function getDerivedStateFromProps(props, state) { if (state.fileLoading && props.fileLoading === false && state.files.length) { return { files: [], fileLoading: props.fileLoading }; } return { fileLoading: props.fileLoading }; } }]); return FileUpload; }(_react.Component); return (0, _reactIntl.injectIntl)(FileUpload); } var _default = FileUploadFactory; exports["default"] = _default; var FileUpload = FileUploadFactory(); exports.FileUpload = FileUpload; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/common/file-uploader/file-upload.js"],"names":["fileIconColor","LinkRenderer","props","href","children","StyledUploadMessage","styled","div","theme","textColorLT","media","portable","WarningMsg","span","errorColor","StyledFileDrop","dragOver","subtextColorLT","linkBtnColor","MsgWrapper","modalTitleColor","StyledDragNDropIcon","palm","StyledFileTypeFow","StyledFileUpload","StyledMessage","StyledDragFileWrapper","StyledDisclaimer","FileUploadFactory","FileUpload","fileLoading","files","errorFiles","filename","fileExtensions","fileExt","find","ext","endsWith","Boolean","fileList","event","stopPropagation","filter","disableExtensionFilter","filesToLoad","file","_isValidFileType","name","push","nextState","setState","length","onFileUpload","newState","state","fileLoadingProgress","intl","fileFormatNames","frame","FileDrop","current","document","_toggleDragState","_handleFileInput","formatMessage","id","map","format","join","GUIDES_FILE_FORMAT_DOC","link","opacity","Component"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport React, {Component, createRef} from 'react';\nimport styled from 'styled-components';\nimport {injectIntl} from 'react-intl';\nimport UploadButton from './upload-button';\nimport {DragNDrop, FileType} from 'components/common/icons';\nimport FileUploadProgress from 'components/common/file-uploader/file-upload-progress';\nimport FileDrop from './file-drop';\n\nimport {isChrome} from 'utils/utils';\nimport {GUIDES_FILE_FORMAT_DOC} from 'constants/user-guides';\nimport ReactMarkdown from 'react-markdown';\n// Breakpoints\nimport {media} from 'styles/media-breakpoints';\nimport {FormattedMessage} from 'localization';\n\n/** @typedef {import('./file-upload').FileUploadProps} FileUploadProps */\n\nconst fileIconColor = '#D3D8E0';\n\nconst LinkRenderer = props => {\n  return (\n    <a href={props.href} target=\"_blank\" rel=\"noopener noreferrer\">\n      {props.children}\n    </a>\n  );\n};\nconst StyledUploadMessage = styled.div`\n  color: ${props => props.theme.textColorLT};\n  font-size: 14px;\n  margin-bottom: 12px;\n\n  ${media.portable`\n    font-size: 12px;\n  `};\n`;\n\nexport const WarningMsg = styled.span`\n  margin-top: 10px;\n  color: ${props => props.theme.errorColor};\n  font-weight: 500;\n`;\n\nconst StyledFileDrop = styled.div`\n  background-color: white;\n  border-radius: 4px;\n  border-style: ${props => (props.dragOver ? 'solid' : 'dashed')};\n  border-width: 1px;\n  border-color: ${props => (props.dragOver ? props.theme.textColorLT : props.theme.subtextColorLT)};\n  text-align: center;\n  width: 100%;\n  padding: 48px 8px 0;\n  height: 360px;\n\n  .file-upload-or {\n    color: ${props => props.theme.linkBtnColor};\n    padding-right: 4px;\n  }\n\n  .file-type-row {\n    opacity: 0.5;\n  }\n  ${media.portable`\n    padding: 16px 4px 0;\n  `};\n`;\n\nconst MsgWrapper = styled.div`\n  color: ${props => props.theme.modalTitleColor};\n  font-size: 20px;\n  height: 36px;\n`;\n\nconst StyledDragNDropIcon = styled.div`\n  color: ${fileIconColor};\n  margin-bottom: 48px;\n\n  ${media.portable`\n    margin-bottom: 16px;\n  `};\n  ${media.palm`\n    margin-bottom: 8px;\n  `};\n`;\n\nconst StyledFileTypeFow = styled.div`\n  margin-bottom: 24px;\n  ${media.portable`\n    margin-bottom: 16px;\n  `};\n  ${media.palm`\n    margin-bottom: 8px;\n  `};\n`;\n\nconst StyledFileUpload = styled.div`\n  .file-drop {\n    position: relative;\n  }\n`;\n\nconst StyledMessage = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  margin-bottom: 32px;\n\n  .loading-action {\n    margin-right: 10px;\n  }\n  .loading-spinner {\n    margin-left: 10px;\n  }\n`;\n\nconst StyledDragFileWrapper = styled.div`\n  margin-bottom: 32px;\n  ${media.portable`\n    margin-bottom: 24px;\n  `};\n  ${media.portable`\n    margin-bottom: 16px;\n  `};\n`;\n\nconst StyledDisclaimer = styled(StyledMessage)`\n  margin: 0 auto;\n`;\n\nfunction FileUploadFactory() {\n  /** @augments {Component<FileUploadProps>} */\n  class FileUpload extends Component {\n    state = {\n      dragOver: false,\n      fileLoading: false,\n      files: [],\n      errorFiles: []\n    };\n\n    static getDerivedStateFromProps(props, state) {\n      if (state.fileLoading && props.fileLoading === false && state.files.length) {\n        return {\n          files: [],\n          fileLoading: props.fileLoading\n        };\n      }\n      return {\n        fileLoading: props.fileLoading\n      };\n    }\n\n    frame = createRef();\n\n    _isValidFileType = filename => {\n      const {fileExtensions = []} = this.props;\n      const fileExt = fileExtensions.find(ext => filename.endsWith(ext));\n\n      return Boolean(fileExt);\n    };\n\n    /** @param {FileList} fileList */\n    _handleFileInput = (fileList, event) => {\n      if (event) {\n        event.stopPropagation();\n      }\n\n      const files = [...fileList].filter(Boolean);\n\n      const {disableExtensionFilter = false} = this.props;\n\n      // TODO - move this code out of the component\n      const filesToLoad = [];\n      const errorFiles = [];\n      for (const file of files) {\n        if (disableExtensionFilter || this._isValidFileType(file.name)) {\n          filesToLoad.push(file);\n        } else {\n          errorFiles.push(file.name);\n        }\n      }\n\n      const nextState = {files: filesToLoad, errorFiles, dragOver: false};\n\n      this.setState(nextState, () =>\n        nextState.files.length ? this.props.onFileUpload(nextState.files) : null\n      );\n    };\n\n    _toggleDragState = newState => {\n      this.setState({dragOver: newState});\n    };\n\n    render() {\n      const {dragOver, files, errorFiles} = this.state;\n      const {fileLoading, fileLoadingProgress, theme, intl} = this.props;\n      const {fileExtensions = [], fileFormatNames = []} = this.props;\n      return (\n        <StyledFileUpload className=\"file-uploader\" ref={this.frame}>\n          {FileDrop ? (\n            <FileDrop\n              frame={this.frame.current || document}\n              onDragOver={() => this._toggleDragState(true)}\n              onDragLeave={() => this._toggleDragState(false)}\n              onDrop={this._handleFileInput}\n              className=\"file-uploader__file-drop\"\n            >\n              <StyledUploadMessage className=\"file-upload__message\">\n                <ReactMarkdown\n                  source={`${intl.formatMessage(\n                    {\n                      id: 'fileUploader.configUploadMessage'\n                    },\n                    {\n                      fileFormatNames: fileFormatNames.map(format => `**${format}**`).join(', ')\n                    }\n                  )}(${GUIDES_FILE_FORMAT_DOC}).`}\n                  renderers={{link: LinkRenderer}}\n                />\n              </StyledUploadMessage>\n              <StyledFileDrop dragOver={dragOver}>\n                <StyledFileTypeFow className=\"file-type-row\">\n                  {fileExtensions.map(ext => (\n                    <FileType key={ext} ext={ext} height=\"50px\" fontSize=\"9px\" />\n                  ))}\n                </StyledFileTypeFow>\n                {fileLoading ? (\n                  <FileUploadProgress fileLoadingProgress={fileLoadingProgress} theme={theme} />\n                ) : (\n                  <>\n                    <div\n                      style={{opacity: dragOver ? 0.5 : 1}}\n                      className=\"file-upload-display-message\"\n                    >\n                      <StyledDragNDropIcon>\n                        <DragNDrop height=\"44px\" />\n                      </StyledDragNDropIcon>\n\n                      {errorFiles.length ? (\n                        <WarningMsg>\n                          <FormattedMessage\n                            id={'fileUploader.fileNotSupported'}\n                            values={{errorFiles: errorFiles.join(', ')}}\n                          />\n                        </WarningMsg>\n                      ) : null}\n                    </div>\n                    {!files.length ? (\n                      <StyledDragFileWrapper>\n                        <MsgWrapper>\n                          <FormattedMessage id={'fileUploader.message'} />\n                        </MsgWrapper>\n                        <span className=\"file-upload-or\">\n                          <FormattedMessage id={'fileUploader.or'} />\n                        </span>\n                        <UploadButton onUpload={this._handleFileInput}>\n                          <FormattedMessage id={'fileUploader.browseFiles'} />\n                        </UploadButton>\n                      </StyledDragFileWrapper>\n                    ) : null}\n\n                    <StyledDisclaimer>\n                      <FormattedMessage id={'fileUploader.disclaimer'} />\n                    </StyledDisclaimer>\n                  </>\n                )}\n              </StyledFileDrop>\n            </FileDrop>\n          ) : null}\n\n          <WarningMsg>\n            {isChrome() ? <FormattedMessage id={'fileUploader.chromeMessage'} /> : ''}\n          </WarningMsg>\n        </StyledFileUpload>\n      );\n    }\n  }\n\n  return injectIntl(FileUpload);\n}\n\nexport default FileUploadFactory;\nexport const FileUpload = FileUploadFactory();\n"]}