kepler.gl 3.2.0 → 3.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (96) hide show
  1. package/dist/src/ai-assistant/src/config/models.d.ts +8 -0
  2. package/dist/src/components/src/side-panel/layer-panel/vector-tile-layer-configurator.d.ts +3 -2
  3. package/dist/src/localization/src/translations/en.d.ts +1 -0
  4. package/dist/src/utils/src/arrow-data-container.d.ts +3 -2
  5. package/dist/src/utils/src/data-container-utils.d.ts +2 -0
  6. package/package.json +2 -2
  7. package/src/actions/package.json +8 -8
  8. package/src/ai-assistant/dist/components/ai-assistant-config.js +40 -24
  9. package/src/ai-assistant/dist/config/models.d.ts +8 -0
  10. package/src/ai-assistant/dist/config/models.js +16 -8
  11. package/src/ai-assistant/dist/localization.js +7 -7
  12. package/src/ai-assistant/dist/reducers/index.js +3 -2
  13. package/src/ai-assistant/package.json +16 -16
  14. package/src/ai-assistant/src/components/ai-assistant-config.tsx +39 -28
  15. package/src/ai-assistant/src/config/models.ts +37 -25
  16. package/src/ai-assistant/src/localization.ts +6 -6
  17. package/src/ai-assistant/src/reducers/index.ts +2 -1
  18. package/src/cloud-providers/package.json +2 -2
  19. package/src/common-utils/package.json +3 -3
  20. package/src/components/dist/common/color-legend.js +8 -8
  21. package/src/components/dist/common/data-table/index.js +13 -9
  22. package/src/components/dist/map/map-legend-panel.js +10 -4
  23. package/src/components/dist/map/map-legend.js +2 -2
  24. package/src/components/dist/plot-container.js +4 -2
  25. package/src/components/dist/side-panel/interaction-panel/interaction-panel.js +2 -2
  26. package/src/components/dist/side-panel/layer-panel/color-breaks-panel.js +11 -2
  27. package/src/components/dist/side-panel/layer-panel/color-scale-selector.js +65 -12
  28. package/src/components/dist/side-panel/layer-panel/custom-palette.js +18 -7
  29. package/src/components/dist/side-panel/layer-panel/vector-tile-layer-configurator.d.ts +3 -2
  30. package/src/components/dist/side-panel/layer-panel/vector-tile-layer-configurator.js +18 -4
  31. package/src/components/package.json +15 -15
  32. package/src/components/src/common/color-legend.tsx +15 -2
  33. package/src/components/src/common/data-table/index.tsx +1 -1
  34. package/src/components/src/map/map-legend-panel.tsx +21 -2
  35. package/src/components/src/map/map-legend.tsx +1 -1
  36. package/src/components/src/plot-container.tsx +2 -1
  37. package/src/components/src/side-panel/interaction-panel/interaction-panel.tsx +1 -0
  38. package/src/components/src/side-panel/layer-panel/color-breaks-panel.tsx +14 -3
  39. package/src/components/src/side-panel/layer-panel/color-scale-selector.tsx +62 -8
  40. package/src/components/src/side-panel/layer-panel/custom-palette.tsx +11 -5
  41. package/src/components/src/side-panel/layer-panel/vector-tile-layer-configurator.tsx +19 -2
  42. package/src/constants/dist/default-settings.js +1 -1
  43. package/src/constants/node_modules/.cache/terser-webpack-plugin/content-v2/sha512/1b/11/43d4199b6142de0b88c672f2b036c5aa4ca836cf35977bbafcdb1962b91e94f8336655a57f0742571ceb13fc69ef4ba0e3cb91dc9a8d61ef041c6eb15e7a +1 -0
  44. package/src/constants/node_modules/.cache/terser-webpack-plugin/content-v2/sha512/b3/bd/e4f91c7af9e320b979e29ad3b9e3a4dfcd61e4a09d6e4579104c40dcace7651b443fdd6d7ff5d947ed6c9df2c0bbbcc76a2ea86d6398e4945257eeb80dd5 +1 -0
  45. package/src/constants/node_modules/.cache/terser-webpack-plugin/index-v5/ac/e2/e903ec95ada0b0075fdcfb6133e2e75c9b3b0504a29ca665704aaed90b2b +2 -0
  46. package/src/constants/node_modules/.cache/terser-webpack-plugin/index-v5/b4/c5/a43653dff3b380f7b0793080a57c980a9a136764933e79454de0fe43a5ca +2 -0
  47. package/src/constants/package.json +2 -2
  48. package/src/constants/umd/keplergl.min.js +1 -1
  49. package/src/deckgl-arrow-layers/package.json +2 -2
  50. package/src/deckgl-layers/package.json +4 -4
  51. package/src/duckdb/dist/table/duckdb-table-utils.js +3 -2
  52. package/src/duckdb/package.json +6 -6
  53. package/src/duckdb/src/table/duckdb-table-utils.ts +5 -1
  54. package/src/effects/package.json +5 -5
  55. package/src/layers/dist/geojson-layer/geojson-utils.js +23 -5
  56. package/src/layers/dist/icon-layer/icon-layer.js +12 -2
  57. package/src/layers/dist/vector-tile/common-tile/tile-dataset.d.ts +4 -0
  58. package/src/layers/dist/vector-tile/common-tile/tile-dataset.js +10 -1
  59. package/src/layers/dist/vector-tile/vector-tile-layer.d.ts +11 -0
  60. package/src/layers/dist/vector-tile/vector-tile-layer.js +113 -7
  61. package/src/layers/package.json +9 -9
  62. package/src/layers/src/geojson-layer/geojson-utils.ts +22 -0
  63. package/src/layers/src/icon-layer/icon-layer.ts +49 -38
  64. package/src/layers/src/vector-tile/common-tile/tile-dataset.ts +7 -0
  65. package/src/layers/src/vector-tile/vector-tile-layer.ts +110 -6
  66. package/src/localization/dist/translations/en.d.ts +1 -0
  67. package/src/localization/dist/translations/en.js +2 -1
  68. package/src/localization/package.json +1 -1
  69. package/src/localization/src/translations/en.ts +1 -0
  70. package/src/processors/dist/data-processor.js +15 -5
  71. package/src/processors/package.json +7 -7
  72. package/src/processors/src/data-processor.ts +19 -4
  73. package/src/reducers/package.json +16 -16
  74. package/src/schemas/package.json +7 -7
  75. package/src/styles/node_modules/.cache/terser-webpack-plugin/content-v2/sha512/52/82/28cacf6fd462b779c22675964b655bf3a9f3ce9ec3c9b141a401a5bf90cb7d904ac65ab8e484570130b12771af0a0d5bab20e6976cfa773666763e046a6a +1 -0
  76. package/src/styles/node_modules/.cache/terser-webpack-plugin/content-v2/sha512/53/93/f8e389b6450ee0636bf336363d2d6865d8a1fe2445c15cc1e36c651e1ddf448358eb74e894f4bf6fc48ef881dc64cc221c48b133ecf0e02132f2c5fbfe11 +1 -0
  77. package/src/styles/node_modules/.cache/terser-webpack-plugin/index-v5/2e/45/ed6e0c1beb8bca4698a47b5feda8789a22d96978bc4839949bd26e827454 +2 -0
  78. package/src/styles/node_modules/.cache/terser-webpack-plugin/index-v5/56/db/b5a812c56b0d1dcdcd33da37e464062a19c8752cb2296603dc72d2c54d31 +2 -0
  79. package/src/styles/package.json +2 -2
  80. package/src/styles/umd/keplergl.min.js +1 -1
  81. package/src/table/dist/dataset-utils.js +18 -7
  82. package/src/table/dist/kepler-table.js +2 -1
  83. package/src/table/package.json +5 -5
  84. package/src/table/src/dataset-utils.ts +7 -2
  85. package/src/table/src/kepler-table.ts +1 -0
  86. package/src/tasks/package.json +2 -2
  87. package/src/types/actions.d.ts +1 -0
  88. package/src/types/package.json +1 -1
  89. package/src/utils/dist/arrow-data-container.d.ts +3 -2
  90. package/src/utils/dist/arrow-data-container.js +3 -3
  91. package/src/utils/dist/data-container-utils.d.ts +2 -0
  92. package/src/utils/dist/data-container-utils.js +3 -2
  93. package/src/utils/package.json +4 -4
  94. package/src/utils/src/arrow-data-container.ts +9 -7
  95. package/src/utils/src/data-container-utils.ts +3 -1
  96. package/umd/keplergl.min.js +1366 -1333
@@ -12,6 +12,7 @@ var _react = _interopRequireDefault(require("react"));
12
12
  var _reactRedux = require("react-redux");
13
13
  var _styledComponents = _interopRequireDefault(require("styled-components"));
14
14
  var _sourceDataSelector = _interopRequireDefault(require("../common/source-data-selector"));
15
+ var _fieldSelector = _interopRequireDefault(require("../../common/field-selector"));
15
16
  var _channelByValueSelector = _interopRequireDefault(require("./channel-by-value-selector"));
16
17
  var _layerConfigGroup = _interopRequireWildcard(require("./layer-config-group"));
17
18
  var _layerColorSelector = require("./layer-color-selector");
@@ -23,8 +24,8 @@ var _templateObject; // SPDX-License-Identifier: MIT
23
24
  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); }
24
25
  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; }
25
26
  var StyledLayerConfigurator = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n margin-top: 12px;\n"])));
26
- VectorTileLayerConfiguratorFactory.deps = [_channelByValueSelector["default"], _layerColorSelector.LayerColorRangeSelectorFactory, _layerColorSelector.LayerColorSelectorFactory, _layerConfigGroup["default"], _visConfigSlider["default"], _visConfigSwitch["default"], _sourceDataSelector["default"]];
27
- function VectorTileLayerConfiguratorFactory(ChannelByValueSelector, LayerColorRangeSelector, LayerColorSelector, LayerConfigGroup, VisConfigSlider, VisConfigSwitch) {
27
+ VectorTileLayerConfiguratorFactory.deps = [_channelByValueSelector["default"], _layerColorSelector.LayerColorRangeSelectorFactory, _layerColorSelector.LayerColorSelectorFactory, _layerConfigGroup["default"], _visConfigSlider["default"], _visConfigSwitch["default"], _sourceDataSelector["default"], _fieldSelector["default"]];
28
+ function VectorTileLayerConfiguratorFactory(ChannelByValueSelector, LayerColorRangeSelector, LayerColorSelector, LayerConfigGroup, VisConfigSlider, VisConfigSwitch, _SourceDataSelector, FieldSelector) {
28
29
  var VectorTileLayerConfigurator = function VectorTileLayerConfigurator(_ref) {
29
30
  var _layer$config$visConf;
30
31
  var layer = _ref.layer,
@@ -77,7 +78,20 @@ function VectorTileLayerConfiguratorFactory(ChannelByValueSelector, LayerColorRa
77
78
  label: false
78
79
  })), /*#__PURE__*/_react["default"].createElement(_layerConfigGroup.ConfigGroupCollapsibleContent, null, layerChannelConfigProps.fields ? /*#__PURE__*/_react["default"].createElement(ChannelByValueSelector, (0, _extends2["default"])({}, layerChannelConfigProps, {
79
80
  channel: layer.visualChannels.radius
80
- })) : null, /*#__PURE__*/_react["default"].createElement(VisConfigSwitch, (0, _extends2["default"])({}, layer.visConfigSettings.radiusUnits, visConfiguratorProps)))));
81
+ })) : null, /*#__PURE__*/_react["default"].createElement(VisConfigSwitch, (0, _extends2["default"])({}, layer.visConfigSettings.radiusUnits, visConfiguratorProps)))), /*#__PURE__*/_react["default"].createElement(LayerConfigGroup, (0, _extends2["default"])({}, visConfiguratorProps, {
82
+ label: "layer.uniqueIdField"
83
+ }), /*#__PURE__*/_react["default"].createElement(FieldSelector, {
84
+ fields: layerChannelConfigProps.fields || [],
85
+ value: layer.config.uniqueIdField || null,
86
+ onSelect: function onSelect(val) {
87
+ var _layerConfiguratorPro;
88
+ return (_layerConfiguratorPro = layerConfiguratorProps.onChange) === null || _layerConfiguratorPro === void 0 ? void 0 : _layerConfiguratorPro.call(layerConfiguratorProps, {
89
+ uniqueIdField: (val === null || val === void 0 ? void 0 : val.name) || null
90
+ });
91
+ },
92
+ placeholder: 'placeholder.selectField',
93
+ erasable: true
94
+ })));
81
95
  };
82
96
  var ConnectedVectorTileLayerConfigurator = (0, _reactRedux.connect)(function (state) {
83
97
  return state;
@@ -85,4 +99,4 @@ function VectorTileLayerConfiguratorFactory(ChannelByValueSelector, LayerColorRa
85
99
  return ConnectedVectorTileLayerConfigurator;
86
100
  }
87
101
  var _default = exports["default"] = VectorTileLayerConfiguratorFactory;
88
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_reactRedux","_styledComponents","_sourceDataSelector","_channelByValueSelector","_layerConfigGroup","_interopRequireWildcard","_layerColorSelector","_radiusByZoomInput","_visConfigSlider","_visConfigSwitch","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledLayerConfigurator","styled","div","_taggedTemplateLiteral2","VectorTileLayerConfiguratorFactory","deps","ChannelByValueSelectorFactory","LayerColorRangeSelectorFactory","LayerColorSelectorFactory","LayerConfigGroupFactory","VisConfigSliderFactory","VisConfigSwitchFactory","SourceDataSelectorFactory","ChannelByValueSelector","LayerColorRangeSelector","LayerColorSelector","LayerConfigGroup","VisConfigSlider","VisConfigSwitch","VectorTileLayerConfigurator","_ref","_layer$config$visConf","layer","visConfiguratorProps","layerChannelConfigProps","layerConfiguratorProps","createElement","_extends2","label","fields","channel","visualChannels","color","config","colorField","Fragment","visConfigSettings","dynamicColor","opacity","stroked","collapsible","strokeColor","strokeColorField","property","selectedColor","visConfig","ConfigGroupCollapsibleContent","strokeOpacity","sizeField","sizeRange","strokeWidth","size","enable3d","elevationScale","height","description","radiusByZoom","enabled","onChange","unit","radius","radiusUnits","ConnectedVectorTileLayerConfigurator","connect","state","_default","exports"],"sources":["../../../src/side-panel/layer-panel/vector-tile-layer-configurator.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React from 'react';\nimport {connect} from 'react-redux';\nimport styled from 'styled-components';\n\nimport {VectorTileLayer} from '@kepler.gl/layers';\nimport {KeplerTable as KeplerDataset} from '@kepler.gl/table';\n\nimport SourceDataSelectorFactory from '../common/source-data-selector';\nimport ChannelByValueSelectorFactory from './channel-by-value-selector';\nimport LayerConfigGroupFactory, {ConfigGroupCollapsibleContent} from './layer-config-group';\nimport {LayerColorRangeSelectorFactory, LayerColorSelectorFactory} from './layer-color-selector';\nimport VisConfigByZoomInput from './radius-by-zoom-input';\nimport VisConfigSliderFactory from './vis-config-slider';\nimport VisConfigSwitchFactory from './vis-config-switch';\n\nconst StyledLayerConfigurator = styled.div`\n  margin-top: 12px;\n`;\n\ntype GetProps<T extends (...args: any[]) => React.FC<any>> = Parameters<ReturnType<T>>[0];\n\ntype Props = {\n  layer: VectorTileLayer;\n  dataset?: KeplerDataset;\n  visConfiguratorProps: any;\n  layerChannelConfigProps: GetProps<typeof ChannelByValueSelectorFactory>;\n  layerConfiguratorProps: any;\n};\n\nVectorTileLayerConfiguratorFactory.deps = [\n  ChannelByValueSelectorFactory,\n  LayerColorRangeSelectorFactory,\n  LayerColorSelectorFactory,\n  LayerConfigGroupFactory,\n  VisConfigSliderFactory,\n  VisConfigSwitchFactory,\n  SourceDataSelectorFactory\n];\n\nfunction VectorTileLayerConfiguratorFactory(\n  ChannelByValueSelector: ReturnType<typeof ChannelByValueSelectorFactory>,\n  LayerColorRangeSelector: ReturnType<typeof LayerColorRangeSelectorFactory>,\n  LayerColorSelector: ReturnType<typeof LayerColorSelectorFactory>,\n  LayerConfigGroup: ReturnType<typeof LayerConfigGroupFactory>,\n  VisConfigSlider: ReturnType<typeof VisConfigSliderFactory>,\n  VisConfigSwitch: ReturnType<typeof VisConfigSwitchFactory>\n): React.FC<Props> {\n  const VectorTileLayerConfigurator = ({\n    layer,\n    visConfiguratorProps,\n    layerChannelConfigProps,\n    layerConfiguratorProps\n  }: Props) => {\n    return (\n      <StyledLayerConfigurator>\n        {/* Fill Color */}\n        <LayerConfigGroup {...visConfiguratorProps} label=\"layer.fillColor\">\n          {layerChannelConfigProps.fields ? (\n            <ChannelByValueSelector\n              {...layerChannelConfigProps}\n              channel={layer.visualChannels.color}\n            />\n          ) : null}\n          {layer.config.colorField ? (\n            <>\n              <VisConfigSwitch\n                {...visConfiguratorProps}\n                {...layer.visConfigSettings.dynamicColor}\n              />\n              <LayerColorRangeSelector\n                {...visConfiguratorProps}\n                channel={layer.visualChannels.color}\n              />\n            </>\n          ) : (\n            <LayerColorSelector {...layerConfiguratorProps} />\n          )}\n          <VisConfigSlider {...layer.visConfigSettings.opacity} {...visConfiguratorProps} />\n        </LayerConfigGroup>\n\n        {/* Stroke color */}\n        <LayerConfigGroup\n          {...layer.visConfigSettings.stroked}\n          {...visConfiguratorProps}\n          label=\"layer.strokeColor\"\n          collapsible\n        >\n          <ChannelByValueSelector\n            {...layerChannelConfigProps}\n            channel={layer.visualChannels.strokeColor}\n          />\n          {layer.config.strokeColorField ? (\n            <LayerColorRangeSelector\n              {...visConfiguratorProps}\n              property=\"strokeColorRange\"\n              channel={layer.visualChannels.strokeColor}\n            />\n          ) : (\n            <LayerColorSelector\n              {...visConfiguratorProps}\n              selectedColor={layer.config.visConfig.strokeColor}\n              property=\"strokeColor\"\n            />\n          )}\n          <ConfigGroupCollapsibleContent>\n            <VisConfigSlider {...layer.visConfigSettings.strokeOpacity} {...visConfiguratorProps} />\n          </ConfigGroupCollapsibleContent>\n        </LayerConfigGroup>\n\n        {/* Stroke Width */}\n        <LayerConfigGroup\n          {...visConfiguratorProps}\n          {...layer.visConfigSettings.stroked}\n          label=\"layer.strokeWidth\"\n          collapsible\n        >\n          {layer.config.sizeField ? (\n            <VisConfigSlider\n              {...layer.visConfigSettings.sizeRange}\n              {...visConfiguratorProps}\n              label={false}\n            />\n          ) : (\n            <VisConfigSlider\n              {...layer.visConfigSettings.strokeWidth}\n              {...visConfiguratorProps}\n              label={false}\n            />\n          )}\n          <ConfigGroupCollapsibleContent>\n            <ChannelByValueSelector\n              {...layerChannelConfigProps}\n              channel={layer.visualChannels.size}\n            />\n          </ConfigGroupCollapsibleContent>\n        </LayerConfigGroup>\n\n        {/* Elevation */}\n        <LayerConfigGroup\n          {...visConfiguratorProps}\n          {...layer.visConfigSettings.enable3d}\n          collapsible\n        >\n          <VisConfigSlider\n            {...layer.visConfigSettings.elevationScale}\n            {...visConfiguratorProps}\n            label={false}\n          />\n          {layerChannelConfigProps.fields ? (\n            <ChannelByValueSelector\n              {...layerChannelConfigProps}\n              channel={layer.visualChannels.height}\n            />\n          ) : null}\n        </LayerConfigGroup>\n\n        {/* Radius */}\n        <LayerConfigGroup\n          {...visConfiguratorProps}\n          label={'layer.radius'}\n          description=\"Point radius in pixels or meters\"\n          collapsible\n        >\n          {layer.config.visConfig.radiusByZoom?.enabled && visConfiguratorProps.onChange ? (\n            <VisConfigByZoomInput\n              config={layer.config.visConfig.radiusByZoom}\n              onChange={visConfiguratorProps.onChange}\n              label=\"Radius\"\n              property=\"radiusByZoom\"\n              unit=\"px\"\n            />\n          ) : (\n            <VisConfigSlider\n              {...layer.visConfigSettings.radius}\n              {...visConfiguratorProps}\n              label={false}\n            />\n          )}\n\n          <ConfigGroupCollapsibleContent>\n            {layerChannelConfigProps.fields ? (\n              <ChannelByValueSelector\n                {...layerChannelConfigProps}\n                channel={layer.visualChannels.radius}\n              />\n            ) : null}\n            <VisConfigSwitch {...layer.visConfigSettings.radiusUnits} {...visConfiguratorProps} />\n          </ConfigGroupCollapsibleContent>\n        </LayerConfigGroup>\n      </StyledLayerConfigurator>\n    );\n  };\n\n  const ConnectedVectorTileLayerConfigurator = connect(state => state)(VectorTileLayerConfigurator);\n  return ConnectedVectorTileLayerConfigurator;\n}\n\nexport default VectorTileLayerConfiguratorFactory;\n"],"mappings":"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","ignoreList":[]}
102
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_reactRedux","_styledComponents","_sourceDataSelector","_fieldSelector","_channelByValueSelector","_layerConfigGroup","_interopRequireWildcard","_layerColorSelector","_radiusByZoomInput","_visConfigSlider","_visConfigSwitch","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledLayerConfigurator","styled","div","_taggedTemplateLiteral2","VectorTileLayerConfiguratorFactory","deps","ChannelByValueSelectorFactory","LayerColorRangeSelectorFactory","LayerColorSelectorFactory","LayerConfigGroupFactory","VisConfigSliderFactory","VisConfigSwitchFactory","SourceDataSelectorFactory","FieldSelectorFactory","ChannelByValueSelector","LayerColorRangeSelector","LayerColorSelector","LayerConfigGroup","VisConfigSlider","VisConfigSwitch","_SourceDataSelector","FieldSelector","VectorTileLayerConfigurator","_ref","_layer$config$visConf","layer","visConfiguratorProps","layerChannelConfigProps","layerConfiguratorProps","createElement","_extends2","label","fields","channel","visualChannels","color","config","colorField","Fragment","visConfigSettings","dynamicColor","opacity","stroked","collapsible","strokeColor","strokeColorField","property","selectedColor","visConfig","ConfigGroupCollapsibleContent","strokeOpacity","sizeField","sizeRange","strokeWidth","size","enable3d","elevationScale","height","description","radiusByZoom","enabled","onChange","unit","radius","radiusUnits","value","uniqueIdField","onSelect","val","_layerConfiguratorPro","name","placeholder","erasable","ConnectedVectorTileLayerConfigurator","connect","state","_default","exports"],"sources":["../../../src/side-panel/layer-panel/vector-tile-layer-configurator.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React from 'react';\nimport {connect} from 'react-redux';\nimport styled from 'styled-components';\n\nimport {VectorTileLayer} from '@kepler.gl/layers';\nimport {KeplerTable as KeplerDataset} from '@kepler.gl/table';\n\nimport SourceDataSelectorFactory from '../common/source-data-selector';\nimport FieldSelectorFactory from '../../common/field-selector';\nimport ChannelByValueSelectorFactory from './channel-by-value-selector';\nimport LayerConfigGroupFactory, {ConfigGroupCollapsibleContent} from './layer-config-group';\nimport {LayerColorRangeSelectorFactory, LayerColorSelectorFactory} from './layer-color-selector';\nimport VisConfigByZoomInput from './radius-by-zoom-input';\nimport VisConfigSliderFactory from './vis-config-slider';\nimport VisConfigSwitchFactory from './vis-config-switch';\n\nconst StyledLayerConfigurator = styled.div`\n  margin-top: 12px;\n`;\n\ntype GetProps<T extends (...args: any[]) => React.FC<any>> = Parameters<ReturnType<T>>[0];\n\ntype Props = {\n  layer: VectorTileLayer;\n  dataset?: KeplerDataset;\n  visConfiguratorProps: any;\n  layerChannelConfigProps: GetProps<typeof ChannelByValueSelectorFactory>;\n  layerConfiguratorProps: any;\n};\n\nVectorTileLayerConfiguratorFactory.deps = [\n  ChannelByValueSelectorFactory,\n  LayerColorRangeSelectorFactory,\n  LayerColorSelectorFactory,\n  LayerConfigGroupFactory,\n  VisConfigSliderFactory,\n  VisConfigSwitchFactory,\n  SourceDataSelectorFactory,\n  FieldSelectorFactory\n];\n\nfunction VectorTileLayerConfiguratorFactory(\n  ChannelByValueSelector: ReturnType<typeof ChannelByValueSelectorFactory>,\n  LayerColorRangeSelector: ReturnType<typeof LayerColorRangeSelectorFactory>,\n  LayerColorSelector: ReturnType<typeof LayerColorSelectorFactory>,\n  LayerConfigGroup: ReturnType<typeof LayerConfigGroupFactory>,\n  VisConfigSlider: ReturnType<typeof VisConfigSliderFactory>,\n  VisConfigSwitch: ReturnType<typeof VisConfigSwitchFactory>,\n  _SourceDataSelector: ReturnType<typeof SourceDataSelectorFactory>,\n  FieldSelector: ReturnType<typeof FieldSelectorFactory>\n): React.FC<Props> {\n  const VectorTileLayerConfigurator = ({\n    layer,\n    visConfiguratorProps,\n    layerChannelConfigProps,\n    layerConfiguratorProps\n  }: Props) => {\n    return (\n      <StyledLayerConfigurator>\n        {/* Fill Color */}\n        <LayerConfigGroup {...visConfiguratorProps} label=\"layer.fillColor\">\n          {layerChannelConfigProps.fields ? (\n            <ChannelByValueSelector\n              {...layerChannelConfigProps}\n              channel={layer.visualChannels.color}\n            />\n          ) : null}\n          {layer.config.colorField ? (\n            <>\n              <VisConfigSwitch\n                {...visConfiguratorProps}\n                {...layer.visConfigSettings.dynamicColor}\n              />\n              <LayerColorRangeSelector\n                {...visConfiguratorProps}\n                channel={layer.visualChannels.color}\n              />\n            </>\n          ) : (\n            <LayerColorSelector {...layerConfiguratorProps} />\n          )}\n          <VisConfigSlider {...layer.visConfigSettings.opacity} {...visConfiguratorProps} />\n        </LayerConfigGroup>\n\n        {/* Stroke color */}\n        <LayerConfigGroup\n          {...layer.visConfigSettings.stroked}\n          {...visConfiguratorProps}\n          label=\"layer.strokeColor\"\n          collapsible\n        >\n          <ChannelByValueSelector\n            {...layerChannelConfigProps}\n            channel={layer.visualChannels.strokeColor}\n          />\n          {layer.config.strokeColorField ? (\n            <LayerColorRangeSelector\n              {...visConfiguratorProps}\n              property=\"strokeColorRange\"\n              channel={layer.visualChannels.strokeColor}\n            />\n          ) : (\n            <LayerColorSelector\n              {...visConfiguratorProps}\n              selectedColor={layer.config.visConfig.strokeColor}\n              property=\"strokeColor\"\n            />\n          )}\n          <ConfigGroupCollapsibleContent>\n            <VisConfigSlider {...layer.visConfigSettings.strokeOpacity} {...visConfiguratorProps} />\n          </ConfigGroupCollapsibleContent>\n        </LayerConfigGroup>\n\n        {/* Stroke Width */}\n        <LayerConfigGroup\n          {...visConfiguratorProps}\n          {...layer.visConfigSettings.stroked}\n          label=\"layer.strokeWidth\"\n          collapsible\n        >\n          {layer.config.sizeField ? (\n            <VisConfigSlider\n              {...layer.visConfigSettings.sizeRange}\n              {...visConfiguratorProps}\n              label={false}\n            />\n          ) : (\n            <VisConfigSlider\n              {...layer.visConfigSettings.strokeWidth}\n              {...visConfiguratorProps}\n              label={false}\n            />\n          )}\n          <ConfigGroupCollapsibleContent>\n            <ChannelByValueSelector\n              {...layerChannelConfigProps}\n              channel={layer.visualChannels.size}\n            />\n          </ConfigGroupCollapsibleContent>\n        </LayerConfigGroup>\n\n        {/* Elevation */}\n        <LayerConfigGroup\n          {...visConfiguratorProps}\n          {...layer.visConfigSettings.enable3d}\n          collapsible\n        >\n          <VisConfigSlider\n            {...layer.visConfigSettings.elevationScale}\n            {...visConfiguratorProps}\n            label={false}\n          />\n          {layerChannelConfigProps.fields ? (\n            <ChannelByValueSelector\n              {...layerChannelConfigProps}\n              channel={layer.visualChannels.height}\n            />\n          ) : null}\n        </LayerConfigGroup>\n\n        {/* Radius */}\n        <LayerConfigGroup\n          {...visConfiguratorProps}\n          label={'layer.radius'}\n          description=\"Point radius in pixels or meters\"\n          collapsible\n        >\n          {layer.config.visConfig.radiusByZoom?.enabled && visConfiguratorProps.onChange ? (\n            <VisConfigByZoomInput\n              config={layer.config.visConfig.radiusByZoom}\n              onChange={visConfiguratorProps.onChange}\n              label=\"Radius\"\n              property=\"radiusByZoom\"\n              unit=\"px\"\n            />\n          ) : (\n            <VisConfigSlider\n              {...layer.visConfigSettings.radius}\n              {...visConfiguratorProps}\n              label={false}\n            />\n          )}\n\n          <ConfigGroupCollapsibleContent>\n            {layerChannelConfigProps.fields ? (\n              <ChannelByValueSelector\n                {...layerChannelConfigProps}\n                channel={layer.visualChannels.radius}\n              />\n            ) : null}\n            <VisConfigSwitch {...layer.visConfigSettings.radiusUnits} {...visConfiguratorProps} />\n          </ConfigGroupCollapsibleContent>\n        </LayerConfigGroup>\n\n        {/* Unique ID Field */}\n        <LayerConfigGroup {...visConfiguratorProps} label=\"layer.uniqueIdField\">\n          <FieldSelector\n            fields={layerChannelConfigProps.fields || []}\n            value={layer.config.uniqueIdField || null}\n            onSelect={(val: any) =>\n              layerConfiguratorProps.onChange?.({uniqueIdField: val?.name || null})\n            }\n            placeholder={'placeholder.selectField'}\n            erasable\n          />\n        </LayerConfigGroup>\n      </StyledLayerConfigurator>\n    );\n  };\n\n  const ConnectedVectorTileLayerConfigurator = connect(state => state)(VectorTileLayerConfigurator);\n  return ConnectedVectorTileLayerConfigurator;\n}\n\nexport default VectorTileLayerConfiguratorFactory;\n"],"mappings":"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","ignoreList":[]}
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@kepler.gl/components",
3
3
  "author": "Shan He <shan@uber.com>",
4
- "version": "3.2.0",
4
+ "version": "3.2.2",
5
5
  "description": "kepler.gl constants used by kepler.gl components, actions and reducers",
6
6
  "license": "MIT",
7
7
  "main": "dist/index.js",
@@ -38,20 +38,20 @@
38
38
  "@dnd-kit/utilities": "^3.2.2",
39
39
  "@emotion/is-prop-valid": "^1.2.1",
40
40
  "@floating-ui/react": "0.25.1",
41
- "@kepler.gl/actions": "3.2.0",
42
- "@kepler.gl/cloud-providers": "3.2.0",
43
- "@kepler.gl/common-utils": "3.2.0",
44
- "@kepler.gl/constants": "3.2.0",
45
- "@kepler.gl/effects": "3.2.0",
46
- "@kepler.gl/layers": "3.2.0",
47
- "@kepler.gl/localization": "3.2.0",
48
- "@kepler.gl/processors": "3.2.0",
49
- "@kepler.gl/reducers": "3.2.0",
50
- "@kepler.gl/schemas": "3.2.0",
51
- "@kepler.gl/styles": "3.2.0",
52
- "@kepler.gl/table": "3.2.0",
53
- "@kepler.gl/types": "3.2.0",
54
- "@kepler.gl/utils": "3.2.0",
41
+ "@kepler.gl/actions": "3.2.2",
42
+ "@kepler.gl/cloud-providers": "3.2.2",
43
+ "@kepler.gl/common-utils": "3.2.2",
44
+ "@kepler.gl/constants": "3.2.2",
45
+ "@kepler.gl/effects": "3.2.2",
46
+ "@kepler.gl/layers": "3.2.2",
47
+ "@kepler.gl/localization": "3.2.2",
48
+ "@kepler.gl/processors": "3.2.2",
49
+ "@kepler.gl/reducers": "3.2.2",
50
+ "@kepler.gl/schemas": "3.2.2",
51
+ "@kepler.gl/styles": "3.2.2",
52
+ "@kepler.gl/table": "3.2.2",
53
+ "@kepler.gl/types": "3.2.2",
54
+ "@kepler.gl/utils": "3.2.2",
55
55
  "@loaders.gl/mvt": "^4.3.2",
56
56
  "@loaders.gl/pmtiles": "^4.3.2",
57
57
  "@loaders.gl/wms": "4.3.2",
@@ -32,7 +32,8 @@ const inputCss = css`
32
32
  const StyledLegend = styled.div<{disableEdit: boolean; isExpanded?: boolean}>`
33
33
  ${props => props.theme.sidePanelScrollBar};
34
34
  ${props => (props.isExpanded ? '' : `max-height: 156px;`)};
35
- overflow: auto;
35
+ overflow-y: auto;
36
+ overflow-x: hidden;
36
37
  margin-bottom: ${GAP}px;
37
38
  display: grid;
38
39
  grid-row-gap: ${GAP}px;
@@ -45,12 +46,15 @@ const StyledLegendRow = styled.div`
45
46
  display: flex;
46
47
  align-items: center;
47
48
  height: 20px;
49
+ min-width: 0;
48
50
  `;
49
51
 
50
52
  export function ResetColorLabelFactory() {
51
53
  return styled(Reset)`
52
54
  color: ${props => props.theme.labelColorLT};
53
55
  cursor: pointer;
56
+ flex-shrink: 0;
57
+ margin-left: ${GAP}px;
54
58
 
55
59
  &:hover {
56
60
  color: ${props => props.theme.panelHeaderIconHover};
@@ -66,6 +70,10 @@ const StyleInlineInput = styled(InlineInput)`
66
70
  width: unset;
67
71
  padding: 2px;
68
72
  flex: 1;
73
+ min-width: 0;
74
+ overflow: hidden;
75
+ text-overflow: ellipsis;
76
+ white-space: nowrap;
69
77
  margin: 0 ${GAP}px;
70
78
  :hover {
71
79
  height: ${ROW_H}px;
@@ -125,6 +133,11 @@ const StyledLabel = styled.div`
125
133
  font-size: 10px;
126
134
  color: ${props => props.theme.textColor};
127
135
  padding-left: 2px;
136
+ flex: 1;
137
+ min-width: 0;
138
+ overflow: hidden;
139
+ text-overflow: ellipsis;
140
+ white-space: nowrap;
128
141
  `;
129
142
 
130
143
  export type LegendRowProps = {
@@ -155,7 +168,7 @@ export function LegendRowFactory(
155
168
  [color, onUpdateLabel]
156
169
  );
157
170
  const onReset = useCallback(() => onResetLabel && onResetLabel(color), [color, onResetLabel]);
158
- const value = displayLabel ? label.toString() : '';
171
+ const value = displayLabel ? String(label ?? '') : '';
159
172
  return (
160
173
  <StyledLegendRow>
161
174
  <LegendColorDisplay color={color} />
@@ -349,7 +349,7 @@ export const TableSection = ({
349
349
  height={headerGridProps.height + browserScrollBarWidth}
350
350
  width={headerGridWidth}
351
351
  scrollLeft={scrollLeft}
352
- onScroll={onScroll}
352
+ onScroll={args => onScroll?.({...args, scrollTop:scrollTop ?? 0 })}
353
353
  />
354
354
  </div>
355
355
  <div
@@ -116,6 +116,23 @@ const StyledResizeHandle = styled.div`
116
116
  cursor: ns-resize;
117
117
  `;
118
118
 
119
+ const StyledFixedLegendContent = styled.div<{contentHeight?: number}>`
120
+ .map-control__panel-content {
121
+ max-height: calc(100vh - 100px);
122
+ ${props => (props.contentHeight ? `height: ${props.contentHeight}px;` : '')};
123
+ }
124
+
125
+ /* Hide scrollbars in export to avoid OS default styling differences */
126
+ .styled-color-legend {
127
+ -ms-overflow-style: none; /* IE and old Edge */
128
+ scrollbar-width: none; /* Firefox */
129
+ }
130
+ .styled-color-legend::-webkit-scrollbar {
131
+ width: 0 !important; /* Chrome, Safari, new Edge */
132
+ height: 0 !important;
133
+ }
134
+ `;
135
+
119
136
  export type MapLegendPanelFactoryDeps = [
120
137
  typeof MapControlTooltipFactory,
121
138
  typeof MapControlPanelFactory,
@@ -240,7 +257,7 @@ const ImageExportLegend = withTheme(({settings, isSidePanelShown, theme, childre
240
257
  const containerRef: React.MutableRefObject<HTMLDivElement | null> = useRef(null);
241
258
  const legendContentRef: React.MutableRefObject<HTMLDivElement | null> = useRef(null);
242
259
 
243
- const {positionStyles} = useLegendPosition({
260
+ const {positionStyles, contentHeight} = useLegendPosition({
244
261
  legendContentRef,
245
262
  isSidePanelShown,
246
263
  theme,
@@ -263,7 +280,9 @@ const ImageExportLegend = withTheme(({settings, isSidePanelShown, theme, childre
263
280
  ref={legendContentRef}
264
281
  style={{...positionStyles, position: 'absolute'}}
265
282
  >
266
- {children}
283
+ <StyledFixedLegendContent contentHeight={contentHeight}>
284
+ {children}
285
+ </StyledFixedLegendContent>
267
286
  </div>,
268
287
  portalRoot
269
288
  )
@@ -202,7 +202,7 @@ export function LayerColorLegendFactory(
202
202
  fieldType={(colorField && colorField.type) || 'real'}
203
203
  range={colorRange}
204
204
  onUpdateColorLegend={onUpdateColorLegend}
205
- disableEdit={disableEdit}
205
+ disableEdit={disableEdit || Boolean(isExport)}
206
206
  isFixed={isFixed}
207
207
  mapState={mapState}
208
208
  labelFormat={
@@ -276,7 +276,8 @@ export default function PlotContainerFactory(
276
276
  mapControls: {
277
277
  mapLegend: {
278
278
  show: Boolean(legend),
279
- active: true
279
+ active: true,
280
+ settings: mapFields.mapControls?.mapLegend?.settings
280
281
  }
281
282
  },
282
283
  MapComponent: Map,
@@ -35,6 +35,7 @@ interface InteractionPanelProps {
35
35
 
36
36
  const StyledInteractionPanel = styled.div`
37
37
  padding-bottom: 6px;
38
+ contain: layout paint;
38
39
  `;
39
40
 
40
41
  InteractionPanelFactory.deps = [TooltipConfigFactory, BrushConfigFactory];
@@ -12,7 +12,7 @@ import {
12
12
  colorMapToColorBreaks,
13
13
  isNumericColorBreaks as notOrdinalColorBreaks
14
14
  } from '@kepler.gl/utils';
15
- import React, {useCallback, useMemo} from 'react';
15
+ import React, {useCallback, useMemo, useEffect} from 'react';
16
16
  import styled from 'styled-components';
17
17
  import ColumnStatsChartFactory from '../../common/column-stats-chart';
18
18
  import {Edit} from '../../common/icons';
@@ -155,6 +155,17 @@ function ColorBreaksPanelFactory(
155
155
  [customPalette.colorMap, isEditingCustomBreaks, colorBreaks]
156
156
  );
157
157
 
158
+ // Update layers on editing custom breaks
159
+ useEffect(() => {
160
+ const {type} = customPalette || {};
161
+ if (
162
+ isEditingCustomBreaks &&
163
+ (type === SCALE_TYPES.customOrdinal || type === SCALE_TYPES.custom)
164
+ ) {
165
+ onScaleChange(type, customPalette);
166
+ }
167
+ }, [isEditingCustomBreaks, customPalette, onScaleChange]);
168
+
158
169
  const onClickEditCustomBreaks = useCallback(() => {
159
170
  setColorUI({
160
171
  colorRangeConfig: {
@@ -231,8 +242,8 @@ function ColorBreaksPanelFactory(
231
242
  currentBreaks={currentBreaks}
232
243
  onEdit={isCustomBreaks ? onClickEditCustomBreaks : null}
233
244
  />
234
- ) : customPalette.colorMap &&
235
- customPalette.type === 'customOrdinal' &&
245
+ ) : (isCustomBreaks || customPalette.type === SCALE_TYPES.customOrdinal) &&
246
+ customPalette.colorMap &&
236
247
  customPalette.name?.endsWith(colorField.name) ? (
237
248
  <CategoricalColorDisplay
238
249
  colorMap={customPalette.colorMap}
@@ -148,6 +148,28 @@ function ColorScaleSelectorFactory(
148
148
  );
149
149
  const [tippyInstance, setTippyInstance] = useState<TippyInstance>();
150
150
  const isEditingColorBreaks = colorUIConfig?.colorRangeConfig?.customBreaks;
151
+
152
+ // Stores the previous selection for live preview: when choosing Custom/Custom Ordinal, we apply a temporary palette.
153
+ // Cancel restores {scale, range} from this ref; Confirm keeps the change and clears the ref.
154
+ // If the user switches between different custom scale types (e.g., from "Custom" to "Custom Ordinal") or is already in a custom scale state,
155
+ // this ref is updated to always store the most recent non-custom selection. Only the latest non-custom selection is restorable on cancel.
156
+ const prevSelectionRef = React.useRef<{scale: string; range: ColorRange} | null>(null);
157
+
158
+ // when custom color scale - but Confirm is not clicked yet
159
+ const pendingOption = useMemo(
160
+ () =>
161
+ isEditingColorBreaks
162
+ ? (dropdownSelectProps.options || []).find(
163
+ o => getOptionValue(o) === colorUIConfig?.customPalette?.type
164
+ ) || null
165
+ : null,
166
+ [
167
+ isEditingColorBreaks,
168
+ dropdownSelectProps.options,
169
+ getOptionValue,
170
+ colorUIConfig?.customPalette?.type
171
+ ]
172
+ );
151
173
  const colorScale = useMemo(
152
174
  () =>
153
175
  getLayerColorScale({
@@ -234,14 +256,16 @@ function ColorScaleSelectorFactory(
234
256
  const onSelectScale = useCallback(
235
257
  val => {
236
258
  // highlight selected option
237
- if (!val || isEditingColorBreaks) return;
259
+ if (!val) return;
260
+
238
261
  const selectedScale = getOptionValue(val);
239
- if (selectedScale === SCALE_TYPES.custom) {
262
+ if (selectedScale === SCALE_TYPES.custom || selectedScale === SCALE_TYPES.customOrdinal) {
240
263
  const customPalette = initCustomPaletteByCustomScale({
241
264
  scale: selectedScale,
242
265
  field,
243
266
  range,
244
- colorBreaks
267
+ colorBreaks,
268
+ ...(selectedScale === SCALE_TYPES.customOrdinal ? {ordinalDomain} : {})
245
269
  });
246
270
  setColorUI({
247
271
  showColorChart: true,
@@ -250,28 +274,55 @@ function ColorScaleSelectorFactory(
250
274
  },
251
275
  customPalette
252
276
  });
277
+ // store previous selection for cancel, then preview custom on the map
278
+ if (!prevSelectionRef.current) {
279
+ prevSelectionRef.current = {scale: scaleType, range};
280
+ }
253
281
  onSelect(selectedScale, customPalette);
254
- } else if (hasColorMap(range) && selectedScale !== SCALE_TYPES.customOrdinal) {
282
+ } else if (hasColorMap(range)) {
255
283
  // not custom
256
284
  // remove colorMap
257
285
  // eslint-disable-next-line no-unused-vars
258
286
  const {colorMap: _, ...newRange} = range;
287
+ // reset colorUI before changing the scale
288
+ setColorUI({
289
+ showColorChart: false,
290
+ colorRangeConfig: {
291
+ customBreaks: false
292
+ }
293
+ });
259
294
  onSelect(selectedScale, newRange);
260
295
  } else {
296
+ // reset colorUI before changing the scale
297
+ setColorUI({
298
+ showColorChart: false,
299
+ colorRangeConfig: {
300
+ customBreaks: false
301
+ }
302
+ });
261
303
  onSelect(selectedScale);
262
304
  }
263
305
  },
264
- [isEditingColorBreaks, field, setColorUI, onSelect, range, getOptionValue, colorBreaks]
306
+ [field, setColorUI, onSelect, range, getOptionValue, colorBreaks, ordinalDomain, scaleType]
265
307
  );
266
308
 
267
309
  const onApply = useCallback(() => {
268
- onSelect(scaleType, colorUIConfig.customPalette);
310
+ // change scale type only if confirmed
311
+ const nextScaleType = colorUIConfig?.customPalette?.type || scaleType;
312
+ onSelect(nextScaleType, colorUIConfig.customPalette);
269
313
  hideTippy(tippyInstance);
314
+ prevSelectionRef.current = null;
270
315
  }, [onSelect, colorUIConfig.customPalette, tippyInstance, scaleType]);
271
316
 
272
317
  const onCancel = useCallback(() => {
318
+ // restore previous selection if any
319
+ if (prevSelectionRef.current) {
320
+ const {scale: prevScale, range: prevRange} = prevSelectionRef.current;
321
+ onSelect(prevScale, prevRange);
322
+ }
273
323
  hideTippy(tippyInstance);
274
- }, [tippyInstance]);
324
+ prevSelectionRef.current = null;
325
+ }, [tippyInstance, onSelect]);
275
326
 
276
327
  const isCustomBreaks =
277
328
  scaleType === SCALE_TYPES.custom || scaleType === SCALE_TYPES.customOrdinal;
@@ -317,6 +368,9 @@ function ColorScaleSelectorFactory(
317
368
  customListComponent={ColorScaleSelectDropdown}
318
369
  searchable={false}
319
370
  showOptionsWhenEmpty
371
+ selectedItems={
372
+ pendingOption ? [pendingOption] : dropdownSelectProps.selectedItems
373
+ }
320
374
  />
321
375
  )}
322
376
  </DropdownWrapper>
@@ -327,7 +381,7 @@ function ColorScaleSelectorFactory(
327
381
  <DropdownSelect
328
382
  {...dropdownSelectProps}
329
383
  displayOption={displayOption}
330
- value={dropdownSelectProps.selectedItems[0]}
384
+ value={pendingOption || dropdownSelectProps.selectedItems[0]}
331
385
  />
332
386
  </div>
333
387
  </LazyTippy>
@@ -377,8 +377,11 @@ export const EditableColorRange: React.FC<EditableColorRangeProps> = ({
377
377
  editColorMap,
378
378
  editable
379
379
  }) => {
380
- const noMinBound = !Number.isFinite(item.inputs[0]) && index === 0;
381
- const noMaxBound = !Number.isFinite(item.inputs[1]) && isLast;
380
+ const hasInputs = Array.isArray(item?.inputs);
381
+ const leftInput = hasInputs ? item.inputs[0] : undefined;
382
+ const rightInput = hasInputs ? item.inputs[1] : undefined;
383
+ const noMinBound = !Number.isFinite(leftInput) && index === 0;
384
+ const noMaxBound = !Number.isFinite(rightInput) && isLast;
382
385
  const onChangeLeft = useCallback(
383
386
  val => {
384
387
  if (editable && editColorMap) editColorMap(parseFloat(val), index - 1);
@@ -395,7 +398,7 @@ export const EditableColorRange: React.FC<EditableColorRangeProps> = ({
395
398
  return (
396
399
  <StyledRangeInput>
397
400
  <ColorPaletteInput
398
- value={noMinBound ? 'Less' : item.inputs[0].toString()}
401
+ value={noMinBound ? 'Less' : String(leftInput ?? '')}
399
402
  id={`color-palette-input-${index}-left`}
400
403
  width="50px"
401
404
  textAlign="end"
@@ -404,7 +407,7 @@ export const EditableColorRange: React.FC<EditableColorRangeProps> = ({
404
407
  />
405
408
  <Dash />
406
409
  <ColorPaletteInput
407
- value={noMaxBound ? 'More' : item.inputs[1].toString()}
410
+ value={noMaxBound ? 'More' : String(rightInput ?? '')}
408
411
  id={`color-palette-input-${index}-right`}
409
412
  width="50px"
410
413
  textAlign="end"
@@ -468,7 +471,7 @@ export const CustomPaletteInput: React.FC<CustomPaletteInputProps> = ({
468
471
  />
469
472
  </StyledColorHexInput>
470
473
  ) : null}
471
- {isNumericColorBreaks(colorBreaks) ? (
474
+ {colorBreaks && index < colorBreaks.length && isNumericColorBreaks(colorBreaks) ? (
472
475
  <EditableColorRange
473
476
  item={colorBreaks[index]}
474
477
  isLast={index === colorBreaks.length - 1}
@@ -719,6 +722,9 @@ export const CategoricalSelector: React.FC<CategoricalSelectorProps> = ({
719
722
  listAnchor: 'list__item__anchor'
720
723
  }}
721
724
  options={allValues}
725
+ // add safe string casting for the Typeahead, so fuzzy search never receives non-strings, preventing the toLowerCase crash
726
+ displayOption={o => String(o ?? '')}
727
+ filterOption={(input, o) => String(o ?? '').includes(String(input ?? ''))}
722
728
  placeholder={'Search'}
723
729
  onOptionSelected={onOptionSelected}
724
730
  customListComponent={ModifiedDropdownList}
@@ -9,6 +9,7 @@ import {VectorTileLayer} from '@kepler.gl/layers';
9
9
  import {KeplerTable as KeplerDataset} from '@kepler.gl/table';
10
10
 
11
11
  import SourceDataSelectorFactory from '../common/source-data-selector';
12
+ import FieldSelectorFactory from '../../common/field-selector';
12
13
  import ChannelByValueSelectorFactory from './channel-by-value-selector';
13
14
  import LayerConfigGroupFactory, {ConfigGroupCollapsibleContent} from './layer-config-group';
14
15
  import {LayerColorRangeSelectorFactory, LayerColorSelectorFactory} from './layer-color-selector';
@@ -37,7 +38,8 @@ VectorTileLayerConfiguratorFactory.deps = [
37
38
  LayerConfigGroupFactory,
38
39
  VisConfigSliderFactory,
39
40
  VisConfigSwitchFactory,
40
- SourceDataSelectorFactory
41
+ SourceDataSelectorFactory,
42
+ FieldSelectorFactory
41
43
  ];
42
44
 
43
45
  function VectorTileLayerConfiguratorFactory(
@@ -46,7 +48,9 @@ function VectorTileLayerConfiguratorFactory(
46
48
  LayerColorSelector: ReturnType<typeof LayerColorSelectorFactory>,
47
49
  LayerConfigGroup: ReturnType<typeof LayerConfigGroupFactory>,
48
50
  VisConfigSlider: ReturnType<typeof VisConfigSliderFactory>,
49
- VisConfigSwitch: ReturnType<typeof VisConfigSwitchFactory>
51
+ VisConfigSwitch: ReturnType<typeof VisConfigSwitchFactory>,
52
+ _SourceDataSelector: ReturnType<typeof SourceDataSelectorFactory>,
53
+ FieldSelector: ReturnType<typeof FieldSelectorFactory>
50
54
  ): React.FC<Props> {
51
55
  const VectorTileLayerConfigurator = ({
52
56
  layer,
@@ -190,6 +194,19 @@ function VectorTileLayerConfiguratorFactory(
190
194
  <VisConfigSwitch {...layer.visConfigSettings.radiusUnits} {...visConfiguratorProps} />
191
195
  </ConfigGroupCollapsibleContent>
192
196
  </LayerConfigGroup>
197
+
198
+ {/* Unique ID Field */}
199
+ <LayerConfigGroup {...visConfiguratorProps} label="layer.uniqueIdField">
200
+ <FieldSelector
201
+ fields={layerChannelConfigProps.fields || []}
202
+ value={layer.config.uniqueIdField || null}
203
+ onSelect={(val: any) =>
204
+ layerConfiguratorProps.onChange?.({uniqueIdField: val?.name || null})
205
+ }
206
+ placeholder={'placeholder.selectField'}
207
+ erasable
208
+ />
209
+ </LayerConfigGroup>
193
210
  </StyledLayerConfigurator>
194
211
  );
195
212
  };
@@ -101,7 +101,7 @@ var KEPLER_GL_NAME = exports.KEPLER_GL_NAME = 'kepler.gl';
101
101
  // Since we are injecting this during the build process with babel
102
102
  // while developing VERSION is not defined, we capture the exception and return
103
103
  // an empty string which will allow us to retrieve the latest umd version
104
- var KEPLER_GL_VERSION = exports.KEPLER_GL_VERSION = "3.2.0";
104
+ var KEPLER_GL_VERSION = exports.KEPLER_GL_VERSION = "3.2.2";
105
105
  var KEPLER_GL_WEBSITE = exports.KEPLER_GL_WEBSITE = 'http://kepler.gl/';
106
106
  var DIMENSIONS = exports.DIMENSIONS = {
107
107
  sidePanel: {