kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
287 lines (239 loc) • 32.2 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ColorPaletteGroup = exports.PaletteConfig = exports["default"] = exports.ALL_STEPS = exports.ALL_TYPES = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _lodash = _interopRequireDefault(require("lodash.uniq"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _reselect = require("reselect");
var _itemSelector = _interopRequireDefault(require("../../common/item-selector/item-selector"));
var _styledComponents2 = require("../../common/styled-components");
var _switch = _interopRequireDefault(require("../../common/switch"));
var _colorPalette = _interopRequireDefault(require("./color-palette"));
var _customPalette = _interopRequireDefault(require("./custom-palette"));
var _colorRanges = require("../../../constants/color-ranges");
var _dataUtils = require("../../../utils/data-utils");
var _colorUtils = require("../../../utils/color-utils");
var _localization = require("../../../localization");
var _templateObject, _templateObject2, _templateObject3, _templateObject4;
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
var ALL_TYPES = (0, _lodash["default"])(_colorRanges.COLOR_RANGES.map(function (c) {
return c.type;
}).filter(function (ctype) {
return ctype;
}).concat(['all', 'custom']));
exports.ALL_TYPES = ALL_TYPES;
var ALL_STEPS = (0, _lodash["default"])(_colorRanges.COLOR_RANGES.map(function (d) {
return d.colors.length;
})).sort(_dataUtils.numberSort);
exports.ALL_STEPS = ALL_STEPS;
var StyledColorConfig = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n padding: 12px 12px 0 12px;\n"])));
var StyledColorRangeSelector = _styledComponents["default"].div.attrs({
className: 'color-range-selector'
})(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n padding-bottom: 12px;\n"])));
var StyledPaletteConfig = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 8px;\n display: flex;\n justify-content: space-between;\n align-items: center;\n .color-palette__config__label {\n flex-grow: 1;\n }\n .color-palette__config__select {\n flex-grow: 1;\n }\n .item-selector .item-selector__dropdown {\n ", ";\n }\n"])), function (props) {
return props.theme.secondaryInput;
});
var CONFIG_SETTINGS = {
type: {
type: 'select',
options: ALL_TYPES
},
steps: {
type: 'select',
options: ALL_STEPS
},
reversed: {
type: 'switch',
options: [true, false]
},
custom: {
label: 'customPalette',
type: 'switch',
options: [true, false]
}
};
var ColorRangeSelect = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(ColorRangeSelect, _Component);
var _super = _createSuper(ColorRangeSelect);
function ColorRangeSelect() {
var _this;
(0, _classCallCheck2["default"])(this, ColorRangeSelect);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = _super.call.apply(_super, [this].concat(args));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "colorRangesSelector", function (props) {
return props.colorRanges;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "configTypeSelector", function (props) {
return props.colorPaletteUI.colorRangeConfig.type;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "configStepSelector", function (props) {
return props.colorPaletteUI.colorRangeConfig.steps;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "filteredColorRange", (0, _reselect.createSelector)(_this.colorRangesSelector, _this.configTypeSelector, _this.configStepSelector, function (colorRanges, type, steps) {
return colorRanges.filter(function (colorRange) {
var isType = type === 'all' || type === colorRange.type;
var isStep = Number(steps) === colorRange.colors.length;
return isType && isStep;
});
}));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_updateConfig", function (_ref) {
var key = _ref.key,
value = _ref.value;
_this._setColorRangeConfig((0, _defineProperty2["default"])({}, key, value));
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onSetCustomPalette", function (config) {
_this.props.setColorPaletteUI({
customPalette: config
});
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_setColorRangeConfig", function (newConfig) {
_this.props.setColorPaletteUI({
colorRangeConfig: newConfig
});
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onCustomPaletteCancel", function (newConfig) {
_this.props.setColorPaletteUI({
showSketcher: false,
colorRangeConfig: {
custom: false
}
});
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onToggleSketcher", function (val) {
_this.props.setColorPaletteUI({
showSketcher: val
});
});
return _this;
}
(0, _createClass2["default"])(ColorRangeSelect, [{
key: "render",
value: function render() {
var _this2 = this;
var _this$props$colorPale = this.props.colorPaletteUI,
customPalette = _this$props$colorPale.customPalette,
showSketcher = _this$props$colorPale.showSketcher,
colorRangeConfig = _this$props$colorPale.colorRangeConfig;
var filteredColorRanges = this.filteredColorRange(this.props);
return /*#__PURE__*/_react["default"].createElement(StyledColorRangeSelector, null, /*#__PURE__*/_react["default"].createElement(StyledColorConfig, null, (colorRangeConfig.custom ? ['custom'] : Object.keys(colorRangeConfig)).map(function (key) {
return /*#__PURE__*/_react["default"].createElement(PaletteConfig, {
key: key,
label: CONFIG_SETTINGS[key].label || key,
config: CONFIG_SETTINGS[key],
value: colorRangeConfig[key],
onChange: function onChange(value) {
return _this2._updateConfig({
key: key,
value: value
});
}
});
})), colorRangeConfig.custom ? /*#__PURE__*/_react["default"].createElement(_customPalette["default"], {
customPalette: customPalette,
showSketcher: showSketcher,
selected: this.props.selectedColorRange,
onApply: this.props.onSelectColorRange,
onToggleSketcher: this._onToggleSketcher,
setCustomPalette: this._onSetCustomPalette,
onCancel: this._onCustomPaletteCancel
}) : /*#__PURE__*/_react["default"].createElement(ColorPaletteGroup, {
colorRanges: filteredColorRanges,
onSelect: this.props.onSelectColorRange,
selected: this.props.selectedColorRange,
reversed: colorRangeConfig.reversed
}));
}
}]);
return ColorRangeSelect;
}(_react.Component);
exports["default"] = ColorRangeSelect;
(0, _defineProperty2["default"])(ColorRangeSelect, "propTypes", {
colorPaletteUI: _propTypes["default"].object.isRequired,
selectedColorRange: _propTypes["default"].object.isRequired,
onSelectColorRange: _propTypes["default"].func.isRequired,
setColorPaletteUI: _propTypes["default"].func.isRequired,
// optional
colorRanges: _propTypes["default"].arrayOf(_propTypes["default"].any)
});
(0, _defineProperty2["default"])(ColorRangeSelect, "defaultProps", {
colorRanges: _colorRanges.COLOR_RANGES,
onSelectColorRange: function onSelectColorRange() {},
setColorPaletteUI: function setColorPaletteUI() {}
});
var PaletteConfig = function PaletteConfig(_ref2) {
var label = _ref2.label,
value = _ref2.value,
_ref2$config = _ref2.config,
type = _ref2$config.type,
options = _ref2$config.options,
_onChange = _ref2.onChange;
return /*#__PURE__*/_react["default"].createElement(StyledPaletteConfig, {
className: "color-palette__config",
onClick: function onClick(e) {
return e.stopPropagation();
}
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "color-palette__config__label"
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "color.".concat(label)
}))), type === 'select' && /*#__PURE__*/_react["default"].createElement("div", {
className: "color-palette__config__select"
}, /*#__PURE__*/_react["default"].createElement(_itemSelector["default"], {
selectedItems: value,
options: options,
multiSelect: false,
searchable: false,
onChange: _onChange
})), type === 'switch' && /*#__PURE__*/_react["default"].createElement(_switch["default"], {
checked: value,
id: "".concat(label, "-toggle"),
onChange: function onChange() {
return _onChange(!value);
},
secondary: true
}));
};
exports.PaletteConfig = PaletteConfig;
var StyledColorRange = _styledComponents["default"].div.attrs({
className: 'color-palette-outer'
})(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 0 8px;\n :hover {\n background-color: ", ";\n cursor: pointer;\n }\n"])), function (props) {
return props.theme.panelBackgroundHover;
});
var ColorPaletteGroup = function ColorPaletteGroup(_ref3) {
var reversed = _ref3.reversed,
onSelect = _ref3.onSelect,
selected = _ref3.selected,
colorRanges = _ref3.colorRanges;
return /*#__PURE__*/_react["default"].createElement("div", {
className: "color-palette__group"
}, colorRanges.map(function (colorRange, i) {
return /*#__PURE__*/_react["default"].createElement(StyledColorRange, {
key: "".concat(colorRange.name, "-").concat(i),
onClick: function onClick(e) {
return onSelect(reversed ? (0, _colorUtils.reverseColorRange)(true, colorRange) : colorRange, e);
}
}, /*#__PURE__*/_react["default"].createElement(_colorPalette["default"], {
colors: colorRange.colors,
isReversed: reversed,
isSelected: colorRange.name === selected.name && reversed === Boolean(selected.reversed)
}));
}));
};
exports.ColorPaletteGroup = ColorPaletteGroup;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/layer-panel/color-range-selector.js"],"names":["ALL_TYPES","COLOR_RANGES","map","c","type","filter","ctype","concat","ALL_STEPS","d","colors","length","sort","numberSort","StyledColorConfig","styled","div","StyledColorRangeSelector","attrs","className","StyledPaletteConfig","props","theme","secondaryInput","CONFIG_SETTINGS","options","steps","reversed","custom","label","ColorRangeSelect","colorRanges","colorPaletteUI","colorRangeConfig","colorRangesSelector","configTypeSelector","configStepSelector","colorRange","isType","isStep","Number","key","value","_setColorRangeConfig","config","setColorPaletteUI","customPalette","newConfig","showSketcher","val","filteredColorRanges","filteredColorRange","Object","keys","_updateConfig","selectedColorRange","onSelectColorRange","_onToggleSketcher","_onSetCustomPalette","_onCustomPaletteCancel","Component","PropTypes","object","isRequired","func","arrayOf","any","PaletteConfig","onChange","e","stopPropagation","StyledColorRange","panelBackgroundHover","ColorPaletteGroup","onSelect","selected","i","name","Boolean"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 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 uniq from 'lodash.uniq';\nimport styled from 'styled-components';\nimport {createSelector} from 'reselect';\n\nimport ItemSelector from 'components/common/item-selector/item-selector';\nimport {PanelLabel} from 'components/common/styled-components';\nimport Switch from 'components/common/switch';\nimport ColorPalette from './color-palette';\nimport CustomPalette from './custom-palette';\nimport {COLOR_RANGES} from 'constants/color-ranges';\nimport {numberSort} from 'utils/data-utils';\nimport {reverseColorRange} from 'utils/color-utils';\nimport {FormattedMessage} from 'localization';\n\nexport const ALL_TYPES = uniq(\n  COLOR_RANGES.map(c => c.type)\n    .filter(ctype => ctype)\n    .concat(['all', 'custom'])\n);\n\nexport const ALL_STEPS = uniq(COLOR_RANGES.map(d => d.colors.length)).sort(numberSort);\n\nconst StyledColorConfig = styled.div`\n  padding: 12px 12px 0 12px;\n`;\n\nconst StyledColorRangeSelector = styled.div.attrs({\n  className: 'color-range-selector'\n})`\n  padding-bottom: 12px;\n`;\n\nconst StyledPaletteConfig = styled.div`\n  margin-bottom: 8px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  .color-palette__config__label {\n    flex-grow: 1;\n  }\n  .color-palette__config__select {\n    flex-grow: 1;\n  }\n  .item-selector .item-selector__dropdown {\n    ${props => props.theme.secondaryInput};\n  }\n`;\n\nconst CONFIG_SETTINGS = {\n  type: {\n    type: 'select',\n    options: ALL_TYPES\n  },\n  steps: {\n    type: 'select',\n    options: ALL_STEPS\n  },\n  reversed: {\n    type: 'switch',\n    options: [true, false]\n  },\n  custom: {\n    label: 'customPalette',\n    type: 'switch',\n    options: [true, false]\n  }\n};\n\nexport default class ColorRangeSelect extends Component {\n  static propTypes = {\n    colorPaletteUI: PropTypes.object.isRequired,\n    selectedColorRange: PropTypes.object.isRequired,\n    onSelectColorRange: PropTypes.func.isRequired,\n    setColorPaletteUI: PropTypes.func.isRequired,\n    // optional\n    colorRanges: PropTypes.arrayOf(PropTypes.any)\n  };\n\n  static defaultProps = {\n    colorRanges: COLOR_RANGES,\n    onSelectColorRange: () => {},\n    setColorPaletteUI: () => {}\n  };\n\n  colorRangesSelector = props => props.colorRanges;\n  configTypeSelector = props => props.colorPaletteUI.colorRangeConfig.type;\n  configStepSelector = props => props.colorPaletteUI.colorRangeConfig.steps;\n  filteredColorRange = createSelector(\n    this.colorRangesSelector,\n    this.configTypeSelector,\n    this.configStepSelector,\n    (colorRanges, type, steps) => {\n      return colorRanges.filter(colorRange => {\n        const isType = type === 'all' || type === colorRange.type;\n        const isStep = Number(steps) === colorRange.colors.length;\n\n        return isType && isStep;\n      });\n    }\n  );\n\n  _updateConfig = ({key, value}) => {\n    this._setColorRangeConfig({[key]: value});\n  };\n\n  _onSetCustomPalette = config => {\n    this.props.setColorPaletteUI({\n      customPalette: config\n    });\n  };\n\n  _setColorRangeConfig = newConfig => {\n    this.props.setColorPaletteUI({\n      colorRangeConfig: newConfig\n    });\n  };\n\n  _onCustomPaletteCancel = newConfig => {\n    this.props.setColorPaletteUI({\n      showSketcher: false,\n      colorRangeConfig: {custom: false}\n    });\n  };\n\n  _onToggleSketcher = val => {\n    this.props.setColorPaletteUI({\n      showSketcher: val\n    });\n  };\n\n  render() {\n    const {customPalette, showSketcher, colorRangeConfig} = this.props.colorPaletteUI;\n\n    const filteredColorRanges = this.filteredColorRange(this.props);\n\n    return (\n      <StyledColorRangeSelector>\n        <StyledColorConfig>\n          {(colorRangeConfig.custom ? ['custom'] : Object.keys(colorRangeConfig)).map(key => (\n            <PaletteConfig\n              key={key}\n              label={CONFIG_SETTINGS[key].label || key}\n              config={CONFIG_SETTINGS[key]}\n              value={colorRangeConfig[key]}\n              onChange={value => this._updateConfig({key, value})}\n            />\n          ))}\n        </StyledColorConfig>\n\n        {colorRangeConfig.custom ? (\n          <CustomPalette\n            customPalette={customPalette}\n            showSketcher={showSketcher}\n            selected={this.props.selectedColorRange}\n            onApply={this.props.onSelectColorRange}\n            onToggleSketcher={this._onToggleSketcher}\n            setCustomPalette={this._onSetCustomPalette}\n            onCancel={this._onCustomPaletteCancel}\n          />\n        ) : (\n          <ColorPaletteGroup\n            colorRanges={filteredColorRanges}\n            onSelect={this.props.onSelectColorRange}\n            selected={this.props.selectedColorRange}\n            reversed={colorRangeConfig.reversed}\n          />\n        )}\n      </StyledColorRangeSelector>\n    );\n  }\n}\n\nexport const PaletteConfig = ({label, value, config: {type, options}, onChange}) => (\n  <StyledPaletteConfig className=\"color-palette__config\" onClick={e => e.stopPropagation()}>\n    <div className=\"color-palette__config__label\">\n      <PanelLabel>\n        <FormattedMessage id={`color.${label}`} />\n      </PanelLabel>\n    </div>\n    {type === 'select' && (\n      <div className=\"color-palette__config__select\">\n        <ItemSelector\n          selectedItems={value}\n          options={options}\n          multiSelect={false}\n          searchable={false}\n          onChange={onChange}\n        />\n      </div>\n    )}\n    {type === 'switch' && (\n      <Switch checked={value} id={`${label}-toggle`} onChange={() => onChange(!value)} secondary />\n    )}\n  </StyledPaletteConfig>\n);\n\nconst StyledColorRange = styled.div.attrs({\n  className: 'color-palette-outer'\n})`\n  padding: 0 8px;\n  :hover {\n    background-color: ${props => props.theme.panelBackgroundHover};\n    cursor: pointer;\n  }\n`;\n\nexport const ColorPaletteGroup = ({reversed, onSelect, selected, colorRanges}) => (\n  <div className=\"color-palette__group\">\n    {colorRanges.map((colorRange, i) => (\n      <StyledColorRange\n        key={`${colorRange.name}-${i}`}\n        onClick={e => onSelect(reversed ? reverseColorRange(true, colorRange) : colorRange, e)}\n      >\n        <ColorPalette\n          colors={colorRange.colors}\n          isReversed={reversed}\n          isSelected={colorRange.name === selected.name && reversed === Boolean(selected.reversed)}\n        />\n      </StyledColorRange>\n    ))}\n  </div>\n);\n"]}