kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
111 lines (93 loc) • 16.6 kB
JavaScript
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 _defaultSettings = require("../constants/default-settings");
function _templateObject() {
var data = (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: 0;\n z-index: 1;\n"]);
_templateObject = function _templateObject() {
return data;
};
return data;
}
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(), 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 === _defaultSettings.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 _react["default"].createElement(BottomWidgetContainer, {
width: Math.min(maxWidth, enlargedFilterWidth),
className: "bottom-widget--container"
}, animatedLayer.length && readToAnimation ? _react["default"].createElement(AnimationControl, {
animationConfig: animationConfig,
updateAnimationTime: visStateActions.updateAnimationTime,
updateAnimationSpeed: visStateActions.updateLayerAnimationSpeed
}) : null, enlargedFilterIdx > -1 && Object.keys(datasets).length > 0 ? _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","Object","keys","setFilterPlot","setFilter","toggleFilterAnimation","updateFilterAnimationSpeed","enlargeFilter"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 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 'constants/default-settings';\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: 0;\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 ? containerW - sidePanelWidth : 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 => l.config.animation && l.config.animation.enabled && l.config.isVisible\n    );\n\n    const readToAnimation = 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 && Object.keys(datasets).length > 0 ? (\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"]}
;