kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
64 lines (63 loc) • 12.1 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = AnimationSpeedSliderFactory;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _react2 = require("@floating-ui/react");
var _constants = require("@kepler.gl/constants");
var _rangeSlider = _interopRequireDefault(require("../range-slider"));
var _templateObject, _templateObject2; // 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 SliderWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n"])));
var SpeedSliderContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n bottom: 50px;\n right: calc(0% - 32px);\n width: 180px;\n padding: 2px 8px 2px 12px;\n background-color: ", ";\n box-shadow: -2px -2px 0 0 rgba(0, 0, 0, 0.1);\n\n .kg-range-slider__input {\n width: 48px;\n padding: 6px;\n }\n"])), function (props) {
return props.theme.bottomWidgetBgd;
});
AnimationSpeedSliderFactory.deps = [_rangeSlider["default"]];
function AnimationSpeedSliderFactory(RangeSlider) {
var AnimationSpeedSlider = function AnimationSpeedSlider(_ref) {
var onHide = _ref.onHide,
speed = _ref.speed,
updateAnimationSpeed = _ref.updateAnimationSpeed;
// floating-ui boilerplate to establish close on outside click
var _useFloating = (0, _react2.useFloating)({
open: true,
onOpenChange: function onOpenChange(v) {
if (!v) {
onHide();
}
}
}),
refs = _useFloating.refs,
context = _useFloating.context;
var dismiss = (0, _react2.useDismiss)(context);
var _useInteractions = (0, _react2.useInteractions)([dismiss]),
getFloatingProps = _useInteractions.getFloatingProps;
var onChange = (0, _react.useCallback)(function (v) {
return updateAnimationSpeed(v[1]);
}, [updateAnimationSpeed]);
return /*#__PURE__*/_react["default"].createElement(SpeedSliderContainer, (0, _extends2["default"])({
className: "animation-control__speed-slider",
ref: refs.setFloating
}, getFloatingProps()), /*#__PURE__*/_react["default"].createElement(SliderWrapper, null, /*#__PURE__*/_react["default"].createElement(RangeSlider, {
range: _constants.SPEED_CONTROL_RANGE,
step: _constants.SPEED_CONTROL_STEP,
value0: 0,
value1: speed,
onChange: onChange,
isRanged: false,
showInput: true,
inputTheme: "secondary",
inputSize: "tiny"
})));
};
return AnimationSpeedSlider;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_react2","_constants","_rangeSlider","_templateObject","_templateObject2","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","SliderWrapper","styled","div","_taggedTemplateLiteral2","SpeedSliderContainer","props","theme","bottomWidgetBgd","AnimationSpeedSliderFactory","deps","RangeSliderFactory","RangeSlider","AnimationSpeedSlider","_ref","onHide","speed","updateAnimationSpeed","_useFloating","useFloating","open","onOpenChange","v","refs","context","dismiss","useDismiss","_useInteractions","useInteractions","getFloatingProps","onChange","useCallback","createElement","_extends2","className","ref","setFloating","range","SPEED_CONTROL_RANGE","step","SPEED_CONTROL_STEP","value0","value1","isRanged","showInput","inputTheme","inputSize"],"sources":["../../../src/common/animation-control/animation-speed-slider.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback} from 'react';\nimport styled from 'styled-components';\nimport {useDismiss, useFloating, useInteractions} from '@floating-ui/react';\n\nimport {SPEED_CONTROL_RANGE, SPEED_CONTROL_STEP} from '@kepler.gl/constants';\n\nimport RangeSliderFactory from '../range-slider';\n\nconst SliderWrapper = styled.div`\n  position: relative;\n`;\n\nconst SpeedSliderContainer = styled.div`\n  position: absolute;\n  bottom: 50px;\n  right: calc(0% - 32px);\n  width: 180px;\n  padding: 2px 8px 2px 12px;\n  background-color: ${props => props.theme.bottomWidgetBgd};\n  box-shadow: -2px -2px 0 0 rgba(0, 0, 0, 0.1);\n\n  .kg-range-slider__input {\n    width: 48px;\n    padding: 6px;\n  }\n`;\n\nAnimationSpeedSliderFactory.deps = [RangeSliderFactory];\n\ninterface AnimationSpeedSliderProps {\n  onHide: () => void;\n  speed: number;\n  updateAnimationSpeed: (val: number) => void;\n}\n\nexport default function AnimationSpeedSliderFactory(\n  RangeSlider: ReturnType<typeof RangeSliderFactory>\n): React.FC<AnimationSpeedSliderProps> {\n  const AnimationSpeedSlider: React.FC<AnimationSpeedSliderProps> = ({\n    onHide,\n    speed,\n    updateAnimationSpeed\n  }: AnimationSpeedSliderProps) => {\n    // floating-ui boilerplate to establish close on outside click\n    const {refs, context} = useFloating({\n      open: true,\n      onOpenChange: v => {\n        if (!v) {\n          onHide();\n        }\n      }\n    });\n    const dismiss = useDismiss(context);\n    const {getFloatingProps} = useInteractions([dismiss]);\n\n    const onChange = useCallback(v => updateAnimationSpeed(v[1]), [updateAnimationSpeed]);\n\n    return (\n      <SpeedSliderContainer\n        className=\"animation-control__speed-slider\"\n        ref={refs.setFloating}\n        {...getFloatingProps()}\n      >\n        <SliderWrapper>\n          <RangeSlider\n            range={SPEED_CONTROL_RANGE}\n            step={SPEED_CONTROL_STEP}\n            value0={0}\n            value1={speed}\n            onChange={onChange}\n            isRanged={false}\n            showInput\n            inputTheme=\"secondary\"\n            inputSize=\"tiny\"\n          />\n        </SliderWrapper>\n      </SpeedSliderContainer>\n    );\n  };\n  return AnimationSpeedSlider;\n}\n"],"mappings":"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","ignoreList":[]}
;