UNPKG

kepler.gl

Version:

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

85 lines (84 loc) 15 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"] = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireDefault(require("react")); var _styledComponents = _interopRequireWildcard(require("styled-components")); var _classnames = _interopRequireDefault(require("classnames")); var _progressBar = _interopRequireDefault(require("../progress-bar")); var _styledComponents2 = require("../styled-components"); var _utils = require("@kepler.gl/utils"); var _templateObject, _templateObject2, _templateObject3; // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project 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; } var StyledFileProgress = _styledComponents["default"].div.attrs(function (props) { return { className: (0, _classnames["default"])('file-upload__progress', props.className) }; })(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-size: 12px;\n margin-top: 12px;\n border-image: initial;\n padding: 8px 12px;\n\n .top-row {\n display: flex;\n justify-content: space-between;\n }\n\n .file-name {\n font-weight: 500;\n }\n .middle-row {\n margin-top: 6px;\n }\n .bottom-row {\n margin-top: 6px;\n text-align: start;\n }\n"])), function (props) { return props.theme.textColorLT; }); var StyledProgressWrapper = _styledComponents["default"].div.attrs({ className: 'file-upload__progress__wrapper' })(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n width: 400px;\n"]))); var StyledContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n display: flex;\n justify-content: center;\n"]))); var formatPercent = function formatPercent(percent) { return "".concat(Math.floor(percent * 100), "%"); }; /** * @param {object} params * @param {string} params.message * @param {string} params.fileName * @param {number} params.percent * @param {any} params.error * @param {object} params.theme */ var UploadProgress = function UploadProgress(_ref) { var message = _ref.message, fileName = _ref.fileName, percent = _ref.percent, error = _ref.error, theme = _ref.theme; var percentStr = formatPercent(percent); var barColor = error ? theme.errorColor : theme.activeColorLT; return /*#__PURE__*/_react["default"].createElement(StyledFileProgress, { className: "file-upload-progress__message" }, /*#__PURE__*/_react["default"].createElement("div", { className: "top-row" }, /*#__PURE__*/_react["default"].createElement(_styledComponents2.TruncatedTitleText, { className: "file-name", title: fileName }, fileName), /*#__PURE__*/_react["default"].createElement("div", { className: "percent" }, percentStr)), /*#__PURE__*/_react["default"].createElement("div", { className: "middle-row" }, /*#__PURE__*/_react["default"].createElement(_progressBar["default"], { percent: percentStr, barColor: barColor, isLoading: true, theme: theme })), /*#__PURE__*/_react["default"].createElement("div", { className: "bottom-row", style: { color: error ? theme.errorColor : theme.textColorLT } }, error ? (0, _utils.getError)(error) : message)); }; var FileUploadProgress = function FileUploadProgress(_ref2) { var fileLoadingProgress = _ref2.fileLoadingProgress, theme = _ref2.theme; return /*#__PURE__*/_react["default"].createElement(StyledContainer, null, /*#__PURE__*/_react["default"].createElement(StyledProgressWrapper, null, Object.values(fileLoadingProgress).map(function (item) { return /*#__PURE__*/_react["default"].createElement(UploadProgress, (0, _extends2["default"])({}, item, { key: item.fileName, theme: theme })); }))); }; var _default = exports["default"] = (0, _styledComponents.withTheme)(FileUploadProgress); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_styledComponents","_interopRequireWildcard","_classnames","_progressBar","_styledComponents2","_utils","_templateObject","_templateObject2","_templateObject3","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledFileProgress","styled","div","attrs","props","className","classnames","_taggedTemplateLiteral2","theme","textColorLT","StyledProgressWrapper","StyledContainer","formatPercent","percent","concat","Math","floor","UploadProgress","_ref","message","fileName","error","percentStr","barColor","errorColor","activeColorLT","createElement","TruncatedTitleText","title","isLoading","style","color","getError","FileUploadProgress","_ref2","fileLoadingProgress","values","map","item","_extends2","key","_default","exports","withTheme"],"sources":["../../../src/common/file-uploader/file-upload-progress.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React from 'react';\nimport styled, {withTheme} from 'styled-components';\nimport classnames from 'classnames';\nimport ProgressBar from '../progress-bar';\nimport {TruncatedTitleText} from '../styled-components';\nimport {getError} from '@kepler.gl/utils';\nimport {FileLoadingProgress} from '@kepler.gl/types';\n\nconst StyledFileProgress = styled.div.attrs(props => ({\n  className: classnames('file-upload__progress', props.className)\n}))`\n  color: ${props => props.theme.textColorLT};\n  font-size: 12px;\n  margin-top: 12px;\n  border-image: initial;\n  padding: 8px 12px;\n\n  .top-row {\n    display: flex;\n    justify-content: space-between;\n  }\n\n  .file-name {\n    font-weight: 500;\n  }\n  .middle-row {\n    margin-top: 6px;\n  }\n  .bottom-row {\n    margin-top: 6px;\n    text-align: start;\n  }\n`;\n\nconst StyledProgressWrapper = styled.div.attrs({\n  className: 'file-upload__progress__wrapper'\n})`\n  width: 400px;\n`;\n\nconst StyledContainer = styled.div`\n  width: 100%;\n  display: flex;\n  justify-content: center;\n`;\n\nconst formatPercent = percent => `${Math.floor(percent * 100)}%`;\n\ninterface UploadProgressProps {\n  message?: string;\n  fileName?: string;\n  percent: number;\n  error?: any;\n  theme: any;\n}\n\n/**\n * @param {object} params\n * @param {string} params.message\n * @param {string} params.fileName\n * @param {number} params.percent\n * @param {any} params.error\n * @param {object} params.theme\n */\nconst UploadProgress = ({message, fileName, percent, error, theme}: UploadProgressProps) => {\n  const percentStr = formatPercent(percent);\n  const barColor = error ? theme.errorColor : theme.activeColorLT;\n\n  return (\n    <StyledFileProgress className=\"file-upload-progress__message\">\n      <div className=\"top-row\">\n        <TruncatedTitleText className=\"file-name\" title={fileName}>\n          {fileName}\n        </TruncatedTitleText>\n        <div className=\"percent\">{percentStr}</div>\n      </div>\n      <div className=\"middle-row\">\n        <ProgressBar percent={percentStr} barColor={barColor} isLoading theme={theme} />\n      </div>\n      <div className=\"bottom-row\" style={{color: error ? theme.errorColor : theme.textColorLT}}>\n        {error ? getError(error) : message}\n      </div>\n    </StyledFileProgress>\n  );\n};\n\ntype FileUploadProgressProps = {\n  fileLoadingProgress: FileLoadingProgress;\n  theme: any;\n};\n\nconst FileUploadProgress: React.FC<FileUploadProgressProps> = ({\n  fileLoadingProgress,\n  theme\n}: FileUploadProgressProps) => (\n  <StyledContainer>\n    <StyledProgressWrapper>\n      {Object.values(fileLoadingProgress).map(item => (\n        <UploadProgress {...item} key={item.fileName} theme={theme} />\n      ))}\n    </StyledProgressWrapper>\n  </StyledContainer>\n);\n\nexport default withTheme(FileUploadProgress) as React.FC<FileUploadProgressProps>;\n"],"mappings":"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","ignoreList":[]}