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
JavaScript
;
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"]}