kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
223 lines (182 loc) • 21.9 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = undefined;
var _extends2 = require('babel-runtime/helpers/extends');
var _extends3 = _interopRequireDefault(_extends2);
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral');
var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2);
var _class, _temp2;
var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n position: relative;\n margin-bottom: 12px;\n background-color: ', ';\n height: ', ';\n'], ['\n position: relative;\n margin-bottom: 12px;\n background-color: ', ';\n height: ', ';\n']),
_templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n flex-grow: 1;\n margin-top: ', 'px;\n'], ['\n flex-grow: 1;\n margin-top: ', 'px;\n']); // Copyright (c) 2018 Uber Technologies, Inc.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames);
var _styledComponents = require('styled-components');
var _styledComponents2 = _interopRequireDefault(_styledComponents);
var _sliderHandle = require('./slider-handle');
var _sliderHandle2 = _interopRequireDefault(_sliderHandle);
var _sliderBarHandle = require('./slider-bar-handle');
var _sliderBarHandle2 = _interopRequireDefault(_sliderBarHandle);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function noop() {}
var StyledRangeSlider = _styledComponents2.default.div(_templateObject, function (props) {
return props.theme.sliderBarBgd;
}, function (props) {
return props.theme.sliderBarHeight;
});
var SliderWrapper = _styledComponents2.default.div(_templateObject2, function (props) {
return props.isRanged ? 0 : 10;
});
var Slider = (_temp2 = _class = function (_Component) {
(0, _inherits3.default)(Slider, _Component);
function Slider() {
var _ref;
var _temp, _this, _ret;
(0, _classCallCheck3.default)(this, Slider);
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = Slider.__proto__ || Object.getPrototypeOf(Slider)).call.apply(_ref, [this].concat(args))), _this), _this.ref = undefined, _this._saveRef = function (ref) {
_this.ref = ref;
}, _this.slide0Listener = function (x) {
var xPercent = x / _this.ref.offsetWidth;
var maxDelta = _this.props.maxValue - _this.props.minValue;
var val = xPercent * maxDelta;
_this.props.onSlider0Change.call(_this, val + _this.props.value0);
}, _this.slide1Listener = function (x) {
var xPercent = x / _this.ref.offsetWidth;
var maxDelta = _this.props.maxValue - _this.props.minValue;
var val = xPercent * maxDelta;
_this.props.onSlider1Change(val + _this.props.value1);
}, _this.sliderBarListener = function (x) {
var xPercent = x / _this.ref.offsetWidth;
var maxDelta = _this.props.maxValue - _this.props.minValue;
var val = xPercent * maxDelta;
var val0 = val + _this.props.value0;
var val1 = val + _this.props.value1;
_this.props.onSliderBarChange(val0, val1);
}, _this.calcHandleLeft0 = function (w, l, num) {
return w === 0 ? 'calc(' + l + '% - ' + _this.props.sliderHandleWidth / 2 + 'px)' : 'calc(' + l + '% - ' + _this.props.sliderHandleWidth / 2 + 'px)';
}, _this.calcHandleLeft1 = function (w, l) {
return _this.props.isRanged && w === 0 ? l + '%' : 'calc(' + (l + w) + '% - ' + _this.props.sliderHandleWidth / 2 + 'px)';
}, _this.createSlider = function (width, v0Left) {
return _react2.default.createElement(
'div',
null,
_react2.default.createElement(
StyledRangeSlider,
{ className: 'kg-range-slider' },
_react2.default.createElement(_sliderHandle2.default, {
className: 'kg-range-slider__handle',
left: _this.calcHandleLeft0(width, v0Left),
valueListener: _this.slide0Listener,
sliderHandleWidth: _this.props.sliderHandleWidth,
display: _this.props.isRanged
}),
_react2.default.createElement(_sliderHandle2.default, {
className: 'kg-range-slider__handle',
left: _this.calcHandleLeft1(width, v0Left),
valueListener: _this.slide1Listener,
sliderHandleWidth: _this.props.sliderHandleWidth
}),
_react2.default.createElement(_sliderBarHandle2.default, {
width: width,
v0Left: v0Left,
enableBarDrag: _this.props.enableBarDrag,
sliderBarListener: _this.sliderBarListener
})
)
);
}, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret);
}
(0, _createClass3.default)(Slider, [{
key: 'render',
value: function render() {
var _props = this.props,
classSet = _props.classSet,
isRanged = _props.isRanged,
maxValue = _props.maxValue,
minValue = _props.minValue,
value1 = _props.value1;
var value0 = !isRanged && minValue > 0 ? minValue : this.props.value0;
var currValDelta = value1 - value0;
var maxDelta = maxValue - minValue;
var width = currValDelta / maxDelta * 100;
var v0Left = (value0 - minValue) / maxDelta * 100;
return _react2.default.createElement(
SliderWrapper,
{
className: (0, _classnames2.default)('kg-slider', (0, _extends3.default)({}, classSet)),
innerRef: this._saveRef,
isRanged: isRanged
},
this.createSlider(width, v0Left)
);
}
}]);
return Slider;
}(_react.Component), _class.propTypes = {
title: _propTypes2.default.string,
isRanged: _propTypes2.default.bool,
value0: _propTypes2.default.number,
value1: _propTypes2.default.number,
minValue: _propTypes2.default.number,
maxValue: _propTypes2.default.number,
sliderHandleWidth: _propTypes2.default.number,
onSlider0Change: _propTypes2.default.func,
onInput0Change: _propTypes2.default.func,
onSlider1Change: _propTypes2.default.func,
onInput1Change: _propTypes2.default.func,
onSliderBarChange: _propTypes2.default.func,
step: _propTypes2.default.number,
enableBarDrag: _propTypes2.default.bool
}, _class.defaultProps = {
title: '',
isRanged: true,
value0: 0,
value1: 100,
minValue: 0,
maxValue: 100,
step: 1,
sliderHandleWidth: 12,
enableBarDrag: false,
onSlider0Change: noop,
onInput0Change: noop,
onSlider1Change: noop,
onInput1Change: noop,
onSliderBarChange: noop,
disabled: false
}, _temp2);
exports.default = Slider;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/common/slider/slider.js"],"names":["noop","StyledRangeSlider","styled","div","props","theme","sliderBarBgd","sliderBarHeight","SliderWrapper","isRanged","Slider","ref","undefined","_saveRef","slide0Listener","xPercent","x","offsetWidth","maxDelta","maxValue","minValue","val","onSlider0Change","call","value0","slide1Listener","onSlider1Change","value1","sliderBarListener","val0","val1","onSliderBarChange","calcHandleLeft0","w","l","num","sliderHandleWidth","calcHandleLeft1","createSlider","width","v0Left","enableBarDrag","classSet","currValDelta","Component","propTypes","title","PropTypes","string","bool","number","func","onInput0Change","onInput1Change","step","defaultProps","disabled"],"mappings":"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","file":"slider.js","sourcesContent":["// Copyright (c) 2018 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, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport classnames from 'classnames';\nimport styled from 'styled-components';\n\nimport SliderHandle from './slider-handle';\nimport SliderBarHandle from './slider-bar-handle';\n\nfunction noop() {}\n\nconst StyledRangeSlider = styled.div`\n  position: relative;\n  margin-bottom: 12px;\n  background-color: ${props => props.theme.sliderBarBgd};\n  height: ${props => props.theme.sliderBarHeight};\n`;\n\nconst SliderWrapper = styled.div`\n  flex-grow: 1;\n  margin-top: ${props => props.isRanged ? 0 : 10}px;\n`;\n\nexport default class Slider extends Component {\n  static propTypes = {\n    title: PropTypes.string,\n    isRanged: PropTypes.bool,\n    value0: PropTypes.number,\n    value1: PropTypes.number,\n    minValue: PropTypes.number,\n    maxValue: PropTypes.number,\n    sliderHandleWidth: PropTypes.number,\n    onSlider0Change: PropTypes.func,\n    onInput0Change: PropTypes.func,\n    onSlider1Change: PropTypes.func,\n    onInput1Change: PropTypes.func,\n    onSliderBarChange: PropTypes.func,\n    step: PropTypes.number,\n    enableBarDrag: PropTypes.bool\n  };\n\n  static defaultProps = {\n    title: '',\n    isRanged: true,\n    value0: 0,\n    value1: 100,\n    minValue: 0,\n    maxValue: 100,\n    step: 1,\n    sliderHandleWidth: 12,\n    enableBarDrag: false,\n    onSlider0Change: noop,\n    onInput0Change: noop,\n    onSlider1Change: noop,\n    onInput1Change: noop,\n    onSliderBarChange: noop,\n    disabled: false\n  };\n\n  ref = undefined;\n\n  _saveRef = ref => {\n    this.ref = ref;\n  };\n\n  slide0Listener = x => {\n    const xPercent = x / this.ref.offsetWidth;\n    const maxDelta = this.props.maxValue - this.props.minValue;\n    const val = xPercent * maxDelta;\n    this.props.onSlider0Change.call(this, val + this.props.value0);\n  };\n\n  slide1Listener = x => {\n    const xPercent = x / this.ref.offsetWidth;\n    const maxDelta = this.props.maxValue - this.props.minValue;\n    const val = xPercent * maxDelta;\n    this.props.onSlider1Change(val + this.props.value1);\n  };\n\n  sliderBarListener = x => {\n    const xPercent = x / this.ref.offsetWidth;\n    const maxDelta = this.props.maxValue - this.props.minValue;\n    const val = xPercent * maxDelta;\n    const val0 = val + this.props.value0;\n    const val1 = val + this.props.value1;\n    this.props.onSliderBarChange(val0, val1);\n  };\n\n  calcHandleLeft0 = (w, l, num) => {\n    return w === 0 ? `calc(${l}% - ${this.props.sliderHandleWidth / 2}px)` :\n      `calc(${l}% - ${this.props.sliderHandleWidth / 2}px)`;\n  };\n\n  calcHandleLeft1 = (w, l) => {\n    return this.props.isRanged && w === 0\n      ? `${l}%`\n      : `calc(${l + w}% - ${this.props.sliderHandleWidth / 2}px)`;\n  };\n\n  createSlider = (width, v0Left) => {\n    return (\n      <div>\n        <StyledRangeSlider className=\"kg-range-slider\">\n          <SliderHandle\n            className=\"kg-range-slider__handle\"\n            left={this.calcHandleLeft0(width, v0Left)}\n            valueListener={this.slide0Listener}\n            sliderHandleWidth={this.props.sliderHandleWidth}\n            display={this.props.isRanged}\n          />\n          <SliderHandle\n            className=\"kg-range-slider__handle\"\n            left={this.calcHandleLeft1(width, v0Left)}\n            valueListener={this.slide1Listener}\n            sliderHandleWidth={this.props.sliderHandleWidth}\n          />\n          <SliderBarHandle\n            width={width}\n            v0Left={v0Left}\n            enableBarDrag={this.props.enableBarDrag}\n            sliderBarListener={this.sliderBarListener}\n          />\n        </StyledRangeSlider>\n      </div>\n    );\n  };\n\n  render() {\n    const {\n      classSet,\n      isRanged,\n      maxValue,\n      minValue,\n      value1\n    } = this.props;\n    const value0 = !isRanged && minValue > 0 ? minValue : this.props.value0;\n    const currValDelta = value1 - value0;\n    const maxDelta = maxValue - minValue;\n    const width = currValDelta / maxDelta * 100;\n\n    const v0Left = (value0 - minValue) / maxDelta * 100;\n\n    return (\n      <SliderWrapper\n        className={classnames('kg-slider', {...classSet})}\n        innerRef={this._saveRef}\n        isRanged={isRanged}\n      >\n        {this.createSlider(width, v0Left)}\n      </SliderWrapper>\n    );\n  }\n}\n"]}