UNPKG

kepler.gl

Version:

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

304 lines (248 loc) 35.7 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); 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 _classnames = _interopRequireDefault(require("classnames")); var _propTypes = _interopRequireDefault(require("prop-types")); var _styledComponents = _interopRequireWildcard(require("styled-components")); var _reactSortableHoc = require("react-sortable-hoc"); var _portaled = _interopRequireDefault(require("../../common/portaled")); var _styledComponents2 = require("../../common/styled-components"); var _icons = require("../../common/icons"); var _colorPalette = _interopRequireDefault(require("./color-palette")); var _customPicker = _interopRequireDefault(require("./custom-picker")); var _dataUtils = require("../../../utils/data-utils"); var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9; 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 dragHandleActive = (0, _styledComponents.css)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n .layer__drag-handle {\n color: ", ";\n opacity: 1;\n cursor: move;\n }\n"])), function (props) { return props.theme.textColorHl; }); var StyledSortableItem = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n padding-top: 6px;\n padding-bottom: 6px;\n z-index: ", ";\n\n :not(.sorting) {\n :hover {\n background-color: ", ";\n ", ";\n }\n }\n\n &.sorting-colors {\n background-color: ", ";\n ", ";\n }\n"])), function (props) { return props.theme.dropdownWrapperZ + 1; }, function (props) { return props.theme.panelBackgroundHover; }, dragHandleActive, function (props) { return props.theme.panelBackgroundHover; }, dragHandleActive); var StyledDragHandle = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n opacity: 0;\n"]))); var StyledTrash = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n svg {\n :hover {\n color: ", ";\n }\n }\n height: 12px;\n margin-left: auto;\n margin-right: 12px;\n :hover {\n cursor: pointer;\n }\n"])), function (props) { return props.theme.textColor; }, function (props) { return props.theme.subtextColorActive; }); var StyledLine = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n width: calc(100% - 16px);\n height: 1px;\n background-color: ", ";\n margin-top: 8px;\n margin-left: 8px;\n"])), function (props) { return props.theme.labelColor; }); var StyledSwatch = _styledComponents["default"].div.attrs({ className: 'custom-palette__swatch' })(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n width: 32px;\n height: 18px;\n display: inline-block;\n :hover {\n box-shadow: ", ";\n cursor: pointer;\n }\n"])), function (props) { return props.color; }, function (props) { return props.theme.boxShadow; }); var StyledColorRange = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 0 8px;\n :hover {\n background-color: ", ";\n cursor: pointer;\n }\n"])), function (props) { return props.theme.panelBackgroundHover; }); var StyledButtonContainer = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n margin-top: 11px;\n display: flex;\n direction: rtl;\n"]))); var StyledInlineInput = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: 12px;\n input {\n color: ", ";\n font-size: 10px;\n }\n"])), function (props) { return props.theme.textColorHl; }); var SortableItem = (0, _reactSortableHoc.SortableElement)(function (_ref) { var children = _ref.children, isSorting = _ref.isSorting; return /*#__PURE__*/_react["default"].createElement(StyledSortableItem, { className: (0, _classnames["default"])('custom-palette__sortable-items', { sorting: isSorting }) }, children); }); // TODO: Should className be applied to the div here? var WrappedSortableContainer = (0, _reactSortableHoc.SortableContainer)(function (_ref2) { var children = _ref2.children, className = _ref2.className; return /*#__PURE__*/_react["default"].createElement("div", { className: className }, children); }); var DragHandle = (0, _reactSortableHoc.SortableHandle)(function (_ref3) { var className = _ref3.className, children = _ref3.children; return /*#__PURE__*/_react["default"].createElement(StyledDragHandle, { className: className }, children); }); var CustomPalette = /*#__PURE__*/function (_Component) { (0, _inherits2["default"])(CustomPalette, _Component); var _super = _createSuper(CustomPalette); function CustomPalette() { var _this; (0, _classCallCheck2["default"])(this, CustomPalette); 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), "state", { isSorting: false }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "root", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onPickerUpdate", function (color) { var colors = _this.props.customPalette.colors; var newColors = (0, _toConsumableArray2["default"])(colors); newColors[_this.props.showSketcher] = color.hex; _this._setColorPaletteUI(newColors); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onColorDelete", function (index) { var colors = _this.props.customPalette.colors; var newColors = (0, _toConsumableArray2["default"])(colors); if (newColors.length > 1) { newColors.splice(index, 1); } _this._setColorPaletteUI(newColors); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onColorAdd", function () { var colors = _this.props.customPalette.colors; // add the last color var newColors = [].concat((0, _toConsumableArray2["default"])(colors), [colors[colors.length - 1]]); _this._setColorPaletteUI(newColors); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onSwatchClick", function (index) { _this.props.onToggleSketcher(index); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onSwatchClose", function () { _this.props.onToggleSketcher(false); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onApply", function (event) { event.stopPropagation(); event.preventDefault(); _this.props.onCancel(); _this.props.onApply(_this.props.customPalette, event); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onSortEnd", function (_ref4) { var oldIndex = _ref4.oldIndex, newIndex = _ref4.newIndex; var colors = _this.props.customPalette.colors; var newColors = (0, _dataUtils.arrayMove)(colors, oldIndex, newIndex); _this._setColorPaletteUI(newColors); _this.setState({ isSorting: false }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onSortStart", function () { _this.setState({ isSorting: true }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_inputColorHex", function (index, _ref5) { var value = _ref5.target.value; var colors = _this.props.customPalette.colors; var newColors = (0, _toConsumableArray2["default"])(colors); newColors[index] = value.toUpperCase(); _this._setColorPaletteUI(newColors); }); return _this; } (0, _createClass2["default"])(CustomPalette, [{ key: "_setColorPaletteUI", value: function _setColorPaletteUI(colors) { this.props.setCustomPalette({ colors: colors }); } }, { key: "render", value: function render() { var _this2 = this; var colors = this.props.customPalette.colors; return /*#__PURE__*/_react["default"].createElement("div", { className: "custom-palette-panel", ref: this.root }, /*#__PURE__*/_react["default"].createElement(StyledColorRange, null, /*#__PURE__*/_react["default"].createElement(_colorPalette["default"], { colors: colors })), /*#__PURE__*/_react["default"].createElement(WrappedSortableContainer, { className: "custom-palette-container", onSortEnd: this._onSortEnd, onSortStart: this._onSortStart, lockAxis: "y", helperClass: "sorting-colors", useDragHandle: true }, colors.map(function (color, index) { return /*#__PURE__*/_react["default"].createElement(SortableItem, { key: index, index: index, isSorting: _this2.state.isSorting }, /*#__PURE__*/_react["default"].createElement(DragHandle, { className: "layer__drag-handle" }, /*#__PURE__*/_react["default"].createElement(_icons.VertDots, { height: "20px" })), /*#__PURE__*/_react["default"].createElement(StyledSwatch, { color: color, onClick: function onClick() { return _this2._onSwatchClick(index); } }), /*#__PURE__*/_react["default"].createElement(StyledInlineInput, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.InlineInput, { type: "text", className: "custom-palette-hex__input", value: color.toUpperCase(), onClick: function onClick(e) { e.stopPropagation(); }, onChange: function onChange(e) { return _this2._inputColorHex(index, e); }, id: "input-layer-label-".concat(index) })), /*#__PURE__*/_react["default"].createElement(StyledTrash, { onClick: function onClick() { return _this2._onColorDelete(index); } }, /*#__PURE__*/_react["default"].createElement(_icons.Trash, { className: "trashbin" }))); })), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, { className: "add-step__button", link: true, onClick: this._onColorAdd }, "+ Add Step"), /*#__PURE__*/_react["default"].createElement(StyledLine, null), /*#__PURE__*/_react["default"].createElement(StyledButtonContainer, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, { className: "confirm-apply__button", link: true, onClick: this._onApply }, "Confirm"), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, { link: true, onClick: this.props.onCancel }, "Cancel")), /*#__PURE__*/_react["default"].createElement(_portaled["default"], { isOpened: this.props.showSketcher !== false, left: 280, top: -300 }, /*#__PURE__*/_react["default"].createElement(_customPicker["default"], { color: colors[this.props.showSketcher], onChange: this._onPickerUpdate, onSwatchClose: this._onSwatchClose }))); } }]); return CustomPalette; }(_react.Component); (0, _defineProperty2["default"])(CustomPalette, "propTypes", { customPalette: _propTypes["default"].shape({ name: _propTypes["default"].string, type: _propTypes["default"].string, category: _propTypes["default"].string, colors: _propTypes["default"].arrayOf(_propTypes["default"].string) }), setCustomPalette: _propTypes["default"].func, showSketcher: _propTypes["default"].oneOfType([_propTypes["default"].bool, _propTypes["default"].number]) }); var _default = CustomPalette; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/layer-panel/custom-palette.js"],"names":["dragHandleActive","css","props","theme","textColorHl","StyledSortableItem","styled","div","dropdownWrapperZ","panelBackgroundHover","StyledDragHandle","StyledTrash","textColor","subtextColorActive","StyledLine","labelColor","StyledSwatch","attrs","className","color","boxShadow","StyledColorRange","StyledButtonContainer","StyledInlineInput","SortableItem","children","isSorting","sorting","WrappedSortableContainer","DragHandle","CustomPalette","colors","customPalette","newColors","showSketcher","hex","_setColorPaletteUI","index","length","splice","onToggleSketcher","event","stopPropagation","preventDefault","onCancel","onApply","oldIndex","newIndex","setState","value","target","toUpperCase","setCustomPalette","root","_onSortEnd","_onSortStart","map","state","_onSwatchClick","e","_inputColorHex","_onColorDelete","_onColorAdd","_onApply","_onPickerUpdate","_onSwatchClose","Component","PropTypes","shape","name","string","type","category","arrayOf","func","oneOfType","bool","number"],"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, createRef} from 'react';\nimport classnames from 'classnames';\nimport PropTypes from 'prop-types';\nimport styled, {css} from 'styled-components';\nimport {SortableContainer, SortableElement, SortableHandle} from 'react-sortable-hoc';\nimport Portaled from 'components/common/portaled';\n\nimport {Button, InlineInput} from 'components/common/styled-components';\nimport {VertDots, Trash} from 'components/common/icons';\nimport ColorPalette from './color-palette';\nimport CustomPicker from './custom-picker';\nimport {arrayMove} from 'utils/data-utils';\n\nconst dragHandleActive = css`\n  .layer__drag-handle {\n    color: ${props => props.theme.textColorHl};\n    opacity: 1;\n    cursor: move;\n  }\n`;\n\nconst StyledSortableItem = styled.div`\n  display: flex;\n  align-items: center;\n  padding-top: 6px;\n  padding-bottom: 6px;\n  z-index: ${props => props.theme.dropdownWrapperZ + 1};\n\n  :not(.sorting) {\n    :hover {\n      background-color: ${props => props.theme.panelBackgroundHover};\n      ${dragHandleActive};\n    }\n  }\n\n  &.sorting-colors {\n    background-color: ${props => props.theme.panelBackgroundHover};\n    ${dragHandleActive};\n  }\n`;\n\nconst StyledDragHandle = styled.div`\n  display: flex;\n  align-items: center;\n  opacity: 0;\n`;\n\nconst StyledTrash = styled.div`\n  color: ${props => props.theme.textColor};\n  svg {\n    :hover {\n      color: ${props => props.theme.subtextColorActive};\n    }\n  }\n  height: 12px;\n  margin-left: auto;\n  margin-right: 12px;\n  :hover {\n    cursor: pointer;\n  }\n`;\n\nconst StyledLine = styled.div`\n  width: calc(100% - 16px);\n  height: 1px;\n  background-color: ${props => props.theme.labelColor};\n  margin-top: 8px;\n  margin-left: 8px;\n`;\n\nconst StyledSwatch = styled.div.attrs({\n  className: 'custom-palette__swatch'\n})`\n  background-color: ${props => props.color};\n  width: 32px;\n  height: 18px;\n  display: inline-block;\n  :hover {\n    box-shadow: ${props => props.theme.boxShadow};\n    cursor: pointer;\n  }\n`;\n\nconst StyledColorRange = styled.div`\n  padding: 0 8px;\n  :hover {\n    background-color: ${props => props.theme.panelBackgroundHover};\n    cursor: pointer;\n  }\n`;\n\nconst StyledButtonContainer = styled.div`\n  margin-top: 11px;\n  display: flex;\n  direction: rtl;\n`;\n\nconst StyledInlineInput = styled.div`\n  margin-left: 12px;\n  input {\n    color: ${props => props.theme.textColorHl};\n    font-size: 10px;\n  }\n`;\n\nconst SortableItem = SortableElement(({children, isSorting}) => (\n  <StyledSortableItem\n    className={classnames('custom-palette__sortable-items', {sorting: isSorting})}\n  >\n    {children}\n  </StyledSortableItem>\n));\n\n// TODO: Should className be applied to the div here?\nconst WrappedSortableContainer = SortableContainer(({children, className}) => (\n  <div className={className}>{children}</div>\n));\n\nconst DragHandle = SortableHandle(({className, children}) => (\n  <StyledDragHandle className={className}>{children}</StyledDragHandle>\n));\n\nclass CustomPalette extends Component {\n  static propTypes = {\n    customPalette: PropTypes.shape({\n      name: PropTypes.string,\n      type: PropTypes.string,\n      category: PropTypes.string,\n      colors: PropTypes.arrayOf(PropTypes.string)\n    }),\n    setCustomPalette: PropTypes.func,\n    showSketcher: PropTypes.oneOfType([PropTypes.bool, PropTypes.number])\n  };\n\n  state = {\n    isSorting: false\n  };\n\n  root = createRef();\n\n  _setColorPaletteUI(colors) {\n    this.props.setCustomPalette({\n      colors\n    });\n  }\n\n  _onPickerUpdate = color => {\n    const {colors} = this.props.customPalette;\n    const newColors = [...colors];\n    newColors[this.props.showSketcher] = color.hex;\n    this._setColorPaletteUI(newColors);\n  };\n\n  _onColorDelete = index => {\n    const {colors} = this.props.customPalette;\n    const newColors = [...colors];\n    if (newColors.length > 1) {\n      newColors.splice(index, 1);\n    }\n    this._setColorPaletteUI(newColors);\n  };\n\n  _onColorAdd = () => {\n    const {colors} = this.props.customPalette;\n    // add the last color\n    const newColors = [...colors, colors[colors.length - 1]];\n    this._setColorPaletteUI(newColors);\n  };\n\n  _onSwatchClick = index => {\n    this.props.onToggleSketcher(index);\n  };\n\n  _onSwatchClose = () => {\n    this.props.onToggleSketcher(false);\n  };\n\n  _onApply = event => {\n    event.stopPropagation();\n    event.preventDefault();\n    this.props.onCancel();\n    this.props.onApply(this.props.customPalette, event);\n  };\n\n  _onSortEnd = ({oldIndex, newIndex}) => {\n    const {colors} = this.props.customPalette;\n    const newColors = arrayMove(colors, oldIndex, newIndex);\n    this._setColorPaletteUI(newColors);\n    this.setState({isSorting: false});\n  };\n\n  _onSortStart = () => {\n    this.setState({isSorting: true});\n  };\n\n  _inputColorHex = (index, {target: {value}}) => {\n    const {colors} = this.props.customPalette;\n    const newColors = [...colors];\n    newColors[index] = value.toUpperCase();\n    this._setColorPaletteUI(newColors);\n  };\n\n  render() {\n    const {colors} = this.props.customPalette;\n\n    return (\n      <div className=\"custom-palette-panel\" ref={this.root}>\n        <StyledColorRange>\n          <ColorPalette colors={colors} />\n        </StyledColorRange>\n        <WrappedSortableContainer\n          className=\"custom-palette-container\"\n          onSortEnd={this._onSortEnd}\n          onSortStart={this._onSortStart}\n          lockAxis=\"y\"\n          helperClass=\"sorting-colors\"\n          useDragHandle\n        >\n          {colors.map((color, index) => (\n            <SortableItem key={index} index={index} isSorting={this.state.isSorting}>\n              <DragHandle className=\"layer__drag-handle\">\n                <VertDots height=\"20px\" />\n              </DragHandle>\n              <StyledSwatch color={color} onClick={() => this._onSwatchClick(index)} />\n              <StyledInlineInput>\n                <InlineInput\n                  type=\"text\"\n                  className=\"custom-palette-hex__input\"\n                  value={color.toUpperCase()}\n                  onClick={e => {\n                    e.stopPropagation();\n                  }}\n                  onChange={e => this._inputColorHex(index, e)}\n                  id={`input-layer-label-${index}`}\n                />\n              </StyledInlineInput>\n              <StyledTrash onClick={() => this._onColorDelete(index)}>\n                <Trash className=\"trashbin\" />\n              </StyledTrash>\n            </SortableItem>\n          ))}\n        </WrappedSortableContainer>\n        {/* Add Step Button */}\n        <Button className=\"add-step__button\" link onClick={this._onColorAdd}>\n          + Add Step\n        </Button>\n        <StyledLine />\n        {/* Cancel or Confirm Buttons */}\n        <StyledButtonContainer>\n          <Button className=\"confirm-apply__button\" link onClick={this._onApply}>\n            Confirm\n          </Button>\n          <Button link onClick={this.props.onCancel}>\n            Cancel\n          </Button>\n        </StyledButtonContainer>\n\n        <Portaled isOpened={this.props.showSketcher !== false} left={280} top={-300}>\n          <CustomPicker\n            color={colors[this.props.showSketcher]}\n            onChange={this._onPickerUpdate}\n            onSwatchClose={this._onSwatchClose}\n          />\n        </Portaled>\n      </div>\n    );\n  }\n}\n\nexport default CustomPalette;\n"]}