UNPKG

kepler.gl.geoiq

Version:

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

104 lines (88 loc) 16.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = BottomWidgetFactory; var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireDefault(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _propTypes = _interopRequireDefault(require("prop-types")); var _timeWidget = _interopRequireDefault(require("./filters/time-widget")); var _animationControl = _interopRequireDefault(require("./common/animation-control/animation-control")); var _filterUtils = require("../utils/filter-utils"); var _templateObject; var propTypes = { filters: _propTypes["default"].arrayOf(_propTypes["default"].object), datasets: _propTypes["default"].object, uiState: _propTypes["default"].object, layers: _propTypes["default"].arrayOf(_propTypes["default"].object), animationConfig: _propTypes["default"].object, visStateActions: _propTypes["default"].object, sidePanelWidth: _propTypes["default"].number, containerW: _propTypes["default"].number }; var maxWidth = 1080; BottomWidgetFactory.deps = [_timeWidget["default"], _animationControl["default"]]; var BottomWidgetContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n display: flex;\n flex-direction: column;\n padding-top: ", "px;\n padding-right: ", "px;\n padding-bottom: ", "px;\n padding-left: ", "px;\n width: ", "px;\n bottom: 0;\n right: 150px;\n z-index: 1;\n"])), function (props) { return props.theme.sidePanel.margin.top; }, function (props) { return props.theme.sidePanel.margin.right; }, function (props) { return props.theme.sidePanel.margin.bottom; }, function (props) { return props.theme.sidePanel.margin.left; }, function (props) { return props.width; }); function BottomWidgetFactory(TimeWidget, AnimationControl) { var BottomWidget = function BottomWidget(props) { var datasets = props.datasets, filters = props.filters, animationConfig = props.animationConfig, visStateActions = props.visStateActions, containerW = props.containerW, uiState = props.uiState, sidePanelWidth = props.sidePanelWidth, layers = props.layers; var activeSidePanel = uiState.activeSidePanel, readOnly = uiState.readOnly; var isOpen = Boolean(activeSidePanel); var enlargedFilterIdx = filters.findIndex(function (f) { return f.enlarged && f.type === _filterUtils.FILTER_TYPES.timeRange; }); var isAnyFilterAnimating = filters.some(function (f) { return f.isAnimating; }); var enlargedFilterWidth = isOpen ? containerW - sidePanelWidth : containerW; // show playback control if layers contain trip layer & at least one trip layer is visible var animatedLayer = layers.filter(function (l) { return l.config.animation && l.config.animation.enabled && l.config.isVisible; }); var readToAnimation = Array.isArray(animationConfig.domain) && animationConfig.currentTime; // if animation control is showing, hide time display in time slider var showFloatingTimeDisplay = !animatedLayer.length; return (/*#__PURE__*/_react["default"].createElement(BottomWidgetContainer, { width: Math.min(maxWidth, enlargedFilterWidth), className: "bottom-widget--container" }, animatedLayer.length && readToAnimation ? /*#__PURE__*/_react["default"].createElement(AnimationControl, { animationConfig: animationConfig, updateAnimationTime: visStateActions.updateAnimationTime, updateAnimationSpeed: visStateActions.updateLayerAnimationSpeed }) : null, enlargedFilterIdx > -1 ? /*#__PURE__*/_react["default"].createElement(TimeWidget, { filter: filters[enlargedFilterIdx], index: enlargedFilterIdx, isAnyFilterAnimating: isAnyFilterAnimating, datasets: datasets, readOnly: readOnly, showTimeDisplay: showFloatingTimeDisplay, setFilterPlot: visStateActions.setFilterPlot, setFilter: visStateActions.setFilter, toggleAnimation: visStateActions.toggleFilterAnimation, updateAnimationSpeed: visStateActions.updateFilterAnimationSpeed, enlargeFilter: visStateActions.enlargeFilter }) : null) ); }; BottomWidget.propTypes = propTypes; return BottomWidget; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/bottom-widget.js"],"names":["propTypes","filters","PropTypes","arrayOf","object","datasets","uiState","layers","animationConfig","visStateActions","sidePanelWidth","number","containerW","maxWidth","BottomWidgetFactory","deps","TimeWidgetFactory","AnimationControlFactory","BottomWidgetContainer","styled","div","props","theme","sidePanel","margin","top","right","bottom","left","width","TimeWidget","AnimationControl","BottomWidget","activeSidePanel","readOnly","isOpen","Boolean","enlargedFilterIdx","findIndex","f","enlarged","type","FILTER_TYPES","timeRange","isAnyFilterAnimating","some","isAnimating","enlargedFilterWidth","animatedLayer","filter","l","config","animation","enabled","isVisible","readToAnimation","Array","isArray","domain","currentTime","showFloatingTimeDisplay","length","Math","min","updateAnimationTime","updateLayerAnimationSpeed","setFilterPlot","setFilter","toggleFilterAnimation","updateFilterAnimationSpeed","enlargeFilter"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 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 from 'react';\nimport styled from 'styled-components';\nimport PropTypes from 'prop-types';\nimport TimeWidgetFactory from './filters/time-widget';\nimport AnimationControlFactory from './common/animation-control/animation-control';\nimport {FILTER_TYPES} from 'utils/filter-utils';\n\nconst propTypes = {\n  filters: PropTypes.arrayOf(PropTypes.object),\n  datasets: PropTypes.object,\n  uiState: PropTypes.object,\n  layers: PropTypes.arrayOf(PropTypes.object),\n  animationConfig: PropTypes.object,\n  visStateActions: PropTypes.object,\n  sidePanelWidth: PropTypes.number,\n  containerW: PropTypes.number\n};\n\nconst maxWidth = 1080;\n\nBottomWidgetFactory.deps = [TimeWidgetFactory, AnimationControlFactory];\n\nconst BottomWidgetContainer = styled.div`\n  position: absolute;\n  display: flex;\n  flex-direction: column;\n  padding-top: ${props => props.theme.sidePanel.margin.top}px;\n  padding-right: ${props => props.theme.sidePanel.margin.right}px;\n  padding-bottom: ${props => props.theme.sidePanel.margin.bottom}px;\n  padding-left: ${props => props.theme.sidePanel.margin.left}px;\n  width: ${props => props.width}px;\n  bottom: 0;\n  right: 150px;\n  z-index: 1;\n`;\n\nexport default function BottomWidgetFactory(TimeWidget, AnimationControl) {\n  const BottomWidget = props => {\n    const {\n      datasets,\n      filters,\n      animationConfig,\n      visStateActions,\n      containerW,\n      uiState,\n      sidePanelWidth,\n      layers\n    } = props;\n\n    const {activeSidePanel, readOnly} = uiState;\n    const isOpen = Boolean(activeSidePanel);\n\n    const enlargedFilterIdx = filters.findIndex(\n      f => f.enlarged && f.type === FILTER_TYPES.timeRange\n    );\n    const isAnyFilterAnimating = filters.some(f => f.isAnimating);\n    const enlargedFilterWidth = isOpen\n      ? containerW - sidePanelWidth\n      : containerW;\n\n    // show playback control if layers contain trip layer & at least one trip layer is visible\n    const animatedLayer = layers.filter(\n      l =>\n        l.config.animation && l.config.animation.enabled && l.config.isVisible\n    );\n\n    const readToAnimation =\n      Array.isArray(animationConfig.domain) && animationConfig.currentTime;\n    // if animation control is showing, hide time display in time slider\n    const showFloatingTimeDisplay = !animatedLayer.length;\n    return (\n      <BottomWidgetContainer\n        width={Math.min(maxWidth, enlargedFilterWidth)}\n        className=\"bottom-widget--container\"\n      >\n        {animatedLayer.length && readToAnimation ? (\n          <AnimationControl\n            animationConfig={animationConfig}\n            updateAnimationTime={visStateActions.updateAnimationTime}\n            updateAnimationSpeed={visStateActions.updateLayerAnimationSpeed}\n          />\n        ) : null}\n        {enlargedFilterIdx > -1 ? (\n          <TimeWidget\n            filter={filters[enlargedFilterIdx]}\n            index={enlargedFilterIdx}\n            isAnyFilterAnimating={isAnyFilterAnimating}\n            datasets={datasets}\n            readOnly={readOnly}\n            showTimeDisplay={showFloatingTimeDisplay}\n            setFilterPlot={visStateActions.setFilterPlot}\n            setFilter={visStateActions.setFilter}\n            toggleAnimation={visStateActions.toggleFilterAnimation}\n            updateAnimationSpeed={visStateActions.updateFilterAnimationSpeed}\n            enlargeFilter={visStateActions.enlargeFilter}\n          />\n        ) : null}\n      </BottomWidgetContainer>\n    );\n  };\n\n  BottomWidget.propTypes = propTypes;\n\n  return BottomWidget;\n}\n"]}