UNPKG

kepler.gl

Version:

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

86 lines (85 loc) 14.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _classnames = _interopRequireDefault(require("classnames")); var _utils = require("@kepler.gl/utils"); var _localization = require("@kepler.gl/localization"); var _constants = require("@kepler.gl/constants"); var _customPicker = _interopRequireDefault(require("./custom-picker")); var _colorPalettePreset = _interopRequireDefault(require("./color-palette-preset")); var _templateObject; // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; } var MODE = { preset: 'preset', picker: 'picker' }; var StyledColorPickerTop = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n border-bottom: 1px solid ", ";\n display: flex;\n padding-top: 2px 4px 0 4px;\n .color-palette-tab {\n padding: 8px 0;\n margin: 0 8px;\n color: ", ";\n border-bottom: 2px;\n border-bottom-style: solid;\n border-bottom-color: transparent;\n &.active {\n color: ", ";\n border-bottom-color: ", ";\n }\n &:hover {\n cursor: pointer;\n color: ", ";\n }\n }\n"])), function (_ref) { var theme = _ref.theme; return theme.dropdownListBorderTop; }, function (_ref2) { var theme = _ref2.theme; return theme.subtextColor; }, function (_ref3) { var theme = _ref3.theme; return theme.textColorHl; }, function (_ref4) { var theme = _ref4.theme; return theme.panelToggleBorderColor; }, function (props) { return props.theme.textColorHl; }); var ColorPickerTop = function ColorPickerTop(_ref5) { var setMode = _ref5.setMode, mode = _ref5.mode; return /*#__PURE__*/_react["default"].createElement(StyledColorPickerTop, null, Object.keys(MODE).map(function (modeId) { return /*#__PURE__*/_react["default"].createElement("div", { onClick: function onClick() { return setMode(modeId); }, key: modeId, className: (0, _classnames["default"])('color-palette-tab', { active: mode === modeId }) }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: "color.".concat(modeId) })); })); }; var SingleColorPalette = function SingleColorPalette(_ref6) { var selectedColor = _ref6.selectedColor, onSelectColor = _ref6.onSelectColor; var _useState = (0, _react.useState)(MODE.preset), _useState2 = (0, _slicedToArray2["default"])(_useState, 2), mode = _useState2[0], setMode = _useState2[1]; var onSetColor = (0, _react.useCallback)(function (color, e) { // color picker return an object, with color.hex var hex = color.hex || color; onSelectColor((0, _utils.hexToRgb)(hex), e); }, [onSelectColor]); return /*#__PURE__*/_react["default"].createElement("div", { className: "single-color-palette" }, /*#__PURE__*/_react["default"].createElement(ColorPickerTop, { mode: mode, setMode: setMode }), mode === MODE.preset ? /*#__PURE__*/_react["default"].createElement(_colorPalettePreset["default"], { themes: _constants.Themes, onSelectColor: onSetColor, selectedColor: selectedColor }) : null, mode === MODE.picker ? /*#__PURE__*/_react["default"].createElement(_customPicker["default"], { color: selectedColor, onChange: onSetColor }) : null); }; var _default = exports["default"] = SingleColorPalette; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_classnames","_utils","_localization","_constants","_customPicker","_colorPalettePreset","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","MODE","preset","picker","StyledColorPickerTop","styled","div","_taggedTemplateLiteral2","_ref","theme","dropdownListBorderTop","_ref2","subtextColor","_ref3","textColorHl","_ref4","panelToggleBorderColor","props","ColorPickerTop","_ref5","setMode","mode","createElement","keys","map","modeId","onClick","key","className","classnames","active","FormattedMessage","id","concat","SingleColorPalette","_ref6","selectedColor","onSelectColor","_useState","useState","_useState2","_slicedToArray2","onSetColor","useCallback","color","hex","hexToRgb","themes","Themes","onChange","_default","exports"],"sources":["../../../src/side-panel/layer-panel/single-color-palette.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {MouseEvent, useCallback, useState} from 'react';\nimport styled from 'styled-components';\nimport classnames from 'classnames';\n\nimport {hexToRgb} from '@kepler.gl/utils';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {Themes} from '@kepler.gl/constants';\nimport {ColorRange, HexColor, RGBColor} from '@kepler.gl/types';\n\nimport CustomPicker from './custom-picker';\nimport PresetColorPalette from './color-palette-preset';\n\nconst MODE = {\n  preset: 'preset',\n  picker: 'picker'\n};\n\nexport type SingleColorPaletteProps = {\n  selectedColor: HexColor;\n  onSelectColor: (color: RGBColor | ColorRange, e: MouseEvent) => void;\n};\n\nconst StyledColorPickerTop = styled.div`\n  border-bottom: 1px solid ${({theme}) => theme.dropdownListBorderTop};\n  display: flex;\n  padding-top: 2px 4px 0 4px;\n  .color-palette-tab {\n    padding: 8px 0;\n    margin: 0 8px;\n    color: ${({theme}) => theme.subtextColor};\n    border-bottom: 2px;\n    border-bottom-style: solid;\n    border-bottom-color: transparent;\n    &.active {\n      color: ${({theme}) => theme.textColorHl};\n      border-bottom-color: ${({theme}) => theme.panelToggleBorderColor};\n    }\n    &:hover {\n      cursor: pointer;\n      color: ${props => props.theme.textColorHl};\n    }\n  }\n`;\n\nconst ColorPickerTop = ({setMode, mode}) => (\n  <StyledColorPickerTop>\n    {Object.keys(MODE).map(modeId => (\n      <div\n        onClick={() => setMode(modeId)}\n        key={modeId}\n        className={classnames('color-palette-tab', {active: mode === modeId})}\n      >\n        <FormattedMessage id={`color.${modeId}`} />\n      </div>\n    ))}\n  </StyledColorPickerTop>\n);\n\nconst SingleColorPalette: React.FC<SingleColorPaletteProps> = ({\n  selectedColor,\n  onSelectColor\n}: SingleColorPaletteProps) => {\n  const [mode, setMode] = useState(MODE.preset);\n  const onSetColor = useCallback(\n    (color, e) => {\n      // color picker return an object, with color.hex\n      const hex = color.hex || color;\n      onSelectColor(hexToRgb(hex), e);\n    },\n    [onSelectColor]\n  );\n  return (\n    <div className=\"single-color-palette\">\n      <ColorPickerTop mode={mode} setMode={setMode} />\n      {mode === MODE.preset ? (\n        <PresetColorPalette\n          themes={Themes}\n          onSelectColor={onSetColor}\n          selectedColor={selectedColor}\n        />\n      ) : null}\n      {mode === MODE.picker ? <CustomPicker color={selectedColor} onChange={onSetColor} /> : null}\n    </div>\n  );\n};\n\nexport default SingleColorPalette;\n"],"mappings":"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","ignoreList":[]}