UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

210 lines (164 loc) 20 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _typeof2 = require('babel-runtime/helpers/typeof'); var _typeof3 = _interopRequireDefault(_typeof2); 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 width: 32px;\n height: 18px;\n border-radius: 1px;\n background-color: ', ';\n'], ['\n width: 32px;\n height: 18px;\n border-radius: 1px;\n background-color: ', ';\n']), _templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n ', ';\n height: ', ';\n'], ['\n ', ';\n height: ', ';\n']), _templateObject3 = (0, _taggedTemplateLiteral3.default)(['\n display: flex;\n justify-content: space-between;\n\n .color-select__input-group {\n flex-grow: 1;\n }\n .color-select__input-group:nth-child(2) {\n margin-left: 12px;\n }\n'], ['\n display: flex;\n justify-content: space-between;\n\n .color-select__input-group {\n flex-grow: 1;\n }\n .color-select__input-group:nth-child(2) {\n margin-left: 12px;\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 _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 _colorUtils = require('../../../utils/color-utils'); var _singleColorPalette = require('./single-color-palette'); var _singleColorPalette2 = _interopRequireDefault(_singleColorPalette); var _colorRangeSelector = require('./color-range-selector'); var _colorRangeSelector2 = _interopRequireDefault(_colorRangeSelector); var _colorPalette = require('./color-palette'); var _colorPalette2 = _interopRequireDefault(_colorPalette); var _styledComponents3 = require('../../common/styled-components'); var _reactOnclickoutside = require('react-onclickoutside'); var _reactOnclickoutside2 = _interopRequireDefault(_reactOnclickoutside); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var ColorBlock = _styledComponents2.default.div(_templateObject, function (props) { return 'rgb(' + props.color.slice(0, 3).join(',') + ')'; }); var ColorSelectorInput = _styledComponents2.default.div(_templateObject2, function (props) { return props.inputTheme === 'secondary' ? props.theme.secondaryInput : props.theme.input; }, function (props) { return props.theme.inputBoxHeight; }); var InputBoxContainer = _styledComponents2.default.div(_templateObject3); var ColorSelector = (_temp2 = _class = function (_Component) { (0, _inherits3.default)(ColorSelector, _Component); function ColorSelector() { var _ref; var _temp, _this, _ret; (0, _classCallCheck3.default)(this, ColorSelector); 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 = ColorSelector.__proto__ || Object.getPrototypeOf(ColorSelector)).call.apply(_ref, [this].concat(args))), _this), _this.state = { editing: false }, _this.handleClickOutside = function (e) { if (_this.state.editing !== false) { _this.setState({ editing: false }); } }, _this._onSelectColor = function (color, e) { e.stopPropagation(); if (_this.props.colorSets[_this.state.editing]) { _this.props.colorSets[_this.state.editing].setColor(color); } }, _this._showDropdown = function (e, i) { e.stopPropagation(); e.preventDefault(); _this.setState({ editing: i }); }, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret); } (0, _createClass3.default)(ColorSelector, [{ key: 'render', value: function render() { var _this2 = this; var _props = this.props, colorSets = _props.colorSets, disabled = _props.disabled, inputTheme = _props.inputTheme; var editing = this.state.editing; var currentEditing = colorSets[editing] && (0, _typeof3.default)(colorSets[editing]) === 'object'; return _react2.default.createElement( 'div', { className: 'color-selector' }, _react2.default.createElement( InputBoxContainer, null, colorSets.map(function (cSet, i) { return _react2.default.createElement( 'div', { className: 'color-select__input-group', key: i }, cSet.label ? _react2.default.createElement( _styledComponents3.PanelLabel, null, cSet.label ) : null, _react2.default.createElement( ColorSelectorInput, { className: 'color-selector__selector', active: editing === i, disabled: disabled, inputTheme: inputTheme, onMouseDown: function onMouseDown(e) { return _this2._showDropdown(e, i); } }, cSet.isRange ? _react2.default.createElement(_colorPalette2.default, { colors: cSet.selectedColor.colors }) : _react2.default.createElement(ColorBlock, { className: 'color-selector__selector__block', color: cSet.selectedColor }) ) ); }) ), currentEditing ? _react2.default.createElement( _styledComponents3.StyledPanelDropdown, { className: 'color-selector__dropdown' }, colorSets[editing].isRange ? _react2.default.createElement(_colorRangeSelector2.default, { selectedColorRange: colorSets[editing].selectedColor, onSelectColorRange: this._onSelectColor }) : _react2.default.createElement(_singleColorPalette2.default, { selectedColor: (0, _colorUtils.rgbToHex)(colorSets[editing].selectedColor), onSelectColor: this._onSelectColor }) ) : null ); } }]); return ColorSelector; }(_react.Component), _class.propTypes = { colorSets: _propTypes2.default.arrayOf(_propTypes2.default.shape({ selectedColor: _propTypes2.default.oneOfType([_propTypes2.default.arrayOf(_propTypes2.default.any), _propTypes2.default.object]), setColor: _propTypes2.default.func.isRequired, isRange: _propTypes2.default.bool, label: _propTypes2.default.string })), inputTheme: _propTypes2.default.string, disabled: _propTypes2.default.bool }, _class.defaultProps = { colorSets: [] }, _temp2); ; exports.default = (0, _reactOnclickoutside2.default)(ColorSelector); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/layer-panel/color-selector.js"],"names":["ColorBlock","styled","div","props","color","slice","join","ColorSelectorInput","inputTheme","theme","secondaryInput","input","inputBoxHeight","InputBoxContainer","ColorSelector","state","editing","handleClickOutside","setState","_onSelectColor","e","stopPropagation","colorSets","setColor","_showDropdown","i","preventDefault","disabled","currentEditing","map","cSet","label","isRange","selectedColor","colors","Component","propTypes","PropTypes","arrayOf","shape","oneOfType","any","object","func","isRequired","bool","string","defaultProps"],"mappings":"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","file":"color-selector.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';\nimport {rgbToHex} from 'utils/color-utils';\nimport SingleColorPalette from 'components/side-panel/layer-panel/single-color-palette';\nimport ColorRangeSelector from 'components/side-panel/layer-panel/color-range-selector';\nimport ColorPalette from 'components/side-panel/layer-panel/color-palette';\nimport {\n  PanelLabel,\n  StyledPanelDropdown\n} from 'components/common/styled-components';\nimport onClickOutside from 'react-onclickoutside';\n\nconst ColorBlock = styled.div`\n  width: 32px;\n  height: 18px;\n  border-radius: 1px;\n  background-color: ${props => `rgb(${props.color.slice(0, 3).join(',')})`};\n`;\n\nconst ColorSelectorInput = styled.div`\n  ${props =>\n    props.inputTheme === 'secondary'\n      ? props.theme.secondaryInput\n      : props.theme.input};\n  height: ${props => props.theme.inputBoxHeight};\n`;\n\nconst InputBoxContainer = styled.div`\n  display: flex;\n  justify-content: space-between;\n\n  .color-select__input-group {\n    flex-grow: 1;\n  }\n  .color-select__input-group:nth-child(2) {\n    margin-left: 12px;\n  }\n`;\n\nclass ColorSelector extends Component {\n  static propTypes = {\n    colorSets: PropTypes.arrayOf(\n      PropTypes.shape({\n        selectedColor: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.any), PropTypes.object]),\n        setColor: PropTypes.func.isRequired,\n        isRange: PropTypes.bool,\n        label: PropTypes.string\n      })\n    ),\n    inputTheme: PropTypes.string,\n    disabled: PropTypes.bool\n  };\n\n  static defaultProps = {\n    colorSets: []\n  };\n\n  state = {\n    editing: false\n  };\n\n  handleClickOutside = e => {\n    if (this.state.editing !== false) {\n      this.setState({editing: false});\n    }\n  };\n\n  _onSelectColor = (color, e) => {\n    e.stopPropagation();\n    if (this.props.colorSets[this.state.editing]) {\n      this.props.colorSets[this.state.editing].setColor(color);\n    }\n  };\n\n  _showDropdown = (e, i) => {\n    e.stopPropagation();\n    e.preventDefault();\n    this.setState({editing: i});\n  };\n\n  render() {\n    const {colorSets, disabled, inputTheme} = this.props;\n    const {editing} = this.state;\n    const currentEditing =\n      colorSets[editing] && typeof colorSets[editing] === 'object';\n\n    return (\n      <div className=\"color-selector\">\n        <InputBoxContainer>\n          {colorSets.map((cSet, i) => (\n            <div className=\"color-select__input-group\" key={i}>\n              {cSet.label ? <PanelLabel>{cSet.label}</PanelLabel> : null}\n              <ColorSelectorInput\n                className=\"color-selector__selector\"\n                active={editing === i}\n                disabled={disabled}\n                inputTheme={inputTheme}\n                onMouseDown={e => this._showDropdown(e, i)}\n              >\n                {cSet.isRange ? (\n                  <ColorPalette colors={cSet.selectedColor.colors} />\n                ) : (\n                  <ColorBlock\n                    className=\"color-selector__selector__block\"\n                    color={cSet.selectedColor}\n                  />\n                )}\n              </ColorSelectorInput>\n            </div>\n          ))}\n        </InputBoxContainer>\n        {currentEditing ? (\n          <StyledPanelDropdown className=\"color-selector__dropdown\">\n            {colorSets[editing].isRange ? (\n              <ColorRangeSelector\n                selectedColorRange={colorSets[editing].selectedColor}\n                onSelectColorRange={this._onSelectColor}\n              />\n            ) : (\n              <SingleColorPalette\n                selectedColor={rgbToHex(colorSets[editing].selectedColor)}\n                onSelectColor={this._onSelectColor}\n              />\n            )}\n          </StyledPanelDropdown>\n        ) : null}\n      </div>\n    );\n  }\n};\n\nexport default onClickOutside(ColorSelector);\n"]}