UNPKG

kepler.gl

Version:

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

244 lines (242 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 _reactMarkdown = _interopRequireDefault(require("react-markdown")); var _localization = require("@kepler.gl/localization"); var _styles = require("@kepler.gl/styles"); 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 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; }, _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(_reactMarkdown["default"], { components: { a: LinkRenderer } }, 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","_reactMarkdown","_localization","_styles","_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","LinkRenderer","props","createElement","href","target","rel","children","StyledUploadMessage","styled","div","_taggedTemplateLiteral2","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","className","ref","frame","FileDrop","current","document","onDragOver","_toggleDragState","onDragLeave","onDrop","_handleFileInput","components","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 ReactMarkdown from 'react-markdown';\n// Breakpoints\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {media} from '@kepler.gl/styles';\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\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                <ReactMarkdown components={{a: LinkRenderer}}>{fileUploadInfoText}</ReactMarkdown>\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":[]}