UNPKG

kepler.gl

Version:

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

302 lines (296 loc) 55.7 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = EffectTimeConfiguratorFactory; var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _reactIntl = require("react-intl"); var _styledComponents = _interopRequireDefault(require("styled-components")); var _momentTimezone = _interopRequireDefault(require("moment-timezone")); var _suncalc = _interopRequireDefault(require("suncalc")); var _localization = require("@kepler.gl/localization"); var _utils = require("@kepler.gl/utils"); var _constants = require("@kepler.gl/constants"); var _reducers = require("@kepler.gl/reducers"); var _injector = require("../injector"); var _styledComponents2 = require("../common/styled-components"); var _checkbox = _interopRequireDefault(require("../common/checkbox")); var _button = _interopRequireDefault(require("../common/data-table/button")); var _icons = require("../common/icons"); var _timezoneSelector = _interopRequireDefault(require("./timezone-selector")); var _effectTimeSlider = _interopRequireDefault(require("./effect-time-slider")); var _effectTimeSelector = _interopRequireDefault(require("./effect-time-selector")); var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9; // 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 DAY_MILISECONDS = 1000 * 60 * 60 * 24; var StyledWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n align-items: center;\n margin-bottom: ", "px;\n ", "\n"])), function (props) { var _props$marginBottom; return (_props$marginBottom = props.marginBottom) !== null && _props$marginBottom !== void 0 ? _props$marginBottom : 9; }, function (props) { return props.hidden ? 'display: none;' : ''; }); var SliderWrapper = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n margin-top: 13px;\n margin-bottom: 12px;\n ", "\n"])), function (props) { return props.hidden ? 'display: none;' : ''; }); var StyledButton = (0, _styledComponents["default"])(_button["default"])(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n background-color: ", ";\n height: 32px;\n width: 32px;\n padding: 5px;\n border-radius: 4px;\n justify-content: center;\n &:hover {\n color: ", ";\n background-color: ", ";\n }\n"])), function (props) { return props.theme.effectPanelTextSecondary2; }, function (props) { return props.theme.inputBgd; }, function (props) { return props.theme.effectPanelTextMain; }, function (props) { return props.theme.inputBgdHover; }); var StyledRadio = (0, _styledComponents["default"])(_checkbox["default"])(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n .kg-checkbox__label {\n font-family: ", ";\n font-size: ", ";\n }\n .kg-checkbox__label:before {\n background: transparent;\n border-color: ", ";\n }\n input:checked + .kg-checkbox__label:before {\n border-color: ", ";\n }\n .kg-checkbox__label:after {\n background-color: ", ";\n }\n"])), function (props) { return props.theme.fontFamily; }, function (props) { return props.theme.inputFontSize; }, function (props) { return props.theme.effectPanelTextSecondary2; }, function (props) { return props.theme.activeColor; }, function (props) { return props.theme.activeColor; }); var StyledEffectTimeConfigurator = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 8px;\n margin-top: 3px;\n"]))); var StyledDatePicker = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n .react-date-picker--open .react-date-picker__wrapper .react-date-picker__inputGroup {\n border: 1px solid ", ";\n border-radius: 4px 4px 0px 0px !important;\n }\n .react-calendar__navigation__prev2-button,\n .react-calendar__navigation__next2-button {\n display: none;\n }\n .react-calendar__navigation__label {\n position: absolute;\n top: 20px;\n }\n .react-calendar__navigation__arrow {\n position: absolute;\n top: 18px;\n font-size: 16px;\n }\n .react-calendar__navigation__prev-button {\n right: 36px;\n }\n .react-calendar__navigation__next-button {\n right: 12px;\n }\n"])), function (props) { return props.theme.activeColor; }); var WithIconWrapper = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n ", "\n"])), function (props) { return props.width ? "width: ".concat(props.width) : ''; }); var StyledExtraIcon = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n top: 0px;\n left: 8px;\n width: 0px;\n height: 32px;\n color: ", ";\n pointer-events: none;\n"])), function (props) { return props.theme.effectPanelTextSecondary2; }); var TextBlock = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n width: ", ";\n font-size: ", ";\n"])), function (props) { return props.theme.effectPanelTextSecondary2; }, function (props) { return props.width; }, function (props) { return props.theme.inputFontSize; }); /** * Converts date, time and timezone into a UTC timestamp. * @param dateStr Date string in YYYY-MM-DD format. * @param timeStr Time string in HH:MM format. * @param timezone Timezone name. * @returns Timestamp or null if case of bad inputs. */ var getTimestamp = function getTimestamp(dateStr, timeStr, timezone) { var timestamp = null; var curr = _momentTimezone["default"].tz("".concat(dateStr, "T").concat(timeStr, ":00"), timezone); if (curr.isValid()) { timestamp = curr.utc().valueOf(); } return timestamp; }; /** * Converts time of the day into [0, 1] range * @param date * @returns */ var getDayRatio = function getDayRatio(date) { return (date.hours() * 60 + date.minutes()) * 60 * 1000 / DAY_MILISECONDS; }; EffectTimeConfiguratorFactory.deps = [_timezoneSelector["default"], _effectTimeSlider["default"], _effectTimeSelector["default"]]; function EffectTimeConfiguratorFactory(TimezoneSelector, EffectTimeSlider, EffectTimeSelector) { var EffectTimeConfigurator = function EffectTimeConfigurator(_ref) { var timestamp = _ref.timestamp, _timezone = _ref.timezone, timeMode = _ref.timeMode, onTimeParametersChanged = _ref.onChange, mapState = _ref.mapState, intl = _ref.intl; var timezone = (0, _react.useMemo)(function () { return _momentTimezone["default"].tz.names().includes(_timezone) ? _timezone : _constants.DEFAULT_TIMEZONE; }, [_timezone]); var _useMemo = (0, _react.useMemo)(function () { var currentMoment = _momentTimezone["default"].tz(timestamp, timezone); // Slider value from 0 to 1 var dayProgress = getDayRatio(currentMoment); // Date picker always renders Date in local timezone var date = new Date(); date.setFullYear(currentMoment.year(), currentMoment.month(), currentMoment.date()); date.setHours(0, 0, 0, 0); return [date, currentMoment.toDate(), currentMoment.format('HH:mm'), currentMoment.format('YYYY-MM-DD'), dayProgress]; }, [timestamp, timezone]), _useMemo2 = (0, _slicedToArray2["default"])(_useMemo, 5), datePickerDate = _useMemo2[0], fullDate = _useMemo2[1], formattedTime = _useMemo2[2], formattedDate = _useMemo2[3], dayTimeProgress = _useMemo2[4]; var timeSliderConfig = (0, _react.useMemo)(function () { var times = _suncalc["default"].getTimes(fullDate, mapState.latitude, mapState.longitude); var dawn = times.dawn, sunrise = times.sunrise, sunset = times.sunset, dusk = times.dusk; return { dawn: getDayRatio(_momentTimezone["default"].tz(dawn.valueOf(), timezone)), sunrise: getDayRatio(_momentTimezone["default"].tz(sunrise.valueOf(), timezone)), sunset: getDayRatio(_momentTimezone["default"].tz(sunset.valueOf(), timezone)), dusk: getDayRatio(_momentTimezone["default"].tz(dusk.valueOf(), timezone)), sunriseTime: _momentTimezone["default"].tz(sunrise.valueOf(), timezone).format('hh:mm A'), sunsetTime: _momentTimezone["default"].tz(sunset.valueOf(), timezone).format('hh:mm A') }; }, [fullDate, timezone, mapState.latitude, mapState.longitude]); var onTimeSliderChange = (0, _react.useCallback)(function (value) { var hours = (0, _utils.clamp)([0, 23], Math.floor(value[1] * 24)); var minutes = (0, _utils.clamp)([0, 59], Math.floor((value[1] * 24 - hours) * 60)); var newFormattedTime = "".concat(hours < 10 ? "0".concat(hours) : hours, ":").concat(minutes < 10 ? "0".concat(minutes) : minutes); var newTimestamp = getTimestamp(formattedDate, newFormattedTime, timezone); onTimeParametersChanged({ timestamp: newTimestamp }); }, [formattedDate, timezone, onTimeParametersChanged]); var setDate = (0, _react.useCallback)(function (newDate) { if (!newDate) return; var newFormattedDate = (0, _momentTimezone["default"])(newDate).format('YYYY-MM-DD'); var newTimestamp = getTimestamp(newFormattedDate, formattedTime, timezone); onTimeParametersChanged({ timestamp: newTimestamp }); }, [formattedTime, timezone, onTimeParametersChanged]); var setTime = (0, _react.useCallback)(function (newTime) { if (!newTime) return; var newTimestamp = getTimestamp(formattedDate, newTime, timezone); onTimeParametersChanged({ timestamp: newTimestamp }); }, [formattedDate, timezone, onTimeParametersChanged]); var setTimezone = (0, _react.useCallback)(function (newTimezone) { if (!newTimezone) return; var newTimestamp = getTimestamp(formattedDate, formattedTime, newTimezone); // date and time are adjusted to have the same value but in the new timezone onTimeParametersChanged({ timestamp: newTimestamp, timezone: newTimezone }); }, [formattedDate, formattedTime, onTimeParametersChanged]); var setCurrentDateTime = (0, _react.useCallback)(function () { onTimeParametersChanged({ timestamp: new Date().valueOf() }); }, [onTimeParametersChanged]); var formatShortWeekday = (0, _react.useCallback)(function (locale, date) { return ['S', 'M', 'T', 'W', 'T', 'F', 'S'][date.getDay()]; }, []); var disableDateTimePick = timeMode !== _constants.LIGHT_AND_SHADOW_EFFECT_TIME_MODES.pick; return /*#__PURE__*/_react["default"].createElement(StyledEffectTimeConfigurator, null, /*#__PURE__*/_react["default"].createElement(StyledWrapper, { marginBottom: 16 }, /*#__PURE__*/_react["default"].createElement(StyledRadio, { type: "radio", checked: timeMode === _constants.LIGHT_AND_SHADOW_EFFECT_TIME_MODES.pick, id: "effect-time-toggle-use-pick-time", label: intl.formatMessage({ id: 'effectManager.pickDateTime' }), onChange: function onChange() { onTimeParametersChanged({ timeMode: _constants.LIGHT_AND_SHADOW_EFFECT_TIME_MODES.pick }); } })), /*#__PURE__*/_react["default"].createElement(SliderWrapper, { hidden: disableDateTimePick }, /*#__PURE__*/_react["default"].createElement(EffectTimeSlider, { value: dayTimeProgress, onChange: onTimeSliderChange, config: timeSliderConfig })), /*#__PURE__*/_react["default"].createElement(StyledWrapper, { hidden: disableDateTimePick, marginBottom: 2 }, /*#__PURE__*/_react["default"].createElement(TextBlock, { width: "32px" }), /*#__PURE__*/_react["default"].createElement(TextBlock, { width: "110px" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'effectManager.date' })), /*#__PURE__*/_react["default"].createElement(TextBlock, { width: "110px" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'effectManager.time' }))), /*#__PURE__*/_react["default"].createElement(StyledWrapper, { hidden: disableDateTimePick, marginBottom: 16 }, /*#__PURE__*/_react["default"].createElement(StyledButton, { onClick: setCurrentDateTime, "data-for": "pick-time-button", "data-tip": true }, /*#__PURE__*/_react["default"].createElement(_icons.LocationMarker, { height: "16px" }), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, { id: "pick-time-button", effect: "solid", place: "top", delayShow: 500 }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'effectManager.pickCurrrentTime' }))), /*#__PURE__*/_react["default"].createElement(WithIconWrapper, null, /*#__PURE__*/_react["default"].createElement(StyledDatePicker, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledDatePicker, { value: datePickerDate, onChange: setDate, minDetail: 'month', formatShortWeekday: formatShortWeekday })), /*#__PURE__*/_react["default"].createElement(StyledExtraIcon, null, /*#__PURE__*/_react["default"].createElement(_icons.Calendar, { width: "16px", height: "32px" }))), /*#__PURE__*/_react["default"].createElement(WithIconWrapper, null, /*#__PURE__*/_react["default"].createElement(EffectTimeSelector, { value: formattedTime, onChange: setTime }), /*#__PURE__*/_react["default"].createElement(StyledExtraIcon, null, /*#__PURE__*/_react["default"].createElement(_icons.Clock, { width: "16px", height: "32px" })))), /*#__PURE__*/_react["default"].createElement(StyledWrapper, { hidden: disableDateTimePick, marginBottom: 2 }, /*#__PURE__*/_react["default"].createElement(TextBlock, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'effectManager.timezone' }))), /*#__PURE__*/_react["default"].createElement(StyledWrapper, { hidden: disableDateTimePick, marginBottom: 24 }, /*#__PURE__*/_react["default"].createElement(WithIconWrapper, { width: '100%' }, /*#__PURE__*/_react["default"].createElement(TimezoneSelector, { selected: timezone, onSelect: setTimezone }), /*#__PURE__*/_react["default"].createElement(StyledExtraIcon, null, /*#__PURE__*/_react["default"].createElement(_icons.Globe, { width: "16px", height: "32px" })))), /*#__PURE__*/_react["default"].createElement(StyledWrapper, { marginBottom: 16 }, /*#__PURE__*/_react["default"].createElement(StyledRadio, { type: "radio", checked: timeMode === _constants.LIGHT_AND_SHADOW_EFFECT_TIME_MODES.current, id: "effect-time-toggle-use-current-time", label: intl.formatMessage({ id: 'effectManager.currentTime' }), onChange: function onChange() { onTimeParametersChanged({ timeMode: _constants.LIGHT_AND_SHADOW_EFFECT_TIME_MODES.current }); } })), /*#__PURE__*/_react["default"].createElement(StyledWrapper, { marginBottom: 16 }, /*#__PURE__*/_react["default"].createElement(StyledRadio, { type: "radio", checked: timeMode === _constants.LIGHT_AND_SHADOW_EFFECT_TIME_MODES.animation, id: "effect-time-toggle-use-animation-time", label: 'Animation time', onChange: function onChange() { onTimeParametersChanged({ timeMode: _constants.LIGHT_AND_SHADOW_EFFECT_TIME_MODES.animation }); } }))); }; // @ts-expect-error how to properly type? return (0, _injector.withState)([_reducers.mapStateLens])((0, _reactIntl.injectIntl)(EffectTimeConfigurator)); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactIntl","_styledComponents","_interopRequireDefault","_momentTimezone","_suncalc","_localization","_utils","_constants","_reducers","_injector","_styledComponents2","_checkbox","_button","_icons","_timezoneSelector","_effectTimeSlider","_effectTimeSelector","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","_templateObject7","_templateObject8","_templateObject9","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","DAY_MILISECONDS","StyledWrapper","styled","div","_taggedTemplateLiteral2","props","_props$marginBottom","marginBottom","hidden","SliderWrapper","StyledButton","Button","theme","effectPanelTextSecondary2","inputBgd","effectPanelTextMain","inputBgdHover","StyledRadio","Checkbox","fontFamily","inputFontSize","activeColor","StyledEffectTimeConfigurator","StyledDatePicker","WithIconWrapper","width","concat","StyledExtraIcon","TextBlock","getTimestamp","dateStr","timeStr","timezone","timestamp","curr","moment","tz","isValid","utc","valueOf","getDayRatio","date","hours","minutes","EffectTimeConfiguratorFactory","deps","TimezoneSelectorFactory","EffectTimeSliderFactory","EffectTimeSelectorFactory","TimezoneSelector","EffectTimeSlider","EffectTimeSelector","EffectTimeConfigurator","_ref","_timezone","timeMode","onTimeParametersChanged","onChange","mapState","intl","useMemo","names","includes","DEFAULT_TIMEZONE","_useMemo","currentMoment","dayProgress","Date","setFullYear","year","month","setHours","toDate","format","_useMemo2","_slicedToArray2","datePickerDate","fullDate","formattedTime","formattedDate","dayTimeProgress","timeSliderConfig","times","SunCalc","getTimes","latitude","longitude","dawn","sunrise","sunset","dusk","sunriseTime","sunsetTime","onTimeSliderChange","useCallback","value","clamp","Math","floor","newFormattedTime","newTimestamp","setDate","newDate","newFormattedDate","setTime","newTime","setTimezone","newTimezone","setCurrentDateTime","formatShortWeekday","locale","getDay","disableDateTimePick","LIGHT_AND_SHADOW_EFFECT_TIME_MODES","pick","createElement","type","checked","id","label","formatMessage","config","FormattedMessage","onClick","LocationMarker","height","Tooltip","effect","place","delayShow","minDetail","Calendar","Clock","selected","onSelect","Globe","current","animation","withState","mapStateLens","injectIntl"],"sources":["../../src/effects/effect-time-configurator.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo} from 'react';\nimport {injectIntl, IntlShape} from 'react-intl';\nimport styled from 'styled-components';\nimport moment from 'moment-timezone';\nimport SunCalc from 'suncalc';\n\nimport {MapState} from '@kepler.gl/types';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {clamp} from '@kepler.gl/utils';\nimport {\n  LIGHT_AND_SHADOW_EFFECT_TIME_MODES,\n  LightAndShadowEffectTimeMode,\n  DEFAULT_TIMEZONE\n} from '@kepler.gl/constants';\nimport {mapStateLens} from '@kepler.gl/reducers';\n\nimport {withState} from '../injector';\nimport {StyledDatePicker as DatePicker, Tooltip} from '../common/styled-components';\nimport Checkbox from '../common/checkbox';\nimport Button from '../common/data-table/button';\nimport {LocationMarker, Calendar, Clock, Globe} from '../common/icons';\nimport TimezoneSelectorFactory from './timezone-selector';\nimport EffectTimeSliderFactory from './effect-time-slider';\nimport EffectTimeSelectorFactory from './effect-time-selector';\n\nconst DAY_MILISECONDS = 1000 * 60 * 60 * 24;\n\nexport type EffectTimeConfiguratorProps = {\n  timestamp: number;\n  timezone: string;\n  timeMode: LightAndShadowEffectTimeMode;\n  onChange: (parameters: {\n    timestamp?: number | null;\n    timezone?: string;\n    timeMode?: LightAndShadowEffectTimeMode;\n  }) => void;\n};\n\ntype StyledWrapperProps = {disabled?: boolean; marginBottom?: number};\nconst StyledWrapper = styled.div<StyledWrapperProps>`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: ${props => props.marginBottom ?? 9}px;\n  ${props => (props.hidden ? 'display: none;' : '')}\n`;\n\ntype SliderWrapperProps = {disabled?: boolean};\nconst SliderWrapper = styled.div<SliderWrapperProps>`\n  margin-top: 13px;\n  margin-bottom: 12px;\n  ${props => (props.hidden ? 'display: none;' : '')}\n`;\n\nconst StyledButton = styled(Button)`\n  color: ${props => props.theme.effectPanelTextSecondary2};\n  background-color: ${props => props.theme.inputBgd};\n  height: 32px;\n  width: 32px;\n  padding: 5px;\n  border-radius: 4px;\n  justify-content: center;\n  &:hover {\n    color: ${props => props.theme.effectPanelTextMain};\n    background-color: ${props => props.theme.inputBgdHover};\n  }\n`;\n\nconst StyledRadio = styled(Checkbox)`\n  .kg-checkbox__label {\n    font-family: ${props => props.theme.fontFamily};\n    font-size: ${props => props.theme.inputFontSize};\n  }\n  .kg-checkbox__label:before {\n    background: transparent;\n    border-color: ${props => props.theme.effectPanelTextSecondary2};\n  }\n  input:checked + .kg-checkbox__label:before {\n    border-color: ${props => props.theme.activeColor};\n  }\n  .kg-checkbox__label:after {\n    background-color: ${props => props.theme.activeColor};\n  }\n`;\n\nconst StyledEffectTimeConfigurator = styled.div`\n  margin-bottom: 8px;\n  margin-top: 3px;\n`;\n\nconst StyledDatePicker = styled.div`\n  .react-date-picker--open .react-date-picker__wrapper .react-date-picker__inputGroup {\n    border: 1px solid ${props => props.theme.activeColor};\n    border-radius: 4px 4px 0px 0px !important;\n  }\n  .react-calendar__navigation__prev2-button,\n  .react-calendar__navigation__next2-button {\n    display: none;\n  }\n  .react-calendar__navigation__label {\n    position: absolute;\n    top: 20px;\n  }\n  .react-calendar__navigation__arrow {\n    position: absolute;\n    top: 18px;\n    font-size: 16px;\n  }\n  .react-calendar__navigation__prev-button {\n    right: 36px;\n  }\n  .react-calendar__navigation__next-button {\n    right: 12px;\n  }\n`;\n\ntype WithIconWrapperProps = {width?: string};\nconst WithIconWrapper = styled.div<WithIconWrapperProps>`\n  position: relative;\n  ${props => (props.width ? `width: ${props.width}` : '')}\n`;\n\nconst StyledExtraIcon = styled.div`\n  position: absolute;\n  top: 0px;\n  left: 8px;\n  width: 0px;\n  height: 32px;\n  color: ${props => props.theme.effectPanelTextSecondary2};\n  pointer-events: none;\n`;\n\ntype TextBlockProps = {\n  width?: string;\n};\nconst TextBlock = styled.div<TextBlockProps>`\n  color: ${props => props.theme.effectPanelTextSecondary2};\n  width: ${props => props.width};\n  font-size: ${props => props.theme.inputFontSize};\n`;\n\n/**\n * Converts date, time and timezone into a UTC timestamp.\n * @param dateStr Date string in YYYY-MM-DD format.\n * @param timeStr Time string in HH:MM format.\n * @param timezone Timezone name.\n * @returns Timestamp or null if case of bad inputs.\n */\nconst getTimestamp = (dateStr: string, timeStr: string, timezone: string): number | null => {\n  let timestamp: number | null = null;\n  const curr = moment.tz(`${dateStr}T${timeStr}:00`, timezone);\n  if (curr.isValid()) {\n    timestamp = curr.utc().valueOf();\n  }\n  return timestamp;\n};\n\n/**\n * Converts time of the day into [0, 1] range\n * @param date\n * @returns\n */\nconst getDayRatio = (date: moment.Moment) => {\n  return ((date.hours() * 60 + date.minutes()) * 60 * 1000) / DAY_MILISECONDS;\n};\n\nEffectTimeConfiguratorFactory.deps = [\n  TimezoneSelectorFactory,\n  EffectTimeSliderFactory,\n  EffectTimeSelectorFactory\n];\n\nexport default function EffectTimeConfiguratorFactory(\n  TimezoneSelector: ReturnType<typeof TimezoneSelectorFactory>,\n  EffectTimeSlider: ReturnType<typeof EffectTimeSliderFactory>,\n  EffectTimeSelector: ReturnType<typeof EffectTimeSelectorFactory>\n): React.FC<EffectTimeConfiguratorProps> {\n  const EffectTimeConfigurator = ({\n    timestamp,\n    timezone: _timezone,\n    timeMode,\n    onChange: onTimeParametersChanged,\n    mapState,\n    intl\n  }: EffectTimeConfiguratorProps & {intl: IntlShape; mapState: MapState}) => {\n    const timezone = useMemo(() => {\n      return moment.tz.names().includes(_timezone) ? _timezone : DEFAULT_TIMEZONE;\n    }, [_timezone]);\n\n    const [datePickerDate, fullDate, formattedTime, formattedDate, dayTimeProgress] =\n      useMemo(() => {\n        const currentMoment = moment.tz(timestamp, timezone);\n\n        // Slider value from 0 to 1\n        const dayProgress = getDayRatio(currentMoment);\n\n        // Date picker always renders Date in local timezone\n        const date = new Date();\n        date.setFullYear(currentMoment.year(), currentMoment.month(), currentMoment.date());\n        date.setHours(0, 0, 0, 0);\n\n        return [\n          date,\n          currentMoment.toDate(),\n          currentMoment.format('HH:mm'),\n          currentMoment.format('YYYY-MM-DD'),\n          dayProgress\n        ];\n      }, [timestamp, timezone]);\n\n    const timeSliderConfig = useMemo(() => {\n      const times = SunCalc.getTimes(fullDate, mapState.latitude, mapState.longitude);\n      const {dawn, sunrise, sunset, dusk} = times;\n\n      return {\n        dawn: getDayRatio(moment.tz(dawn.valueOf(), timezone)),\n        sunrise: getDayRatio(moment.tz(sunrise.valueOf(), timezone)),\n        sunset: getDayRatio(moment.tz(sunset.valueOf(), timezone)),\n        dusk: getDayRatio(moment.tz(dusk.valueOf(), timezone)),\n        sunriseTime: moment.tz(sunrise.valueOf(), timezone).format('hh:mm A'),\n        sunsetTime: moment.tz(sunset.valueOf(), timezone).format('hh:mm A')\n      };\n    }, [fullDate, timezone, mapState.latitude, mapState.longitude]);\n\n    const onTimeSliderChange = useCallback(\n      value => {\n        const hours = clamp([0, 23], Math.floor(value[1] * 24));\n        const minutes = clamp([0, 59], Math.floor((value[1] * 24 - hours) * 60));\n\n        const newFormattedTime = `${hours < 10 ? `0${hours}` : hours}:${\n          minutes < 10 ? `0${minutes}` : minutes\n        }`;\n        const newTimestamp = getTimestamp(formattedDate, newFormattedTime, timezone);\n        onTimeParametersChanged({timestamp: newTimestamp});\n      },\n      [formattedDate, timezone, onTimeParametersChanged]\n    );\n\n    const setDate = useCallback(\n      newDate => {\n        if (!newDate) return;\n\n        const newFormattedDate = moment(newDate).format('YYYY-MM-DD');\n        const newTimestamp = getTimestamp(newFormattedDate, formattedTime, timezone);\n        onTimeParametersChanged({timestamp: newTimestamp});\n      },\n      [formattedTime, timezone, onTimeParametersChanged]\n    );\n\n    const setTime = useCallback(\n      newTime => {\n        if (!newTime) return;\n\n        const newTimestamp = getTimestamp(formattedDate, newTime, timezone);\n        onTimeParametersChanged({timestamp: newTimestamp});\n      },\n      [formattedDate, timezone, onTimeParametersChanged]\n    );\n\n    const setTimezone = useCallback(\n      newTimezone => {\n        if (!newTimezone) return;\n\n        const newTimestamp = getTimestamp(formattedDate, formattedTime, newTimezone);\n        // date and time are adjusted to have the same value but in the new timezone\n        onTimeParametersChanged({timestamp: newTimestamp, timezone: newTimezone});\n      },\n      [formattedDate, formattedTime, onTimeParametersChanged]\n    );\n\n    const setCurrentDateTime = useCallback(() => {\n      onTimeParametersChanged({timestamp: new Date().valueOf()});\n    }, [onTimeParametersChanged]);\n\n    const formatShortWeekday = useCallback((locale, date) => {\n      return ['S', 'M', 'T', 'W', 'T', 'F', 'S'][date.getDay()];\n    }, []);\n\n    const disableDateTimePick = timeMode !== LIGHT_AND_SHADOW_EFFECT_TIME_MODES.pick;\n\n    return (\n      <StyledEffectTimeConfigurator>\n        <StyledWrapper marginBottom={16}>\n          <StyledRadio\n            type=\"radio\"\n            checked={timeMode === LIGHT_AND_SHADOW_EFFECT_TIME_MODES.pick}\n            id={`effect-time-toggle-use-pick-time`}\n            label={intl.formatMessage({\n              id: 'effectManager.pickDateTime'\n            })}\n            onChange={() => {\n              onTimeParametersChanged({timeMode: LIGHT_AND_SHADOW_EFFECT_TIME_MODES.pick});\n            }}\n          />\n        </StyledWrapper>\n\n        <SliderWrapper hidden={disableDateTimePick}>\n          <EffectTimeSlider\n            value={dayTimeProgress}\n            onChange={onTimeSliderChange}\n            config={timeSliderConfig}\n          />\n        </SliderWrapper>\n\n        <StyledWrapper hidden={disableDateTimePick} marginBottom={2}>\n          <TextBlock width=\"32px\" />\n          <TextBlock width=\"110px\">\n            <FormattedMessage id={'effectManager.date'} />\n          </TextBlock>\n          <TextBlock width=\"110px\">\n            <FormattedMessage id={'effectManager.time'} />\n          </TextBlock>\n        </StyledWrapper>\n\n        <StyledWrapper hidden={disableDateTimePick} marginBottom={16}>\n          <StyledButton onClick={setCurrentDateTime} data-for=\"pick-time-button\" data-tip>\n            <LocationMarker height=\"16px\" />\n            <Tooltip id=\"pick-time-button\" effect=\"solid\" place=\"top\" delayShow={500}>\n              <FormattedMessage id={'effectManager.pickCurrrentTime'} />\n            </Tooltip>\n          </StyledButton>\n          <WithIconWrapper>\n            <StyledDatePicker>\n              <DatePicker\n                value={datePickerDate}\n                onChange={setDate}\n                minDetail={'month'}\n                formatShortWeekday={formatShortWeekday}\n              />\n            </StyledDatePicker>\n            <StyledExtraIcon>\n              <Calendar width=\"16px\" height=\"32px\" />\n            </StyledExtraIcon>\n          </WithIconWrapper>\n          <WithIconWrapper>\n            <EffectTimeSelector value={formattedTime} onChange={setTime} />\n            <StyledExtraIcon>\n              <Clock width=\"16px\" height=\"32px\" />\n            </StyledExtraIcon>\n          </WithIconWrapper>\n        </StyledWrapper>\n\n        <StyledWrapper hidden={disableDateTimePick} marginBottom={2}>\n          <TextBlock>\n            <FormattedMessage id={'effectManager.timezone'} />\n          </TextBlock>\n        </StyledWrapper>\n\n        <StyledWrapper hidden={disableDateTimePick} marginBottom={24}>\n          <WithIconWrapper width={'100%'}>\n            <TimezoneSelector selected={timezone} onSelect={setTimezone} />\n            <StyledExtraIcon>\n              <Globe width=\"16px\" height=\"32px\" />\n            </StyledExtraIcon>\n          </WithIconWrapper>\n        </StyledWrapper>\n\n        <StyledWrapper marginBottom={16}>\n          <StyledRadio\n            type=\"radio\"\n            checked={timeMode === LIGHT_AND_SHADOW_EFFECT_TIME_MODES.current}\n            id={`effect-time-toggle-use-current-time`}\n            label={intl.formatMessage({\n              id: 'effectManager.currentTime'\n            })}\n            onChange={() => {\n              onTimeParametersChanged({timeMode: LIGHT_AND_SHADOW_EFFECT_TIME_MODES.current});\n            }}\n          />\n        </StyledWrapper>\n\n        <StyledWrapper marginBottom={16}>\n          <StyledRadio\n            type=\"radio\"\n            checked={timeMode === LIGHT_AND_SHADOW_EFFECT_TIME_MODES.animation}\n            id={`effect-time-toggle-use-animation-time`}\n            label={'Animation time'}\n            onChange={() => {\n              onTimeParametersChanged({timeMode: LIGHT_AND_SHADOW_EFFECT_TIME_MODES.animation});\n            }}\n          />\n        </StyledWrapper>\n      </StyledEffectTimeConfigurator>\n    );\n  };\n\n  // @ts-expect-error how to properly type?\n  return withState([mapStateLens])(injectIntl(EffectTimeConfigurator));\n}\n"],"mappings":"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