kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
318 lines (261 loc) • 29.2 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = undefined;
var _defineProperty2 = require('babel-runtime/helpers/defineProperty');
var _defineProperty3 = _interopRequireDefault(_defineProperty2);
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 height: 24px;\n width: 40px;\n padding: 4px 6px;\n margin-left: ', 'px;\n'], ['\n height: 24px;\n width: 40px;\n padding: 4px 6px;\n margin-left: ', 'px;\n']),
_templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n display: flex;\n position: relative;\n'], ['\n display: flex;\n position: relative;\n']),
_templateObject3 = (0, _taggedTemplateLiteral3.default)(['\n margin-top: 6px;\n display: flex;\n justify-content: space-between;\n'], ['\n margin-top: 6px;\n display: flex;\n justify-content: space-between;\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 _styledComponents = require('styled-components');
var _styledComponents2 = _interopRequireDefault(_styledComponents);
var _rangePlot = require('./range-plot');
var _rangePlot2 = _interopRequireDefault(_rangePlot);
var _slider = require('./slider/slider');
var _slider2 = _interopRequireDefault(_slider);
var _styledComponents3 = require('./styled-components');
var _dataUtils = require('../../utils/data-utils');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var SliderInput = _styledComponents3.Input.extend(_templateObject, function (props) {
return props.flush ? 0 : 24;
});
var SliderWrapper = _styledComponents2.default.div(_templateObject2);
var RangeInputWrapper = _styledComponents2.default.div(_templateObject3);
var RangeSlider = (_temp2 = _class = function (_Component) {
(0, _inherits3.default)(RangeSlider, _Component);
function RangeSlider() {
var _ref;
var _temp, _this, _ret;
(0, _classCallCheck3.default)(this, RangeSlider);
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 = RangeSlider.__proto__ || Object.getPrototypeOf(RangeSlider)).call.apply(_ref, [this].concat(args))), _this), _this.state = { value0: 0, value1: 1, width: 288 }, _this._setValueFromProps = function (props) {
var value0 = props.value0,
value1 = props.value1;
if (!isNaN(value0) && !isNaN(value1)) {
_this.setState({ value0: value0, value1: value1 });
}
}, _this._isVal0InRange = function (val) {
var _this$props = _this.props,
value1 = _this$props.value1,
range = _this$props.range;
return Boolean(val >= range[0] && val <= value1);
}, _this._isVal1InRange = function (val) {
var _this$props2 = _this.props,
range = _this$props2.range,
value0 = _this$props2.value0;
return Boolean(val <= range[1] && val >= value0);
}, _this._roundValToStep = function (val) {
var _this$props3 = _this.props,
range = _this$props3.range,
step = _this$props3.step;
return (0, _dataUtils.roundValToStep)(range[0], step, val);
}, _this._setRangeVal1 = function (val) {
var _this$props4 = _this.props,
value0 = _this$props4.value0,
onChange = _this$props4.onChange;
val = Number(val);
if (_this._isVal1InRange(val)) {
onChange([value0, _this._roundValToStep(val)]);
return true;
}
return false;
}, _this._setRangeVal0 = function (val) {
var _this$props5 = _this.props,
value1 = _this$props5.value1,
onChange = _this$props5.onChange;
val = Number(val);
if (_this._isVal0InRange(val)) {
onChange([_this._roundValToStep(val), value1]);
return true;
}
return false;
}, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret);
}
(0, _createClass3.default)(RangeSlider, [{
key: 'componentDidMount',
value: function componentDidMount() {
this._setValueFromProps(this.props);
this._resize();
}
}, {
key: 'componentWillReceiveProps',
value: function componentWillReceiveProps(nextProps) {
this._setValueFromProps(nextProps);
}
}, {
key: 'componentDidUpdate',
value: function componentDidUpdate() {
this._resize();
}
}, {
key: '_resize',
value: function _resize() {
var width = this.sliderContainer.offsetWidth;
if (width !== this.state.width) {
this.setState({ width: width });
}
}
}, {
key: '_renderInput',
value: function _renderInput(key) {
var _this2 = this;
var setRange = key === 'value0' ? this._setRangeVal0 : this._setRangeVal1;
var update = function update(e) {
if (!setRange(e.target.value)) {
_this2.setState((0, _defineProperty3.default)({}, key, _this2.state[key]));
}
};
return _react2.default.createElement(SliderInput, {
className: 'kg-range-slider__input',
type: 'number',
innerRef: function innerRef(comp) {
_this2['input-' + key] = comp;
},
id: 'filter-' + key,
value: this.state[key],
onChange: function onChange(e) {
_this2.setState((0, _defineProperty3.default)({}, key, e.target.value));
},
onKeyPress: function onKeyPress(e) {
if (e.key === 'Enter') {
update(e);
_this2['input-' + key].blur();
}
},
onBlur: update,
flush: key === 'value0',
secondary: this.props.inputTheme === 'secondary'
});
}
}, {
key: 'render',
value: function render() {
var _this3 = this;
var _props = this.props,
isRanged = _props.isRanged,
showInput = _props.showInput,
histogram = _props.histogram,
lineChart = _props.lineChart,
plotType = _props.plotType,
isEnlarged = _props.isEnlarged,
range = _props.range,
onChange = _props.onChange,
value0 = _props.value0,
value1 = _props.value1,
sliderHandleWidth = _props.sliderHandleWidth;
var height = this.props.xAxis ? '24px' : '16px';
var width = this.state.width;
var plotWidth = width - sliderHandleWidth;
return _react2.default.createElement(
'div',
{
className: 'kg-range-slider', style: { width: '100%', padding: '0 ' + sliderHandleWidth / 2 + 'px' },
ref: function ref(comp) {
_this3.sliderContainer = comp;
} },
histogram && histogram.length ? _react2.default.createElement(_rangePlot2.default, {
histogram: histogram,
lineChart: lineChart,
plotType: plotType,
isEnlarged: isEnlarged,
onBrush: function onBrush(val0, val1) {
onChange([_this3._roundValToStep(val0), _this3._roundValToStep(val1)]);
},
range: range,
value: [value0, value1],
width: plotWidth
}) : null,
_react2.default.createElement(
SliderWrapper,
{
style: { height: height },
className: 'kg-range-slider__slider' },
this.props.xAxis ? _react2.default.createElement(this.props.xAxis, { width: plotWidth, domain: range }) : null,
_react2.default.createElement(_slider2.default, {
showValues: false,
isRanged: isRanged,
minValue: range[0],
maxValue: range[1],
value0: value0,
value1: value1,
handleWidth: sliderHandleWidth,
onSlider0Change: this._setRangeVal0,
onSlider1Change: this._setRangeVal1,
onSliderBarChange: function onSliderBarChange(val0, val1) {
if (_this3._isVal1InRange(val1) && _this3._isVal0InRange(val0)) {
onChange([_this3._roundValToStep(val0), _this3._roundValToStep(val1)]);
}
},
enableBarDrag: true
}),
!isRanged && showInput ? this._renderInput('value1') : null
),
isRanged && showInput ? _react2.default.createElement(
RangeInputWrapper,
{ className: 'range-slider__input-group' },
this._renderInput('value0'),
this._renderInput('value1')
) : null
);
}
}]);
return RangeSlider;
}(_react.Component), _class.propTypes = {
range: _propTypes2.default.arrayOf(_propTypes2.default.number).isRequired,
value0: _propTypes2.default.number.isRequired,
value1: _propTypes2.default.number.isRequired,
onChange: _propTypes2.default.func.isRequired,
histogram: _propTypes2.default.arrayOf(_propTypes2.default.any),
isRanged: _propTypes2.default.bool,
isEnlarged: _propTypes2.default.bool,
showInput: _propTypes2.default.bool,
inputTheme: _propTypes2.default.string,
step: _propTypes2.default.number,
sliderHandleWidth: _propTypes2.default.number,
xAxis: _propTypes2.default.func
}, _class.defaultProps = {
isEnlarged: false,
isRanged: true,
showInput: true,
sliderHandleWidth: 12,
onChange: function onChange() {}
}, _temp2);
exports.default = RangeSlider;
;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/common/range-slider.js"],"names":["SliderInput","Input","extend","props","flush","SliderWrapper","styled","div","RangeInputWrapper","RangeSlider","state","value0","value1","width","_setValueFromProps","isNaN","setState","_isVal0InRange","range","Boolean","val","_isVal1InRange","_roundValToStep","step","_setRangeVal1","onChange","Number","_setRangeVal0","_resize","nextProps","sliderContainer","offsetWidth","key","setRange","update","e","target","value","comp","blur","inputTheme","isRanged","showInput","histogram","lineChart","plotType","isEnlarged","sliderHandleWidth","height","xAxis","plotWidth","padding","length","val0","val1","_renderInput","Component","propTypes","PropTypes","arrayOf","number","isRequired","func","any","bool","string","defaultProps"],"mappings":"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","file":"range-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 styled from 'styled-components';\n\nimport RangePlot from './range-plot';\nimport Slider from 'components/common/slider/slider';\nimport {Input} from 'components/common/styled-components';\n\nimport {roundValToStep} from 'utils/data-utils';\n\nconst SliderInput = Input.extend`\n  height: 24px;\n  width: 40px;\n  padding: 4px 6px;\n  margin-left: ${props => props.flush ? 0 : 24}px;\n`;\n\nconst SliderWrapper = styled.div`\n  display: flex;\n  position: relative;\n`;\n\nconst RangeInputWrapper =styled.div`\n  margin-top: 6px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nexport default class RangeSlider extends Component {\n  static propTypes = {\n    range: PropTypes.arrayOf(PropTypes.number).isRequired,\n    value0: PropTypes.number.isRequired,\n    value1: PropTypes.number.isRequired,\n    onChange: PropTypes.func.isRequired,\n    histogram: PropTypes.arrayOf(PropTypes.any),\n    isRanged: PropTypes.bool,\n    isEnlarged: PropTypes.bool,\n    showInput: PropTypes.bool,\n    inputTheme: PropTypes.string,\n    step: PropTypes.number,\n    sliderHandleWidth: PropTypes.number,\n    xAxis: PropTypes.func\n  };\n\n  static defaultProps = {\n    isEnlarged: false,\n    isRanged: true,\n    showInput: true,\n    sliderHandleWidth: 12,\n    onChange: () => {}\n  };\n\n  state = {value0: 0, value1: 1, width: 288};\n\n  componentDidMount() {\n    this._setValueFromProps(this.props);\n    this._resize();\n  }\n\n  componentWillReceiveProps(nextProps) {\n    this._setValueFromProps(nextProps);\n  }\n\n  componentDidUpdate() {\n    this._resize();\n  }\n\n  _setValueFromProps = props => {\n    const {value0, value1} = props;\n\n    if (!isNaN(value0) && !isNaN(value1)) {\n      this.setState({value0, value1});\n    }\n  };\n\n  _isVal0InRange = val => {\n    const {value1, range} = this.props;\n\n    return Boolean(val >= range[0] && val <= value1);\n  };\n\n  _isVal1InRange = val => {\n    const {range, value0} = this.props;\n\n    return Boolean(val <= range[1] && val >= value0);\n  };\n\n  _roundValToStep = val => {\n    const {range, step} = this.props;\n\n    return roundValToStep(range[0], step, val);\n  };\n\n  _setRangeVal1 = val => {\n    const {value0, onChange} = this.props;\n    val = Number(val);\n\n    if (this._isVal1InRange(val)) {\n      onChange([value0, this._roundValToStep(val)]);\n      return true;\n    }\n    return false;\n  };\n\n  _setRangeVal0 = val => {\n    const {value1, onChange} = this.props;\n    val = Number(val);\n\n    if (this._isVal0InRange(val)) {\n      onChange([this._roundValToStep(val), value1]);\n      return true;\n    }\n    return false;\n  };\n\n  _resize() {\n    const width = this.sliderContainer.offsetWidth;\n    if (width !== this.state.width) {\n      this.setState({width});\n    }\n  }\n\n  _renderInput(key) {\n    const setRange = key === 'value0' ? this._setRangeVal0 : this._setRangeVal1;\n    const update = e => {\n      if (!setRange(e.target.value)) {\n        this.setState({[key]: this.state[key]});\n      }\n    };\n\n    return (\n      <SliderInput\n        className=\"kg-range-slider__input\"\n        type=\"number\"\n        innerRef={comp => {\n          this[`input-${key}`] = comp;\n        }}\n        id={`filter-${key}`}\n        value={this.state[key]}\n        onChange={e => {\n          this.setState({[key]: e.target.value});\n        }}\n        onKeyPress={e => {\n          if (e.key === 'Enter') {\n            update(e);\n            this[`input-${key}`].blur();\n          }\n        }}\n        onBlur={update}\n        flush={key === 'value0'}\n        secondary={this.props.inputTheme === 'secondary'}\n      />\n    );\n  }\n\n  render() {\n    const {\n      isRanged,\n      showInput,\n      histogram,\n      lineChart,\n      plotType,\n      isEnlarged,\n      range,\n      onChange,\n      value0,\n      value1,\n      sliderHandleWidth\n    } = this.props;\n\n    const height = this.props.xAxis ? '24px' : '16px';\n    const {width} = this.state;\n    const plotWidth =  width - sliderHandleWidth;\n\n    return (\n      <div\n        className=\"kg-range-slider\" style={{width: '100%', padding: `0 ${sliderHandleWidth / 2}px`}}\n        ref={comp => {\n          this.sliderContainer = comp;\n        }}>\n        {histogram && histogram.length ? (\n          <RangePlot\n            histogram={histogram}\n            lineChart={lineChart}\n            plotType={plotType}\n            isEnlarged={isEnlarged}\n            onBrush={(val0, val1) => {\n              onChange([\n                this._roundValToStep(val0),\n                this._roundValToStep(val1)\n              ]);\n            }}\n            range={range}\n            value={[value0, value1]}\n            width={plotWidth}\n          />\n        ) : null}\n        <SliderWrapper\n          style={{height}}\n          className=\"kg-range-slider__slider\">\n          {this.props.xAxis ? <this.props.xAxis width={plotWidth} domain={range}/> : null}\n          <Slider\n            showValues={false}\n            isRanged={isRanged}\n            minValue={range[0]}\n            maxValue={range[1]}\n            value0={value0}\n            value1={value1}\n            handleWidth={sliderHandleWidth}\n            onSlider0Change={this._setRangeVal0}\n            onSlider1Change={this._setRangeVal1}\n            onSliderBarChange={(val0, val1) => {\n              if (this._isVal1InRange(val1) && this._isVal0InRange(val0)) {\n                onChange([\n                  this._roundValToStep(val0),\n                  this._roundValToStep(val1)\n                ]);\n              }\n            }}\n            enableBarDrag\n          />\n          {!isRanged && showInput ? this._renderInput('value1') : null}\n        </SliderWrapper>\n        {isRanged && showInput ? <RangeInputWrapper className=\"range-slider__input-group\">\n          {this._renderInput('value0')}\n          {this._renderInput('value1')}\n        </RangeInputWrapper> : null}\n      </div>\n    );\n  }\n};\n"]}