UNPKG

kepler.gl

Version:

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

242 lines (240 loc) 48.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.WarningMsg = exports.FileUpload = 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 _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); 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 _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("@kepler.gl/utils"); var _constants = require("@kepler.gl/constants"); var _markdownToJsx = _interopRequireDefault(require("markdown-to-jsx")); var _localization = require("@kepler.gl/localization"); var _styles = require("@kepler.gl/styles"); var _linkRenderer = _interopRequireDefault(require("../link-renderer")); var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12, _templateObject13, _templateObject14, _templateObject15, _templateObject16, _templateObject17, _templateObject18; // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project // Breakpoints function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; } function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, 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 o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); } function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } var fileIconColor = '#D3D8E0'; 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; }, _styles.media.portable(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: 12px;\n "])))); var WarningMsg = exports.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; }); 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; }, _styles.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 display: flex;\n justify-content: center;\n\n ", ";\n ", ";\n"])), fileIconColor, _styles.media.portable(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 16px;\n "]))), _styles.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"])), _styles.media.portable(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 16px;\n "]))), _styles.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"])), _styles.media.portable(_templateObject16 || (_templateObject16 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 24px;\n "]))), _styles.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) { 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 = _callSuper(this, FileUpload, [].concat(args)); (0, _defineProperty2["default"])(_this, "state", { dragOver: false, fileLoading: false, files: [], errorFiles: [] }); (0, _defineProperty2["default"])(_this, "frame", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2["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); }); /** @param {FileList} fileList */ (0, _defineProperty2["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"])(_this, "_toggleDragState", function (newState) { _this.setState({ dragOver: newState }); }); return _this; } (0, _inherits2["default"])(FileUpload, _Component); return (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; var fileUploadInfoText = "".concat(intl.formatMessage({ id: 'fileUploader.configUploadMessage' }, { fileFormatNames: fileFormatNames.map(function (format) { return "**".concat(format, "**"); }).join(', ') }), "(").concat(_constants.GUIDES_FILE_FORMAT_DOC, ")."); 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(_markdownToJsx["default"], { options: { overrides: { a: { component: _linkRenderer["default"] } } } }, fileUploadInfoText)), /*#__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 }; } }]); }(_react.Component); return (0, _reactIntl.injectIntl)(FileUpload); } var _default = exports["default"] = FileUploadFactory; var FileUpload = exports.FileUpload = FileUploadFactory(); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_reactIntl","_uploadButton","_icons","_fileUploadProgress","_fileDrop","_utils","_constants","_markdownToJsx","_localization","_styles","_linkRenderer","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","_templateObject7","_templateObject8","_templateObject9","_templateObject10","_templateObject11","_templateObject12","_templateObject13","_templateObject14","_templateObject15","_templateObject16","_templateObject17","_templateObject18","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","_createForOfIteratorHelper","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","_n","F","s","done","value","f","TypeError","o","next","_arrayLikeToArray","toString","slice","constructor","name","from","test","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","apply","Boolean","prototype","valueOf","fileIconColor","StyledUploadMessage","styled","div","_taggedTemplateLiteral2","props","theme","textColorLT","media","portable","WarningMsg","exports","span","errorColor","StyledFileDrop","dragOver","subtextColorLT","linkBtnColor","MsgWrapper","modalTitleColor","StyledDragNDropIcon","palm","StyledFileTypeFow","StyledFileUpload","StyledMessage","StyledDragFileWrapper","StyledDisclaimer","FileUploadFactory","FileUpload","_Component","_this","_classCallCheck2","_len","arguments","args","_key","concat","_defineProperty2","fileLoading","files","errorFiles","createRef","filename","_this$props$fileExten","fileExtensions","fileExt","find","ext","endsWith","fileList","event","stopPropagation","_toConsumableArray2","filter","_this$props$disableEx","disableExtensionFilter","filesToLoad","_iterator","_step","file","_isValidFileType","push","err","nextState","setState","onFileUpload","newState","_inherits2","_createClass2","key","render","_this2","_this$state","state","_this$props","fileLoadingProgress","intl","_this$props2","_this$props2$fileExte","_this$props2$fileForm","fileFormatNames","fileUploadInfoText","formatMessage","id","map","format","join","GUIDES_FILE_FORMAT_DOC","createElement","className","ref","frame","FileDrop","current","document","onDragOver","_toggleDragState","onDragLeave","onDrop","_handleFileInput","options","overrides","component","LinkRenderer","FileType","height","fontSize","Fragment","style","opacity","DragNDrop","FormattedMessage","values","onUpload","isChrome","getDerivedStateFromProps","Component","injectIntl","_default"],"sources":["../../../src/common/file-uploader/file-upload.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {Component, createRef} from 'react';\nimport styled from 'styled-components';\nimport {injectIntl, WrappedComponentProps} from 'react-intl';\nimport UploadButton from './upload-button';\nimport {DragNDrop, FileType} from '../icons';\nimport FileUploadProgress from './file-upload-progress';\nimport FileDrop from './file-drop';\nimport {FileLoading, FileLoadingProgress} from '@kepler.gl/types';\n\nimport {isChrome} from '@kepler.gl/utils';\nimport {GUIDES_FILE_FORMAT_DOC} from '@kepler.gl/constants';\nimport Markdown from 'markdown-to-jsx';\n// Breakpoints\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {media} from '@kepler.gl/styles';\n\nimport LinkRenderer from '../link-renderer';\n\nconst fileIconColor = '#D3D8E0';\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\ninterface StyledFileDropProps {\n  dragOver?: boolean;\n}\n\nconst StyledFileDrop = styled.div<StyledFileDropProps>`\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  display: flex;\n  justify-content: center;\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\ntype FileUploadProps = {\n  onFileUpload: (files: File[]) => void;\n  fileLoading: FileLoading | false;\n  fileLoadingProgress: FileLoadingProgress;\n  theme: object;\n  /** A list of names of supported formats suitable to present to user */\n  fileFormatNames?: string[];\n  /** A list of typically 3 letter extensions (without '.') for file matching */\n  fileExtensions?: string[];\n  /** Set to true if app wants to do its own file filtering */\n  disableExtensionFilter?: boolean;\n} & WrappedComponentProps;\n\nfunction FileUploadFactory() {\n  /** @augments {Component<FileUploadProps>} */\n  class FileUpload extends Component<FileUploadProps> {\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<HTMLDivElement>();\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: FileList, event: any) => {\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: File[] = [];\n      const errorFiles: string[] = [];\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      const fileUploadInfoText = `${intl.formatMessage(\n        {\n          id: 'fileUploader.configUploadMessage'\n        },\n        {\n          fileFormatNames: fileFormatNames.map(format => `**${format}**`).join(', ')\n        }\n      )}(${GUIDES_FILE_FORMAT_DOC}).`;\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                <Markdown\n                  options={{\n                    overrides: {\n                      a: {\n                        component: LinkRenderer\n                      }\n                    }\n                  }}\n                >\n                  {fileUploadInfoText}\n                </Markdown>\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"],"mappings":"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","ignoreList":[]}