kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
185 lines (182 loc) • 34 kB
JavaScript
"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.EditButton = exports.ColorBreaksDisplay = exports.CategoricalColorDisplay = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _commonUtils = require("@kepler.gl/common-utils");
var _constants = require("@kepler.gl/constants");
var _utils = require("@kepler.gl/utils");
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _columnStatsChart = _interopRequireDefault(require("../../common/column-stats-chart"));
var _icons = require("../../common/icons");
var _styledComponents2 = require("../../common/styled-components");
var _customPalette = _interopRequireWildcard(require("./custom-palette"));
var _templateObject, _templateObject2, _templateObject3; // 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; }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
var StyledColorBreaksPanel = _styledComponents["default"].div.attrs({
className: 'styled-color-breaks-panel'
})(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 10px;\n"])));
var StyledColorBreaksDisplay = _styledComponents["default"].div.attrs({
className: 'styled-color-breaks-display'
})(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 8px 12px 0 12px;\n"])));
var ColorBreaksPanelWrapper = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])([""])));
var EditButton = exports.EditButton = function EditButton(_ref) {
var onClickEdit = _ref.onClickEdit;
return /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, {
className: "editp__button",
link: true,
onClick: onClickEdit
}, /*#__PURE__*/_react["default"].createElement(_icons.Edit, {
height: "16px"
}), "Edit");
};
var ColorBreaksDisplay = exports.ColorBreaksDisplay = function ColorBreaksDisplay(_ref2) {
var currentBreaks = _ref2.currentBreaks,
onEdit = _ref2.onEdit;
if (!(0, _utils.isNumericColorBreaks)(currentBreaks)) {
// don't display color breaks for ordinal breaks, user can change it in custom breaks
return null;
}
return /*#__PURE__*/_react["default"].createElement(StyledColorBreaksDisplay, null, onEdit ? /*#__PURE__*/_react["default"].createElement(EditButton, {
onClickEdit: onEdit
}) : null, currentBreaks.map(function (item, index) {
return /*#__PURE__*/_react["default"].createElement(_customPalette.ColorPaletteItem, {
className: "disabled",
key: index
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "custom-palette-input__left"
}, /*#__PURE__*/_react["default"].createElement(_customPalette.ColorSwatch, {
color: item.data
}), /*#__PURE__*/_react["default"].createElement(_customPalette.EditableColorRange, {
item: item,
isLast: index === currentBreaks.length - 1,
index: index,
editable: false
})));
}));
};
var CategoricalColorDisplay = exports.CategoricalColorDisplay = function CategoricalColorDisplay(_ref3) {
var colorMap = _ref3.colorMap,
onEdit = _ref3.onEdit;
return /*#__PURE__*/_react["default"].createElement(StyledColorBreaksDisplay, null, onEdit ? /*#__PURE__*/_react["default"].createElement(EditButton, {
onClickEdit: onEdit
}) : null, colorMap === null || colorMap === void 0 ? void 0 : colorMap.map(function (cm, index) {
return /*#__PURE__*/_react["default"].createElement(_customPalette.ColorPaletteItem, {
className: "disabled",
key: index
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "custom-palette-input__left"
}, /*#__PURE__*/_react["default"].createElement(_customPalette.ColorSwatch, {
color: cm[1]
}), /*#__PURE__*/_react["default"].createElement(_customPalette.CategoricalSelector, {
index: index,
selectedValues: (0, _commonUtils.toArray)(cm[0]),
allValues: [],
editable: false
})));
}));
};
ColorBreaksPanelFactory.deps = [_customPalette["default"], _columnStatsChart["default"]];
function ColorBreaksPanelFactory(CustomPalette, ColumnStatsChart) {
// eslint-disable-next-line complexity
var ColorBreaksPanel = function ColorBreaksPanel(_ref4) {
var _customPalette$name;
var colorBreaks = _ref4.colorBreaks,
colorUIConfig = _ref4.colorUIConfig,
dataset = _ref4.dataset,
colorField = _ref4.colorField,
isCustomBreaks = _ref4.isCustomBreaks,
allBins = _ref4.allBins,
filteredBins = _ref4.filteredBins,
isFiltered = _ref4.isFiltered,
histogramDomain = _ref4.histogramDomain,
ordinalDomain = _ref4.ordinalDomain,
setColorUI = _ref4.setColorUI,
onScaleChange = _ref4.onScaleChange,
onApply = _ref4.onApply,
onCancel = _ref4.onCancel;
var customPalette = colorUIConfig.customPalette,
showSketcher = colorUIConfig.showSketcher,
colorRangeConfig = colorUIConfig.colorRangeConfig;
var isEditingCustomBreaks = Boolean(colorRangeConfig.customBreaks);
var currentBreaks = (0, _react.useMemo)(function () {
return isEditingCustomBreaks ? (0, _utils.colorMapToColorBreaks)(customPalette.colorMap) : colorBreaks;
}, [customPalette.colorMap, isEditingCustomBreaks, colorBreaks]);
var onClickEditCustomBreaks = (0, _react.useCallback)(function () {
setColorUI({
colorRangeConfig: {
customBreaks: true
}
});
}, [setColorUI]);
var onCilckCancel = (0, _react.useCallback)(function () {
setColorUI({
showSketcher: false,
colorRangeConfig: {
customBreaks: false
}
});
onCancel();
}, [setColorUI, onCancel]);
var onColumnStatsChartChanged = (0, _react.useCallback)(function (newColorBreaks) {
var newColors = newColorBreaks.map(function (cb) {
return cb.data;
});
var newColorMap = (0, _utils.colorBreaksToColorMap)(newColorBreaks);
var newCustomPalette = _objectSpread(_objectSpread({}, customPalette), {}, {
colorMap: newColorMap,
colors: newColors
});
// update custom pallette editor
if (!isEditingCustomBreaks) {
setColorUI({
colorRangeConfig: {
customBreaks: true
},
customPalette: newCustomPalette
});
} else {
setColorUI({
customPalette: newCustomPalette
});
}
// trigger the map to re-render using newCustomPalette
onScaleChange(_constants.SCALE_TYPES.custom, newCustomPalette);
}, [setColorUI, customPalette, isEditingCustomBreaks, onScaleChange]);
return /*#__PURE__*/_react["default"].createElement(ColorBreaksPanelWrapper, null, dataset && allBins.length > 1 && (0, _utils.isNumericColorBreaks)(colorBreaks) ? /*#__PURE__*/_react["default"].createElement(ColumnStatsChart, {
colorField: colorField,
dataset: dataset,
colorBreaks: currentBreaks,
allBins: allBins,
filteredBins: filteredBins,
isFiltered: isFiltered,
histogramDomain: histogramDomain,
onChangedUpdater: onColumnStatsChartChanged
}) : null, /*#__PURE__*/_react["default"].createElement(StyledColorBreaksPanel, null, isEditingCustomBreaks ? /*#__PURE__*/_react["default"].createElement(CustomPalette, {
ordinalDomain: ordinalDomain,
customPalette: customPalette,
setColorPaletteUI: setColorUI,
showSketcher: showSketcher,
onApply: onApply,
onCancel: onCilckCancel
}) : currentBreaks && allBins.length > 1 && (0, _utils.isNumericColorBreaks)(colorBreaks) ? /*#__PURE__*/_react["default"].createElement(ColorBreaksDisplay, {
currentBreaks: currentBreaks,
onEdit: isCustomBreaks ? onClickEditCustomBreaks : null
}) : customPalette.colorMap && customPalette.type === 'customOrdinal' && (_customPalette$name = customPalette.name) !== null && _customPalette$name !== void 0 && _customPalette$name.endsWith(colorField.name) ? /*#__PURE__*/_react["default"].createElement(CategoricalColorDisplay, {
colorMap: customPalette.colorMap,
onEdit: isCustomBreaks ? onClickEditCustomBreaks : null
}) : null));
};
return /*#__PURE__*/_react["default"].memo(ColorBreaksPanel);
}
var _default = exports["default"] = ColorBreaksPanelFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_commonUtils","require","_constants","_utils","_react","_interopRequireWildcard","_styledComponents","_interopRequireDefault","_columnStatsChart","_icons","_styledComponents2","_customPalette","_templateObject","_templateObject2","_templateObject3","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","StyledColorBreaksPanel","styled","div","attrs","className","_taggedTemplateLiteral2","StyledColorBreaksDisplay","ColorBreaksPanelWrapper","EditButton","exports","_ref","onClickEdit","createElement","Button","link","onClick","Edit","height","ColorBreaksDisplay","_ref2","currentBreaks","onEdit","notOrdinalColorBreaks","map","item","index","ColorPaletteItem","key","ColorSwatch","color","data","EditableColorRange","isLast","editable","CategoricalColorDisplay","_ref3","colorMap","cm","CategoricalSelector","selectedValues","toArray","allValues","ColorBreaksPanelFactory","deps","CustomPaletteFactory","ColumnStatsChartFactory","CustomPalette","ColumnStatsChart","ColorBreaksPanel","_ref4","_customPalette$name","colorBreaks","colorUIConfig","dataset","colorField","isCustomBreaks","allBins","filteredBins","isFiltered","histogramDomain","ordinalDomain","setColorUI","onScaleChange","onApply","onCancel","customPalette","showSketcher","colorRangeConfig","isEditingCustomBreaks","Boolean","customBreaks","useMemo","colorMapToColorBreaks","onClickEditCustomBreaks","useCallback","onCilckCancel","onColumnStatsChartChanged","newColorBreaks","newColors","cb","newColorMap","colorBreaksToColorMap","newCustomPalette","colors","SCALE_TYPES","custom","onChangedUpdater","setColorPaletteUI","type","name","endsWith","React","memo","_default"],"sources":["../../../src/side-panel/layer-panel/color-breaks-panel.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {toArray} from '@kepler.gl/common-utils';\nimport {SCALE_TYPES} from '@kepler.gl/constants';\nimport {KeplerTable} from '@kepler.gl/table';\nimport {Bin, ColorMap, ColorUI, Field} from '@kepler.gl/types';\nimport {\n  ColorBreak,\n  ColorBreakOrdinal,\n  colorBreaksToColorMap,\n  colorMapToColorBreaks,\n  isNumericColorBreaks as notOrdinalColorBreaks\n} from '@kepler.gl/utils';\nimport React, {useCallback, useMemo} from 'react';\nimport styled from 'styled-components';\nimport ColumnStatsChartFactory from '../../common/column-stats-chart';\nimport {Edit} from '../../common/icons';\nimport {Button} from '../../common/styled-components';\nimport CustomPaletteFactory, {\n  ColorPaletteItem,\n  ColorSwatch,\n  EditableColorRange,\n  CategoricalSelector,\n  SetColorUIFunc\n} from './custom-palette';\n\nconst StyledColorBreaksPanel = styled.div.attrs({\n  className: 'styled-color-breaks-panel'\n})`\n  margin-bottom: 10px;\n`;\n\nconst StyledColorBreaksDisplay = styled.div.attrs({\n  className: 'styled-color-breaks-display'\n})`\n  padding: 8px 12px 0 12px;\n`;\n\nconst ColorBreaksPanelWrapper = styled.div``;\n\ntype EditButtonProps = {onClickEdit: () => void};\n\nexport const EditButton: React.FC<EditButtonProps> = ({onClickEdit}) => (\n  <Button className=\"editp__button\" link onClick={onClickEdit}>\n    <Edit height=\"16px\" />\n    Edit\n  </Button>\n);\n\nexport type ColorBreaksDisplayProps = {\n  currentBreaks?: ColorBreak[] | ColorBreakOrdinal[] | null;\n  onEdit: (() => void) | null;\n};\n\nexport const ColorBreaksDisplay: React.FC<ColorBreaksDisplayProps> = ({currentBreaks, onEdit}) => {\n  if (!notOrdinalColorBreaks(currentBreaks)) {\n    // don't display color breaks for ordinal breaks, user can change it in custom breaks\n    return null;\n  }\n  return (\n    <StyledColorBreaksDisplay>\n      {onEdit ? <EditButton onClickEdit={onEdit} /> : null}\n      {currentBreaks.map((item, index) => (\n        <ColorPaletteItem className=\"disabled\" key={index}>\n          <div className=\"custom-palette-input__left\">\n            <ColorSwatch color={item.data} />\n            <EditableColorRange\n              item={item}\n              isLast={index === currentBreaks.length - 1}\n              index={index}\n              editable={false}\n            />\n          </div>\n        </ColorPaletteItem>\n      ))}\n    </StyledColorBreaksDisplay>\n  );\n};\n\nexport type CategoricalColorDisplayProps = {\n  colorMap?: ColorMap;\n  onEdit: (() => void) | null;\n};\n\nexport const CategoricalColorDisplay: React.FC<CategoricalColorDisplayProps> = ({\n  colorMap,\n  onEdit\n}: CategoricalColorDisplayProps) => {\n  return (\n    <StyledColorBreaksDisplay>\n      {onEdit ? <EditButton onClickEdit={onEdit} /> : null}\n      {colorMap?.map((cm, index) => (\n        <ColorPaletteItem className=\"disabled\" key={index}>\n          <div className=\"custom-palette-input__left\">\n            <ColorSwatch color={cm[1]} />\n            <CategoricalSelector\n              index={index}\n              selectedValues={toArray(cm[0])}\n              allValues={[]}\n              editable={false}\n            />\n          </div>\n        </ColorPaletteItem>\n      ))}\n    </StyledColorBreaksDisplay>\n  );\n};\n\nexport type ColorBreaksPanelProps = {\n  colorBreaks: ColorBreak[] | ColorBreakOrdinal[] | null;\n  colorUIConfig: ColorUI;\n  dataset: KeplerTable | undefined;\n  colorField: Field;\n  isCustomBreaks: boolean;\n  allBins: Bin[];\n  filteredBins: Bin[];\n  isFiltered: boolean;\n  histogramDomain: number[];\n  ordinalDomain: number[] | string[];\n  setColorUI: SetColorUIFunc;\n  onScaleChange: (v: string, visConfg?: Record<string, any>) => void;\n  onApply: (e: React.MouseEvent) => void;\n  onCancel: () => void;\n};\n\nColorBreaksPanelFactory.deps = [CustomPaletteFactory, ColumnStatsChartFactory];\n\nfunction ColorBreaksPanelFactory(\n  CustomPalette: ReturnType<typeof CustomPaletteFactory>,\n  ColumnStatsChart: ReturnType<typeof ColumnStatsChartFactory>\n): React.FC<ColorBreaksPanelProps> {\n  // eslint-disable-next-line complexity\n  const ColorBreaksPanel: React.FC<ColorBreaksPanelProps> = ({\n    colorBreaks,\n    colorUIConfig,\n    dataset,\n    colorField,\n    isCustomBreaks,\n    allBins,\n    filteredBins,\n    isFiltered,\n    histogramDomain,\n    ordinalDomain,\n    setColorUI,\n    onScaleChange,\n    onApply,\n    onCancel\n  }) => {\n    const {customPalette, showSketcher, colorRangeConfig} = colorUIConfig;\n    const isEditingCustomBreaks = Boolean(colorRangeConfig.customBreaks);\n\n    const currentBreaks = useMemo(\n      () => (isEditingCustomBreaks ? colorMapToColorBreaks(customPalette.colorMap) : colorBreaks),\n      [customPalette.colorMap, isEditingCustomBreaks, colorBreaks]\n    );\n\n    const onClickEditCustomBreaks = useCallback(() => {\n      setColorUI({\n        colorRangeConfig: {\n          customBreaks: true\n        }\n      });\n    }, [setColorUI]);\n\n    const onCilckCancel = useCallback(() => {\n      setColorUI({\n        showSketcher: false,\n        colorRangeConfig: {\n          customBreaks: false\n        }\n      });\n      onCancel();\n    }, [setColorUI, onCancel]);\n\n    const onColumnStatsChartChanged = useCallback(\n      newColorBreaks => {\n        const newColors = newColorBreaks.map(cb => cb.data);\n        const newColorMap = colorBreaksToColorMap(newColorBreaks);\n\n        const newCustomPalette = {\n          ...customPalette,\n          colorMap: newColorMap,\n          colors: newColors\n        };\n\n        // update custom pallette editor\n        if (!isEditingCustomBreaks) {\n          setColorUI({\n            colorRangeConfig: {\n              customBreaks: true\n            },\n            customPalette: newCustomPalette\n          });\n        } else {\n          setColorUI({customPalette: newCustomPalette});\n        }\n\n        // trigger the map to re-render using newCustomPalette\n        onScaleChange(SCALE_TYPES.custom, newCustomPalette);\n      },\n      [setColorUI, customPalette, isEditingCustomBreaks, onScaleChange]\n    );\n\n    return (\n      <ColorBreaksPanelWrapper>\n        {dataset && allBins.length > 1 && notOrdinalColorBreaks(colorBreaks) ? (\n          <ColumnStatsChart\n            colorField={colorField}\n            dataset={dataset}\n            colorBreaks={currentBreaks}\n            allBins={allBins}\n            filteredBins={filteredBins}\n            isFiltered={isFiltered}\n            histogramDomain={histogramDomain}\n            onChangedUpdater={onColumnStatsChartChanged}\n          />\n        ) : null}\n        <StyledColorBreaksPanel>\n          {isEditingCustomBreaks ? (\n            <CustomPalette\n              ordinalDomain={ordinalDomain}\n              customPalette={customPalette}\n              setColorPaletteUI={setColorUI}\n              showSketcher={showSketcher}\n              onApply={onApply}\n              onCancel={onCilckCancel}\n            />\n          ) : currentBreaks && allBins.length > 1 && notOrdinalColorBreaks(colorBreaks) ? (\n            <ColorBreaksDisplay\n              currentBreaks={currentBreaks}\n              onEdit={isCustomBreaks ? onClickEditCustomBreaks : null}\n            />\n          ) : customPalette.colorMap &&\n            customPalette.type === 'customOrdinal' &&\n            customPalette.name?.endsWith(colorField.name) ? (\n            <CategoricalColorDisplay\n              colorMap={customPalette.colorMap}\n              onEdit={isCustomBreaks ? onClickEditCustomBreaks : null}\n            />\n          ) : null}\n        </StyledColorBreaksPanel>\n      </ColorBreaksPanelWrapper>\n    );\n  };\n\n  return React.memo(ColorBreaksPanel);\n}\n\nexport default ColorBreaksPanelFactory;\n"],"mappings":"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","ignoreList":[]}