UNPKG

kepler.gl

Version:

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

157 lines (125 loc) 24.6 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = FloatingTimeDisplayFactory; var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _icons = require("../icons"); var _defaultSettings = require("../../../constants/default-settings"); var _styledComponents2 = require("../styled-components"); var _dataUtils = require("../../../utils/data-utils"); var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8; var StyledTimeDisplayWrapper = _styledComponents["default"].div.attrs({ className: 'floating-time-display' })(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n bottom: ", ";\n display: flex;\n position: absolute;\n width: 100%;\n margin-left: -", "px;\n justify-content: center;\n pointer-events: none; /* prevent padding from blocking input */\n & > * {\n /* all children should allow input */\n pointer-events: all;\n }\n"])), function (props) { return "calc(100% + ".concat(props.theme.bottomPanelGap, "px)"); }, function (props) { return props.theme.bottomInnerPdSide; }); var StyledTimeDisplay = _styledComponents["default"].div.attrs({ className: 'floating-time-display__inner' })(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n border-radius: ", "px;\n color: ", ";\n display: flex;\n height: ", "px;\n justify-content: center;\n min-width: ", "px;\n opacity: ", ";\n padding: ", ";\n"])), function (props) { return props.theme.panelBackground; }, function (props) { return props.theme.timeDisplayBorderRadius; }, function (props) { return props.theme.titleTextColor; }, function (props) { return props.theme.timeDisplayHeight; }, function (props) { return props.theme.timeDisplayMinWidth; }, function (props) { return props.theme.timeDisplayOpacity; }, function (props) { return props.theme.timeDisplayPadding; }); var StyledTimeDisplayGroups = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n align-items: center;\n display: flex;\n flex-direction: row;\n"]))); var StyledTimeDisplayRows = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n justify-content: center;\n"]))); var StyledTimeDisplayTop = _styledComponents["default"].div.attrs({ className: 'animation-control__time-display__top' })(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n display: flex;\n font-size: 12px;\n font-weight: 500;\n justify-content: center;\n"])), function (props) { return props.theme.textColor; }); var StyledTimeDisplayBottom = _styledComponents["default"].div.attrs({ className: 'animation-control__time-display__bottom' })(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n display: flex;\n font-size: 14px;\n font-weight: 500;\n justify-content: center;\n"])), function (props) { return props.theme.titleTextColor; }); var StyledTimeValueGroup = _styledComponents["default"].div.attrs({ className: 'animation-control__time-value-group' })(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n"]))); var StyledHorizontalBar = _styledComponents["default"].div.attrs({ className: 'animation-control__horizontal-bar' })(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n margin: 0 12px;\n"]))); var TimeDivider = function TimeDivider() { return /*#__PURE__*/_react["default"].createElement(StyledHorizontalBar, null, /*#__PURE__*/_react["default"].createElement(_icons.Minus, { height: "12px" })); }; var TimeDisplayRow = function TimeDisplayRow(_ref) { var _ref$timeValues = _ref.timeValues, timeValues = _ref$timeValues === void 0 ? [] : _ref$timeValues; return /*#__PURE__*/_react["default"].createElement(_styledComponents2.CenterFlexbox, null, /*#__PURE__*/_react["default"].createElement("div", { className: "time-value" }, timeValues[0]), timeValues[1] ? /*#__PURE__*/_react["default"].createElement(TimeDivider, null) : null, timeValues[1] ? /*#__PURE__*/_react["default"].createElement("div", { className: "time-value" }, timeValues[1]) : null); }; function FloatingTimeDisplayFactory() { var FloatingTimeDisplay = function FloatingTimeDisplay(_ref2) { var currentTime = _ref2.currentTime, defaultTimeFormat = _ref2.defaultTimeFormat, timeFormat = _ref2.timeFormat, timezone = _ref2.timezone; var _useMemo = (0, _react.useMemo)(function () { var groupTime = Array.isArray(currentTime) ? currentTime : [currentTime]; var hasUserFormat = typeof timeFormat === 'string'; var currentFormat = (hasUserFormat ? timeFormat : defaultTimeFormat) || _defaultSettings.DEFAULT_TIME_FORMAT; var dateFunc = (0, _dataUtils.datetimeFormatter)(timezone); if (hasUserFormat) { // dont split time if user defined it return { displayDate: groupTime.map(dateFunc(currentFormat)), displayTime: [] }; } return groupTime.reduce(function (accu, curr) { var _currentFormat$split = currentFormat.split(' '), _currentFormat$split2 = (0, _slicedToArray2["default"])(_currentFormat$split, 2), dateFormat = _currentFormat$split2[0], datetimeFormat = _currentFormat$split2[1]; var dateString = dateFunc(dateFormat)(curr); var timeString = datetimeFormat ? dateFunc(datetimeFormat)(curr) : null; if (!accu.displayDate.includes(dateString)) { accu.displayDate.push(dateString); } if (timeString) { accu.displayTime.push(timeString); } return accu; }, { displayDate: [], displayTime: [] }); }, [currentTime, timeFormat, defaultTimeFormat, timezone]), displayDate = _useMemo.displayDate, displayTime = _useMemo.displayTime; var twoGroups = displayDate.length === 2 && displayTime.length === 2; var bottomRow = displayTime.length ? displayTime : displayDate.length ? displayDate : null; var topRow = displayDate.length && displayTime.length ? displayDate : null; return /*#__PURE__*/_react["default"].createElement(StyledTimeDisplayWrapper, null, /*#__PURE__*/_react["default"].createElement(StyledTimeDisplay, { className: "animation-control__time-display" }, twoGroups ? /*#__PURE__*/_react["default"].createElement(StyledTimeDisplayGroups, null, /*#__PURE__*/_react["default"].createElement(StyledTimeValueGroup, null, /*#__PURE__*/_react["default"].createElement(StyledTimeDisplayTop, null, displayDate[0]), /*#__PURE__*/_react["default"].createElement(StyledTimeDisplayBottom, null, displayTime[0])), /*#__PURE__*/_react["default"].createElement(TimeDivider, null), /*#__PURE__*/_react["default"].createElement(StyledTimeValueGroup, null, /*#__PURE__*/_react["default"].createElement(StyledTimeDisplayTop, null, displayDate[1]), /*#__PURE__*/_react["default"].createElement(StyledTimeDisplayBottom, null, displayTime[1]))) : /*#__PURE__*/_react["default"].createElement(StyledTimeDisplayRows, null, topRow ? /*#__PURE__*/_react["default"].createElement(StyledTimeDisplayTop, null, /*#__PURE__*/_react["default"].createElement(TimeDisplayRow, { timeValues: topRow })) : null, bottomRow ? /*#__PURE__*/_react["default"].createElement(StyledTimeDisplayBottom, null, /*#__PURE__*/_react["default"].createElement(TimeDisplayRow, { timeValues: bottomRow })) : null))); }; return FloatingTimeDisplay; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/common/animation-control/floating-time-display.js"],"names":["StyledTimeDisplayWrapper","styled","div","attrs","className","props","theme","bottomPanelGap","bottomInnerPdSide","StyledTimeDisplay","panelBackground","timeDisplayBorderRadius","titleTextColor","timeDisplayHeight","timeDisplayMinWidth","timeDisplayOpacity","timeDisplayPadding","StyledTimeDisplayGroups","StyledTimeDisplayRows","StyledTimeDisplayTop","textColor","StyledTimeDisplayBottom","StyledTimeValueGroup","StyledHorizontalBar","TimeDivider","TimeDisplayRow","timeValues","FloatingTimeDisplayFactory","FloatingTimeDisplay","currentTime","defaultTimeFormat","timeFormat","timezone","groupTime","Array","isArray","hasUserFormat","currentFormat","DEFAULT_TIME_FORMAT","dateFunc","displayDate","map","displayTime","reduce","accu","curr","split","dateFormat","datetimeFormat","dateString","timeString","includes","push","twoGroups","length","bottomRow","topRow"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 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, {useMemo} from 'react';\nimport styled from 'styled-components';\nimport {Minus} from 'components/common/icons';\nimport {DEFAULT_TIME_FORMAT} from 'constants/default-settings';\nimport {CenterFlexbox} from 'components/common/styled-components';\nimport {datetimeFormatter} from 'utils/data-utils';\n\nconst StyledTimeDisplayWrapper = styled.div.attrs({\n  className: 'floating-time-display'\n})`\n  bottom: ${props => `calc(100% + ${props.theme.bottomPanelGap}px)`};\n  display: flex;\n  position: absolute;\n  width: 100%;\n  margin-left: -${props => props.theme.bottomInnerPdSide}px;\n  justify-content: center;\n  pointer-events: none; /* prevent padding from blocking input */\n  & > * {\n    /* all children should allow input */\n    pointer-events: all;\n  }\n`;\n\nconst StyledTimeDisplay = styled.div.attrs({\n  className: 'floating-time-display__inner'\n})`\n  background-color: ${props => props.theme.panelBackground};\n  border-radius: ${props => props.theme.timeDisplayBorderRadius}px;\n  color: ${props => props.theme.titleTextColor};\n  display: flex;\n  height: ${props => props.theme.timeDisplayHeight}px;\n  justify-content: center;\n  min-width: ${props => props.theme.timeDisplayMinWidth}px;\n  opacity: ${props => props.theme.timeDisplayOpacity};\n  padding: ${props => props.theme.timeDisplayPadding};\n`;\n\nconst StyledTimeDisplayGroups = styled.div`\n  align-items: center;\n  display: flex;\n  flex-direction: row;\n`;\n\nconst StyledTimeDisplayRows = styled.div`\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n`;\n\nconst StyledTimeDisplayTop = styled.div.attrs({\n  className: 'animation-control__time-display__top'\n})`\n  color: ${props => props.theme.textColor};\n  display: flex;\n  font-size: 12px;\n  font-weight: 500;\n  justify-content: center;\n`;\n\nconst StyledTimeDisplayBottom = styled.div.attrs({\n  className: 'animation-control__time-display__bottom'\n})`\n  color: ${props => props.theme.titleTextColor};\n  display: flex;\n  font-size: 14px;\n  font-weight: 500;\n  justify-content: center;\n`;\n\nconst StyledTimeValueGroup = styled.div.attrs({\n  className: 'animation-control__time-value-group'\n})`\n  display: flex;\n  flex-direction: column;\n`;\n\nconst StyledHorizontalBar = styled.div.attrs({\n  className: 'animation-control__horizontal-bar'\n})`\n  margin: 0 12px;\n`;\n\nconst TimeDivider = () => (\n  <StyledHorizontalBar>\n    <Minus height=\"12px\" />\n  </StyledHorizontalBar>\n);\n\nconst TimeDisplayRow = ({timeValues = []}) => (\n  <CenterFlexbox>\n    <div className=\"time-value\">{timeValues[0]}</div>\n    {timeValues[1] ? <TimeDivider /> : null}\n    {timeValues[1] ? <div className=\"time-value\">{timeValues[1]}</div> : null}\n  </CenterFlexbox>\n);\n\nexport default function FloatingTimeDisplayFactory() {\n  const FloatingTimeDisplay = ({currentTime, defaultTimeFormat, timeFormat, timezone}) => {\n    const {displayDate, displayTime} = useMemo(() => {\n      const groupTime = Array.isArray(currentTime) ? currentTime : [currentTime];\n      const hasUserFormat = typeof timeFormat === 'string';\n      const currentFormat = (hasUserFormat ? timeFormat : defaultTimeFormat) || DEFAULT_TIME_FORMAT;\n      const dateFunc = datetimeFormatter(timezone);\n\n      if (hasUserFormat) {\n        // dont split time if user defined it\n        return {\n          displayDate: groupTime.map(dateFunc(currentFormat)),\n          displayTime: []\n        };\n      }\n      return groupTime.reduce(\n        (accu, curr) => {\n          const [dateFormat, datetimeFormat] = currentFormat.split(' ');\n          const dateString = dateFunc(dateFormat)(curr);\n          const timeString = datetimeFormat ? dateFunc(datetimeFormat)(curr) : null;\n\n          if (!accu.displayDate.includes(dateString)) {\n            accu.displayDate.push(dateString);\n          }\n          if (timeString) {\n            accu.displayTime.push(timeString);\n          }\n\n          return accu;\n        },\n        {displayDate: [], displayTime: []}\n      );\n    }, [currentTime, timeFormat, defaultTimeFormat, timezone]);\n\n    const twoGroups = displayDate.length === 2 && displayTime.length === 2;\n    const bottomRow = displayTime.length ? displayTime : displayDate.length ? displayDate : null;\n    const topRow = displayDate.length && displayTime.length ? displayDate : null;\n\n    return (\n      <StyledTimeDisplayWrapper>\n        <StyledTimeDisplay className=\"animation-control__time-display\">\n          {twoGroups ? (\n            <StyledTimeDisplayGroups>\n              <StyledTimeValueGroup>\n                {/* Time Start */}\n                <StyledTimeDisplayTop>{displayDate[0]}</StyledTimeDisplayTop>\n                <StyledTimeDisplayBottom>{displayTime[0]}</StyledTimeDisplayBottom>\n              </StyledTimeValueGroup>\n              <TimeDivider />\n              <StyledTimeValueGroup>\n                {/* Time End */}\n                <StyledTimeDisplayTop>{displayDate[1]}</StyledTimeDisplayTop>\n                <StyledTimeDisplayBottom>{displayTime[1]}</StyledTimeDisplayBottom>\n              </StyledTimeValueGroup>\n            </StyledTimeDisplayGroups>\n          ) : (\n            <StyledTimeDisplayRows>\n              {topRow ? (\n                <StyledTimeDisplayTop>\n                  <TimeDisplayRow timeValues={topRow} />\n                </StyledTimeDisplayTop>\n              ) : null}\n              {bottomRow ? (\n                <StyledTimeDisplayBottom>\n                  <TimeDisplayRow timeValues={bottomRow} />\n                </StyledTimeDisplayBottom>\n              ) : null}\n            </StyledTimeDisplayRows>\n          )}\n        </StyledTimeDisplay>\n      </StyledTimeDisplayWrapper>\n    );\n  };\n\n  return FloatingTimeDisplay;\n}\n"]}