/
tableConfigLogic.ts
71 lines (67 loc) 路 2.43 KB
/
tableConfigLogic.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
import { kea } from 'kea'
import { tableConfigLogicType } from './tableConfigLogicType'
import { router } from 'kea-router'
import { ColumnChoice } from '~/types'
export const tableConfigLogic = kea<tableConfigLogicType>({
path: ['lib', 'components', 'ResizableTable', 'tableConfigLogic'],
actions: {
showModal: true,
hideModal: false,
setSelectedColumns: (columnConfig: ColumnChoice) => ({ columnConfig }),
},
reducers: () => ({
selectedColumns: [
'DEFAULT' as ColumnChoice,
{
setSelectedColumns: (_, { columnConfig }) => columnConfig,
},
],
modalVisible: [
false,
{
showModal: () => true,
save: () => false,
hideModal: () => false,
setSelectedColumns: () => false,
},
],
}),
selectors: {
tableWidth: [
(selectors) => [selectors.selectedColumns],
(selectedColumns: ColumnChoice): number => {
return selectedColumns === 'DEFAULT' ? 7 : selectedColumns.length + 1
},
],
},
urlToAction: ({ actions, values }) => ({
'*': (_, searchParams) => {
const columnsFromURL: string[] = searchParams.tableColumns
// URL columns must be present, an array, and have content
if (!columnsFromURL || !Array.isArray(columnsFromURL) || columnsFromURL.length === 0) {
return
}
const currentColumns: ColumnChoice = values.selectedColumns
const arrayEqualsInAnyOrder =
columnsFromURL.length === currentColumns.length &&
columnsFromURL.every((value) => currentColumns.includes(value))
// URL columns should be applied if the current columns are not set, or are not the same as the URL columns
if (currentColumns === 'DEFAULT' || !arrayEqualsInAnyOrder) {
actions.setSelectedColumns(columnsFromURL)
}
},
}),
actionToUrl: ({ values }) => ({
setSelectedColumns: () => {
return [
router.values.location.pathname,
{
...router.values.searchParams,
tableColumns: values.selectedColumns,
},
router.values.hashParams,
{ replace: true },
]
},
}),
})