pixel-react 1.5.9 → 1.6.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/.yarn/install-state.gz +0 -0
- package/lib/assets/fonts/Poppins-Bold.ttf +0 -0
- package/lib/assets/fonts/Poppins-Medium.ttf +0 -0
- package/lib/assets/fonts/Poppins-Regular.ttf +0 -0
- package/lib/assets/fonts/Poppins-SemiBold.ttf +0 -0
- package/lib/components/AddButton/AddButton.d.ts +5 -0
- package/lib/components/AddButton/AddButton.stories.d.ts +6 -0
- package/lib/components/AddButton/index.d.ts +1 -0
- package/lib/components/AddButton/types.d.ts +4 -0
- package/lib/components/AttachImage/AttachImage.stories.d.ts +7 -0
- package/lib/components/Charts/BarChart/BarChart.stories.d.ts +6 -0
- package/lib/components/Charts/IconRadialChart/IconRadialChart.stories.d.ts +8 -0
- package/lib/components/Charts/LineChart/LineChart.stories.d.ts +7 -0
- package/lib/components/Charts/MultiRadialChart/MultiRadialChart.stories.d.ts +8 -0
- package/lib/components/ConnectingBranch/ConnectingBranch.stories.d.ts +6 -0
- package/lib/components/EditTextField/EditTextField.stories.d.ts +10 -0
- package/lib/components/Editor/Editor.stories.d.ts +6 -0
- package/lib/components/Excel/ContextMenu/ContextMenu.d.ts +4 -0
- package/lib/components/Excel/ExcelFile.stories.d.ts +6 -0
- package/lib/components/ExcelFile/ChangeExcelStyles.d.ts +14 -0
- package/lib/components/ExcelFile/ImportExcelStyles.d.ts +24 -0
- package/lib/components/FieldSet/FieldSet.d.ts +5 -0
- package/lib/components/FieldSet/index.d.ts +1 -0
- package/lib/components/FieldSet/types.d.ts +7 -0
- package/lib/components/FileDropzone/types.d.ts +8 -0
- package/lib/components/LabelEditTextField/LabelEditTextField.stories.d.ts +2 -0
- package/lib/components/MultiSelect/MultiSelect.d.ts +1 -1
- package/lib/components/MultiSelect/MultiSelect.stories.d.ts +1 -0
- package/lib/components/MultiSelect/MultiSelectTypes.d.ts +1 -0
- package/lib/components/Select/Select.stories.d.ts +1 -0
- package/lib/components/StatusCard/StatusCard.stories.d.ts +11 -0
- package/lib/components/TableTree/TableTree.d.ts +4 -24
- package/lib/components/TableTree/data.d.ts +78 -273
- package/lib/components/TableTree/types.d.ts +29 -0
- package/lib/index.d.ts +98 -20
- package/lib/index.esm.js +367 -370
- package/lib/index.esm.js.map +1 -1
- package/lib/index.js +371 -370
- package/lib/index.js.map +1 -1
- package/lib/tsconfig.tsbuildinfo +1 -1
- package/lib/utils/getSequentialPayload/getSequentialPayload.stories.d.ts +10 -0
- package/package.json +2 -2
- package/src/assets/icons/approval_pending.svg +8 -8
- package/src/assets/icons/configuration.svg +3 -3
- package/src/assets/icons/defects.svg +8 -8
- package/src/assets/icons/element.svg +4 -4
- package/src/assets/icons/export.svg +5 -0
- package/src/assets/icons/import.svg +5 -0
- package/src/assets/icons/info_icon.svg +4 -16
- package/src/assets/icons/project_element.svg +4 -4
- package/src/assets/icons/replace_file.svg +14 -0
- package/src/assets/icons/step_group.svg +10 -10
- package/src/assets/icons/variable.svg +3 -3
- package/src/assets/icons/web_service_icon.svg +3 -0
- package/src/components/Checkbox/Checkbox.tsx +1 -7
- package/src/components/DragAndDrop/DragAndDropList.tsx +5 -4
- package/src/components/FieldSet/FieldSet.scss +9 -0
- package/src/components/FieldSet/FieldSet.stories.tsx +103 -0
- package/src/components/FieldSet/FieldSet.tsx +29 -0
- package/src/components/FieldSet/index.ts +1 -0
- package/src/components/FieldSet/types.ts +8 -0
- package/src/components/FileDropzone/FileDropzone.scss +1 -1
- package/src/components/FileDropzone/FileDropzone.stories.tsx +15 -3
- package/src/components/FileDropzone/FileDropzone.tsx +5 -0
- package/src/components/FileDropzone/FilePreview.tsx +1 -1
- package/src/components/FileDropzone/types.ts +8 -0
- package/src/components/Icon/iconList.ts +11 -7
- package/src/components/MultiSelect/Dropdown.tsx +7 -3
- package/src/components/MultiSelect/MultiSelect.stories.tsx +6 -1
- package/src/components/MultiSelect/MultiSelect.tsx +4 -20
- package/src/components/MultiSelect/MultiSelectTypes.ts +2 -0
- package/src/components/TableTree/TableTree.scss +154 -123
- package/src/components/TableTree/TableTree.stories.tsx +10 -5
- package/src/components/TableTree/TableTree.tsx +220 -287
- package/src/components/TableTree/data.ts +677 -569
- package/src/components/TableTree/types.ts +31 -0
- package/src/components/Toast/Toast.tsx +1 -1
- package/src/index.ts +8 -0
- /package/lib/components/ExcelFile/{ColorBarselector → ColorBarSelector}/ColorBarSelector.d.ts +0 -0
@@ -1,307 +1,240 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
import React, {
|
4
|
-
ReactNode,
|
5
|
-
useEffect,
|
6
|
-
useLayoutEffect,
|
7
|
-
useRef,
|
8
|
-
useState,
|
9
|
-
} from 'react';
|
1
|
+
import React, { useMemo, useCallback } from 'react';
|
2
|
+
import './TableTree.scss';
|
10
3
|
import { prepareData } from '../../utils/TableCell/TableCell';
|
11
|
-
import
|
12
|
-
import { checkEmpty } from '../../utils/checkEmpty/checkEmpty';
|
13
|
-
|
4
|
+
import Arrow from '../../assets/icons/arrows_down_icon.svg?react';
|
14
5
|
import Checkbox from '../Checkbox';
|
15
|
-
import './TableTree.scss';
|
16
6
|
import RadioButton from '../RadioButton';
|
17
|
-
import
|
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
|
-
|
7
|
+
import { TreeTableProps } from './types';
|
8
|
+
|
9
|
+
// Helper to render spaces for levels
|
10
|
+
const renderSpaces = (level: number) =>
|
11
|
+
Array.from({ length: level }).map((_, i) => (
|
12
|
+
<span key={i} className="tree-table-space-block" />
|
13
|
+
));
|
14
|
+
|
15
|
+
// Component: TableCell
|
16
|
+
const TableCell = React.memo(
|
17
|
+
({
|
18
|
+
col,
|
19
|
+
node,
|
20
|
+
level,
|
21
|
+
isExpanded,
|
22
|
+
selected,
|
23
|
+
select,
|
24
|
+
onCheckBoxChange,
|
25
|
+
onToggleExpand,
|
26
|
+
}: {
|
27
|
+
col: any;
|
28
|
+
node: any;
|
29
|
+
level: number;
|
30
|
+
isExpanded: boolean;
|
31
|
+
selected: string[];
|
32
|
+
select: string | null;
|
33
|
+
onCheckBoxChange: (e: any, node: any) => void;
|
34
|
+
onToggleExpand: (node: any) => void;
|
35
|
+
}) => (
|
36
|
+
<td>
|
37
|
+
{col.isTree && renderSpaces(level + 1)}
|
38
|
+
{col.isTree && (
|
39
|
+
<span
|
40
|
+
className={`tree-table-space-block last-block ${
|
41
|
+
isExpanded ? 'tree-row-expanded' : 'tree-row-collapsed'
|
42
|
+
} ${node.folder ? '': 'no-folder'}`}
|
43
|
+
onClick={() => onToggleExpand(node)}
|
44
|
+
>
|
45
|
+
{node.folder && <Arrow />}
|
46
|
+
</span>
|
47
|
+
)}
|
48
|
+
<span className="tree-table-td-content">
|
49
|
+
{col.isTree && select === 'checkbox' && (
|
50
|
+
<Checkbox
|
51
|
+
checked={selected.includes(node.searchKey)}
|
52
|
+
onChange={(e) => onCheckBoxChange(e, node)}
|
53
|
+
/>
|
54
|
+
)}
|
55
|
+
{col.isTree && select === 'radio' && (
|
56
|
+
<RadioButton
|
57
|
+
name={node.title}
|
58
|
+
checked={selected.includes(node.searchKey)}
|
59
|
+
value={node.searchKey}
|
60
|
+
onChange={(e) => onCheckBoxChange(e, node)}
|
61
|
+
/>
|
62
|
+
)}
|
63
|
+
{prepareData(node, col)}
|
64
|
+
</span>
|
65
|
+
{col.actions && (
|
66
|
+
<div className="table-tree-row-action">{col.actions(node)}</div>
|
67
|
+
)}
|
68
|
+
</td>
|
69
|
+
)
|
70
|
+
);
|
71
|
+
|
72
|
+
// Component: TableRow
|
73
|
+
const TableRow = React.memo(
|
74
|
+
({
|
75
|
+
node,
|
76
|
+
level,
|
77
|
+
columnsData,
|
78
|
+
isExpanded,
|
79
|
+
selected,
|
80
|
+
select,
|
81
|
+
onRowClick,
|
82
|
+
onToggleExpand,
|
83
|
+
onCheckBoxChange,
|
84
|
+
}: {
|
85
|
+
node: any;
|
86
|
+
level: number;
|
87
|
+
columnsData: any[];
|
88
|
+
isExpanded: boolean;
|
89
|
+
selected: string[];
|
90
|
+
select: string | null;
|
91
|
+
onRowClick: (e: any, node: any) => void;
|
92
|
+
onToggleExpand: (node: any) => void;
|
93
|
+
onCheckBoxChange: (e: any, node: any) => void;
|
94
|
+
}) => (
|
95
|
+
<tr
|
96
|
+
data-level={level}
|
97
|
+
className="show"
|
98
|
+
onClick={(e) => onRowClick(e, node)}
|
99
|
+
>
|
100
|
+
{columnsData.map((col) => (
|
101
|
+
<TableCell
|
102
|
+
key={col.name}
|
103
|
+
col={col}
|
104
|
+
node={node}
|
105
|
+
level={level}
|
106
|
+
isExpanded={isExpanded}
|
107
|
+
selected={selected}
|
108
|
+
select={select}
|
109
|
+
onCheckBoxChange={onCheckBoxChange}
|
110
|
+
onToggleExpand={onToggleExpand}
|
111
|
+
/>
|
112
|
+
))}
|
113
|
+
</tr>
|
114
|
+
)
|
115
|
+
);
|
116
|
+
|
117
|
+
// Component: TableHead
|
118
|
+
const TableHead = React.memo(({ columnsData }: { columnsData: any[] }) => {
|
119
|
+
const hasDefaultValues = useMemo(
|
120
|
+
() => columnsData.some(({ defaultValue }) => !!defaultValue),
|
121
|
+
[columnsData]
|
59
122
|
);
|
60
|
-
const triggeredPaginationNodes = useRef(new Set()); // Tracks nodes for which pagination is triggered
|
61
|
-
|
62
|
-
useLayoutEffect(() => {
|
63
|
-
const defaultExpanded: Set<ObjectProps> = new Set();
|
64
|
-
|
65
|
-
// Recursive function to add nodes and their children to the expanded set
|
66
|
-
const expandNodeRecursively = (node: ObjectProps) => {
|
67
|
-
if (node.expanded) {
|
68
|
-
defaultExpanded.add(node);
|
69
|
-
|
70
|
-
if (node.children) {
|
71
|
-
node.children.forEach((child: ObjectProps) =>
|
72
|
-
expandNodeRecursively(child)
|
73
|
-
);
|
74
|
-
}
|
75
|
-
}
|
76
|
-
};
|
77
|
-
|
78
|
-
treeData.forEach((node) => {
|
79
|
-
expandNodeRecursively(node);
|
80
|
-
});
|
81
|
-
|
82
|
-
setExpandedNodes(defaultExpanded);
|
83
|
-
}, [treeData]);
|
84
|
-
|
85
|
-
// Function to calculate total children height
|
86
|
-
const calculateTotalChildrenHeight = (node: any): number => {
|
87
|
-
if (!node.children || node.children.length === 0) {
|
88
|
-
return 1;
|
89
|
-
}
|
90
|
-
let totalHeight = 1;
|
91
|
-
if (expandedNodes.has(node)) {
|
92
|
-
node.children.forEach((child: any) => {
|
93
|
-
totalHeight += calculateTotalChildrenHeight(child);
|
94
|
-
});
|
95
|
-
}
|
96
|
-
return totalHeight;
|
97
|
-
};
|
98
|
-
|
99
|
-
const TreeNode = ({ node, level, isLast }: any) => {
|
100
|
-
const nodeRef = useRef<HTMLTableRowElement | null>(null);
|
101
|
-
const lastChildRef = useRef<HTMLTableRowElement | null>(null); // Ref for pagination
|
102
|
-
const [nodeHeight, setNodeHeight] = useState<number>(0);
|
103
|
-
const [totalChildrenHeight, setTotalChildrenHeight] = useState<number>(0);
|
104
|
-
|
105
|
-
const isExpanded = expandedNodes.has(node);
|
106
|
-
|
107
|
-
useLayoutEffect(() => {
|
108
|
-
if (nodeRef.current) {
|
109
|
-
const observer = new ResizeObserver(() => {
|
110
|
-
const currentHeight = nodeRef.current?.offsetHeight || 0;
|
111
|
-
setNodeHeight(currentHeight);
|
112
|
-
|
113
|
-
const childrenHeight = calculateTotalChildrenHeight(node);
|
114
|
-
setTotalChildrenHeight(childrenHeight);
|
115
|
-
});
|
116
|
-
|
117
|
-
observer.observe(nodeRef.current);
|
118
|
-
|
119
|
-
return () => {
|
120
|
-
observer.disconnect();
|
121
|
-
};
|
122
|
-
}
|
123
|
-
}, [isExpanded, node]);
|
124
|
-
|
125
|
-
useEffect(() => {
|
126
|
-
if (!isExpanded || !lastChildRef.current || !onPagination) return;
|
127
123
|
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
return () => observer.disconnect();
|
147
|
-
}, [isExpanded, onPagination, node]);
|
148
|
-
|
149
|
-
const handleToggleExpand = () => {
|
150
|
-
setExpandedNodes((prev) => {
|
151
|
-
const newExpandedNodes = new Set(prev);
|
152
|
-
if (newExpandedNodes.has(node)) {
|
153
|
-
newExpandedNodes.delete(node); // Collapse the node
|
154
|
-
} else {
|
155
|
-
newExpandedNodes.add(node); // Expand the node
|
156
|
-
}
|
157
|
-
return newExpandedNodes;
|
158
|
-
});
|
159
|
-
};
|
160
|
-
|
161
|
-
const handleCheckBoxChange = (e, node) => {
|
162
|
-
if (onChange) {
|
163
|
-
onChange(e, node);
|
164
|
-
}
|
165
|
-
};
|
166
|
-
|
167
|
-
const renderRowData = (columnsData: any) => {
|
168
|
-
return columnsData.map((column: any) => {
|
169
|
-
if (column.accessor === 'title') {
|
170
|
-
return (
|
171
|
-
<td className={`ff-title-container ${isLast ? 'ff-is-last' : ''}`}>
|
172
|
-
<div className="first-div">
|
173
|
-
{' '}
|
174
|
-
<span className="ff-toggle-folder" onClick={handleToggleExpand}>
|
175
|
-
{node.folder && (
|
176
|
-
<span
|
177
|
-
className={`ff-toggle-arrow-icon ${
|
178
|
-
isExpanded ? 'ff-expanded' : 'ff-collapsed'
|
179
|
-
}`}
|
180
|
-
>
|
181
|
-
<Arrow />
|
182
|
-
</span>
|
183
|
-
)}
|
184
|
-
</span>
|
185
|
-
<div
|
186
|
-
className="ff-title"
|
187
|
-
style={{ fontWeight: node.folder ? 600 : 400 }}
|
188
|
-
onClick={(event) => onClick(event, node)}
|
189
|
-
>
|
190
|
-
{select === 'checkbox' && (
|
191
|
-
<Checkbox
|
192
|
-
checked={selected.includes(node.key)}
|
193
|
-
onChange={(e) => handleCheckBoxChange(e, node)}
|
194
|
-
/>
|
195
|
-
)}
|
196
|
-
{select === 'radio' && (
|
197
|
-
<RadioButton
|
198
|
-
name={node.title}
|
199
|
-
value={node.key}
|
200
|
-
onChange={(e) => handleCheckBoxChange(e, node)}
|
201
|
-
/>
|
202
|
-
)}
|
203
|
-
|
204
|
-
<Typography className="ff-title-label" fontWeight="medium">
|
205
|
-
{prepareData(node, column)}
|
206
|
-
</Typography>
|
207
|
-
|
208
|
-
{column.actions && (
|
209
|
-
<div className="ff-title-action-container">
|
210
|
-
{column.actions(node)}
|
124
|
+
return (
|
125
|
+
<thead>
|
126
|
+
<tr>
|
127
|
+
{columnsData.map(({ name }) => (
|
128
|
+
<th key={name}>{name}</th>
|
129
|
+
))}
|
130
|
+
</tr>
|
131
|
+
{hasDefaultValues && (
|
132
|
+
<tr>
|
133
|
+
{columnsData.map(({ defaultValue, defaultActions }, index) => (
|
134
|
+
<td key={index}>
|
135
|
+
{defaultValue && (
|
136
|
+
<span className="">
|
137
|
+
{defaultValue}
|
138
|
+
{defaultActions && (
|
139
|
+
<div className="table-tree-row-action">
|
140
|
+
{defaultActions()}
|
211
141
|
</div>
|
212
142
|
)}
|
213
|
-
</
|
214
|
-
|
215
|
-
</td>
|
216
|
-
);
|
217
|
-
} else if (column.accessor) {
|
218
|
-
return (
|
219
|
-
<td key={column.accessor} style={{ maxWidth: column.width }}>
|
220
|
-
{prepareData(node, column)}
|
143
|
+
</span>
|
144
|
+
)}
|
221
145
|
</td>
|
222
|
-
)
|
223
|
-
|
224
|
-
}
|
225
|
-
|
226
|
-
|
227
|
-
|
228
|
-
|
229
|
-
|
230
|
-
|
146
|
+
))}
|
147
|
+
</tr>
|
148
|
+
)}
|
149
|
+
</thead>
|
150
|
+
);
|
151
|
+
});
|
152
|
+
|
153
|
+
// Component: TableBody
|
154
|
+
const TableBody = React.memo(
|
155
|
+
({
|
156
|
+
flattenedTreeData,
|
157
|
+
columnsData,
|
158
|
+
expandedNodes,
|
159
|
+
selected,
|
160
|
+
select,
|
161
|
+
onRowClick,
|
162
|
+
onToggleExpand,
|
163
|
+
onCheckBoxChange,
|
164
|
+
}: {
|
165
|
+
flattenedTreeData: any[];
|
166
|
+
columnsData: any[];
|
167
|
+
expandedNodes: string[];
|
168
|
+
selected: string[];
|
169
|
+
select: string | null;
|
170
|
+
onRowClick: (e: any, node: any) => void;
|
171
|
+
onToggleExpand: (node: any) => void;
|
172
|
+
onCheckBoxChange: (e: any, node: any) => void;
|
173
|
+
}) => (
|
174
|
+
<tbody>
|
175
|
+
{flattenedTreeData.map(({ node, level }) => {
|
176
|
+
const isExpanded = expandedNodes.includes(node.searchKey);
|
231
177
|
return (
|
232
|
-
<
|
233
|
-
key={
|
234
|
-
node={
|
178
|
+
<TableRow
|
179
|
+
key={node.id}
|
180
|
+
node={node}
|
235
181
|
level={level}
|
236
|
-
|
237
|
-
|
182
|
+
columnsData={columnsData}
|
183
|
+
isExpanded={isExpanded}
|
184
|
+
selected={selected}
|
185
|
+
select={select}
|
186
|
+
onRowClick={onRowClick}
|
187
|
+
onToggleExpand={onToggleExpand}
|
188
|
+
onCheckBoxChange={onCheckBoxChange}
|
238
189
|
/>
|
239
190
|
);
|
240
|
-
})
|
241
|
-
|
242
|
-
|
243
|
-
|
244
|
-
<>
|
245
|
-
<tr
|
246
|
-
ref={nodeRef}
|
247
|
-
className={`ff-node-li ${node.children ? 'ff-has-children' : ''} `}
|
248
|
-
style={
|
249
|
-
{
|
250
|
-
'--level': level,
|
251
|
-
'--node-height': `${nodeHeight}px`,
|
252
|
-
'--total-children-height': `${
|
253
|
-
totalChildrenHeight * nodeHeight
|
254
|
-
}px`,
|
255
|
-
} as React.CSSProperties
|
256
|
-
}
|
257
|
-
>
|
258
|
-
{renderRowData(columnsData)}
|
259
|
-
</tr>
|
191
|
+
})}
|
192
|
+
</tbody>
|
193
|
+
)
|
194
|
+
);
|
260
195
|
|
261
|
-
|
262
|
-
|
263
|
-
|
264
|
-
|
265
|
-
|
266
|
-
|
267
|
-
|
268
|
-
|
269
|
-
|
270
|
-
|
271
|
-
|
272
|
-
|
273
|
-
|
274
|
-
|
275
|
-
|
276
|
-
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
|
196
|
+
// Component: TreeTable
|
197
|
+
const TreeTable: React.FC<TreeTableProps> = ({
|
198
|
+
treeData,
|
199
|
+
columnsData,
|
200
|
+
selected = [],
|
201
|
+
select = null,
|
202
|
+
onChange,
|
203
|
+
onClick,
|
204
|
+
expandedNodes = [],
|
205
|
+
onExpand,
|
206
|
+
}) => {
|
207
|
+
const handleToggleExpand = useCallback(
|
208
|
+
(node: any) =>
|
209
|
+
onExpand?.(!expandedNodes.includes(node.searchKey), node.searchKey),
|
210
|
+
[expandedNodes, onExpand]
|
211
|
+
);
|
212
|
+
const handleCheckBoxChange = useCallback(
|
213
|
+
(e: any, node: any) => onChange?.(e, node),
|
214
|
+
[onChange]
|
215
|
+
);
|
216
|
+
const handleRowClick = useCallback(
|
217
|
+
(e: any, node: any) => onClick?.(e, node),
|
218
|
+
[onClick]
|
219
|
+
);
|
281
220
|
|
282
221
|
return (
|
283
|
-
<div className="
|
284
|
-
<table>
|
285
|
-
<
|
286
|
-
|
287
|
-
|
288
|
-
|
289
|
-
|
290
|
-
|
291
|
-
|
292
|
-
|
293
|
-
|
294
|
-
|
295
|
-
|
296
|
-
{column.name}
|
297
|
-
</th>
|
298
|
-
))}
|
299
|
-
</tr>
|
300
|
-
</thead>
|
301
|
-
<tbody>{renderTree(treeData)}</tbody>
|
222
|
+
<div className="tree-table-wrap">
|
223
|
+
<table className="tree-table">
|
224
|
+
<TableHead columnsData={columnsData} />
|
225
|
+
<TableBody
|
226
|
+
flattenedTreeData={treeData}
|
227
|
+
columnsData={columnsData}
|
228
|
+
expandedNodes={expandedNodes}
|
229
|
+
selected={selected}
|
230
|
+
select={select}
|
231
|
+
onRowClick={handleRowClick}
|
232
|
+
onToggleExpand={handleToggleExpand}
|
233
|
+
onCheckBoxChange={handleCheckBoxChange}
|
234
|
+
/>
|
302
235
|
</table>
|
303
236
|
</div>
|
304
237
|
);
|
305
238
|
};
|
306
239
|
|
307
|
-
export default
|
240
|
+
export default TreeTable;
|