kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
278 lines (244 loc) • 35.6 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.AnimationWindowControl = exports.IconButton = void 0;
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
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 _localization = require("../../../localization");
var _styledComponents2 = require("../styled-components");
var _animationSpeedSlider = _interopRequireDefault(require("./animation-speed-slider"));
var _icons = require("../icons");
var _defaultSettings = require("../../../constants/default-settings");
var _dataUtils = require("../../../utils/data-utils");
var _templateObject, _templateObject2, _templateObject3, _DEFAULT_ANIMATE_ITEM;
var DELAY_SHOW = 500;
var DEFAULT_BUTTON_HEIGHT = '20px';
var StyledAnimationControls = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n position: relative;\n\n &.disabled {\n opacity: 0.4;\n pointer-events: none;\n }\n"])));
var StyledSpeedControl = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n\n .animation-control__speed-slider {\n left: 0;\n }\n"])));
var IconButton = (0, _styledComponents["default"])(_styledComponents2.Button)(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", "px;\n height: 32px;\n color: ", ";\n background-color: ", ";\n border-radius: 4px;\n margin-left: 7px;\n border: 0;\n padding: 0;\n\n .__react_component_tooltip {\n font-family: ", ";\n }\n svg {\n margin: 0;\n }\n &.active {\n background-color: ", ";\n }\n"])), function (props) {
return props.collapsed ? 0 : 32;
}, function (props) {
return props.theme.playbackButtonColor;
}, function (props) {
return props.theme.playbackButtonBgColor;
}, function (props) {
return props.theme.fontFamily;
}, function (props) {
return props.theme.playbackButtonActBgColor;
});
exports.IconButton = IconButton;
function nop() {}
var DEFAULT_ICONS = {
/* eslint-disable react/display-name */
reset: function reset(_) {
return /*#__PURE__*/_react["default"].createElement(_icons.Reset, {
height: "18px"
});
},
play: function play(_) {
return /*#__PURE__*/_react["default"].createElement(_icons.Play, {
height: "18px"
});
},
pause: function pause(_) {
return /*#__PURE__*/_react["default"].createElement(_icons.Pause, {
height: "18px"
});
},
/* eslint-enable react/display-name */
speed: _icons.Rocket,
animationFree: _icons.FreeWindow,
animationIncremental: _icons.AnchorWindow
};
var DEFAULT_ANIMATE_ITEMS = (_DEFAULT_ANIMATE_ITEM = {}, (0, _defineProperty2["default"])(_DEFAULT_ANIMATE_ITEM, _defaultSettings.ANIMATION_WINDOW.free, {
id: _defaultSettings.ANIMATION_WINDOW.free,
icon: DEFAULT_ICONS.animationFree,
tooltip: 'tooltip.animationByWindow'
}), (0, _defineProperty2["default"])(_DEFAULT_ANIMATE_ITEM, _defaultSettings.ANIMATION_WINDOW.incremental, {
id: _defaultSettings.ANIMATION_WINDOW.incremental,
icon: DEFAULT_ICONS.animationIncremental,
tooltip: 'tooltip.animationByIncremental'
}), _DEFAULT_ANIMATE_ITEM);
var AnimationWindowControl = function AnimationWindowControl(_ref) {
var _onClick = _ref.onClick,
selected = _ref.selected,
onHide = _ref.onHide,
height = _ref.height,
animationItems = _ref.animationItems,
_ref$btnStyle = _ref.btnStyle,
btnStyle = _ref$btnStyle === void 0 ? {} : _ref$btnStyle;
return /*#__PURE__*/_react["default"].createElement("div", null, Object.values(animationItems).filter(function (item) {
return item.id !== selected;
}).map(function (item) {
return /*#__PURE__*/_react["default"].createElement(IconButton, (0, _extends2["default"])({
key: item.id,
"data-tip": true,
"data-for": "".concat(item.id, "-tooltip"),
className: "playback-control-button",
onClick: function onClick() {
_onClick(item.id);
onHide();
}
}, btnStyle), /*#__PURE__*/_react["default"].createElement(item.icon, {
height: height
}), item.tooltip ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, {
id: "".concat(item.id, "-tooltip"),
effect: "solid",
place: "top"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: item.tooltip
})) : null);
}));
};
exports.AnimationWindowControl = AnimationWindowControl;
PlaybackControlsFactory.deps = [_animationSpeedSlider["default"]];
function PlaybackControlsFactory(AnimationSpeedSlider) {
// eslint-disable-next-line complexity
var PlaybackControls = function PlaybackControls(_ref2) {
var _ref2$isAnimatable = _ref2.isAnimatable,
isAnimatable = _ref2$isAnimatable === void 0 ? true : _ref2$isAnimatable,
isAnimating = _ref2.isAnimating,
width = _ref2.width,
speed = _ref2.speed,
_ref2$animationWindow = _ref2.animationWindow,
animationWindow = _ref2$animationWindow === void 0 ? _defaultSettings.ANIMATION_WINDOW.free : _ref2$animationWindow,
setFilterAnimationWindow = _ref2.setFilterAnimationWindow,
updateAnimationSpeed = _ref2.updateAnimationSpeed,
_ref2$pauseAnimation = _ref2.pauseAnimation,
pauseAnimation = _ref2$pauseAnimation === void 0 ? nop : _ref2$pauseAnimation,
_ref2$resetAnimation = _ref2.resetAnimation,
resetAnimation = _ref2$resetAnimation === void 0 ? nop : _ref2$resetAnimation,
_ref2$startAnimation = _ref2.startAnimation,
startAnimation = _ref2$startAnimation === void 0 ? nop : _ref2$startAnimation,
_ref2$playbackIcons = _ref2.playbackIcons,
playbackIcons = _ref2$playbackIcons === void 0 ? DEFAULT_ICONS : _ref2$playbackIcons,
_ref2$animationItems = _ref2.animationItems,
animationItems = _ref2$animationItems === void 0 ? DEFAULT_ANIMATE_ITEMS : _ref2$animationItems,
_ref2$buttonStyle = _ref2.buttonStyle,
buttonStyle = _ref2$buttonStyle === void 0 ? 'secondary' : _ref2$buttonStyle,
_ref2$buttonHeight = _ref2.buttonHeight,
buttonHeight = _ref2$buttonHeight === void 0 ? DEFAULT_BUTTON_HEIGHT : _ref2$buttonHeight;
var _useState = (0, _react.useState)(false),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
isSpeedControlVisible = _useState2[0],
toggleSpeedControl = _useState2[1];
var _useState3 = (0, _react.useState)(false),
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
showAnimationWindowControl = _useState4[0],
setShowAnimationWindowControl = _useState4[1];
var toggleAnimationWindowControl = (0, _react.useCallback)(function () {
setShowAnimationWindowControl(!showAnimationWindowControl);
}, [showAnimationWindowControl, setShowAnimationWindowControl]);
var btnStyle = buttonStyle ? (0, _defineProperty2["default"])({}, buttonStyle, true) : {};
var hideAndShowSpeedControl = (0, _react.useCallback)(function () {
if (!isSpeedControlVisible) {
toggleSpeedControl(true);
} else {
// TODO: A HACK to allow input onblur get triggered before the input is unmounted
// A better solution should be invested, see https://github.com/facebook/react/issues/12363
window.setTimeout(function () {
return toggleSpeedControl(false);
}, 200);
}
}, [isSpeedControlVisible, toggleSpeedControl]);
return /*#__PURE__*/_react["default"].createElement(StyledAnimationControls, {
className: (0, _classnames["default"])('playback-controls', {
disabled: !isAnimatable
}),
style: {
width: "".concat(width, "px")
}
}, setFilterAnimationWindow ? /*#__PURE__*/_react["default"].createElement(IconButton, (0, _extends2["default"])({
"data-tip": true,
"data-for": "animate-window",
className: (0, _classnames["default"])('playback-control-button', {
active: showAnimationWindowControl
}),
onClick: toggleAnimationWindowControl
}, btnStyle), function () {
if (animationItems[animationWindow]) {
var WindowIcon = animationItems[animationWindow].icon;
return /*#__PURE__*/_react["default"].createElement(WindowIcon, {
height: buttonHeight
});
}
return null;
}(), animationItems[animationWindow] && animationItems[animationWindow].tooltip ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, {
id: "animate-window",
place: "top",
delayShow: 500,
effect: "solid"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: animationItems[animationWindow].tooltip
})) : null) : null, showAnimationWindowControl ? /*#__PURE__*/_react["default"].createElement(AnimationWindowControl, {
onClick: setFilterAnimationWindow,
selected: animationWindow,
onHide: toggleAnimationWindowControl,
height: buttonHeight,
btnStyle: btnStyle,
animationItems: animationItems
}) : null, showAnimationWindowControl || !updateAnimationSpeed ? null : /*#__PURE__*/_react["default"].createElement(StyledSpeedControl, null, /*#__PURE__*/_react["default"].createElement(IconButton, (0, _extends2["default"])({
"data-tip": true,
"data-for": "animate-speed",
className: "playback-control-button"
}, btnStyle, {
onClick: hideAndShowSpeedControl
}), /*#__PURE__*/_react["default"].createElement(playbackIcons.speed, {
height: buttonHeight
}), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, {
id: "animate-speed",
place: "top",
delayShow: DELAY_SHOW,
effect: "solid"
}, /*#__PURE__*/_react["default"].createElement("span", null, (0, _dataUtils.preciseRound)(speed, 1), "x"))), isSpeedControlVisible ? /*#__PURE__*/_react["default"].createElement(AnimationSpeedSlider, {
onHide: hideAndShowSpeedControl,
updateAnimationSpeed: updateAnimationSpeed,
speed: speed
}) : null), showAnimationWindowControl ? null : /*#__PURE__*/_react["default"].createElement(IconButton, (0, _extends2["default"])({
"data-tip": true,
"data-for": "animate-reset",
className: "playback-control-button",
onClick: resetAnimation
}, btnStyle), /*#__PURE__*/_react["default"].createElement(playbackIcons.reset, {
height: buttonHeight
}), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, {
id: "animate-reset",
place: "top",
delayShow: DELAY_SHOW,
effect: "solid"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "tooltip.reset"
}))), showAnimationWindowControl ? null : /*#__PURE__*/_react["default"].createElement(IconButton, (0, _extends2["default"])({
"data-tip": true,
"data-for": "animate-play-pause",
className: (0, _classnames["default"])('playback-control-button', {
active: isAnimating
}),
onClick: isAnimating ? pauseAnimation : startAnimation,
hide: isSpeedControlVisible
}, btnStyle), isAnimating ? /*#__PURE__*/_react["default"].createElement(playbackIcons.pause, {
height: buttonHeight
}) : /*#__PURE__*/_react["default"].createElement(playbackIcons.play, {
height: buttonHeight
}), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, {
id: "animate-play-pause",
place: "top",
delayShow: DELAY_SHOW,
effect: "solid"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: isAnimating ? 'tooltip.pause' : 'tooltip.play'
}))));
};
return PlaybackControls;
}
var _default = PlaybackControlsFactory;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/common/animation-control/playback-controls.js"],"names":["DELAY_SHOW","DEFAULT_BUTTON_HEIGHT","StyledAnimationControls","styled","div","StyledSpeedControl","IconButton","Button","props","collapsed","theme","playbackButtonColor","playbackButtonBgColor","fontFamily","playbackButtonActBgColor","nop","DEFAULT_ICONS","reset","_","play","pause","speed","Rocket","animationFree","FreeWindow","animationIncremental","AnchorWindow","DEFAULT_ANIMATE_ITEMS","ANIMATION_WINDOW","free","id","icon","tooltip","incremental","AnimationWindowControl","onClick","selected","onHide","height","animationItems","btnStyle","Object","values","filter","item","map","PlaybackControlsFactory","deps","AnimationSpeedSliderFactory","AnimationSpeedSlider","PlaybackControls","isAnimatable","isAnimating","width","animationWindow","setFilterAnimationWindow","updateAnimationSpeed","pauseAnimation","resetAnimation","startAnimation","playbackIcons","buttonStyle","buttonHeight","isSpeedControlVisible","toggleSpeedControl","showAnimationWindowControl","setShowAnimationWindowControl","toggleAnimationWindowControl","hideAndShowSpeedControl","window","setTimeout","disabled","active","WindowIcon"],"mappings":";;;;;;;;;;;;;;;;;;;AAoBA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAEA,IAAMA,UAAU,GAAG,GAAnB;AACA,IAAMC,qBAAqB,GAAG,MAA9B;;AAEA,IAAMC,uBAAuB,GAAGC,6BAAOC,GAAV,sMAA7B;;AAUA,IAAMC,kBAAkB,GAAGF,6BAAOC,GAAV,+LAAxB;;AASO,IAAME,UAAU,GAAG,kCAAOC,yBAAP,CAAH,+XACZ,UAAAC,KAAK;AAAA,SAAKA,KAAK,CAACC,SAAN,GAAkB,CAAlB,GAAsB,EAA3B;AAAA,CADO,EAGZ,UAAAD,KAAK;AAAA,SAAIA,KAAK,CAACE,KAAN,CAAYC,mBAAhB;AAAA,CAHO,EAID,UAAAH,KAAK;AAAA,SAAIA,KAAK,CAACE,KAAN,CAAYE,qBAAhB;AAAA,CAJJ,EAWJ,UAAAJ,KAAK;AAAA,SAAIA,KAAK,CAACE,KAAN,CAAYG,UAAhB;AAAA,CAXD,EAiBC,UAAAL,KAAK;AAAA,SAAIA,KAAK,CAACE,KAAN,CAAYI,wBAAhB;AAAA,CAjBN,CAAhB;;;AAqBP,SAASC,GAAT,GAAe,CAAE;;AACjB,IAAMC,aAAa,GAAG;AACpB;AACAC,EAAAA,KAAK,EAAE,eAAAC,CAAC;AAAA,wBAAI,gCAAC,YAAD;AAAO,MAAA,MAAM,EAAC;AAAd,MAAJ;AAAA,GAFY;AAGpBC,EAAAA,IAAI,EAAE,cAAAD,CAAC;AAAA,wBAAI,gCAAC,WAAD;AAAM,MAAA,MAAM,EAAC;AAAb,MAAJ;AAAA,GAHa;AAIpBE,EAAAA,KAAK,EAAE,eAAAF,CAAC;AAAA,wBAAI,gCAAC,YAAD;AAAO,MAAA,MAAM,EAAC;AAAd,MAAJ;AAAA,GAJY;;AAKpB;AACAG,EAAAA,KAAK,EAAEC,aANa;AAOpBC,EAAAA,aAAa,EAAEC,iBAPK;AAQpBC,EAAAA,oBAAoB,EAAEC;AARF,CAAtB;AAWA,IAAMC,qBAAqB,wFACxBC,kCAAiBC,IADO,EACA;AACvBC,EAAAA,EAAE,EAAEF,kCAAiBC,IADE;AAEvBE,EAAAA,IAAI,EAAEf,aAAa,CAACO,aAFG;AAGvBS,EAAAA,OAAO,EAAE;AAHc,CADA,2DAMxBJ,kCAAiBK,WANO,EAMO;AAC9BH,EAAAA,EAAE,EAAEF,kCAAiBK,WADS;AAE9BF,EAAAA,IAAI,EAAEf,aAAa,CAACS,oBAFU;AAG9BO,EAAAA,OAAO,EAAE;AAHqB,CANP,yBAA3B;;AAaO,IAAME,sBAAsB,GAAG,SAAzBA,sBAAyB;AAAA,MACpCC,QADoC,QACpCA,OADoC;AAAA,MAEpCC,QAFoC,QAEpCA,QAFoC;AAAA,MAGpCC,MAHoC,QAGpCA,MAHoC;AAAA,MAIpCC,MAJoC,QAIpCA,MAJoC;AAAA,MAKpCC,cALoC,QAKpCA,cALoC;AAAA,2BAMpCC,QANoC;AAAA,MAMpCA,QANoC,8BAMzB,EANyB;AAAA,sBAQpC,6CACGC,MAAM,CAACC,MAAP,CAAcH,cAAd,EACEI,MADF,CACS,UAAAC,IAAI;AAAA,WAAIA,IAAI,CAACd,EAAL,KAAYM,QAAhB;AAAA,GADb,EAEES,GAFF,CAEM,UAAAD,IAAI;AAAA,wBACP,gCAAC,UAAD;AACE,MAAA,GAAG,EAAEA,IAAI,CAACd,EADZ;AAEE,sBAFF;AAGE,4BAAac,IAAI,CAACd,EAAlB,aAHF;AAIE,MAAA,SAAS,EAAC,yBAJZ;AAKE,MAAA,OAAO,EAAE,mBAAM;AACbK,QAAAA,QAAO,CAACS,IAAI,CAACd,EAAN,CAAP;;AACAO,QAAAA,MAAM;AACP;AARH,OASMG,QATN,gBAWE,gCAAC,IAAD,CAAM,IAAN;AAAW,MAAA,MAAM,EAAEF;AAAnB,MAXF,EAYGM,IAAI,CAACZ,OAAL,gBACC,gCAAC,0BAAD;AAAS,MAAA,EAAE,YAAKY,IAAI,CAACd,EAAV,aAAX;AAAmC,MAAA,MAAM,EAAC,OAA1C;AAAkD,MAAA,KAAK,EAAC;AAAxD,oBACE,gCAAC,8BAAD;AAAkB,MAAA,EAAE,EAAEc,IAAI,CAACZ;AAA3B,MADF,CADD,GAIG,IAhBN,CADO;AAAA,GAFV,CADH,CARoC;AAAA,CAA/B;;;AAkCPc,uBAAuB,CAACC,IAAxB,GAA+B,CAACC,gCAAD,CAA/B;;AACA,SAASF,uBAAT,CAAiCG,oBAAjC,EAAuD;AACrD;AACA,MAAMC,gBAAgB,GAAG,SAAnBA,gBAAmB,QAenB;AAAA,mCAdJC,YAcI;AAAA,QAdJA,YAcI,mCAdW,IAcX;AAAA,QAbJC,WAaI,SAbJA,WAaI;AAAA,QAZJC,KAYI,SAZJA,KAYI;AAAA,QAXJhC,KAWI,SAXJA,KAWI;AAAA,sCAVJiC,eAUI;AAAA,QAVJA,eAUI,sCAVc1B,kCAAiBC,IAU/B;AAAA,QATJ0B,wBASI,SATJA,wBASI;AAAA,QARJC,oBAQI,SARJA,oBAQI;AAAA,qCAPJC,cAOI;AAAA,QAPJA,cAOI,qCAPa1C,GAOb;AAAA,qCANJ2C,cAMI;AAAA,QANJA,cAMI,qCANa3C,GAMb;AAAA,qCALJ4C,cAKI;AAAA,QALJA,cAKI,qCALa5C,GAKb;AAAA,oCAJJ6C,aAII;AAAA,QAJJA,aAII,oCAJY5C,aAIZ;AAAA,qCAHJuB,cAGI;AAAA,QAHJA,cAGI,qCAHaZ,qBAGb;AAAA,kCAFJkC,WAEI;AAAA,QAFJA,WAEI,kCAFU,WAEV;AAAA,mCADJC,YACI;AAAA,QADJA,YACI,mCADW7D,qBACX;;AAAA,oBACgD,qBAAS,KAAT,CADhD;AAAA;AAAA,QACG8D,qBADH;AAAA,QAC0BC,kBAD1B;;AAAA,qBAEgE,qBAAS,KAAT,CAFhE;AAAA;AAAA,QAEGC,0BAFH;AAAA,QAE+BC,6BAF/B;;AAIJ,QAAMC,4BAA4B,GAAG,wBAAY,YAAM;AACrDD,MAAAA,6BAA6B,CAAC,CAACD,0BAAF,CAA7B;AACD,KAFoC,EAElC,CAACA,0BAAD,EAA6BC,6BAA7B,CAFkC,CAArC;AAGA,QAAM1B,QAAQ,GAAGqB,WAAW,wCAAKA,WAAL,EAAmB,IAAnB,IAA2B,EAAvD;AAEA,QAAMO,uBAAuB,GAAG,wBAAY,YAAM;AAChD,UAAI,CAACL,qBAAL,EAA4B;AAC1BC,QAAAA,kBAAkB,CAAC,IAAD,CAAlB;AACD,OAFD,MAEO;AACL;AACA;AACAK,QAAAA,MAAM,CAACC,UAAP,CAAkB;AAAA,iBAAMN,kBAAkB,CAAC,KAAD,CAAxB;AAAA,SAAlB,EAAmD,GAAnD;AACD;AACF,KAR+B,EAQ7B,CAACD,qBAAD,EAAwBC,kBAAxB,CAR6B,CAAhC;AASA,wBACE,gCAAC,uBAAD;AACE,MAAA,SAAS,EAAE,4BAAW,mBAAX,EAAgC;AACzCO,QAAAA,QAAQ,EAAE,CAACpB;AAD8B,OAAhC,CADb;AAIE,MAAA,KAAK,EAAE;AAACE,QAAAA,KAAK,YAAKA,KAAL;AAAN;AAJT,OAOGE,wBAAwB,gBACvB,gCAAC,UAAD;AACE,sBADF;AAEE,kBAAS,gBAFX;AAGE,MAAA,SAAS,EAAE,4BAAW,yBAAX,EAAsC;AAACiB,QAAAA,MAAM,EAAEP;AAAT,OAAtC,CAHb;AAIE,MAAA,OAAO,EAAEE;AAJX,OAKM3B,QALN,GAOI,YAAM;AACN,UAAID,cAAc,CAACe,eAAD,CAAlB,EAAqC;AACnC,YAAMmB,UAAU,GAAGlC,cAAc,CAACe,eAAD,CAAd,CAAgCvB,IAAnD;AACA,4BAAO,gCAAC,UAAD;AAAY,UAAA,MAAM,EAAE+B;AAApB,UAAP;AACD;;AACD,aAAO,IAAP;AACD,KANA,EAPH,EAcGvB,cAAc,CAACe,eAAD,CAAd,IAAmCf,cAAc,CAACe,eAAD,CAAd,CAAgCtB,OAAnE,gBACC,gCAAC,0BAAD;AAAS,MAAA,EAAE,EAAC,gBAAZ;AAA6B,MAAA,KAAK,EAAC,KAAnC;AAAyC,MAAA,SAAS,EAAE,GAApD;AAAyD,MAAA,MAAM,EAAC;AAAhE,oBACE,gCAAC,8BAAD;AAAkB,MAAA,EAAE,EAAEO,cAAc,CAACe,eAAD,CAAd,CAAgCtB;AAAtD,MADF,CADD,GAIG,IAlBN,CADuB,GAqBrB,IA5BN,EA8BGiC,0BAA0B,gBACzB,gCAAC,sBAAD;AACE,MAAA,OAAO,EAAEV,wBADX;AAEE,MAAA,QAAQ,EAAED,eAFZ;AAGE,MAAA,MAAM,EAAEa,4BAHV;AAIE,MAAA,MAAM,EAAEL,YAJV;AAKE,MAAA,QAAQ,EAAEtB,QALZ;AAME,MAAA,cAAc,EAAED;AANlB,MADyB,GASvB,IAvCN,EA0CG0B,0BAA0B,IAAI,CAACT,oBAA/B,GAAsD,IAAtD,gBACC,gCAAC,kBAAD,qBACE,gCAAC,UAAD;AACE,sBADF;AAEE,kBAAS,eAFX;AAGE,MAAA,SAAS,EAAC;AAHZ,OAIMhB,QAJN;AAKE,MAAA,OAAO,EAAE4B;AALX,qBAOE,gCAAC,aAAD,CAAe,KAAf;AAAqB,MAAA,MAAM,EAAEN;AAA7B,MAPF,eAQE,gCAAC,0BAAD;AAAS,MAAA,EAAE,EAAC,eAAZ;AAA4B,MAAA,KAAK,EAAC,KAAlC;AAAwC,MAAA,SAAS,EAAE9D,UAAnD;AAA+D,MAAA,MAAM,EAAC;AAAtE,oBACE,8CAAO,6BAAaqB,KAAb,EAAoB,CAApB,CAAP,MADF,CARF,CADF,EAaG0C,qBAAqB,gBACpB,gCAAC,oBAAD;AACE,MAAA,MAAM,EAAEK,uBADV;AAEE,MAAA,oBAAoB,EAAEZ,oBAFxB;AAGE,MAAA,KAAK,EAAEnC;AAHT,MADoB,GAMlB,IAnBN,CA3CJ,EAmEG4C,0BAA0B,GAAG,IAAH,gBACzB,gCAAC,UAAD;AACE,sBADF;AAEE,kBAAS,eAFX;AAGE,MAAA,SAAS,EAAC,yBAHZ;AAIE,MAAA,OAAO,EAAEP;AAJX,OAKMlB,QALN,gBAOE,gCAAC,aAAD,CAAe,KAAf;AAAqB,MAAA,MAAM,EAAEsB;AAA7B,MAPF,eAQE,gCAAC,0BAAD;AAAS,MAAA,EAAE,EAAC,eAAZ;AAA4B,MAAA,KAAK,EAAC,KAAlC;AAAwC,MAAA,SAAS,EAAE9D,UAAnD;AAA+D,MAAA,MAAM,EAAC;AAAtE,oBACE,gCAAC,8BAAD;AAAkB,MAAA,EAAE,EAAC;AAArB,MADF,CARF,CApEJ,EAmFGiE,0BAA0B,GAAG,IAAH,gBACzB,gCAAC,UAAD;AACE,sBADF;AAEE,kBAAS,oBAFX;AAGE,MAAA,SAAS,EAAE,4BAAW,yBAAX,EAAsC;AAACO,QAAAA,MAAM,EAAEpB;AAAT,OAAtC,CAHb;AAIE,MAAA,OAAO,EAAEA,WAAW,GAAGK,cAAH,GAAoBE,cAJ1C;AAKE,MAAA,IAAI,EAAEI;AALR,OAMMvB,QANN,GAQGY,WAAW,gBACV,gCAAC,aAAD,CAAe,KAAf;AAAqB,MAAA,MAAM,EAAEU;AAA7B,MADU,gBAGV,gCAAC,aAAD,CAAe,IAAf;AAAoB,MAAA,MAAM,EAAEA;AAA5B,MAXJ,eAaE,gCAAC,0BAAD;AAAS,MAAA,EAAE,EAAC,oBAAZ;AAAiC,MAAA,KAAK,EAAC,KAAvC;AAA6C,MAAA,SAAS,EAAE9D,UAAxD;AAAoE,MAAA,MAAM,EAAC;AAA3E,oBACE,gCAAC,8BAAD;AAAkB,MAAA,EAAE,EAAEoD,WAAW,GAAG,eAAH,GAAqB;AAAtD,MADF,CAbF,CApFJ,CADF;AAyGD,GA1ID;;AA2IA,SAAOF,gBAAP;AACD;;eAEcJ,uB","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, {useState, useCallback} from 'react';\nimport styled from 'styled-components';\nimport classnames from 'classnames';\nimport {FormattedMessage} from 'localization';\nimport {Button, Tooltip} from 'components/common/styled-components';\nimport AnimationSpeedSliderFactory from './animation-speed-slider';\nimport {Reset, Play, Pause, Rocket, AnchorWindow, FreeWindow} from 'components/common/icons';\nimport {ANIMATION_WINDOW} from 'constants/default-settings';\nimport {preciseRound} from 'utils/data-utils';\n\nconst DELAY_SHOW = 500;\nconst DEFAULT_BUTTON_HEIGHT = '20px';\n\nconst StyledAnimationControls = styled.div`\n  display: flex;\n  position: relative;\n\n  &.disabled {\n    opacity: 0.4;\n    pointer-events: none;\n  }\n`;\n\nconst StyledSpeedControl = styled.div`\n  display: flex;\n  align-items: center;\n\n  .animation-control__speed-slider {\n    left: 0;\n  }\n`;\n\nexport const IconButton = styled(Button)`\n  width: ${props => (props.collapsed ? 0 : 32)}px;\n  height: 32px;\n  color: ${props => props.theme.playbackButtonColor};\n  background-color: ${props => props.theme.playbackButtonBgColor};\n  border-radius: 4px;\n  margin-left: 7px;\n  border: 0;\n  padding: 0;\n\n  .__react_component_tooltip {\n    font-family: ${props => props.theme.fontFamily};\n  }\n  svg {\n    margin: 0;\n  }\n  &.active {\n    background-color: ${props => props.theme.playbackButtonActBgColor};\n  }\n`;\n\nfunction nop() {}\nconst DEFAULT_ICONS = {\n  /* eslint-disable react/display-name */\n  reset: _ => <Reset height=\"18px\" />,\n  play: _ => <Play height=\"18px\" />,\n  pause: _ => <Pause height=\"18px\" />,\n  /* eslint-enable react/display-name */\n  speed: Rocket,\n  animationFree: FreeWindow,\n  animationIncremental: AnchorWindow\n};\n\nconst DEFAULT_ANIMATE_ITEMS = {\n  [ANIMATION_WINDOW.free]: {\n    id: ANIMATION_WINDOW.free,\n    icon: DEFAULT_ICONS.animationFree,\n    tooltip: 'tooltip.animationByWindow'\n  },\n  [ANIMATION_WINDOW.incremental]: {\n    id: ANIMATION_WINDOW.incremental,\n    icon: DEFAULT_ICONS.animationIncremental,\n    tooltip: 'tooltip.animationByIncremental'\n  }\n};\n\nexport const AnimationWindowControl = ({\n  onClick,\n  selected,\n  onHide,\n  height,\n  animationItems,\n  btnStyle = {}\n}) => (\n  <div>\n    {Object.values(animationItems)\n      .filter(item => item.id !== selected)\n      .map(item => (\n        <IconButton\n          key={item.id}\n          data-tip\n          data-for={`${item.id}-tooltip`}\n          className=\"playback-control-button\"\n          onClick={() => {\n            onClick(item.id);\n            onHide();\n          }}\n          {...btnStyle}\n        >\n          <item.icon height={height} />\n          {item.tooltip ? (\n            <Tooltip id={`${item.id}-tooltip`} effect=\"solid\" place=\"top\">\n              <FormattedMessage id={item.tooltip} />\n            </Tooltip>\n          ) : null}\n        </IconButton>\n      ))}\n  </div>\n);\n\nPlaybackControlsFactory.deps = [AnimationSpeedSliderFactory];\nfunction PlaybackControlsFactory(AnimationSpeedSlider) {\n  // eslint-disable-next-line complexity\n  const PlaybackControls = ({\n    isAnimatable = true,\n    isAnimating,\n    width,\n    speed,\n    animationWindow = ANIMATION_WINDOW.free,\n    setFilterAnimationWindow,\n    updateAnimationSpeed,\n    pauseAnimation = nop,\n    resetAnimation = nop,\n    startAnimation = nop,\n    playbackIcons = DEFAULT_ICONS,\n    animationItems = DEFAULT_ANIMATE_ITEMS,\n    buttonStyle = 'secondary',\n    buttonHeight = DEFAULT_BUTTON_HEIGHT\n  }) => {\n    const [isSpeedControlVisible, toggleSpeedControl] = useState(false);\n    const [showAnimationWindowControl, setShowAnimationWindowControl] = useState(false);\n\n    const toggleAnimationWindowControl = useCallback(() => {\n      setShowAnimationWindowControl(!showAnimationWindowControl);\n    }, [showAnimationWindowControl, setShowAnimationWindowControl]);\n    const btnStyle = buttonStyle ? {[buttonStyle]: true} : {};\n\n    const hideAndShowSpeedControl = useCallback(() => {\n      if (!isSpeedControlVisible) {\n        toggleSpeedControl(true);\n      } else {\n        // TODO: A HACK to allow input onblur get triggered before the input is unmounted\n        // A better solution should be invested, see https://github.com/facebook/react/issues/12363\n        window.setTimeout(() => toggleSpeedControl(false), 200);\n      }\n    }, [isSpeedControlVisible, toggleSpeedControl]);\n    return (\n      <StyledAnimationControls\n        className={classnames('playback-controls', {\n          disabled: !isAnimatable\n        })}\n        style={{width: `${width}px`}}\n      >\n        {/** Window */}\n        {setFilterAnimationWindow ? (\n          <IconButton\n            data-tip\n            data-for=\"animate-window\"\n            className={classnames('playback-control-button', {active: showAnimationWindowControl})}\n            onClick={toggleAnimationWindowControl}\n            {...btnStyle}\n          >\n            {(() => {\n              if (animationItems[animationWindow]) {\n                const WindowIcon = animationItems[animationWindow].icon;\n                return <WindowIcon height={buttonHeight} />;\n              }\n              return null;\n            })()}\n            {animationItems[animationWindow] && animationItems[animationWindow].tooltip ? (\n              <Tooltip id=\"animate-window\" place=\"top\" delayShow={500} effect=\"solid\">\n                <FormattedMessage id={animationItems[animationWindow].tooltip} />\n              </Tooltip>\n            ) : null}\n          </IconButton>\n        ) : null}\n\n        {showAnimationWindowControl ? (\n          <AnimationWindowControl\n            onClick={setFilterAnimationWindow}\n            selected={animationWindow}\n            onHide={toggleAnimationWindowControl}\n            height={buttonHeight}\n            btnStyle={btnStyle}\n            animationItems={animationItems}\n          />\n        ) : null}\n\n        {/** Speed */}\n        {showAnimationWindowControl || !updateAnimationSpeed ? null : (\n          <StyledSpeedControl>\n            <IconButton\n              data-tip\n              data-for=\"animate-speed\"\n              className=\"playback-control-button\"\n              {...btnStyle}\n              onClick={hideAndShowSpeedControl}\n            >\n              <playbackIcons.speed height={buttonHeight} />\n              <Tooltip id=\"animate-speed\" place=\"top\" delayShow={DELAY_SHOW} effect=\"solid\">\n                <span>{preciseRound(speed, 1)}x</span>\n              </Tooltip>\n            </IconButton>\n            {isSpeedControlVisible ? (\n              <AnimationSpeedSlider\n                onHide={hideAndShowSpeedControl}\n                updateAnimationSpeed={updateAnimationSpeed}\n                speed={speed}\n              />\n            ) : null}\n          </StyledSpeedControl>\n        )}\n\n        {/** Reset */}\n        {showAnimationWindowControl ? null : (\n          <IconButton\n            data-tip\n            data-for=\"animate-reset\"\n            className=\"playback-control-button\"\n            onClick={resetAnimation}\n            {...btnStyle}\n          >\n            <playbackIcons.reset height={buttonHeight} />\n            <Tooltip id=\"animate-reset\" place=\"top\" delayShow={DELAY_SHOW} effect=\"solid\">\n              <FormattedMessage id=\"tooltip.reset\" />\n            </Tooltip>\n          </IconButton>\n        )}\n\n        {/** Play and pause */}\n        {showAnimationWindowControl ? null : (\n          <IconButton\n            data-tip\n            data-for=\"animate-play-pause\"\n            className={classnames('playback-control-button', {active: isAnimating})}\n            onClick={isAnimating ? pauseAnimation : startAnimation}\n            hide={isSpeedControlVisible}\n            {...btnStyle}\n          >\n            {isAnimating ? (\n              <playbackIcons.pause height={buttonHeight} />\n            ) : (\n              <playbackIcons.play height={buttonHeight} />\n            )}\n            <Tooltip id=\"animate-play-pause\" place=\"top\" delayShow={DELAY_SHOW} effect=\"solid\">\n              <FormattedMessage id={isAnimating ? 'tooltip.pause' : 'tooltip.play'} />\n            </Tooltip>\n          </IconButton>\n        )}\n      </StyledAnimationControls>\n    );\n  };\n  return PlaybackControls;\n}\n\nexport default PlaybackControlsFactory;\n"]}