UNPKG

kepler.gl

Version:

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

111 lines (110 loc) 19.5 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"] = exports.StyledPanelDropdown = 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 _utils = require("@kepler.gl/utils"); var _styledComponents2 = require("../common/styled-components"); var _portaled = _interopRequireDefault(require("../common/portaled")); var _singleColorPalette = _interopRequireDefault(require("../side-panel/layer-panel/single-color-palette")); var _templateObject, _templateObject2, _templateObject3, _templateObject4; // 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 StyledPanelDropdown = exports.StyledPanelDropdown = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n ", "\n background-color: ", ";\n box-shadow: ", ";\n border-radius: ", ";\n overflow-y: auto;\n max-height: 500px;\n position: relative;\n z-index: 999;\n width: 220px;\n"])), function (props) { return props.theme.panelDropdownScrollBar; }, function (props) { return props.theme.panelBackground; }, function (props) { return props.theme.panelBoxShadow; }, function (props) { return props.theme.panelBorderRadius; }); var StyledConfigSection = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n"]))); var SectionTitle = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: ", ";\n color: ", ";\n margin-bottom: 8px;\n"])), function (props) { return props.theme.inputFontSize; }, function (props) { return props.theme.effectPanelTextSecondary2; }); var StyledDropdownButtonWrapper = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n align-self: flex-start;\n .button {\n color: ", ";\n display: flex;\n gap: 5px;\n border: none;\n transition: background 0.2s;\n background-color: ", ";\n padding: 8px 5px 8px 10px;\n &:active {\n color: ", ";\n background-color: ", ";\n }\n &:hover {\n color: ", ";\n background-color: ", ";\n }\n & > svg {\n margin-right: 0;\n }\n }\n"])), function (props) { return props.theme.effectPanelTextSecondary2; }, function (props) { return props.theme.inputBgd; }, function (props) { return props.theme.effectPanelTextMain; }, function (props) { return props.theme.inputBgdHover; }, function (props) { return props.theme.effectPanelTextMain; }, function (props) { return props.theme.inputBgdHover; }); var DEFAULT_OFFSET = { top: 0, left: 0 }; var SingleColorPickerDropdown = function SingleColorPickerDropdown(_ref) { var isOpened = _ref.isOpened, onClose = _ref.onClose, selectedColor = _ref.selectedColor, onSelectColor = _ref.onSelectColor, _ref$offset = _ref.offset, offset = _ref$offset === void 0 ? DEFAULT_OFFSET : _ref$offset; var onSelectColorCb = (0, _react.useCallback)(function (v) { onSelectColor(v); }, [onSelectColor]); return /*#__PURE__*/_react["default"].createElement(_portaled["default"], { top: offset.top, left: offset.left, isOpened: isOpened, onClose: onClose }, /*#__PURE__*/_react["default"].createElement(StyledPanelDropdown, null, /*#__PURE__*/_react["default"].createElement(_singleColorPalette["default"], { selectedColor: selectedColor, onSelectColor: onSelectColorCb }))); }; var CompactColorPicker = function CompactColorPicker(_ref2) { var color = _ref2.color, onSetColor = _ref2.onSetColor, Icon = _ref2.Icon, label = _ref2.label; var _React$useState = _react["default"].useState(false), _React$useState2 = (0, _slicedToArray2["default"])(_React$useState, 2), isColorPickerOpened = _React$useState2[0], setIsColorPickerOpened = _React$useState2[1]; var hexColor = (0, _react.useMemo)(function () { return (0, _utils.rgbToHex)(color); }, [color]); var colorBlockStyle = (0, _react.useMemo)(function () { return { width: 16, height: 16, backgroundColor: hexColor, borderRadius: 2 }; }, [hexColor]); var toggleDropdown = (0, _react.useCallback)(function () { setIsColorPickerOpened(!isColorPickerOpened); }, [isColorPickerOpened, setIsColorPickerOpened]); var closeDropdown = (0, _react.useCallback)(function () { setIsColorPickerOpened(false); }, [setIsColorPickerOpened]); return /*#__PURE__*/_react["default"].createElement(StyledConfigSection, null, /*#__PURE__*/_react["default"].createElement(SectionTitle, null, label), /*#__PURE__*/_react["default"].createElement(StyledDropdownButtonWrapper, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, { onClick: toggleDropdown }, /*#__PURE__*/_react["default"].createElement("div", { style: colorBlockStyle }), /*#__PURE__*/_react["default"].createElement(Icon, null))), /*#__PURE__*/_react["default"].createElement(SingleColorPickerDropdown, { isOpened: isColorPickerOpened, onClose: closeDropdown, selectedColor: hexColor, onSelectColor: onSetColor })); }; var _default = exports["default"] = CompactColorPicker; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_utils","_styledComponents2","_portaled","_singleColorPalette","_templateObject","_templateObject2","_templateObject3","_templateObject4","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledPanelDropdown","exports","styled","div","_taggedTemplateLiteral2","props","theme","panelDropdownScrollBar","panelBackground","panelBoxShadow","panelBorderRadius","StyledConfigSection","SectionTitle","inputFontSize","effectPanelTextSecondary2","StyledDropdownButtonWrapper","inputBgd","effectPanelTextMain","inputBgdHover","DEFAULT_OFFSET","top","left","SingleColorPickerDropdown","_ref","isOpened","onClose","selectedColor","onSelectColor","_ref$offset","offset","onSelectColorCb","useCallback","v","createElement","CompactColorPicker","_ref2","color","onSetColor","Icon","label","_React$useState","React","useState","_React$useState2","_slicedToArray2","isColorPickerOpened","setIsColorPickerOpened","hexColor","useMemo","rgbToHex","colorBlockStyle","width","height","backgroundColor","borderRadius","toggleDropdown","closeDropdown","Button","onClick","style","_default"],"sources":["../../src/effects/compact-color-picker.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo} from 'react';\nimport styled from 'styled-components';\n\nimport {rgbToHex} from '@kepler.gl/utils';\n\nimport {Button} from '../common/styled-components';\nimport Portaled from '../common/portaled';\nimport SingleColorPalette from '../side-panel/layer-panel/single-color-palette';\n\nexport type SingleColorPickerProps = {\n  color: [number, number, number];\n  onSetColor: (value: [number, number, number]) => void;\n  label: string;\n  Icon: React.ElementType;\n};\n\nexport const StyledPanelDropdown = styled.div`\n  ${props => props.theme.panelDropdownScrollBar}\n  background-color: ${props => props.theme.panelBackground};\n  box-shadow: ${props => props.theme.panelBoxShadow};\n  border-radius: ${props => props.theme.panelBorderRadius};\n  overflow-y: auto;\n  max-height: 500px;\n  position: relative;\n  z-index: 999;\n  width: 220px;\n`;\n\nconst StyledConfigSection = styled.div`\n  display: flex;\n  flex-direction: column;\n`;\n\nconst SectionTitle = styled.div`\n  font-size: ${props => props.theme.inputFontSize};\n  color: ${props => props.theme.effectPanelTextSecondary2};\n  margin-bottom: 8px;\n`;\n\nconst StyledDropdownButtonWrapper = styled.div`\n  align-self: flex-start;\n  .button {\n    color: ${props => props.theme.effectPanelTextSecondary2};\n    display: flex;\n    gap: 5px;\n    border: none;\n    transition: background 0.2s;\n    background-color: ${props => props.theme.inputBgd};\n    padding: 8px 5px 8px 10px;\n    &:active {\n      color: ${props => props.theme.effectPanelTextMain};\n      background-color: ${props => props.theme.inputBgdHover};\n    }\n    &:hover {\n      color: ${props => props.theme.effectPanelTextMain};\n      background-color: ${props => props.theme.inputBgdHover};\n    }\n    & > svg {\n      margin-right: 0;\n    }\n  }\n`;\n\nconst DEFAULT_OFFSET = {\n  top: 0,\n  left: 0\n};\n\nconst SingleColorPickerDropdown = ({\n  isOpened,\n  onClose,\n  selectedColor,\n  onSelectColor,\n  offset = DEFAULT_OFFSET\n}) => {\n  const onSelectColorCb = useCallback(\n    v => {\n      onSelectColor(v);\n    },\n    [onSelectColor]\n  );\n  return (\n    <Portaled top={offset.top} left={offset.left} isOpened={isOpened} onClose={onClose}>\n      <StyledPanelDropdown>\n        <SingleColorPalette selectedColor={selectedColor} onSelectColor={onSelectColorCb} />\n      </StyledPanelDropdown>\n    </Portaled>\n  );\n};\n\nconst CompactColorPicker: React.FC<SingleColorPickerProps> = ({\n  color,\n  onSetColor,\n  Icon,\n  label\n}: SingleColorPickerProps) => {\n  const [isColorPickerOpened, setIsColorPickerOpened] = React.useState(false);\n\n  const hexColor = useMemo(() => {\n    return rgbToHex(color);\n  }, [color]);\n\n  const colorBlockStyle = useMemo(\n    () => ({\n      width: 16,\n      height: 16,\n      backgroundColor: hexColor,\n      borderRadius: 2\n    }),\n    [hexColor]\n  );\n\n  const toggleDropdown = useCallback(() => {\n    setIsColorPickerOpened(!isColorPickerOpened);\n  }, [isColorPickerOpened, setIsColorPickerOpened]);\n\n  const closeDropdown = useCallback(() => {\n    setIsColorPickerOpened(false);\n  }, [setIsColorPickerOpened]);\n\n  return (\n    <StyledConfigSection>\n      <SectionTitle>{label}</SectionTitle>\n      <StyledDropdownButtonWrapper>\n        <Button onClick={toggleDropdown}>\n          <div style={colorBlockStyle} />\n          <Icon />\n        </Button>\n      </StyledDropdownButtonWrapper>\n      <SingleColorPickerDropdown\n        isOpened={isColorPickerOpened}\n        onClose={closeDropdown}\n        selectedColor={hexColor}\n        onSelectColor={onSetColor}\n      />\n    </StyledConfigSection>\n  );\n};\n\nexport default CompactColorPicker;\n"],"mappings":"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","ignoreList":[]}