UNPKG

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
'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"]}