kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
386 lines (307 loc) • 35.2 kB
JavaScript
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
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 _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
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");
function _templateObject9() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: 12px;\n input {\n color: ", ";\n font-size: 10px;\n }\n"]);
_templateObject9 = function _templateObject9() {
return data;
};
return data;
}
function _templateObject8() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-top: 11px;\n display: flex;\n direction: rtl;\n"]);
_templateObject8 = function _templateObject8() {
return data;
};
return data;
}
function _templateObject7() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n padding: 0 8px;\n :hover {\n background-color: ", ";\n cursor: pointer;\n }\n"]);
_templateObject7 = function _templateObject7() {
return data;
};
return data;
}
function _templateObject6() {
var data = (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"]);
_templateObject6 = function _templateObject6() {
return data;
};
return data;
}
function _templateObject5() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n width: calc(100% - 16px);\n height: 1px;\n background-color: ", ";\n margin-top: 8px;\n margin-left: 8px;\n"]);
_templateObject5 = function _templateObject5() {
return data;
};
return data;
}
function _templateObject4() {
var data = (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"]);
_templateObject4 = function _templateObject4() {
return data;
};
return data;
}
function _templateObject3() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n opacity: 0;\n"]);
_templateObject3 = function _templateObject3() {
return data;
};
return data;
}
function _templateObject2() {
var data = (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"]);
_templateObject2 = function _templateObject2() {
return data;
};
return data;
}
function _templateObject() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n .layer__drag-handle {\n color: ", ";\n opacity: 1;\n cursor: move;\n }\n"]);
_templateObject = function _templateObject() {
return data;
};
return data;
}
var dragHandleActive = (0, _styledComponents.css)(_templateObject(), function (props) {
return props.theme.textColorHl;
});
var StyledSortableItem = _styledComponents["default"].div(_templateObject2(), 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());
var StyledTrash = _styledComponents["default"].div(_templateObject4(), function (props) {
return props.theme.textColor;
}, function (props) {
return props.theme.subtextColorActive;
});
var StyledLine = _styledComponents["default"].div(_templateObject5(), function (props) {
return props.theme.labelColor;
});
var StyledSwatch = _styledComponents["default"].div.attrs({
className: 'custom-palette__swatch'
})(_templateObject6(), function (props) {
return props.color;
}, function (props) {
return props.theme.boxShadow;
});
var StyledColorRange = _styledComponents["default"].div(_templateObject7(), function (props) {
return props.theme.panelBackgroundHover;
});
var StyledButtonContainer = _styledComponents["default"].div(_templateObject8());
var StyledInlineInput = _styledComponents["default"].div(_templateObject9(), function (props) {
return props.theme.textColorHl;
});
var SortableItem = (0, _reactSortableHoc.sortableElement)(function (_ref) {
var children = _ref.children,
isSorting = _ref.isSorting;
return _react["default"].createElement(StyledSortableItem, {
className: (0, _classnames["default"])('custom-palette__sortable-items', {
sorting: isSorting
})
}, children);
});
var SortableContainer = (0, _reactSortableHoc.sortableContainer)(function (_ref2) {
var children = _ref2.children;
return _react["default"].createElement("div", null, children);
});
var DragHandle = (0, _reactSortableHoc.sortableHandle)(function (_ref3) {
var className = _ref3.className,
children = _ref3.children;
return _react["default"].createElement(StyledDragHandle, {
className: className
}, children);
});
var CustomPalette =
/*#__PURE__*/
function (_Component) {
(0, _inherits2["default"])(CustomPalette, _Component);
function CustomPalette() {
var _getPrototypeOf2;
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 = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(CustomPalette)).call.apply(_getPrototypeOf2, [this].concat(args)));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", {
isSorting: false
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "root", (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 _react["default"].createElement("div", {
className: "custom-palette-panel",
ref: this.root
}, _react["default"].createElement(StyledColorRange, null, _react["default"].createElement(_colorPalette["default"], {
colors: colors
})), _react["default"].createElement(SortableContainer, {
className: "custom-palette-container",
onSortEnd: this._onSortEnd,
onSortStart: this._onSortStart,
lockAxis: "y",
helperClass: "sorting-colors",
useDragHandle: true
}, colors.map(function (color, index) {
return _react["default"].createElement(SortableItem, {
key: index,
index: index,
isSorting: _this2.state.isSorting
}, _react["default"].createElement(DragHandle, {
className: "layer__drag-handle"
}, _react["default"].createElement(_icons.VertDots, {
height: "20px"
})), _react["default"].createElement(StyledSwatch, {
color: color,
onClick: function onClick(e) {
return _this2._onSwatchClick(index, e);
}
}), _react["default"].createElement(StyledInlineInput, null, _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"
})), _react["default"].createElement(StyledTrash, {
onClick: function onClick() {
return _this2._onColorDelete(index);
}
}, _react["default"].createElement(_icons.Trash, {
className: "trashbin"
})));
})), _react["default"].createElement(_styledComponents2.Button, {
className: "add-step__button",
link: true,
onClick: this._onColorAdd
}, "+ Add Step"), _react["default"].createElement(StyledLine, null), _react["default"].createElement(StyledButtonContainer, null, _react["default"].createElement(_styledComponents2.Button, {
className: "confirm-apply__button",
link: true,
onClick: this._onApply
}, "Confirm"), _react["default"].createElement(_styledComponents2.Button, {
link: true,
onClick: this.props.onCancel
}, "Cancel")), _react["default"].createElement(_portaled["default"], {
isOpened: this.props.showSketcher !== false,
left: 280,
top: -300
}, _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","SortableContainer","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","e","_onSwatchClick","_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) 2020 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\nconst SortableContainer = sortableContainer(({children}) => <div>{children}</div>);\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        <SortableContainer\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={e => this._onSwatchClick(index, e)} />\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\"\n                />\n              </StyledInlineInput>\n              <StyledTrash onClick={() => this._onColorDelete(index)}>\n                <Trash className=\"trashbin\" />\n              </StyledTrash>\n            </SortableItem>\n          ))}\n        </SortableContainer>\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"]}
;