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.
- package/dist/src/ai-assistant/src/config/models.d.ts +8 -0
- package/dist/src/components/src/side-panel/layer-panel/vector-tile-layer-configurator.d.ts +3 -2
- package/dist/src/localization/src/translations/en.d.ts +1 -0
- package/dist/src/utils/src/arrow-data-container.d.ts +3 -2
- package/dist/src/utils/src/data-container-utils.d.ts +2 -0
- package/package.json +2 -2
- package/src/actions/package.json +8 -8
- package/src/ai-assistant/dist/components/ai-assistant-config.js +40 -24
- package/src/ai-assistant/dist/config/models.d.ts +8 -0
- package/src/ai-assistant/dist/config/models.js +16 -8
- package/src/ai-assistant/dist/localization.js +7 -7
- package/src/ai-assistant/dist/reducers/index.js +3 -2
- package/src/ai-assistant/package.json +16 -16
- package/src/ai-assistant/src/components/ai-assistant-config.tsx +39 -28
- package/src/ai-assistant/src/config/models.ts +37 -25
- package/src/ai-assistant/src/localization.ts +6 -6
- package/src/ai-assistant/src/reducers/index.ts +2 -1
- package/src/cloud-providers/package.json +2 -2
- package/src/common-utils/package.json +3 -3
- package/src/components/dist/common/color-legend.js +8 -8
- package/src/components/dist/common/data-table/index.js +13 -9
- package/src/components/dist/map/map-legend-panel.js +10 -4
- package/src/components/dist/map/map-legend.js +2 -2
- package/src/components/dist/plot-container.js +4 -2
- package/src/components/dist/side-panel/interaction-panel/interaction-panel.js +2 -2
- package/src/components/dist/side-panel/layer-panel/color-breaks-panel.js +11 -2
- package/src/components/dist/side-panel/layer-panel/color-scale-selector.js +65 -12
- package/src/components/dist/side-panel/layer-panel/custom-palette.js +18 -7
- package/src/components/dist/side-panel/layer-panel/vector-tile-layer-configurator.d.ts +3 -2
- package/src/components/dist/side-panel/layer-panel/vector-tile-layer-configurator.js +18 -4
- package/src/components/package.json +15 -15
- package/src/components/src/common/color-legend.tsx +15 -2
- package/src/components/src/common/data-table/index.tsx +1 -1
- package/src/components/src/map/map-legend-panel.tsx +21 -2
- package/src/components/src/map/map-legend.tsx +1 -1
- package/src/components/src/plot-container.tsx +2 -1
- package/src/components/src/side-panel/interaction-panel/interaction-panel.tsx +1 -0
- package/src/components/src/side-panel/layer-panel/color-breaks-panel.tsx +14 -3
- package/src/components/src/side-panel/layer-panel/color-scale-selector.tsx +62 -8
- package/src/components/src/side-panel/layer-panel/custom-palette.tsx +11 -5
- package/src/components/src/side-panel/layer-panel/vector-tile-layer-configurator.tsx +19 -2
- package/src/constants/dist/default-settings.js +1 -1
- package/src/constants/node_modules/.cache/terser-webpack-plugin/content-v2/sha512/1b/11/43d4199b6142de0b88c672f2b036c5aa4ca836cf35977bbafcdb1962b91e94f8336655a57f0742571ceb13fc69ef4ba0e3cb91dc9a8d61ef041c6eb15e7a +1 -0
- package/src/constants/node_modules/.cache/terser-webpack-plugin/content-v2/sha512/b3/bd/e4f91c7af9e320b979e29ad3b9e3a4dfcd61e4a09d6e4579104c40dcace7651b443fdd6d7ff5d947ed6c9df2c0bbbcc76a2ea86d6398e4945257eeb80dd5 +1 -0
- package/src/constants/node_modules/.cache/terser-webpack-plugin/index-v5/ac/e2/e903ec95ada0b0075fdcfb6133e2e75c9b3b0504a29ca665704aaed90b2b +2 -0
- package/src/constants/node_modules/.cache/terser-webpack-plugin/index-v5/b4/c5/a43653dff3b380f7b0793080a57c980a9a136764933e79454de0fe43a5ca +2 -0
- package/src/constants/package.json +2 -2
- package/src/constants/umd/keplergl.min.js +1 -1
- package/src/deckgl-arrow-layers/package.json +2 -2
- package/src/deckgl-layers/package.json +4 -4
- package/src/duckdb/dist/table/duckdb-table-utils.js +3 -2
- package/src/duckdb/package.json +6 -6
- package/src/duckdb/src/table/duckdb-table-utils.ts +5 -1
- package/src/effects/package.json +5 -5
- package/src/layers/dist/geojson-layer/geojson-utils.js +23 -5
- package/src/layers/dist/icon-layer/icon-layer.js +12 -2
- package/src/layers/dist/vector-tile/common-tile/tile-dataset.d.ts +4 -0
- package/src/layers/dist/vector-tile/common-tile/tile-dataset.js +10 -1
- package/src/layers/dist/vector-tile/vector-tile-layer.d.ts +11 -0
- package/src/layers/dist/vector-tile/vector-tile-layer.js +113 -7
- package/src/layers/package.json +9 -9
- package/src/layers/src/geojson-layer/geojson-utils.ts +22 -0
- package/src/layers/src/icon-layer/icon-layer.ts +49 -38
- package/src/layers/src/vector-tile/common-tile/tile-dataset.ts +7 -0
- package/src/layers/src/vector-tile/vector-tile-layer.ts +110 -6
- package/src/localization/dist/translations/en.d.ts +1 -0
- package/src/localization/dist/translations/en.js +2 -1
- package/src/localization/package.json +1 -1
- package/src/localization/src/translations/en.ts +1 -0
- package/src/processors/dist/data-processor.js +15 -5
- package/src/processors/package.json +7 -7
- package/src/processors/src/data-processor.ts +19 -4
- package/src/reducers/package.json +16 -16
- package/src/schemas/package.json +7 -7
- package/src/styles/node_modules/.cache/terser-webpack-plugin/content-v2/sha512/52/82/28cacf6fd462b779c22675964b655bf3a9f3ce9ec3c9b141a401a5bf90cb7d904ac65ab8e484570130b12771af0a0d5bab20e6976cfa773666763e046a6a +1 -0
- package/src/styles/node_modules/.cache/terser-webpack-plugin/content-v2/sha512/53/93/f8e389b6450ee0636bf336363d2d6865d8a1fe2445c15cc1e36c651e1ddf448358eb74e894f4bf6fc48ef881dc64cc221c48b133ecf0e02132f2c5fbfe11 +1 -0
- package/src/styles/node_modules/.cache/terser-webpack-plugin/index-v5/2e/45/ed6e0c1beb8bca4698a47b5feda8789a22d96978bc4839949bd26e827454 +2 -0
- package/src/styles/node_modules/.cache/terser-webpack-plugin/index-v5/56/db/b5a812c56b0d1dcdcd33da37e464062a19c8752cb2296603dc72d2c54d31 +2 -0
- package/src/styles/package.json +2 -2
- package/src/styles/umd/keplergl.min.js +1 -1
- package/src/table/dist/dataset-utils.js +18 -7
- package/src/table/dist/kepler-table.js +2 -1
- package/src/table/package.json +5 -5
- package/src/table/src/dataset-utils.ts +7 -2
- package/src/table/src/kepler-table.ts +1 -0
- package/src/tasks/package.json +2 -2
- package/src/types/actions.d.ts +1 -0
- package/src/types/package.json +1 -1
- package/src/utils/dist/arrow-data-container.d.ts +3 -2
- package/src/utils/dist/arrow-data-container.js +3 -3
- package/src/utils/dist/data-container-utils.d.ts +2 -0
- package/src/utils/dist/data-container-utils.js +3 -2
- package/src/utils/package.json +4 -4
- package/src/utils/src/arrow-data-container.ts +9 -7
- package/src/utils/src/data-container-utils.ts +3 -1
- 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.
|
|
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.
|
|
42
|
-
"@kepler.gl/cloud-providers": "3.2.
|
|
43
|
-
"@kepler.gl/common-utils": "3.2.
|
|
44
|
-
"@kepler.gl/constants": "3.2.
|
|
45
|
-
"@kepler.gl/effects": "3.2.
|
|
46
|
-
"@kepler.gl/layers": "3.2.
|
|
47
|
-
"@kepler.gl/localization": "3.2.
|
|
48
|
-
"@kepler.gl/processors": "3.2.
|
|
49
|
-
"@kepler.gl/reducers": "3.2.
|
|
50
|
-
"@kepler.gl/schemas": "3.2.
|
|
51
|
-
"@kepler.gl/styles": "3.2.
|
|
52
|
-
"@kepler.gl/table": "3.2.
|
|
53
|
-
"@kepler.gl/types": "3.2.
|
|
54
|
-
"@kepler.gl/utils": "3.2.
|
|
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
|
|
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
|
-
{
|
|
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={
|
|
@@ -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.
|
|
235
|
-
customPalette.
|
|
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
|
|
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)
|
|
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
|
-
[
|
|
306
|
+
[field, setColorUI, onSelect, range, getOptionValue, colorBreaks, ordinalDomain, scaleType]
|
|
265
307
|
);
|
|
266
308
|
|
|
267
309
|
const onApply = useCallback(() => {
|
|
268
|
-
|
|
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
|
-
|
|
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
|
|
381
|
-
const
|
|
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' :
|
|
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' :
|
|
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.
|
|
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: {
|