kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
169 lines (137 loc) • 17.1 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = undefined;
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: absolute;\n z-index: 10;\n display: ', ';\n margin-top: -4px;\n height: ', ';\n width: ', ';\n box-shadow: ', ';\n background-color: ', ';\n border-width: 1px;\n border-style: solid;\n border-color: ', ';\n\n :hover {\n background-color: ', ';\n cursor: pointer;\n }\n'], ['\n position: absolute;\n z-index: 10;\n display: ', ';\n margin-top: -4px;\n height: ', ';\n width: ', ';\n box-shadow: ', ';\n background-color: ', ';\n border-width: 1px;\n border-style: solid;\n border-color: ', ';\n\n :hover {\n background-color: ', ';\n cursor: pointer;\n }\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 _document = require('global/document');
var _document2 = _interopRequireDefault(_document);
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);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var StyledSliderHandle = _styledComponents2.default.span(_templateObject, function (props) {
return props.hidden ? 'none' : 'block';
}, function (props) {
return Number.isFinite(props.sliderHandleWidth) ? props.sliderHandleWidth + 'px' : props.theme.sliderHandleHeight;
}, function (props) {
return Number.isFinite(props.sliderHandleWidth) ? props.sliderHandleWidth + 'px' : props.theme.sliderHandleHeight;
}, function (props) {
return props.theme.sliderHandleShadow;
}, function (props) {
return props.theme.sliderHandleColor;
}, function (props) {
return props.active ? props.theme.selectBorderColor : props.theme.sliderHandleColor;
}, function (props) {
return props.theme.sliderHandleHoverColor;
});
/**
*
* props:
* width : default 23
* height : default 23
* display
* left
* onMove
* valueListener
*/
var SliderHandle = (_temp2 = _class = function (_Component) {
(0, _inherits3.default)(SliderHandle, _Component);
function SliderHandle() {
var _ref;
var _temp, _this, _ret;
(0, _classCallCheck3.default)(this, SliderHandle);
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 = SliderHandle.__proto__ || Object.getPrototypeOf(SliderHandle)).call.apply(_ref, [this].concat(args))), _this), _this.state = { mouseOver: false }, _this.prevX = 0, _this.handleMouseDown = function () {
_document2.default.addEventListener('mouseup', _this.mouseup);
_document2.default.addEventListener('mousemove', _this.mousemove);
_this.setState({ mouseOver: true });
}, _this.mouseup = function () {
_document2.default.removeEventListener('mouseup', _this.mouseup);
_document2.default.removeEventListener('mousemove', _this.mousemove);
_this.setState({ mouseOver: false });
}, _this.mousemove = function (e) {
e.preventDefault();
_this.props.valueListener(e.movementX);
}, _this.handleTouchStart = function (e) {
_document2.default.addEventListener('touchend', _this.touchend);
_document2.default.addEventListener('touchmove', _this.touchmove);
_this.prevX = e.touches[0].clientX;
_this.setState({ mouseOver: true });
}, _this.touchmove = function (e) {
var deltaX = e.touches[0].clientX - _this.prevX;
_this.prevX = e.touches[0].clientX;
_this.props.valueListener(deltaX);
}, _this.touchend = function () {
_document2.default.removeEventListener('touchend', _this.touchend);
_document2.default.removeEventListener('touchmove', _this.touchmove);
_this.setState({ mouseOver: false });
}, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret);
}
(0, _createClass3.default)(SliderHandle, [{
key: 'render',
value: function render() {
return _react2.default.createElement(StyledSliderHandle, {
className: (0, _classnames2.default)('kg-range-slider__handle', {
'kg-range-slider__handle--active': this.state.mouseOver
}),
sliderHandleWidth: this.props.sliderHandleWidth,
active: this.state.mouseOver,
hidden: !this.props.display,
style: { left: this.props.left },
onMouseDown: this.handleMouseDown,
onTouchStart: this.handleTouchStart
});
}
}]);
return SliderHandle;
}(_react.Component), _class.propTypes = {
width: _propTypes2.default.number,
height: _propTypes2.default.number,
left: _propTypes2.default.string,
display: _propTypes2.default.bool,
valueListener: _propTypes2.default.func
}, _class.defaultProps = {
left: '50%',
display: true,
valueListener: function valueListenerFn() {}
}, _temp2);
exports.default = SliderHandle;
;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/common/slider/slider-handle.js"],"names":["StyledSliderHandle","styled","span","props","hidden","Number","isFinite","sliderHandleWidth","theme","sliderHandleHeight","sliderHandleShadow","sliderHandleColor","active","selectBorderColor","sliderHandleHoverColor","SliderHandle","state","mouseOver","prevX","handleMouseDown","document","addEventListener","mouseup","mousemove","setState","removeEventListener","e","preventDefault","valueListener","movementX","handleTouchStart","touchend","touchmove","touches","clientX","deltaX","display","left","Component","propTypes","width","PropTypes","number","height","string","bool","func","defaultProps","valueListenerFn"],"mappings":"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","file":"slider-handle.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 document from 'global/document';\nimport React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport classnames from 'classnames';\nimport styled from 'styled-components';\n\nconst StyledSliderHandle = styled.span`\n  position: absolute;\n  z-index: 10;\n  display: ${props => (props.hidden ? 'none' : 'block')};\n  margin-top: -4px;\n  height: ${props =>\n    Number.isFinite(props.sliderHandleWidth)\n      ? `${props.sliderHandleWidth}px`\n      : props.theme.sliderHandleHeight};\n  width: ${props =>\n    Number.isFinite(props.sliderHandleWidth)\n      ? `${props.sliderHandleWidth}px`\n      : props.theme.sliderHandleHeight};\n  box-shadow: ${props => props.theme.sliderHandleShadow};\n  background-color: ${props => props.theme.sliderHandleColor};\n  border-width: 1px;\n  border-style: solid;\n  border-color: ${props =>\n    props.active\n      ? props.theme.selectBorderColor\n      : props.theme.sliderHandleColor};\n\n  :hover {\n    background-color: ${props => props.theme.sliderHandleHoverColor};\n    cursor: pointer;\n  }\n`;\n\n/**\n *\n * props:\n *  width : default 23\n *  height : default 23\n *  display\n *  left\n *  onMove\n *  valueListener\n */\nexport default class SliderHandle extends Component {\n  static propTypes = {\n    width: PropTypes.number,\n    height: PropTypes.number,\n    left: PropTypes.string,\n    display: PropTypes.bool,\n    valueListener: PropTypes.func\n  };\n\n  static defaultProps = {\n    left: '50%',\n    display: true,\n    valueListener: function valueListenerFn() {}\n  };\n\n  state = {mouseOver: false};\n  prevX = 0;\n\n  handleMouseDown = () => {\n    document.addEventListener('mouseup', this.mouseup);\n    document.addEventListener('mousemove', this.mousemove);\n    this.setState({mouseOver: true});\n  };\n\n  mouseup = () => {\n    document.removeEventListener('mouseup', this.mouseup);\n    document.removeEventListener('mousemove', this.mousemove);\n    this.setState({mouseOver: false});\n  };\n\n  mousemove = e => {\n    e.preventDefault();\n    this.props.valueListener(e.movementX);\n  };\n\n  handleTouchStart = e => {\n    document.addEventListener('touchend', this.touchend);\n    document.addEventListener('touchmove', this.touchmove);\n    this.prevX = e.touches[0].clientX;\n    this.setState({mouseOver: true});\n  };\n\n  touchmove = e => {\n    const deltaX = e.touches[0].clientX - this.prevX;\n    this.prevX = e.touches[0].clientX;\n    this.props.valueListener(deltaX);\n  };\n\n  touchend = () => {\n    document.removeEventListener('touchend', this.touchend);\n    document.removeEventListener('touchmove', this.touchmove);\n    this.setState({mouseOver: false});\n  };\n\n  render() {\n    return (\n      <StyledSliderHandle\n        className={classnames('kg-range-slider__handle', {\n          'kg-range-slider__handle--active': this.state.mouseOver\n        })}\n        sliderHandleWidth={this.props.sliderHandleWidth}\n        active={this.state.mouseOver}\n        hidden={!this.props.display}\n        style={{left: this.props.left}}\n        onMouseDown={this.handleMouseDown}\n        onTouchStart={this.handleTouchStart}\n      />\n    );\n  }\n};\n"]}
;