UNPKG

kepler.gl

Version:

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

71 lines (68 loc) 15.5 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.StyledContainer = void 0; var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireWildcard(require("styled-components")); var _layers = require("@kepler.gl/layers"); 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 spin = (0, _styledComponents.keyframes)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n 0% { transform: rotate(0deg); }\n 100% { transform: rotate(360deg); }\n"]))); var Spinner = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-block;\n width: 14px;\n height: 14px;\n margin-right: 8px;\n border: 2px solid ", ";\n border-top-color: transparent;\n border-radius: 50%;\n animation: ", " 0.8s linear infinite;\n vertical-align: middle;\n"])), function (props) { return props.theme.textColorHl; }, spin); var StyledContainer = exports.StyledContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n left: ", "px;\n bottom: ", "px;\n z-index: 1;\n color: ", ";\n opacity: ", ";\n transition: opacity 0.5s ease-in-out;\n background-color: ", ";\n padding: 8px 12px;\n font-size: 13px;\n font-weight: 500;\n box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);\n backdrop-filter: blur(4px);\n display: flex;\n align-items: center;\n pointer-events: none;\n"])), function (props) { return props.$left; }, function (props) { return props.theme.sidePanel.margin.left; }, function (props) { return props.theme.textColor; }, function (props) { return props.$isVisible ? 1 : 0; }, function (props) { return props.theme.sidePanelBg; }); /** Extra adjustment for the loading indicator when side panel is visible */ var LEFT_POSITION_ADJUSTMENT = 3; var LoadingIndicator = function LoadingIndicator(_ref) { var isVisible = _ref.isVisible, activeSidePanel = _ref.activeSidePanel, sidePanelWidth = _ref.sidePanelWidth, theme = _ref.theme; var left = (activeSidePanel ? (sidePanelWidth || 0) + LEFT_POSITION_ADJUSTMENT : 0) + theme.sidePanel.margin.left; // Helper message to track number of tiles that are being loaded var numRasterTilesInProgress = (0, _layers.getNumRasterTilesBeingLoaded)(); var numVectorTilesInProgress = (0, _layers.getNumVectorTilesBeingLoaded)(); var extraMessage = ''; if (numRasterTilesInProgress > 0 && numVectorTilesInProgress > 0) { // Both types loading: show combined count var totalTiles = numRasterTilesInProgress + numVectorTilesInProgress; extraMessage = "".concat(totalTiles, " tile").concat(totalTiles === 1 ? ' is' : 's are', " being loaded"); } else if (numRasterTilesInProgress > 0) { // Only raster tiles loading extraMessage = "".concat(numRasterTilesInProgress, " raster tile").concat(numRasterTilesInProgress === 1 ? ' is' : 's are', " being loaded"); } else if (numVectorTilesInProgress > 0) { // Only vector tiles loading extraMessage = "".concat(numVectorTilesInProgress, " vector tile").concat(numVectorTilesInProgress === 1 ? ' is' : 's are', " being loaded"); } // Preserve the last message during fade-out var lastMessageRef = (0, _react.useRef)(extraMessage); (0, _react.useEffect)(function () { if (isVisible && extraMessage) { lastMessageRef.current = extraMessage; } }, [isVisible, extraMessage]); var displayMessage = isVisible ? extraMessage : lastMessageRef.current; return /*#__PURE__*/_react["default"].createElement(StyledContainer, { $isVisible: isVisible, $left: left }, /*#__PURE__*/_react["default"].createElement(Spinner, null), /*#__PURE__*/_react["default"].createElement("span", null, "Loading... ".concat(displayMessage))); }; var _default = exports["default"] = (0, _styledComponents.withTheme)(LoadingIndicator); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_layers","_templateObject","_templateObject2","_templateObject3","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","spin","keyframes","_taggedTemplateLiteral2","Spinner","styled","div","props","theme","textColorHl","StyledContainer","exports","$left","sidePanel","margin","left","textColor","$isVisible","sidePanelBg","LEFT_POSITION_ADJUSTMENT","LoadingIndicator","_ref","isVisible","activeSidePanel","sidePanelWidth","numRasterTilesInProgress","getNumRasterTilesBeingLoaded","numVectorTilesInProgress","getNumVectorTilesBeingLoaded","extraMessage","totalTiles","concat","lastMessageRef","useRef","useEffect","current","displayMessage","createElement","_default","withTheme"],"sources":["../src/loading-indicator.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {PropsWithChildren, useRef, useEffect} from 'react';\nimport styled, {withTheme, keyframes} from 'styled-components';\n\nimport {getNumRasterTilesBeingLoaded, getNumVectorTilesBeingLoaded} from '@kepler.gl/layers';\n\ntype StyledContainerProps = {\n  $isVisible?: boolean;\n  $left: number;\n};\n\nconst spin = keyframes`\n  0% { transform: rotate(0deg); }\n  100% { transform: rotate(360deg); }\n`;\n\nconst Spinner = styled.div`\n  display: inline-block;\n  width: 14px;\n  height: 14px;\n  margin-right: 8px;\n  border: 2px solid ${props => props.theme.textColorHl};\n  border-top-color: transparent;\n  border-radius: 50%;\n  animation: ${spin} 0.8s linear infinite;\n  vertical-align: middle;\n`;\n\nexport const StyledContainer = styled.div<StyledContainerProps>`\n  position: absolute;\n  left: ${props => props.$left}px;\n  bottom: ${props => props.theme.sidePanel.margin.left}px;\n  z-index: 1;\n  color: ${props => props.theme.textColor};\n  opacity: ${props => (props.$isVisible ? 1 : 0)};\n  transition: opacity 0.5s ease-in-out;\n  background-color: ${props => props.theme.sidePanelBg};\n  padding: 8px 12px;\n  font-size: 13px;\n  font-weight: 500;\n  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);\n  backdrop-filter: blur(4px);\n  display: flex;\n  align-items: center;\n  pointer-events: none;\n`;\n\ntype LoadingIndicatorProps = {\n  isVisible?: boolean;\n  activeSidePanel?: boolean;\n  sidePanelWidth?: number;\n};\n\n/** Extra adjustment for the loading indicator when side panel is visible */\nconst LEFT_POSITION_ADJUSTMENT = 3;\n\nconst LoadingIndicator: React.FC<LoadingIndicatorProps & {theme: any}> = ({\n  isVisible,\n  activeSidePanel,\n  sidePanelWidth,\n  theme\n}) => {\n  const left =\n    (activeSidePanel ? (sidePanelWidth || 0) + LEFT_POSITION_ADJUSTMENT : 0) +\n    theme.sidePanel.margin.left;\n\n  // Helper message to track number of tiles that are being loaded\n  const numRasterTilesInProgress = getNumRasterTilesBeingLoaded();\n  const numVectorTilesInProgress = getNumVectorTilesBeingLoaded();\n\n  let extraMessage = '';\n  if (numRasterTilesInProgress > 0 && numVectorTilesInProgress > 0) {\n    // Both types loading: show combined count\n    const totalTiles = numRasterTilesInProgress + numVectorTilesInProgress;\n    extraMessage = `${totalTiles} tile${totalTiles === 1 ? ' is' : 's are'} being loaded`;\n  } else if (numRasterTilesInProgress > 0) {\n    // Only raster tiles loading\n    extraMessage = `${numRasterTilesInProgress} raster tile${\n      numRasterTilesInProgress === 1 ? ' is' : 's are'\n    } being loaded`;\n  } else if (numVectorTilesInProgress > 0) {\n    // Only vector tiles loading\n    extraMessage = `${numVectorTilesInProgress} vector tile${\n      numVectorTilesInProgress === 1 ? ' is' : 's are'\n    } being loaded`;\n  }\n\n  // Preserve the last message during fade-out\n  const lastMessageRef = useRef(extraMessage);\n  useEffect(() => {\n    if (isVisible && extraMessage) {\n      lastMessageRef.current = extraMessage;\n    }\n  }, [isVisible, extraMessage]);\n\n  const displayMessage = isVisible ? extraMessage : lastMessageRef.current;\n\n  return (\n    <StyledContainer $isVisible={isVisible} $left={left}>\n      <Spinner />\n      <span>{`Loading... ${displayMessage}`}</span>\n    </StyledContainer>\n  );\n};\n\nexport default withTheme(LoadingIndicator) as React.FC<PropsWithChildren<LoadingIndicatorProps>>;\n"],"mappings":"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","ignoreList":[]}