kepler.gl 3.1.0-alpha.7 → 3.1.0
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/components/src/common/data-table/index.d.ts +1 -1
- package/dist/src/components/src/common/data-table/option-dropdown.d.ts +3 -3
- package/dist/src/components/src/kepler-gl.d.ts +1 -0
- package/dist/src/reducers/src/vis-state-updaters.d.ts +1 -0
- package/dist/src/reducers/src/vis-state.d.ts +4 -0
- package/dist/src/utils/src/application-config.d.ts +2 -0
- package/package.json +3 -2
- package/src/actions/package.json +8 -8
- package/src/ai-assistant/dist/components/ai-assistant-config.js +66 -53
- package/src/ai-assistant/package.json +10 -9
- package/src/ai-assistant/src/components/ai-assistant-config.tsx +62 -48
- package/src/ai-assistant/src/config/models.json +32 -0
- package/src/cloud-providers/package.json +2 -2
- package/src/common-utils/package.json +3 -3
- package/src/components/dist/common/data-table/header-cell.js +10 -10
- package/src/components/dist/common/data-table/index.d.ts +1 -1
- package/src/components/dist/common/data-table/index.js +1 -1
- package/src/components/dist/common/data-table/option-dropdown.d.ts +3 -3
- package/src/components/dist/common/data-table/option-dropdown.js +5 -5
- package/src/components/dist/kepler-gl.d.ts +1 -0
- package/src/components/dist/modals/save-map-modal.js +4 -3
- package/src/components/package.json +15 -15
- package/src/components/src/common/data-table/header-cell.tsx +5 -3
- package/src/components/src/common/data-table/index.tsx +1 -1
- package/src/components/src/common/data-table/option-dropdown.tsx +7 -7
- package/src/components/src/modals/save-map-modal.tsx +6 -2
- package/src/constants/dist/default-settings.js +8 -5
- package/src/constants/node_modules/.cache/terser-webpack-plugin/content-v2/sha512/72/80/7a7c561d7985e92aab7b9683e7baf5a0286b353a8f2609c4c71099f668d012be027929e4bbac937f9aa0c9a61be3bd4405136f582895f05aa0313c8efa42 +1 -0
- package/src/constants/node_modules/.cache/terser-webpack-plugin/index-v5/f0/6e/aadf3c48345aa72e7b2fb92e8c9788d04986b55caf83daa3fbd749c37c44 +2 -0
- package/src/constants/package.json +2 -2
- package/src/constants/src/default-settings.ts +8 -3
- package/src/constants/umd/keplergl.min.js +1 -1
- package/src/deckgl-arrow-layers/package.json +1 -1
- package/src/deckgl-layers/package.json +4 -4
- package/src/duckdb/dist/components/preview-data-panel.js +2 -9
- package/src/duckdb/dist/components/sql-panel.js +2 -2
- package/src/duckdb/dist/plugin.js +8 -2
- package/src/duckdb/package.json +6 -6
- package/src/duckdb/src/components/preview-data-panel.tsx +0 -3
- package/src/duckdb/src/components/sql-panel.tsx +1 -1
- package/src/duckdb/src/plugin.ts +7 -1
- package/src/effects/package.json +5 -5
- package/src/layers/dist/index.d.ts +3 -0
- package/src/layers/dist/index.js +6 -7
- package/src/layers/package.json +9 -9
- package/src/layers/src/index.ts +5 -5
- package/src/localization/package.json +1 -1
- package/src/processors/package.json +7 -7
- package/src/reducers/dist/vis-state-updaters.d.ts +1 -0
- package/src/reducers/dist/vis-state-updaters.js +2 -2
- package/src/reducers/dist/vis-state.d.ts +4 -0
- package/src/reducers/package.json +16 -16
- package/src/reducers/src/vis-state-updaters.ts +5 -2
- package/src/schemas/dist/dataset-schema.js +32 -2
- package/src/schemas/package.json +8 -7
- package/src/schemas/src/dataset-schema.ts +34 -1
- package/src/styles/node_modules/.cache/terser-webpack-plugin/content-v2/sha512/5f/aa/96c67b383dbcd2b95625113a5389c6078fd8a53e6fc73a054229709f2dac1e0a409e7117049485a569fbebf8434a319451842671398904bfe1a7f7b5991c +1 -0
- package/src/styles/node_modules/.cache/terser-webpack-plugin/index-v5/c1/39/f7cd1d5947ec6e5d82bfa07041271344eb02f9e67bf5823acf2f22c2d01f +2 -0
- package/src/styles/package.json +2 -2
- package/src/styles/umd/keplergl.min.js +1 -1
- package/src/table/package.json +5 -5
- package/src/tasks/package.json +2 -2
- package/src/types/package.json +1 -1
- package/src/utils/dist/application-config.d.ts +2 -0
- package/src/utils/dist/application-config.js +4 -2
- package/src/utils/package.json +4 -4
- package/src/utils/src/application-config.ts +9 -1
- package/umd/keplergl.min.js +1151 -1149
|
@@ -15,25 +15,8 @@ import {
|
|
|
15
15
|
import {AiAssistantConfig} from '../index';
|
|
16
16
|
import ApiKey from '../icons/api-key';
|
|
17
17
|
import {testApiKey} from '@openassistant/core';
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
openai: ['o1-mini', 'o1-preview', 'gpt-4o', 'gpt-4o-mini', 'gpt-3.5-turbo-0125', 'gpt-3.5-turbo'],
|
|
21
|
-
google: ['gemini-2.0-flash-exp', 'gemini-1.5-flash', 'gemini-1.5-pro', 'gemini-1.0-pro'],
|
|
22
|
-
ollama: [
|
|
23
|
-
'phi4',
|
|
24
|
-
'qwen2.5-coder',
|
|
25
|
-
'qwq',
|
|
26
|
-
'llama3.3',
|
|
27
|
-
'llama3.2',
|
|
28
|
-
'llama3.1',
|
|
29
|
-
'llama3.1:70b',
|
|
30
|
-
'qwen2',
|
|
31
|
-
'llava',
|
|
32
|
-
'mistral',
|
|
33
|
-
'gemma2',
|
|
34
|
-
'phi3.5'
|
|
35
|
-
]
|
|
36
|
-
};
|
|
18
|
+
import PROVIDER_MODELS from '../config/models.json';
|
|
19
|
+
import {useLocalStorage} from 'usehooks-ts';
|
|
37
20
|
|
|
38
21
|
type ThemeProps = {theme: any};
|
|
39
22
|
|
|
@@ -143,12 +126,27 @@ function AiAssistantConfigFactory(RangeSlider: ReturnType<typeof RangeSliderFact
|
|
|
143
126
|
const AiAssistantConfig: React.FC<
|
|
144
127
|
AiAssistantConfigProps & WrappedComponentProps & ThemeProps
|
|
145
128
|
> = ({intl, aiAssistantConfig, updateAiAssistantConfig}) => {
|
|
146
|
-
const [provider, setProvider] =
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
const [
|
|
151
|
-
|
|
129
|
+
const [provider, setProvider] = useLocalStorage(
|
|
130
|
+
'ai-assistant-provider',
|
|
131
|
+
aiAssistantConfig.provider || 'openai'
|
|
132
|
+
);
|
|
133
|
+
const [model, setModel] = useLocalStorage(
|
|
134
|
+
'ai-assistant-model',
|
|
135
|
+
aiAssistantConfig.model || PROVIDER_MODELS[provider][0]
|
|
136
|
+
);
|
|
137
|
+
const [apiKey, setApiKey] = useLocalStorage(
|
|
138
|
+
'ai-assistant-api-key',
|
|
139
|
+
aiAssistantConfig.apiKey || ''
|
|
140
|
+
);
|
|
141
|
+
const [temperature, setTemperature] = useLocalStorage(
|
|
142
|
+
'ai-assistant-temperature',
|
|
143
|
+
aiAssistantConfig.temperature || 0.8
|
|
144
|
+
);
|
|
145
|
+
const [topP, setTopP] = useLocalStorage('ai-assistant-top-p', aiAssistantConfig.topP || 0.8);
|
|
146
|
+
const [baseUrl, setBaseUrl] = useLocalStorage(
|
|
147
|
+
'ai-assistant-base-url',
|
|
148
|
+
aiAssistantConfig.baseUrl || 'http://localhost:11434'
|
|
149
|
+
);
|
|
152
150
|
const [connectionError, setConnectionError] = useState(false);
|
|
153
151
|
const [errorMessage, setErrorMessage] = useState('');
|
|
154
152
|
const [isRunning, setIsRunning] = useState(false);
|
|
@@ -191,29 +189,45 @@ function AiAssistantConfigFactory(RangeSlider: ReturnType<typeof RangeSliderFact
|
|
|
191
189
|
|
|
192
190
|
const onStartChat = async () => {
|
|
193
191
|
setIsRunning(true);
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
:
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
192
|
+
try {
|
|
193
|
+
const timeoutPromise = new Promise((_, reject) => {
|
|
194
|
+
setTimeout(() => reject(new Error('Connection timeout after 15 seconds')), 15000);
|
|
195
|
+
});
|
|
196
|
+
|
|
197
|
+
const testPromise = testApiKey({
|
|
198
|
+
modelProvider: provider,
|
|
199
|
+
modelName: model,
|
|
200
|
+
apiKey: apiKey,
|
|
201
|
+
baseUrl: baseUrl
|
|
202
|
+
});
|
|
203
|
+
|
|
204
|
+
const result = (await Promise.race([testPromise, timeoutPromise])) as {
|
|
205
|
+
success: boolean;
|
|
206
|
+
service: string;
|
|
207
|
+
};
|
|
208
|
+
const {success, service} = result;
|
|
209
|
+
const errorMessage = !success
|
|
210
|
+
? service === 'ollama'
|
|
211
|
+
? 'Connection failed: maybe invalid Ollama Base URL'
|
|
212
|
+
: 'Connection failed: maybe invalid API Key'
|
|
213
|
+
: '';
|
|
214
|
+
setConnectionError(!success);
|
|
215
|
+
setErrorMessage(errorMessage);
|
|
216
|
+
updateAiAssistantConfig({
|
|
217
|
+
provider: provider,
|
|
218
|
+
model: model,
|
|
219
|
+
apiKey: apiKey,
|
|
220
|
+
baseUrl: baseUrl,
|
|
221
|
+
isReady: success,
|
|
222
|
+
temperature: temperature,
|
|
223
|
+
topP: topP
|
|
224
|
+
});
|
|
225
|
+
} catch (error) {
|
|
226
|
+
setConnectionError(true);
|
|
227
|
+
setErrorMessage(error instanceof Error ? error.message : 'Connection failed');
|
|
228
|
+
} finally {
|
|
229
|
+
setIsRunning(false);
|
|
230
|
+
}
|
|
217
231
|
};
|
|
218
232
|
|
|
219
233
|
return (
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
{
|
|
2
|
+
"deepseek": ["deepseek-chat", "deepseek-reasoner"],
|
|
3
|
+
"openai": [
|
|
4
|
+
"o1-mini",
|
|
5
|
+
"o1-preview",
|
|
6
|
+
"o1",
|
|
7
|
+
"gpt-4o",
|
|
8
|
+
"gpt-4o-mini",
|
|
9
|
+
"gpt-3.5-turbo-0125",
|
|
10
|
+
"gpt-3.5-turbo"
|
|
11
|
+
],
|
|
12
|
+
"google": ["gemini-2.0-flash-exp", "gemini-1.5-flash", "gemini-1.5-pro", "gemini-1.0-pro"],
|
|
13
|
+
"ollama": [
|
|
14
|
+
"deepseek-r1",
|
|
15
|
+
"deepseek-r1:14b",
|
|
16
|
+
"deepseek-r1:32b",
|
|
17
|
+
"deepseek-r1:70b",
|
|
18
|
+
"deepseek-r1:671b",
|
|
19
|
+
"phi4",
|
|
20
|
+
"qwen2.5-coder",
|
|
21
|
+
"qwq",
|
|
22
|
+
"llama3.3",
|
|
23
|
+
"llama3.2",
|
|
24
|
+
"llama3.1",
|
|
25
|
+
"llama3.1:70b",
|
|
26
|
+
"qwen2",
|
|
27
|
+
"llava",
|
|
28
|
+
"mistral",
|
|
29
|
+
"gemma2",
|
|
30
|
+
"phi3.5"
|
|
31
|
+
]
|
|
32
|
+
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@kepler.gl/cloud-providers",
|
|
3
3
|
"author": "Shan He <shan@uber.com>",
|
|
4
|
-
"version": "3.1.0
|
|
4
|
+
"version": "3.1.0",
|
|
5
5
|
"description": "kepler.gl constants used by kepler.gl components, actions and reducers",
|
|
6
6
|
"license": "MIT",
|
|
7
7
|
"main": "dist/index.js",
|
|
@@ -30,7 +30,7 @@
|
|
|
30
30
|
"umd"
|
|
31
31
|
],
|
|
32
32
|
"dependencies": {
|
|
33
|
-
"@kepler.gl/types": "3.1.0
|
|
33
|
+
"@kepler.gl/types": "3.1.0",
|
|
34
34
|
"react": "^18.2.0"
|
|
35
35
|
},
|
|
36
36
|
"nyc": {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@kepler.gl/common-utils",
|
|
3
3
|
"author": "Shan He <heshan0131@gmail.com>",
|
|
4
|
-
"version": "3.1.0
|
|
4
|
+
"version": "3.1.0",
|
|
5
5
|
"description": "kepler.gl common utils",
|
|
6
6
|
"license": "MIT",
|
|
7
7
|
"main": "dist/index.js",
|
|
@@ -30,8 +30,8 @@
|
|
|
30
30
|
"umd"
|
|
31
31
|
],
|
|
32
32
|
"dependencies": {
|
|
33
|
-
"@kepler.gl/constants": "3.1.0
|
|
34
|
-
"@kepler.gl/types": "3.1.0
|
|
33
|
+
"@kepler.gl/constants": "3.1.0",
|
|
34
|
+
"@kepler.gl/types": "3.1.0",
|
|
35
35
|
"d3-array": "^2.8.0",
|
|
36
36
|
"global": "^4.3.0",
|
|
37
37
|
"h3-js": "^3.1.0",
|
|
@@ -49,7 +49,7 @@ var HeaderCellFactory = function HeaderCellFactory(FieldToken) {
|
|
|
49
49
|
style = cellInfo.style;
|
|
50
50
|
var colMeta = props.colMeta,
|
|
51
51
|
sortColumn = props.sortColumn,
|
|
52
|
-
|
|
52
|
+
sortTableColumn = props.sortTableColumn,
|
|
53
53
|
pinTableColumn = props.pinTableColumn,
|
|
54
54
|
copyTableColumn = props.copyTableColumn,
|
|
55
55
|
setColumnDisplayFormat = props.setColumnDisplayFormat;
|
|
@@ -64,8 +64,8 @@ var HeaderCellFactory = function HeaderCellFactory(FieldToken) {
|
|
|
64
64
|
var isFormatted = Boolean((_colMeta$column = colMeta[column]) === null || _colMeta$column === void 0 ? void 0 : _colMeta$column.displayFormat);
|
|
65
65
|
var formatLabels = isFormatted ? (0, _utils.getFieldFormatLabels)(colMeta[column].type) : [];
|
|
66
66
|
var onSortTable = (0, _react.useCallback)(function () {
|
|
67
|
-
return
|
|
68
|
-
}, [
|
|
67
|
+
return sortTableColumn(column);
|
|
68
|
+
}, [sortTableColumn, column]);
|
|
69
69
|
var onToggleOptionMenu = (0, _react.useCallback)(function () {
|
|
70
70
|
return toggleMoreOptions(column);
|
|
71
71
|
}, [toggleMoreOptions, column]);
|
|
@@ -76,7 +76,7 @@ var HeaderCellFactory = function HeaderCellFactory(FieldToken) {
|
|
|
76
76
|
return copyTableColumn(column);
|
|
77
77
|
}, [copyTableColumn, column]);
|
|
78
78
|
var onSetDisplayFormat = (0, _react.useCallback)(function (displayFormat) {
|
|
79
|
-
setColumnDisplayFormat((0, _defineProperty2["default"])({}, column, displayFormat.format));
|
|
79
|
+
setColumnDisplayFormat === null || setColumnDisplayFormat === void 0 || setColumnDisplayFormat((0, _defineProperty2["default"])({}, column, displayFormat.format));
|
|
80
80
|
}, [column, setColumnDisplayFormat]);
|
|
81
81
|
var onToggleDisplayFormat = (0, _react.useCallback)(function () {
|
|
82
82
|
setShowFormatter(!showFormatter);
|
|
@@ -86,7 +86,7 @@ var HeaderCellFactory = function HeaderCellFactory(FieldToken) {
|
|
|
86
86
|
key: key,
|
|
87
87
|
style: style,
|
|
88
88
|
onClick: function onClick(e) {
|
|
89
|
-
e.shiftKey ?
|
|
89
|
+
e.shiftKey ? sortTableColumn(column) : null;
|
|
90
90
|
},
|
|
91
91
|
onDoubleClick: onSortTable,
|
|
92
92
|
title: column
|
|
@@ -134,16 +134,16 @@ var HeaderCellFactory = function HeaderCellFactory(FieldToken) {
|
|
|
134
134
|
column: column,
|
|
135
135
|
colMeta: colMeta,
|
|
136
136
|
toggleMoreOptions: toggleMoreOptions,
|
|
137
|
-
sortTableColumn: function
|
|
138
|
-
return
|
|
139
|
-
},
|
|
137
|
+
sortTableColumn: sortTableColumn ? function (mode) {
|
|
138
|
+
return sortTableColumn(column, mode);
|
|
139
|
+
} : undefined,
|
|
140
140
|
pinTableColumn: onPin,
|
|
141
141
|
copyTableColumn: onCopy,
|
|
142
|
-
setDisplayFormat: onSetDisplayFormat
|
|
142
|
+
setDisplayFormat: setColumnDisplayFormat ? onSetDisplayFormat : undefined
|
|
143
143
|
}))));
|
|
144
144
|
};
|
|
145
145
|
return HeaderCell;
|
|
146
146
|
};
|
|
147
147
|
HeaderCellFactory.deps = [_fieldToken["default"]];
|
|
148
148
|
var _default = exports["default"] = HeaderCellFactory;
|
|
149
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_classnames2","_button","_icons","_constants","_optionDropdown","_utils","_fieldToken","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledHeaderCell","styled","div","_taggedTemplateLiteral2","props","theme","headerCellBorderColor","headerPaddingTop","headerPaddingBottom","cellPaddingSide","headerCellBackground","HeaderCellFactory","FieldToken","HeaderCell","_ref","_colMeta$column","cellInfo","columns","isPinned","toggleMoreOptions","moreOptionsColumn","columnIndex","key","style","colMeta","sortColumn","sortTableColumn","pinTableColumn","copyTableColumn","setColumnDisplayFormat","_useState","useState","_useState2","_slicedToArray2","showFormatter","setShowFormatter","column","isGhost","ghost","isSorted","firstCell","isFormatted","Boolean","displayFormat","formatLabels","getFieldFormatLabels","type","onSortTable","useCallback","onToggleOptionMenu","onPin","onCopy","onSetDisplayFormat","_defineProperty2","format","onToggleDisplayFormat","createElement","className","classnames","concat","onClick","shiftKey","onDoubleClick","title","Fragment","name","SORT_ORDER","ASCENDING","ArrowUp","height","ArrowDown","Hash","FormatterDropdown","left","top","isOpened","setDisplayFormat","onClose","VertThreeDots","mode","deps","FieldTokenFactory","_default","exports"],"sources":["../../../src/common/data-table/header-cell.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {CSSProperties, useState, useCallback} from 'react';\nimport styled from 'styled-components';\nimport classnames from 'classnames';\nimport Button from './button';\nimport {ArrowUp, ArrowDown, VertThreeDots, Hash} from '../../common/icons';\nimport {SORT_ORDER} from '@kepler.gl/constants';\nimport OptionDropdown, {FormatterDropdown} from './option-dropdown';\nimport {getFieldFormatLabels} from '@kepler.gl/utils';\nimport {ColMeta} from '@kepler.gl/types';\nimport FieldTokenFactory, {FieldTokenProps} from '../../common/field-token';\nimport {DataTableProps} from './index';\n\nconst StyledHeaderCell = styled.div`\n  border-bottom: 1px solid ${props => props.theme.headerCellBorderColor};\n  border-top: 1px solid ${props => props.theme.headerCellBorderColor};\n  padding-top: ${props => props.theme.headerPaddingTop}px;\n  padding-right: 0;\n  padding-bottom: ${props => props.theme.headerPaddingBottom}px;\n  padding-left: ${props => props.theme.cellPaddingSide}px;\n  align-items: center;\n  justify-content: space-between;\n  display: flex;\n  flex-direction: row;\n  background-color: ${props => props.theme.headerCellBackground};\n\n  .n-sort-idx {\n    font-size: 9px;\n  }\n  .details {\n    font-weight: 500;\n    display: flex;\n    flex-direction: column;\n    justify-content: flex-start;\n    height: 100%;\n    overflow: hidden;\n    flex-grow: 1;\n\n    .col-name {\n      display: flex;\n      align-items: center;\n      justify-content: space-between;\n\n      .col-name__left {\n        display: flex;\n        align-items: center;\n        overflow: hidden;\n\n        svg {\n          margin-left: 6px;\n        }\n      }\n      .col-name__name {\n        overflow: hidden;\n        white-space: nowrap;\n        text-overflow: ellipsis;\n      }\n    }\n  }\n\n  .more {\n    margin-left: 5px;\n  }\n\n  .col-name__format svg {\n    width: 10px;\n    height: 10px;\n    stroke-width: 1;\n  }\n`;\n\ntype CellInfo = {\n  columnIndex: number;\n  isScrolling: boolean;\n  isVisible: boolean;\n  key: string;\n  parent: any;\n  rowIndex: number;\n  style: CSSProperties;\n};\n\ntype HeaderCellProps = {\n  // passed down from react virtualized Grid\n  cellInfo: CellInfo;\n  columns: DataTableProps['columns'];\n  colMeta?: ColMeta;\n  isPinned?: boolean;\n  showStats?: boolean;\n  props: DataTableProps;\n  toggleMoreOptions: (moreOptionsColumn: string) => void;\n  moreOptionsColumn: null | string;\n};\n\nconst HeaderCellFactory = (FieldToken: React.FC<FieldTokenProps>) => {\n  const HeaderCell = ({\n    cellInfo,\n    columns,\n    isPinned,\n    props,\n    toggleMoreOptions,\n    moreOptionsColumn\n  }: HeaderCellProps) => {\n    const {columnIndex, key, style} = cellInfo;\n    const {\n      colMeta,\n      sortColumn,\n      sortTableColumn,\n      pinTableColumn,\n      copyTableColumn,\n      setColumnDisplayFormat\n    } = props;\n    const [showFormatter, setShowFormatter] = useState(false);\n    const column = columns[columnIndex];\n\n    const isGhost = column.ghost;\n    const isSorted = sortColumn[column];\n    const firstCell = columnIndex === 0;\n    const isFormatted = Boolean(colMeta[column]?.displayFormat);\n    const formatLabels = isFormatted ? getFieldFormatLabels(colMeta[column].type) : [];\n    const onSortTable = useCallback(() => sortTableColumn(column), [sortTableColumn, column]);\n    const onToggleOptionMenu = useCallback(\n      () => toggleMoreOptions(column),\n      [toggleMoreOptions, column]\n    );\n    const onPin = useCallback(() => pinTableColumn(column), [pinTableColumn, column]);\n    const onCopy = useCallback(() => copyTableColumn(column), [copyTableColumn, column]);\n    const onSetDisplayFormat = useCallback(\n      displayFormat => {\n        setColumnDisplayFormat({[column]: displayFormat.format});\n      },\n      [column, setColumnDisplayFormat]\n    );\n\n    const onToggleDisplayFormat = useCallback(() => {\n      setShowFormatter(!showFormatter);\n    }, [showFormatter]);\n\n    return (\n      <StyledHeaderCell\n        className={classnames('header-cell', {\n          [`column-${columnIndex}`]: true,\n          'pinned-header-cell': isPinned,\n          'first-cell': firstCell\n        })}\n        key={key}\n        style={style}\n        onClick={e => {\n          e.shiftKey ? sortTableColumn(column) : null;\n        }}\n        onDoubleClick={onSortTable}\n        title={column}\n      >\n        {isGhost ? (\n          <div />\n        ) : (\n          <>\n            <section className=\"details\">\n              <div className=\"col-name\">\n                <div className=\"col-name__left\">\n                  <div className=\"col-name__name\">{colMeta[column].name}</div>\n                  <Button className=\"col-name__sort\" onClick={onSortTable}>\n                    {isSorted ? (\n                      isSorted === SORT_ORDER.ASCENDING ? (\n                        <ArrowUp height=\"14px\" />\n                      ) : (\n                        <ArrowDown height=\"14px\" />\n                      )\n                    ) : null}\n                  </Button>\n                  <Button className=\"col-name__format\" onClick={onToggleDisplayFormat}>\n                    {isFormatted ? <Hash height=\"14px\" /> : null}\n                    <FormatterDropdown\n                      left={0}\n                      top={0}\n                      isOpened={isFormatted && showFormatter}\n                      displayFormat={colMeta[column].displayFormat}\n                      setDisplayFormat={onSetDisplayFormat}\n                      onClose={() => setShowFormatter(false)}\n                      formatLabels={formatLabels}\n                    />\n                  </Button>\n                </div>\n                <Button className=\"more\" onClick={onToggleOptionMenu}>\n                  <VertThreeDots height=\"14px\" />\n                </Button>\n              </div>\n              <FieldToken type={colMeta[column].type} />\n            </section>\n\n            <section className=\"options\">\n              <OptionDropdown\n                isOpened={moreOptionsColumn === column}\n                column={column}\n                colMeta={colMeta}\n                toggleMoreOptions={toggleMoreOptions}\n                sortTableColumn={mode => sortTableColumn(column, mode)}\n                pinTableColumn={onPin}\n                copyTableColumn={onCopy}\n                setDisplayFormat={onSetDisplayFormat}\n              />\n            </section>\n          </>\n        )}\n      </StyledHeaderCell>\n    );\n  };\n  return HeaderCell;\n};\nHeaderCellFactory.deps = [FieldTokenFactory];\nexport default HeaderCellFactory;\n"],"mappings":"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","ignoreList":[]}
|
|
149
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_classnames2","_button","_icons","_constants","_optionDropdown","_utils","_fieldToken","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledHeaderCell","styled","div","_taggedTemplateLiteral2","props","theme","headerCellBorderColor","headerPaddingTop","headerPaddingBottom","cellPaddingSide","headerCellBackground","HeaderCellFactory","FieldToken","HeaderCell","_ref","_colMeta$column","cellInfo","columns","isPinned","toggleMoreOptions","moreOptionsColumn","columnIndex","key","style","colMeta","sortColumn","sortTableColumn","pinTableColumn","copyTableColumn","setColumnDisplayFormat","_useState","useState","_useState2","_slicedToArray2","showFormatter","setShowFormatter","column","isGhost","ghost","isSorted","firstCell","isFormatted","Boolean","displayFormat","formatLabels","getFieldFormatLabels","type","onSortTable","useCallback","onToggleOptionMenu","onPin","onCopy","onSetDisplayFormat","_defineProperty2","format","onToggleDisplayFormat","createElement","className","classnames","concat","onClick","shiftKey","onDoubleClick","title","Fragment","name","SORT_ORDER","ASCENDING","ArrowUp","height","ArrowDown","Hash","FormatterDropdown","left","top","isOpened","setDisplayFormat","onClose","VertThreeDots","mode","undefined","deps","FieldTokenFactory","_default","exports"],"sources":["../../../src/common/data-table/header-cell.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {CSSProperties, useState, useCallback} from 'react';\nimport styled from 'styled-components';\nimport classnames from 'classnames';\nimport Button from './button';\nimport {ArrowUp, ArrowDown, VertThreeDots, Hash} from '../../common/icons';\nimport {SORT_ORDER} from '@kepler.gl/constants';\nimport OptionDropdown, {FormatterDropdown} from './option-dropdown';\nimport {getFieldFormatLabels} from '@kepler.gl/utils';\nimport {ColMeta} from '@kepler.gl/types';\nimport FieldTokenFactory, {FieldTokenProps} from '../../common/field-token';\nimport {DataTableProps} from './index';\n\nconst StyledHeaderCell = styled.div`\n  border-bottom: 1px solid ${props => props.theme.headerCellBorderColor};\n  border-top: 1px solid ${props => props.theme.headerCellBorderColor};\n  padding-top: ${props => props.theme.headerPaddingTop}px;\n  padding-right: 0;\n  padding-bottom: ${props => props.theme.headerPaddingBottom}px;\n  padding-left: ${props => props.theme.cellPaddingSide}px;\n  align-items: center;\n  justify-content: space-between;\n  display: flex;\n  flex-direction: row;\n  background-color: ${props => props.theme.headerCellBackground};\n\n  .n-sort-idx {\n    font-size: 9px;\n  }\n  .details {\n    font-weight: 500;\n    display: flex;\n    flex-direction: column;\n    justify-content: flex-start;\n    height: 100%;\n    overflow: hidden;\n    flex-grow: 1;\n\n    .col-name {\n      display: flex;\n      align-items: center;\n      justify-content: space-between;\n\n      .col-name__left {\n        display: flex;\n        align-items: center;\n        overflow: hidden;\n\n        svg {\n          margin-left: 6px;\n        }\n      }\n      .col-name__name {\n        overflow: hidden;\n        white-space: nowrap;\n        text-overflow: ellipsis;\n      }\n    }\n  }\n\n  .more {\n    margin-left: 5px;\n  }\n\n  .col-name__format svg {\n    width: 10px;\n    height: 10px;\n    stroke-width: 1;\n  }\n`;\n\ntype CellInfo = {\n  columnIndex: number;\n  isScrolling: boolean;\n  isVisible: boolean;\n  key: string;\n  parent: any;\n  rowIndex: number;\n  style: CSSProperties;\n};\n\ntype HeaderCellProps = {\n  // passed down from react virtualized Grid\n  cellInfo: CellInfo;\n  columns: DataTableProps['columns'];\n  colMeta?: ColMeta;\n  isPinned?: boolean;\n  showStats?: boolean;\n  props: DataTableProps;\n  toggleMoreOptions: (moreOptionsColumn: string) => void;\n  moreOptionsColumn: null | string;\n};\n\nconst HeaderCellFactory = (FieldToken: React.FC<FieldTokenProps>) => {\n  const HeaderCell = ({\n    cellInfo,\n    columns,\n    isPinned,\n    props,\n    toggleMoreOptions,\n    moreOptionsColumn\n  }: HeaderCellProps) => {\n    const {columnIndex, key, style} = cellInfo;\n    const {\n      colMeta,\n      sortColumn,\n      sortTableColumn,\n      pinTableColumn,\n      copyTableColumn,\n      setColumnDisplayFormat\n    } = props;\n    const [showFormatter, setShowFormatter] = useState(false);\n    const column = columns[columnIndex];\n\n    const isGhost = column.ghost;\n    const isSorted = sortColumn[column];\n    const firstCell = columnIndex === 0;\n    const isFormatted = Boolean(colMeta[column]?.displayFormat);\n    const formatLabels = isFormatted ? getFieldFormatLabels(colMeta[column].type) : [];\n    const onSortTable = useCallback(() => sortTableColumn(column), [sortTableColumn, column]);\n    const onToggleOptionMenu = useCallback(\n      () => toggleMoreOptions(column),\n      [toggleMoreOptions, column]\n    );\n    const onPin = useCallback(() => pinTableColumn(column), [pinTableColumn, column]);\n    const onCopy = useCallback(() => copyTableColumn(column), [copyTableColumn, column]);\n    const onSetDisplayFormat = useCallback(\n      displayFormat => {\n        setColumnDisplayFormat?.({[column]: displayFormat.format});\n      },\n      [column, setColumnDisplayFormat]\n    );\n\n    const onToggleDisplayFormat = useCallback(() => {\n      setShowFormatter(!showFormatter);\n    }, [showFormatter]);\n\n    return (\n      <StyledHeaderCell\n        className={classnames('header-cell', {\n          [`column-${columnIndex}`]: true,\n          'pinned-header-cell': isPinned,\n          'first-cell': firstCell\n        })}\n        key={key}\n        style={style}\n        onClick={e => {\n          e.shiftKey ? sortTableColumn(column) : null;\n        }}\n        onDoubleClick={onSortTable}\n        title={column}\n      >\n        {isGhost ? (\n          <div />\n        ) : (\n          <>\n            <section className=\"details\">\n              <div className=\"col-name\">\n                <div className=\"col-name__left\">\n                  <div className=\"col-name__name\">{colMeta[column].name}</div>\n                  <Button className=\"col-name__sort\" onClick={onSortTable}>\n                    {isSorted ? (\n                      isSorted === SORT_ORDER.ASCENDING ? (\n                        <ArrowUp height=\"14px\" />\n                      ) : (\n                        <ArrowDown height=\"14px\" />\n                      )\n                    ) : null}\n                  </Button>\n                  <Button className=\"col-name__format\" onClick={onToggleDisplayFormat}>\n                    {isFormatted ? <Hash height=\"14px\" /> : null}\n                    <FormatterDropdown\n                      left={0}\n                      top={0}\n                      isOpened={isFormatted && showFormatter}\n                      displayFormat={colMeta[column].displayFormat}\n                      setDisplayFormat={onSetDisplayFormat}\n                      onClose={() => setShowFormatter(false)}\n                      formatLabels={formatLabels}\n                    />\n                  </Button>\n                </div>\n                <Button className=\"more\" onClick={onToggleOptionMenu}>\n                  <VertThreeDots height=\"14px\" />\n                </Button>\n              </div>\n              <FieldToken type={colMeta[column].type} />\n            </section>\n\n            <section className=\"options\">\n              <OptionDropdown\n                isOpened={moreOptionsColumn === column}\n                column={column}\n                colMeta={colMeta}\n                toggleMoreOptions={toggleMoreOptions}\n                sortTableColumn={\n                  sortTableColumn ? mode => sortTableColumn(column, mode) : undefined\n                }\n                pinTableColumn={onPin}\n                copyTableColumn={onCopy}\n                setDisplayFormat={setColumnDisplayFormat ? onSetDisplayFormat : undefined}\n              />\n            </section>\n          </>\n        )}\n      </StyledHeaderCell>\n    );\n  };\n  return HeaderCell;\n};\nHeaderCellFactory.deps = [FieldTokenFactory];\nexport default HeaderCellFactory;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -63,7 +63,7 @@ export interface DataTableProps {
|
|
|
63
63
|
sortColumn: SortColumn;
|
|
64
64
|
sortTableColumn: (column: string, mode?: string) => void;
|
|
65
65
|
pinTableColumn: (column: string) => void;
|
|
66
|
-
setColumnDisplayFormat
|
|
66
|
+
setColumnDisplayFormat?: (formats: {
|
|
67
67
|
[key: string]: string;
|
|
68
68
|
}) => void;
|
|
69
69
|
copyTableColumn: (column: string) => void;
|