UNPKG

kepler.gl

Version:

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

491 lines (380 loc) 39 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.FileUpload = exports["default"] = exports.WarningMsg = void 0; var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _uploadButton = _interopRequireDefault(require("./upload-button")); var _icons = require("../icons"); var _loadingSpinner = _interopRequireDefault(require("../loading-spinner")); 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 _reactIntl = require("react-intl"); function _templateObject19() { var data = (0, _taggedTemplateLiteral2["default"])(["\n margin: 0 auto;\n"]); _templateObject19 = function _templateObject19() { return data; }; return data; } function _templateObject18() { var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 16px;\n "]); _templateObject18 = function _templateObject18() { return data; }; return data; } function _templateObject17() { var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 24px;\n "]); _templateObject17 = function _templateObject17() { return data; }; return data; } function _templateObject16() { var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 32px;\n ", ";\n ", "\n"]); _templateObject16 = function _templateObject16() { return data; }; return data; } function _templateObject15() { var data = (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"]); _templateObject15 = function _templateObject15() { return data; }; return data; } function _templateObject14() { var data = (0, _taggedTemplateLiteral2["default"])(["\n .file-drop {\n position: relative;\n }\n"]); _templateObject14 = function _templateObject14() { return data; }; return data; } function _templateObject13() { var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 8px;\n "]); _templateObject13 = function _templateObject13() { return data; }; return data; } function _templateObject12() { var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 16px;\n "]); _templateObject12 = function _templateObject12() { return data; }; return data; } function _templateObject11() { var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 24px;\n ", ";\n ", ";\n"]); _templateObject11 = function _templateObject11() { return data; }; return data; } function _templateObject10() { var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 8px;\n "]); _templateObject10 = function _templateObject10() { return data; }; return data; } function _templateObject9() { var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 16px;\n "]); _templateObject9 = function _templateObject9() { return data; }; return data; } function _templateObject8() { var data = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n margin-bottom: 48px;\n\n ", ";\n ", ";\n"]); _templateObject8 = function _templateObject8() { return data; }; return data; } function _templateObject7() { var data = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-size: 20px;\n height: 36px;\n"]); _templateObject7 = function _templateObject7() { return data; }; return data; } function _templateObject6() { var data = (0, _taggedTemplateLiteral2["default"])(["\n padding: 16px 4px 0;\n "]); _templateObject6 = function _templateObject6() { return data; }; return data; } function _templateObject5() { var data = (0, _taggedTemplateLiteral2["default"])(["\n background-color: white;\n border-radius: 4px;\n border-style: dashed;\n border-width: 1px;\n border-color: ", ";\n text-align: center;\n width: 100%;\n padding: 48px 8px 0;\n\n .file-upload-or {\n color: ", ";\n padding-right: 4px;\n }\n\n ", ";\n"]); _templateObject5 = function _templateObject5() { return data; }; return data; } function _templateObject4() { var data = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-block;\n color: ", ";\n font-weight: 500;\n margin-right: 8px;\n"]); _templateObject4 = function _templateObject4() { return data; }; return data; } function _templateObject3() { var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-top: 10px;\n color: ", ";\n font-weight: 500;\n"]); _templateObject3 = function _templateObject3() { return data; }; return data; } function _templateObject2() { var data = (0, _taggedTemplateLiteral2["default"])(["\n font-size: 12px;\n "]); _templateObject2 = function _templateObject2() { return data; }; return data; } function _templateObject() { var data = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-size: 14px;\n margin-bottom: 12px;\n\n ", "\n"]); _templateObject = function _templateObject() { return data; }; return data; } // File.type is not reliable if the OS does not have a // registered mapping for the extension. // NOTE: Shapefiles must be in a compressed format since // it requires multiple files to be present. var defaultValidFileExt = ['csv', 'json', 'geojson']; var fileIconColor = '#D3D8E0'; var LinkRenderer = function LinkRenderer(props) { return _react["default"].createElement("a", { href: props.href, target: "_blank", rel: "noopener noreferrer" }, props.children); }; var StyledUploadMessage = _styledComponents["default"].div(_templateObject(), function (props) { return props.theme.textColorLT; }, _mediaBreakpoints.media.portable(_templateObject2())); var WarningMsg = _styledComponents["default"].span(_templateObject3(), function (props) { return props.theme.errorColor; }); exports.WarningMsg = WarningMsg; var PositiveMsg = _styledComponents["default"].span(_templateObject4(), function (props) { return props.theme.primaryBtnActBgd; }); var StyledFileDrop = _styledComponents["default"].div(_templateObject5(), function (props) { return props.theme.subtextColorLT; }, function (props) { return props.theme.linkBtnColor; }, _mediaBreakpoints.media.portable(_templateObject6())); var MsgWrapper = _styledComponents["default"].div(_templateObject7(), function (props) { return props.theme.modalTitleColor; }); var StyledDragNDropIcon = _styledComponents["default"].div(_templateObject8(), fileIconColor, _mediaBreakpoints.media.portable(_templateObject9()), _mediaBreakpoints.media.palm(_templateObject10())); var StyledFileTypeFow = _styledComponents["default"].div(_templateObject11(), _mediaBreakpoints.media.portable(_templateObject12()), _mediaBreakpoints.media.palm(_templateObject13())); var StyledFileUpload = _styledComponents["default"].div(_templateObject14()); var StyledMessage = _styledComponents["default"].div(_templateObject15()); var StyledDragFileWrapper = _styledComponents["default"].div(_templateObject16(), _mediaBreakpoints.media.portable(_templateObject17()), _mediaBreakpoints.media.portable(_templateObject18())); var StyledDisclaimer = (0, _styledComponents["default"])(StyledMessage)(_templateObject19()); function FileUploadFactory() { var FileUpload = /*#__PURE__*/ function (_Component) { (0, _inherits2["default"])(FileUpload, _Component); function FileUpload() { var _getPrototypeOf2; 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 = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(FileUpload)).call.apply(_getPrototypeOf2, [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", (0, _react.createRef)()); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_isValidFileType", function (filename) { var validFileExt = _this.props.validFileExt; var fileExt = validFileExt.find(function (ext) { return filename.endsWith(ext); }); return Boolean(fileExt); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_handleFileInput", function (files, e) { if (e) { e.stopPropagation(); } var nextState = { files: [], errorFiles: [], dragOver: false }; for (var i = 0; i < files.length; i++) { var file = files[i]; if (file && _this._isValidFileType(file.name)) { nextState.files.push(file); } else { nextState.errorFiles.push(file.name); } } _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: "_renderMessage", value: function _renderMessage() { var _this$state = this.state, errorFiles = _this$state.errorFiles, files = _this$state.files; if (errorFiles.length) { return _react["default"].createElement(WarningMsg, null, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'fileUploader.filenNotSupported', values: { errorFiles: errorFiles.join(', ') } })); } else if (this.props.fileLoading && files.length) { return _react["default"].createElement(StyledMessage, { className: "file-uploader__message" }, _react["default"].createElement("div", { className: "loading-action" }, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'fileUploader.uploading' })), _react["default"].createElement("div", null, files.map(function (f, i) { return _react["default"].createElement(PositiveMsg, { key: i }, f.name); }), "..."), _react["default"].createElement("div", { className: "loading-spinner" }, _react["default"].createElement(_loadingSpinner["default"], { size: 20 }))); } return null; } }, { key: "render", value: function render() { var _this2 = this; var _this$state2 = this.state, dragOver = _this$state2.dragOver, files = _this$state2.files; var _this$props = this.props, validFileExt = _this$props.validFileExt, intl = _this$props.intl; return _react["default"].createElement(StyledFileUpload, { className: "file-uploader", ref: this.frame }, _fileDrop["default"] ? _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" }, _react["default"].createElement(StyledUploadMessage, { className: "file-upload__message" }, _react["default"].createElement(_reactMarkdown["default"], { source: "".concat(intl.formatMessage({ id: 'fileUploader.configUploadMessage' }), "(").concat(_userGuides.GUIDES_FILE_FORMAT, ")."), renderers: { link: LinkRenderer } })), _react["default"].createElement(StyledFileDrop, { dragOver: dragOver }, _react["default"].createElement("div", { style: { opacity: dragOver ? 0.5 : 1 } }, _react["default"].createElement(StyledDragNDropIcon, null, _react["default"].createElement(StyledFileTypeFow, { className: "file-type-row" }, validFileExt.map(function (ext) { return _react["default"].createElement(_icons.FileType, { key: ext, ext: ext, height: "50px", fontSize: "9px" }); })), _react["default"].createElement(_icons.DragNDrop, { height: "44px" })), _react["default"].createElement("div", null, this._renderMessage())), !files.length ? _react["default"].createElement(StyledDragFileWrapper, null, _react["default"].createElement(MsgWrapper, null, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'fileUploader.message' })), _react["default"].createElement("span", { className: "file-upload-or" }, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'fileUploader.or' })), _react["default"].createElement(_uploadButton["default"], { onUpload: this._handleFileInput }, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'fileUploader.browseFiles' }))) : null, _react["default"].createElement(StyledDisclaimer, null, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'fileUploader.disclaimer' })))) : null, _react["default"].createElement(WarningMsg, null, (0, _utils.isChrome)() ? _react["default"].createElement(_reactIntl.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); (0, _defineProperty2["default"])(FileUpload, "propTypes", { onFileUpload: _propTypes["default"].func.isRequired, validFileExt: _propTypes["default"].arrayOf(_propTypes["default"].string), fileLoading: _propTypes["default"].bool }); (0, _defineProperty2["default"])(FileUpload, "defaultProps", { validFileExt: defaultValidFileExt }); 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":["defaultValidFileExt","fileIconColor","LinkRenderer","props","href","children","StyledUploadMessage","styled","div","theme","textColorLT","media","portable","WarningMsg","span","errorColor","PositiveMsg","primaryBtnActBgd","StyledFileDrop","subtextColorLT","linkBtnColor","MsgWrapper","modalTitleColor","StyledDragNDropIcon","palm","StyledFileTypeFow","StyledFileUpload","StyledMessage","StyledDragFileWrapper","StyledDisclaimer","FileUploadFactory","FileUpload","dragOver","fileLoading","files","errorFiles","filename","validFileExt","fileExt","find","ext","endsWith","Boolean","e","stopPropagation","nextState","i","length","file","_isValidFileType","name","push","setState","onFileUpload","newState","state","join","map","f","intl","frame","FileDrop","current","document","_toggleDragState","_handleFileInput","formatMessage","id","GUIDES_FILE_FORMAT","link","opacity","_renderMessage","Component","PropTypes","func","isRequired","arrayOf","string","bool"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 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 PropTypes from 'prop-types';\nimport styled from 'styled-components';\n\nimport UploadButton from './upload-button';\nimport {DragNDrop, FileType} from 'components/common/icons';\nimport LoadingSpinner from 'components/common/loading-spinner';\nimport FileDrop from './file-drop';\n\nimport {isChrome} from 'utils/utils';\nimport {GUIDES_FILE_FORMAT} from 'constants/user-guides';\nimport ReactMarkdown from 'react-markdown';\n// Breakpoints\nimport {media} from 'styles/media-breakpoints';\nimport {FormattedMessage, injectIntl} from 'react-intl';\n\n// File.type is not reliable if the OS does not have a\n// registered mapping for the extension.\n// NOTE: Shapefiles must be in a compressed format since\n// it requires multiple files to be present.\nconst defaultValidFileExt = ['csv', 'json', 'geojson'];\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 PositiveMsg = styled.span`\n  display: inline-block;\n  color: ${props => props.theme.primaryBtnActBgd};\n  font-weight: 500;\n  margin-right: 8px;\n`;\n\nconst StyledFileDrop = styled.div`\n  background-color: white;\n  border-radius: 4px;\n  border-style: dashed;\n  border-width: 1px;\n  border-color: ${props => props.theme.subtextColorLT};\n  text-align: center;\n  width: 100%;\n  padding: 48px 8px 0;\n\n  .file-upload-or {\n    color: ${props => props.theme.linkBtnColor};\n    padding-right: 4px;\n  }\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  class FileUpload extends Component {\n    static propTypes = {\n      onFileUpload: PropTypes.func.isRequired,\n      validFileExt: PropTypes.arrayOf(PropTypes.string),\n      fileLoading: PropTypes.bool\n    };\n\n    static defaultProps = {\n      validFileExt: defaultValidFileExt\n    };\n\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 {validFileExt} = this.props;\n      const fileExt = validFileExt.find(ext => filename.endsWith(ext));\n\n      return Boolean(fileExt);\n    };\n\n    _handleFileInput = (files, e) => {\n      if (e) {\n        e.stopPropagation();\n      }\n\n      const nextState = {files: [], errorFiles: [], dragOver: false};\n      for (let i = 0; i < files.length; i++) {\n        const file = files[i];\n\n        if (file && this._isValidFileType(file.name)) {\n          nextState.files.push(file);\n        } else {\n          nextState.errorFiles.push(file.name);\n        }\n      }\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    _renderMessage() {\n      const {errorFiles, files} = this.state;\n      if (errorFiles.length) {\n        return (\n          <WarningMsg>\n            <FormattedMessage\n              id={'fileUploader.filenNotSupported'}\n              values={{errorFiles: errorFiles.join(', ')}}\n            />\n          </WarningMsg>\n        );\n      } else if (this.props.fileLoading && files.length) {\n        return (\n          <StyledMessage className=\"file-uploader__message\">\n            <div className=\"loading-action\">\n              <FormattedMessage id={'fileUploader.uploading'} />\n            </div>\n            <div>\n              {files.map((f, i) => (\n                <PositiveMsg key={i}>{f.name}</PositiveMsg>\n              ))}\n              ...\n            </div>\n            <div className=\"loading-spinner\">\n              <LoadingSpinner size={20} />\n            </div>\n          </StyledMessage>\n        );\n      }\n\n      return null;\n    }\n\n    render() {\n      const {dragOver, files} = this.state;\n      const {validFileExt, intl} = this.props;\n\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                    id: 'fileUploader.configUploadMessage'\n                  })}(${GUIDES_FILE_FORMAT}).`}\n                  renderers={{link: LinkRenderer}}\n                />\n              </StyledUploadMessage>\n              <StyledFileDrop dragOver={dragOver}>\n                <div style={{opacity: dragOver ? 0.5 : 1}}>\n                  <StyledDragNDropIcon>\n                    <StyledFileTypeFow className=\"file-type-row\">\n                      {validFileExt.map(ext => (\n                        <FileType key={ext} ext={ext} height=\"50px\" fontSize=\"9px\" />\n                      ))}\n                    </StyledFileTypeFow>\n                    <DragNDrop height=\"44px\" />\n                  </StyledDragNDropIcon>\n                  <div>{this._renderMessage()}</div>\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                <StyledDisclaimer>\n                  <FormattedMessage id={'fileUploader.disclaimer'} />\n                </StyledDisclaimer>\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"]}