kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
132 lines (131 loc) • 28.6 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
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 _classnames = _interopRequireDefault(require("classnames"));
var _icons = require("../icons");
var _constants = require("@kepler.gl/constants");
var _styledComponents2 = require("../../common/styled-components");
var _utils = require("@kepler.gl/utils");
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8; // 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 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(function (props) {
return {
className: (0, _classnames["default"])('floating-time-display__inner', props.className)
};
})(_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) || _constants.DEFAULT_TIME_FORMAT;
var dateFunc = (0, _utils.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,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_classnames","_icons","_constants","_styledComponents2","_utils","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","_templateObject7","_templateObject8","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledTimeDisplayWrapper","styled","div","attrs","className","_taggedTemplateLiteral2","props","concat","theme","bottomPanelGap","bottomInnerPdSide","StyledTimeDisplay","classnames","panelBackground","timeDisplayBorderRadius","titleTextColor","timeDisplayHeight","timeDisplayMinWidth","timeDisplayOpacity","timeDisplayPadding","StyledTimeDisplayGroups","StyledTimeDisplayRows","StyledTimeDisplayTop","textColor","StyledTimeDisplayBottom","StyledTimeValueGroup","StyledHorizontalBar","TimeDivider","createElement","Minus","height","TimeDisplayRow","_ref","_ref$timeValues","timeValues","CenterFlexbox","FloatingTimeDisplayFactory","FloatingTimeDisplay","_ref2","currentTime","defaultTimeFormat","timeFormat","timezone","_useMemo","useMemo","groupTime","Array","isArray","hasUserFormat","currentFormat","DEFAULT_TIME_FORMAT","dateFunc","datetimeFormatter","displayDate","map","displayTime","reduce","accu","curr","_currentFormat$split","split","_currentFormat$split2","_slicedToArray2","dateFormat","datetimeFormat","dateString","timeString","includes","push","twoGroups","length","bottomRow","topRow"],"sources":["../../../src/common/animation-control/floating-time-display.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useMemo} from 'react';\nimport styled from 'styled-components';\nimport classnames from 'classnames';\nimport {Minus} from '../icons';\nimport {DEFAULT_TIME_FORMAT} from '@kepler.gl/constants';\nimport {CenterFlexbox} from '../../common/styled-components';\nimport {datetimeFormatter} from '@kepler.gl/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(props => ({\n  className: classnames('floating-time-display__inner', props.className)\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\ninterface TimeDisplayRowProps {\n  timeValues?: string[];\n}\n\nconst TimeDisplayRow = ({timeValues = []}: TimeDisplayRowProps) => (\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\ninterface FloatingTimeDisplayProps {\n  currentTime: number | number[];\n  defaultTimeFormat?: string | null;\n  timeFormat?: string | null;\n  timezone?: string | null;\n}\n\nexport default function FloatingTimeDisplayFactory() {\n  const FloatingTimeDisplay = ({\n    currentTime,\n    defaultTimeFormat,\n    timeFormat,\n    timezone\n  }: FloatingTimeDisplayProps) => {\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<{displayDate: string[]; displayTime: string[]}>(\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: []} as {displayDate: string[]; displayTime: string[]}\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"],"mappings":"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","ignoreList":[]}
;