kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
132 lines (131 loc) • 24.3 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = TimeRangeSliderFactory;
exports.getTimeBinsForInterval = getTimeBinsForInterval;
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _lodash = _interopRequireDefault(require("lodash.throttle"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _rangeSlider = _interopRequireDefault(require("./range-slider"));
var _timeSliderMarker = _interopRequireDefault(require("./time-slider-marker"));
var _playbackControls = _interopRequireDefault(require("./animation-control/playback-controls"));
var _timeRangeSliderTimeTitle = _interopRequireDefault(require("./time-range-slider-time-title"));
var _animationControl = _interopRequireDefault(require("./animation-control/animation-control"));
var _templateObject; // 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 animationControlWidth = 176;
var StyledSliderContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n align-items: flex-end;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n padding-left: ", "px;\n\n .timeline-container .kg-slider {\n display: none;\n }\n\n .playback-controls {\n margin-left: 22px;\n }\n"])), function (props) {
return props.isEnlarged ? 24 : 0;
});
var ANIMATION_CONTROL_STYLE = {
flex: 1
};
TimeRangeSliderFactory.deps = [_playbackControls["default"], _rangeSlider["default"], _timeSliderMarker["default"], _timeRangeSliderTimeTitle["default"], _animationControl["default"]];
function getTimeBinsForInterval(timeBins, interval) {
if (!timeBins) return {};
return Object.keys(timeBins).reduce(function (acc, dataId) {
acc[dataId] = timeBins[dataId][interval];
return acc;
}, {});
}
function TimeRangeSliderFactory(PlaybackControls, RangeSlider, TimeSliderMarker, TimeRangeSliderTimeTitle, AnimationControl) {
var TimeRangeSlider = function TimeRangeSlider(props) {
var domain = props.domain,
value = props.value,
isEnlarged = props.isEnlarged,
isMinified = props.isMinified,
hideTimeTitle = props.hideTimeTitle,
isAnimating = props.isAnimating,
resetAnimation = props.resetAnimation,
timeFormat = props.timeFormat,
timezone = props.timezone,
timeBins = props.timeBins,
plotType = props.plotType,
lineChart = props.lineChart,
invertTrendColor = props.invertTrendColor,
step = props.step,
isAnimatable = props.isAnimatable,
speed = props.speed,
animationWindow = props.animationWindow,
updateAnimationSpeed = props.updateAnimationSpeed,
setFilterAnimationWindow = props.setFilterAnimationWindow,
toggleAnimation = props.toggleAnimation,
onChange = props.onChange,
setFilterPlot = props.setFilterPlot,
timeline = props.timeline;
var throttledOnchange = (0, _react.useMemo)(function () {
return (0, _lodash["default"])(onChange, 20);
}, [onChange]);
var binsForInterval = (0, _react.useMemo)(function () {
return getTimeBinsForInterval(timeBins, plotType === null || plotType === void 0 ? void 0 : plotType.interval);
}, [timeBins, plotType === null || plotType === void 0 ? void 0 : plotType.interval]);
var style = (0, _react.useMemo)(function () {
return {
width: isEnlarged ? "calc(100% - ".concat(animationControlWidth, "px)") : '100%'
};
}, [isEnlarged]);
return /*#__PURE__*/_react["default"].createElement("div", {
className: "time-range-slider"
}, !hideTimeTitle && isEnlarged ? /*#__PURE__*/_react["default"].createElement("div", {
className: "time-range-slider__title",
style: style
}, /*#__PURE__*/_react["default"].createElement(TimeRangeSliderTimeTitle, {
timeFormat: timeFormat,
timezone: timezone,
value: value,
isEnlarged: isEnlarged
})) : null, /*#__PURE__*/_react["default"].createElement(StyledSliderContainer, {
className: "time-range-slider__container",
isEnlarged: isEnlarged
}, !isMinified ? /*#__PURE__*/_react["default"].createElement("div", {
className: "timeline-container",
style: style
}, /*#__PURE__*/_react["default"].createElement(RangeSlider, {
range: domain,
value0: value[0],
value1: value[1],
bins: binsForInterval,
lineChart: lineChart,
invertTrendColor: invertTrendColor,
plotType: plotType,
isEnlarged: isEnlarged,
showInput: false,
step: step,
onChange: throttledOnchange,
xAxis: TimeSliderMarker,
timezone: timezone,
timeFormat: timeFormat,
setFilterPlot: setFilterPlot
})) : /*#__PURE__*/_react["default"].createElement(AnimationControl, {
style: ANIMATION_CONTROL_STYLE,
isAnimatable: isAnimatable,
isAnimating: isAnimating,
resetAnimation: resetAnimation,
toggleAnimation: toggleAnimation,
updateAnimationSpeed: updateAnimationSpeed,
setTimelineValue: throttledOnchange,
setAnimationWindow: setFilterAnimationWindow,
showTimeDisplay: false,
timeline: timeline
}), isEnlarged && !isMinified ? /*#__PURE__*/_react["default"].createElement(PlaybackControls, {
isAnimatable: isAnimatable,
width: animationControlWidth,
speed: speed,
animationWindow: animationWindow,
updateAnimationSpeed: updateAnimationSpeed,
setFilterAnimationWindow: setFilterAnimationWindow,
pauseAnimation: toggleAnimation,
resetAnimation: resetAnimation,
isAnimating: isAnimating,
startAnimation: toggleAnimation
}) : null));
};
return /*#__PURE__*/_react["default"].memo(TimeRangeSlider);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_lodash","_interopRequireDefault","_styledComponents","_rangeSlider","_timeSliderMarker","_playbackControls","_timeRangeSliderTimeTitle","_animationControl","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","animationControlWidth","StyledSliderContainer","styled","div","_taggedTemplateLiteral2","props","isEnlarged","ANIMATION_CONTROL_STYLE","flex","TimeRangeSliderFactory","deps","PlaybackControlsFactory","RangeSliderFactory","TimeSliderMarkerFactory","TimeRangeSliderTimeTitleFactory","AnimationControlFactory","getTimeBinsForInterval","timeBins","interval","keys","reduce","acc","dataId","PlaybackControls","RangeSlider","TimeSliderMarker","TimeRangeSliderTimeTitle","AnimationControl","TimeRangeSlider","domain","value","isMinified","hideTimeTitle","isAnimating","resetAnimation","timeFormat","timezone","plotType","lineChart","invertTrendColor","step","isAnimatable","speed","animationWindow","updateAnimationSpeed","setFilterAnimationWindow","toggleAnimation","onChange","setFilterPlot","timeline","throttledOnchange","useMemo","throttle","binsForInterval","style","width","concat","createElement","className","range","value0","value1","bins","showInput","xAxis","setTimelineValue","setAnimationWindow","showTimeDisplay","pauseAnimation","startAnimation","React","memo"],"sources":["../../src/common/time-range-slider.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useMemo} from 'react';\nimport throttle from 'lodash.throttle';\nimport styled, {IStyledComponent} from 'styled-components';\n\nimport RangeSliderFactory from './range-slider';\nimport TimeSliderMarkerFactory from './time-slider-marker';\nimport PlaybackControlsFactory from './animation-control/playback-controls';\nimport TimeRangeSliderTimeTitleFactory from './time-range-slider-time-title';\nimport {LineChart, Timeline, AnimationConfig, TimeBins} from '@kepler.gl/types';\nimport {ActionHandler, setFilterPlot} from '@kepler.gl/actions';\nimport AnimationControlFactory from './animation-control/animation-control';\nimport {BaseComponentProps} from '../types';\n\nconst animationControlWidth = 176;\n\ntype TimeRangeSliderProps = {\n  domain?: [number, number];\n  value: [number, number];\n  isEnlarged?: boolean;\n  isMinified?: boolean;\n  hideTimeTitle?: boolean;\n  isAnimating: boolean;\n  timeFormat: string;\n  timezone?: string | null;\n  timeBins?: TimeBins;\n  plotType?: {\n    [key: string]: any;\n  };\n  lineChart?: LineChart;\n  step: number;\n  isAnimatable?: boolean;\n  speed: number;\n  animationWindow: string;\n  resetAnimation?: () => void;\n  toggleAnimation: () => void;\n  updateAnimationSpeed?: (val: number) => void;\n  setFilterAnimationWindow?: (id: string) => void;\n  setFilterPlot?: ActionHandler<typeof setFilterPlot>;\n  onChange: (v: number[]) => void;\n  timeline: Timeline;\n  invertTrendColor?: boolean;\n  animationConfig?: AnimationConfig;\n};\n\nexport type StyledSliderContainerProps = BaseComponentProps & {\n  isEnlarged?: boolean;\n};\n\nconst StyledSliderContainer: IStyledComponent<\n  'web',\n  StyledSliderContainerProps\n> = styled.div<StyledSliderContainerProps>`\n  align-items: flex-end;\n  display: flex;\n  flex-direction: row;\n  justify-content: space-between;\n  padding-left: ${props => (props.isEnlarged ? 24 : 0)}px;\n\n  .timeline-container .kg-slider {\n    display: none;\n  }\n\n  .playback-controls {\n    margin-left: 22px;\n  }\n`;\n\nconst ANIMATION_CONTROL_STYLE = {flex: 1};\n\nTimeRangeSliderFactory.deps = [\n  PlaybackControlsFactory,\n  RangeSliderFactory,\n  TimeSliderMarkerFactory,\n  TimeRangeSliderTimeTitleFactory,\n  AnimationControlFactory\n];\n\nexport function getTimeBinsForInterval(timeBins: TimeBins | undefined, interval: number) {\n  if (!timeBins) return {};\n  return Object.keys(timeBins).reduce((acc, dataId) => {\n    acc[dataId] = timeBins[dataId][interval];\n    return acc;\n  }, {});\n}\n\nexport default function TimeRangeSliderFactory(\n  PlaybackControls: ReturnType<typeof PlaybackControlsFactory>,\n  RangeSlider: ReturnType<typeof RangeSliderFactory>,\n  TimeSliderMarker: ReturnType<typeof TimeSliderMarkerFactory>,\n  TimeRangeSliderTimeTitle: ReturnType<typeof TimeRangeSliderTimeTitleFactory>,\n  AnimationControl: ReturnType<typeof AnimationControlFactory>\n) {\n  const TimeRangeSlider: React.FC<TimeRangeSliderProps> = props => {\n    const {\n      domain,\n      value,\n      isEnlarged,\n      isMinified,\n      hideTimeTitle,\n      isAnimating,\n      resetAnimation,\n      timeFormat,\n      timezone,\n      timeBins,\n      plotType,\n      lineChart,\n      invertTrendColor,\n      step,\n      isAnimatable,\n      speed,\n      animationWindow,\n      updateAnimationSpeed,\n      setFilterAnimationWindow,\n      toggleAnimation,\n      onChange,\n      setFilterPlot,\n      timeline\n    } = props;\n\n    const throttledOnchange = useMemo(() => throttle(onChange, 20), [onChange]);\n    const binsForInterval = useMemo(\n      () => getTimeBinsForInterval(timeBins, plotType?.interval),\n      [timeBins, plotType?.interval]\n    );\n\n    const style = useMemo(\n      () => ({\n        width: isEnlarged ? `calc(100% - ${animationControlWidth}px)` : '100%'\n      }),\n      [isEnlarged]\n    );\n\n    return (\n      <div className=\"time-range-slider\">\n        {!hideTimeTitle && isEnlarged ? (\n          <div className=\"time-range-slider__title\" style={style}>\n            <TimeRangeSliderTimeTitle\n              timeFormat={timeFormat}\n              timezone={timezone}\n              value={value}\n              isEnlarged={isEnlarged}\n            />\n          </div>\n        ) : null}\n        <StyledSliderContainer className=\"time-range-slider__container\" isEnlarged={isEnlarged}>\n          {!isMinified ? (\n            <div className=\"timeline-container\" style={style}>\n              <RangeSlider\n                range={domain}\n                value0={value[0]}\n                value1={value[1]}\n                bins={binsForInterval}\n                lineChart={lineChart}\n                invertTrendColor={invertTrendColor}\n                plotType={plotType}\n                isEnlarged={isEnlarged}\n                showInput={false}\n                step={step}\n                onChange={throttledOnchange}\n                xAxis={TimeSliderMarker}\n                timezone={timezone}\n                timeFormat={timeFormat}\n                setFilterPlot={setFilterPlot}\n              />\n            </div>\n          ) : (\n            <AnimationControl\n              style={ANIMATION_CONTROL_STYLE}\n              isAnimatable={isAnimatable}\n              isAnimating={isAnimating}\n              resetAnimation={resetAnimation}\n              toggleAnimation={toggleAnimation}\n              updateAnimationSpeed={updateAnimationSpeed}\n              setTimelineValue={throttledOnchange}\n              setAnimationWindow={setFilterAnimationWindow}\n              showTimeDisplay={false}\n              timeline={timeline}\n            />\n          )}\n          {isEnlarged && !isMinified ? (\n            <PlaybackControls\n              isAnimatable={isAnimatable}\n              width={animationControlWidth}\n              speed={speed}\n              animationWindow={animationWindow}\n              updateAnimationSpeed={updateAnimationSpeed}\n              setFilterAnimationWindow={setFilterAnimationWindow}\n              pauseAnimation={toggleAnimation}\n              resetAnimation={resetAnimation}\n              isAnimating={isAnimating}\n              startAnimation={toggleAnimation}\n            />\n          ) : null}\n        </StyledSliderContainer>\n      </div>\n    );\n  };\n\n  return React.memo(TimeRangeSlider);\n}\n"],"mappings":";;;;;;;;;;AAGA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAD,sBAAA,CAAAF,OAAA;AAEA,IAAAI,YAAA,GAAAF,sBAAA,CAAAF,OAAA;AACA,IAAAK,iBAAA,GAAAH,sBAAA,CAAAF,OAAA;AACA,IAAAM,iBAAA,GAAAJ,sBAAA,CAAAF,OAAA;AACA,IAAAO,yBAAA,GAAAL,sBAAA,CAAAF,OAAA;AAGA,IAAAQ,iBAAA,GAAAN,sBAAA,CAAAF,OAAA;AAA4E,IAAAS,eAAA,EAb5E;AACA;AAAA,SAAAC,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAZ,wBAAAY,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,gBAAAK,OAAA,CAAAL,CAAA,0BAAAA,CAAA,sBAAAA,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,cAAAR,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAeA,IAAMW,qBAAqB,GAAG,GAAG;AAmCjC,IAAMC,qBAGL,GAAGC,4BAAM,CAACC,GAAG,CAAAxB,eAAA,KAAAA,eAAA,OAAAyB,uBAAA,6QAKI,UAAAC,KAAK;EAAA,OAAKA,KAAK,CAACC,UAAU,GAAG,EAAE,GAAG,CAAC;AAAA,CAAC,CASrD;AAED,IAAMC,uBAAuB,GAAG;EAACC,IAAI,EAAE;AAAC,CAAC;AAEzCC,sBAAsB,CAACC,IAAI,GAAG,CAC5BC,4BAAuB,EACvBC,uBAAkB,EAClBC,4BAAuB,EACvBC,oCAA+B,EAC/BC,4BAAuB,CACxB;AAEM,SAASC,sBAAsBA,CAACC,QAA8B,EAAEC,QAAgB,EAAE;EACvF,IAAI,CAACD,QAAQ,EAAE,OAAO,CAAC,CAAC;EACxB,OAAOzB,MAAM,CAAC2B,IAAI,CAACF,QAAQ,CAAC,CAACG,MAAM,CAAC,UAACC,GAAG,EAAEC,MAAM,EAAK;IACnDD,GAAG,CAACC,MAAM,CAAC,GAAGL,QAAQ,CAACK,MAAM,CAAC,CAACJ,QAAQ,CAAC;IACxC,OAAOG,GAAG;EACZ,CAAC,EAAE,CAAC,CAAC,CAAC;AACR;AAEe,SAASZ,sBAAsBA,CAC5Cc,gBAA4D,EAC5DC,WAAkD,EAClDC,gBAA4D,EAC5DC,wBAA4E,EAC5EC,gBAA4D,EAC5D;EACA,IAAMC,eAA+C,GAAG,SAAlDA,eAA+CA,CAAGvB,KAAK,EAAI;IAC/D,IACEwB,MAAM,GAuBJxB,KAAK,CAvBPwB,MAAM;MACNC,KAAK,GAsBHzB,KAAK,CAtBPyB,KAAK;MACLxB,UAAU,GAqBRD,KAAK,CArBPC,UAAU;MACVyB,UAAU,GAoBR1B,KAAK,CApBP0B,UAAU;MACVC,aAAa,GAmBX3B,KAAK,CAnBP2B,aAAa;MACbC,WAAW,GAkBT5B,KAAK,CAlBP4B,WAAW;MACXC,cAAc,GAiBZ7B,KAAK,CAjBP6B,cAAc;MACdC,UAAU,GAgBR9B,KAAK,CAhBP8B,UAAU;MACVC,QAAQ,GAeN/B,KAAK,CAfP+B,QAAQ;MACRnB,QAAQ,GAcNZ,KAAK,CAdPY,QAAQ;MACRoB,QAAQ,GAaNhC,KAAK,CAbPgC,QAAQ;MACRC,SAAS,GAYPjC,KAAK,CAZPiC,SAAS;MACTC,gBAAgB,GAWdlC,KAAK,CAXPkC,gBAAgB;MAChBC,IAAI,GAUFnC,KAAK,CAVPmC,IAAI;MACJC,YAAY,GASVpC,KAAK,CATPoC,YAAY;MACZC,KAAK,GAQHrC,KAAK,CARPqC,KAAK;MACLC,eAAe,GAObtC,KAAK,CAPPsC,eAAe;MACfC,oBAAoB,GAMlBvC,KAAK,CANPuC,oBAAoB;MACpBC,wBAAwB,GAKtBxC,KAAK,CALPwC,wBAAwB;MACxBC,eAAe,GAIbzC,KAAK,CAJPyC,eAAe;MACfC,QAAQ,GAGN1C,KAAK,CAHP0C,QAAQ;MACRC,aAAa,GAEX3C,KAAK,CAFP2C,aAAa;MACbC,QAAQ,GACN5C,KAAK,CADP4C,QAAQ;IAGV,IAAMC,iBAAiB,GAAG,IAAAC,cAAO,EAAC;MAAA,OAAM,IAAAC,kBAAQ,EAACL,QAAQ,EAAE,EAAE,CAAC;IAAA,GAAE,CAACA,QAAQ,CAAC,CAAC;IAC3E,IAAMM,eAAe,GAAG,IAAAF,cAAO,EAC7B;MAAA,OAAMnC,sBAAsB,CAACC,QAAQ,EAAEoB,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAEnB,QAAQ,CAAC;IAAA,GAC1D,CAACD,QAAQ,EAAEoB,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAEnB,QAAQ,CAC/B,CAAC;IAED,IAAMoC,KAAK,GAAG,IAAAH,cAAO,EACnB;MAAA,OAAO;QACLI,KAAK,EAAEjD,UAAU,kBAAAkD,MAAA,CAAkBxD,qBAAqB,WAAQ;MAClE,CAAC;IAAA,CAAC,EACF,CAACM,UAAU,CACb,CAAC;IAED,oBACEtC,MAAA,YAAAyF,aAAA;MAAKC,SAAS,EAAC;IAAmB,GAC/B,CAAC1B,aAAa,IAAI1B,UAAU,gBAC3BtC,MAAA,YAAAyF,aAAA;MAAKC,SAAS,EAAC,0BAA0B;MAACJ,KAAK,EAAEA;IAAM,gBACrDtF,MAAA,YAAAyF,aAAA,CAAC/B,wBAAwB;MACvBS,UAAU,EAAEA,UAAW;MACvBC,QAAQ,EAAEA,QAAS;MACnBN,KAAK,EAAEA,KAAM;MACbxB,UAAU,EAAEA;IAAW,CACxB,CACE,CAAC,GACJ,IAAI,eACRtC,MAAA,YAAAyF,aAAA,CAACxD,qBAAqB;MAACyD,SAAS,EAAC,8BAA8B;MAACpD,UAAU,EAAEA;IAAW,GACpF,CAACyB,UAAU,gBACV/D,MAAA,YAAAyF,aAAA;MAAKC,SAAS,EAAC,oBAAoB;MAACJ,KAAK,EAAEA;IAAM,gBAC/CtF,MAAA,YAAAyF,aAAA,CAACjC,WAAW;MACVmC,KAAK,EAAE9B,MAAO;MACd+B,MAAM,EAAE9B,KAAK,CAAC,CAAC,CAAE;MACjB+B,MAAM,EAAE/B,KAAK,CAAC,CAAC,CAAE;MACjBgC,IAAI,EAAET,eAAgB;MACtBf,SAAS,EAAEA,SAAU;MACrBC,gBAAgB,EAAEA,gBAAiB;MACnCF,QAAQ,EAAEA,QAAS;MACnB/B,UAAU,EAAEA,UAAW;MACvByD,SAAS,EAAE,KAAM;MACjBvB,IAAI,EAAEA,IAAK;MACXO,QAAQ,EAAEG,iBAAkB;MAC5Bc,KAAK,EAAEvC,gBAAiB;MACxBW,QAAQ,EAAEA,QAAS;MACnBD,UAAU,EAAEA,UAAW;MACvBa,aAAa,EAAEA;IAAc,CAC9B,CACE,CAAC,gBAENhF,MAAA,YAAAyF,aAAA,CAAC9B,gBAAgB;MACf2B,KAAK,EAAE/C,uBAAwB;MAC/BkC,YAAY,EAAEA,YAAa;MAC3BR,WAAW,EAAEA,WAAY;MACzBC,cAAc,EAAEA,cAAe;MAC/BY,eAAe,EAAEA,eAAgB;MACjCF,oBAAoB,EAAEA,oBAAqB;MAC3CqB,gBAAgB,EAAEf,iBAAkB;MACpCgB,kBAAkB,EAAErB,wBAAyB;MAC7CsB,eAAe,EAAE,KAAM;MACvBlB,QAAQ,EAAEA;IAAS,CACpB,CACF,EACA3C,UAAU,IAAI,CAACyB,UAAU,gBACxB/D,MAAA,YAAAyF,aAAA,CAAClC,gBAAgB;MACfkB,YAAY,EAAEA,YAAa;MAC3Bc,KAAK,EAAEvD,qBAAsB;MAC7B0C,KAAK,EAAEA,KAAM;MACbC,eAAe,EAAEA,eAAgB;MACjCC,oBAAoB,EAAEA,oBAAqB;MAC3CC,wBAAwB,EAAEA,wBAAyB;MACnDuB,cAAc,EAAEtB,eAAgB;MAChCZ,cAAc,EAAEA,cAAe;MAC/BD,WAAW,EAAEA,WAAY;MACzBoC,cAAc,EAAEvB;IAAgB,CACjC,CAAC,GACA,IACiB,CACpB,CAAC;EAEV,CAAC;EAED,oBAAOwB,iBAAK,CAACC,IAAI,CAAC3C,eAAe,CAAC;AACpC","ignoreList":[]}