UNPKG

kepler.gl

Version:

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

187 lines (185 loc) 35.2 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.InputBoxContainer = exports.ColorSelectorInput = exports.ColorBlock = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _reactIntl = require("react-intl"); var _styledComponents = _interopRequireDefault(require("styled-components")); var _react2 = require("@floating-ui/react"); var _utils = require("@kepler.gl/utils"); var _rangeSlider = _interopRequireDefault(require("../../common/range-slider")); var _styledComponents2 = require("../../common/styled-components"); var _colorPalette = _interopRequireDefault(require("./color-palette")); var _colorRangeSelector = _interopRequireDefault(require("./color-range-selector")); var _singleColorPalette = _interopRequireDefault(require("./single-color-palette")); var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5; // 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 OpacitySliderWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n padding: 0px 12px 12px 12px;\n"]))); var OPACITY_SLIDER_PROPS = { type: 'number', range: [0, 1], value0: 0, step: 0.01, isRanged: false, label: 'Opacity', showInput: true }; var ColorBlock = exports.ColorBlock = _styledComponents["default"].div.withConfig({ shouldForwardProp: _styledComponents2.shouldForwardProp })(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n width: 32px;\n height: 18px;\n border-radius: 1px;\n background-color: ", ";\n"])), function (props) { return Array.isArray(props.backgroundcolor) ? "rgb(".concat(props.backgroundcolor.slice(0, 3).join(','), ")") : 'transparent'; }); var StyledColorSelectorWrapper = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n .selector__dropdown {\n max-height: 600px; /* increase from the default 500px defined by StyledPanelDropdown */\n }\n"]))); var ColorSelectorInput = exports.ColorSelectorInput = _styledComponents["default"].div.withConfig({ shouldForwardProp: _styledComponents2.shouldForwardProp })(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n ", ";\n height: ", ";\n\n .color-selector__selector__label {\n text-transform: capitalize;\n font-size: 12px;\n text-align: center;\n color: ", ";\n }\n"])), function (props) { return props.inputTheme === 'secondary' ? props.theme.secondaryInput : props.theme.input; }, function (props) { return props.theme.inputBoxHeight; }, function (props) { return props.theme.inputPlaceholderColor; }); var InputBoxContainer = exports.InputBoxContainer = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n\n .color-select__input-group {\n flex-grow: 1;\n }\n .color-select__input-group:nth-child(2) {\n margin-left: 12px;\n }\n"]))); ColorSelectorFactory.deps = [_colorRangeSelector["default"], _rangeSlider["default"]]; function ColorSelectorFactory(ColorRangeSelector, RangeSlider) { var ColorSelector = function ColorSelector(_ref) { var _ref$colorSets = _ref.colorSets, colorSets = _ref$colorSets === void 0 ? [] : _ref$colorSets, colorUI = _ref.colorUI, inputTheme = _ref.inputTheme, disabled = _ref.disabled, useOpacity = _ref.useOpacity, setColorUI = _ref.setColorUI; var _useState = (0, _react.useState)(colorUI ? colorUI.showDropdown : false), _useState2 = (0, _slicedToArray2["default"])(_useState, 2), showDropdown = _useState2[0], setShowDropdown = _useState2[1]; var showSketcher = colorUI ? colorUI.showSketcher : false; var editingLookup = colorUI ? colorUI.showDropdown : showDropdown; var editingColorSet = typeof editingLookup === 'number' && colorSets[editingLookup] ? colorSets[editingLookup] : false; var closePanelDropdown = (0, _react.useCallback)(function () { if (editingLookup === false) { return; } if (setColorUI) { setColorUI({ showDropdown: false, showSketcher: false }); } else { setShowDropdown(false); } }, [editingLookup, setColorUI, setShowDropdown]); var handleClickOutside = (0, _react.useCallback)(function () { if (Number.isInteger(showSketcher)) { // if sketcher is open, let sketch to close itself first return; } closePanelDropdown(); }, [showSketcher, closePanelDropdown]); // floating-ui boilerplate to establish close on outside click var _useFloating = (0, _react2.useFloating)({ open: true, onOpenChange: function onOpenChange(v) { if (!v) { handleClickOutside(); } } }), refs = _useFloating.refs, context = _useFloating.context; var dismiss = (0, _react2.useDismiss)(context); var _useInteractions = (0, _react2.useInteractions)([dismiss]), getFloatingProps = _useInteractions.getFloatingProps; var setColor = (0, _react.useCallback)(function (colorSet, color, opacity) { var _ref2 = colorSet || {}, setColor = _ref2.setColor; if (!setColor) { return; } if (useOpacity && Array.isArray(color)) { setColor([].concat((0, _toConsumableArray2["default"])(color.slice(0, 3)), [opacity])); } else { setColor(color); } }, [useOpacity]); var onSelectColor = (0, _react.useCallback)(function (color, e) { if (e) e.stopPropagation(); var colorSet = editingColorSet; if (colorSet) { setColor(colorSet, color, colorSet.selectedColor[3]); } }, [editingColorSet, setColor]); var onSelectOpacity = (0, _react.useCallback)(function (opacity, e) { if (e) e.stopPropagation(); var colorSet = editingColorSet; if (colorSet) { setColor(colorSet, colorSet.selectedColor, Math.round(opacity[1] * 255)); } }, [editingColorSet, setColor]); var onToggleDropdown = (0, _react.useCallback)(function (e, i) { e.stopPropagation(); e.preventDefault(); var showDropdownValue = editingLookup === false ? i // open it for the specific color set index : false; // close it if (setColorUI) { setColorUI({ showDropdown: showDropdownValue }); } else { setShowDropdown(showDropdownValue); } }, [editingLookup, setColorUI, setShowDropdown]); return /*#__PURE__*/_react["default"].createElement(StyledColorSelectorWrapper, (0, _extends2["default"])({ className: "color-selector", ref: refs.setFloating }, getFloatingProps()), /*#__PURE__*/_react["default"].createElement(InputBoxContainer, null, colorSets.map(function (cSet, i) { return /*#__PURE__*/_react["default"].createElement("div", { className: "color-select__input-group", key: i }, /*#__PURE__*/_react["default"].createElement(ColorSelectorInput, { className: "color-selector__selector", active: editingLookup === i, disabled: disabled, inputTheme: inputTheme, onClick: function onClick(e) { return onToggleDropdown(e, i); } }, cSet.isRange ? /*#__PURE__*/_react["default"].createElement(_colorPalette["default"], { colors: cSet.selectedColor.colors }) : /*#__PURE__*/_react["default"].createElement(ColorBlock, { className: "color-selector__selector__block", backgroundcolor: cSet.selectedColor }), cSet.label ? /*#__PURE__*/_react["default"].createElement("div", { className: "color-selector__selector__label" }, cSet.label) : null)); })), editingColorSet ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledPanelDropdown, { className: "color-selector__dropdown" }, editingColorSet.isRange && colorUI && setColorUI ? /*#__PURE__*/_react["default"].createElement(ColorRangeSelector, { selectedColorRange: editingColorSet.selectedColor, onSelectColorRange: onSelectColor, setColorPaletteUI: setColorUI, colorPaletteUI: colorUI }) : /*#__PURE__*/_react["default"].createElement(_singleColorPalette["default"], { selectedColor: (0, _utils.rgbToHex)(editingColorSet.selectedColor), onSelectColor: onSelectColor }), useOpacity ? /*#__PURE__*/_react["default"].createElement(OpacitySliderWrapper, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_reactIntl.FormattedMessage, { id: "color.opacity" })), /*#__PURE__*/_react["default"].createElement(RangeSlider, (0, _extends2["default"])({}, OPACITY_SLIDER_PROPS, { value1: editingColorSet.selectedColor[3] / 255, onChange: onSelectOpacity }))) : null) : null); }; return ColorSelector; } var _default = exports["default"] = ColorSelectorFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactIntl","_styledComponents","_interopRequireDefault","_react2","_utils","_rangeSlider","_styledComponents2","_colorPalette","_colorRangeSelector","_singleColorPalette","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","OpacitySliderWrapper","styled","div","_taggedTemplateLiteral2","OPACITY_SLIDER_PROPS","type","range","value0","step","isRanged","label","showInput","ColorBlock","exports","withConfig","shouldForwardProp","props","Array","isArray","backgroundcolor","concat","slice","join","StyledColorSelectorWrapper","ColorSelectorInput","inputTheme","theme","secondaryInput","input","inputBoxHeight","inputPlaceholderColor","InputBoxContainer","ColorSelectorFactory","deps","ColorRangeSelectorFactory","RangeSliderFactory","ColorRangeSelector","RangeSlider","ColorSelector","_ref","_ref$colorSets","colorSets","colorUI","disabled","useOpacity","setColorUI","_useState","useState","showDropdown","_useState2","_slicedToArray2","setShowDropdown","showSketcher","editingLookup","editingColorSet","closePanelDropdown","useCallback","handleClickOutside","Number","isInteger","_useFloating","useFloating","open","onOpenChange","v","refs","context","dismiss","useDismiss","_useInteractions","useInteractions","getFloatingProps","setColor","colorSet","color","opacity","_ref2","_toConsumableArray2","onSelectColor","stopPropagation","selectedColor","onSelectOpacity","Math","round","onToggleDropdown","preventDefault","showDropdownValue","createElement","_extends2","className","ref","setFloating","map","cSet","key","active","onClick","isRange","colors","StyledPanelDropdown","selectedColorRange","onSelectColorRange","setColorPaletteUI","colorPaletteUI","rgbToHex","PanelLabel","FormattedMessage","id","value1","onChange","_default"],"sources":["../../../src/side-panel/layer-panel/color-selector.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useState, MouseEvent} from 'react';\nimport {FormattedMessage} from 'react-intl';\nimport styled from 'styled-components';\nimport {useDismiss, useFloating, useInteractions} from '@floating-ui/react';\n\nimport {ColorRange} from '@kepler.gl/types';\nimport {ColorUI, NestedPartial, RGBAColor, RGBColor} from '@kepler.gl/types';\nimport {rgbToHex} from '@kepler.gl/utils';\n\nimport RangeSliderFactory from '../../common/range-slider';\nimport {PanelLabel, shouldForwardProp, StyledPanelDropdown} from '../../common/styled-components';\nimport ColorPalette from './color-palette';\nimport ColorRangeSelectorFactory from './color-range-selector';\nimport SingleColorPalette from './single-color-palette';\n\ntype ColorSelectorInputProps = {\n  active: boolean;\n  disabled?: boolean;\n  inputTheme?: string;\n};\n\nexport type ColorSet = {\n  selectedColor: RGBColor | RGBAColor | ColorRange;\n  setColor: (v: RGBColor | RGBAColor | ColorRange) => void;\n  isRange?: boolean;\n  label?: string;\n};\n\ntype ColorSelectorProps = {\n  colorSets: ColorSet[];\n  colorUI?: ColorUI;\n  inputTheme?: string;\n  disabled?: boolean;\n  useOpacity?: boolean;\n  setColorUI?: (newConfig: NestedPartial<ColorUI>) => void;\n};\n\nconst OpacitySliderWrapper = styled.div`\n  padding: 0px 12px 12px 12px;\n`;\n\nconst OPACITY_SLIDER_PROPS = {\n  type: 'number',\n  range: [0, 1],\n  value0: 0,\n  step: 0.01,\n  isRanged: false,\n  label: 'Opacity',\n  showInput: true\n};\n\nexport const ColorBlock = styled.div.withConfig({\n  shouldForwardProp\n})<{backgroundcolor: RGBColor}>`\n  width: 32px;\n  height: 18px;\n  border-radius: 1px;\n  background-color: ${props =>\n    Array.isArray(props.backgroundcolor)\n      ? `rgb(${props.backgroundcolor.slice(0, 3).join(',')})`\n      : 'transparent'};\n`;\n\nconst StyledColorSelectorWrapper = styled.div`\n  .selector__dropdown {\n    max-height: 600px; /* increase from the default 500px defined by StyledPanelDropdown */\n  }\n`;\n\nexport const ColorSelectorInput = styled.div.withConfig({\n  shouldForwardProp\n})<ColorSelectorInputProps>`\n  ${props => (props.inputTheme === 'secondary' ? props.theme.secondaryInput : props.theme.input)};\n  height: ${props => props.theme.inputBoxHeight};\n\n  .color-selector__selector__label {\n    text-transform: capitalize;\n    font-size: 12px;\n    text-align: center;\n    color: ${props => props.theme.inputPlaceholderColor};\n  }\n`;\n\nexport const InputBoxContainer = styled.div`\n  display: flex;\n  justify-content: space-between;\n\n  .color-select__input-group {\n    flex-grow: 1;\n  }\n  .color-select__input-group:nth-child(2) {\n    margin-left: 12px;\n  }\n`;\n\nColorSelectorFactory.deps = [ColorRangeSelectorFactory, RangeSliderFactory];\n\nfunction ColorSelectorFactory(\n  ColorRangeSelector: ReturnType<typeof ColorRangeSelectorFactory>,\n  RangeSlider: ReturnType<typeof RangeSliderFactory>\n): React.FC<ColorSelectorProps> {\n  const ColorSelector: React.FC<ColorSelectorProps> = ({\n    colorSets = [],\n    colorUI,\n    inputTheme,\n    disabled,\n    useOpacity,\n    setColorUI\n  }: ColorSelectorProps) => {\n    const [showDropdown, setShowDropdown] = useState(colorUI ? colorUI.showDropdown : false);\n    const showSketcher = colorUI ? colorUI.showSketcher : false;\n    const editingLookup = colorUI ? colorUI.showDropdown : showDropdown;\n    const editingColorSet: ColorSet | false =\n      typeof editingLookup === 'number' && colorSets[editingLookup]\n        ? colorSets[editingLookup]\n        : false;\n\n    const closePanelDropdown = useCallback(() => {\n      if (editingLookup === false) {\n        return;\n      }\n      if (setColorUI) {\n        setColorUI({showDropdown: false, showSketcher: false});\n      } else {\n        setShowDropdown(false);\n      }\n    }, [editingLookup, setColorUI, setShowDropdown]);\n\n    const handleClickOutside = useCallback(() => {\n      if (Number.isInteger(showSketcher)) {\n        // if sketcher is open, let sketch to close itself first\n        return;\n      }\n      closePanelDropdown();\n    }, [showSketcher, closePanelDropdown]);\n\n    // floating-ui boilerplate to establish close on outside click\n    const {refs, context} = useFloating({\n      open: true,\n      onOpenChange: v => {\n        if (!v) {\n          handleClickOutside();\n        }\n      }\n    });\n    const dismiss = useDismiss(context);\n    const {getFloatingProps} = useInteractions([dismiss]);\n\n    const setColor = useCallback(\n      (colorSet: ColorSet, color: RGBColor | RGBAColor | ColorRange, opacity: number) => {\n        const {setColor} = colorSet || {};\n        if (!setColor) {\n          return;\n        }\n        if (useOpacity && Array.isArray(color)) {\n          setColor([...color.slice(0, 3), opacity] as RGBAColor);\n        } else {\n          setColor(color);\n        }\n      },\n      [useOpacity]\n    );\n\n    const onSelectColor = useCallback(\n      (color: RGBColor | ColorRange, e: MouseEvent) => {\n        if (e) e.stopPropagation();\n        const colorSet = editingColorSet;\n        if (colorSet) {\n          setColor(colorSet, color, colorSet.selectedColor[3]);\n        }\n      },\n      [editingColorSet, setColor]\n    );\n\n    const onSelectOpacity = useCallback(\n      (opacity: number[], e: Event | null | undefined) => {\n        if (e) e.stopPropagation();\n        const colorSet = editingColorSet;\n        if (colorSet) {\n          setColor(colorSet, colorSet.selectedColor, Math.round(opacity[1] * 255));\n        }\n      },\n      [editingColorSet, setColor]\n    );\n\n    const onToggleDropdown = useCallback(\n      (e, i) => {\n        e.stopPropagation();\n        e.preventDefault();\n        const showDropdownValue =\n          editingLookup === false\n            ? i // open it for the specific color set index\n            : false; // close it\n        if (setColorUI) {\n          setColorUI({showDropdown: showDropdownValue});\n        } else {\n          setShowDropdown(showDropdownValue);\n        }\n      },\n      [editingLookup, setColorUI, setShowDropdown]\n    );\n\n    return (\n      <StyledColorSelectorWrapper\n        className=\"color-selector\"\n        ref={refs.setFloating}\n        {...getFloatingProps()}\n      >\n        <InputBoxContainer>\n          {colorSets.map((cSet, i) => (\n            <div className=\"color-select__input-group\" key={i}>\n              <ColorSelectorInput\n                className=\"color-selector__selector\"\n                active={editingLookup === i}\n                disabled={disabled}\n                inputTheme={inputTheme}\n                onClick={e => onToggleDropdown(e, i)}\n              >\n                {cSet.isRange ? (\n                  <ColorPalette colors={(cSet.selectedColor as ColorRange).colors} />\n                ) : (\n                  <ColorBlock\n                    className=\"color-selector__selector__block\"\n                    backgroundcolor={cSet.selectedColor as RGBColor}\n                  />\n                )}\n                {cSet.label ? (\n                  <div className=\"color-selector__selector__label\">{cSet.label}</div>\n                ) : null}\n              </ColorSelectorInput>\n            </div>\n          ))}\n        </InputBoxContainer>\n        {editingColorSet ? (\n          <StyledPanelDropdown className=\"color-selector__dropdown\">\n            {editingColorSet.isRange && colorUI && setColorUI ? (\n              <ColorRangeSelector\n                selectedColorRange={editingColorSet.selectedColor as ColorRange}\n                onSelectColorRange={onSelectColor}\n                setColorPaletteUI={setColorUI}\n                colorPaletteUI={colorUI as ColorUI}\n              />\n            ) : (\n              <SingleColorPalette\n                selectedColor={rgbToHex(editingColorSet.selectedColor as RGBColor)}\n                onSelectColor={onSelectColor}\n              />\n            )}\n            {useOpacity ? (\n              <OpacitySliderWrapper>\n                <PanelLabel>\n                  <FormattedMessage id=\"color.opacity\" />\n                </PanelLabel>\n                <RangeSlider\n                  {...OPACITY_SLIDER_PROPS}\n                  value1={editingColorSet.selectedColor[3] / 255}\n                  onChange={onSelectOpacity}\n                />\n              </OpacitySliderWrapper>\n            ) : null}\n          </StyledPanelDropdown>\n        ) : null}\n      </StyledColorSelectorWrapper>\n    );\n  };\n\n  return ColorSelector;\n}\n\nexport default ColorSelectorFactory;\n"],"mappings":"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","ignoreList":[]}