kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
183 lines (181 loc) • 34.7 kB
JavaScript
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(_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(_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","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, 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<{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<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":[]}
;