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
JavaScript
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"]}
;