@bioturing/components 0.46.4 → 0.48.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/components/base-menu/component.js +19 -21
- package/dist/components/base-menu/component.js.map +1 -1
- package/dist/components/base-menu/index.d.ts +1 -1
- package/dist/components/base-menu/index.d.ts.map +1 -1
- package/dist/components/base-menu/index.js +12 -7
- package/dist/components/base-menu/index.js.map +1 -1
- package/dist/components/base-menu/item.css +1 -1
- package/dist/components/base-menu/item.d.ts +13 -2
- package/dist/components/base-menu/item.d.ts.map +1 -1
- package/dist/components/base-menu/item.js +62 -47
- package/dist/components/base-menu/item.js.map +1 -1
- package/dist/components/base-menu/style.css +1 -1
- package/dist/components/checkbox/component.d.ts +2 -2
- package/dist/components/checkbox/component.d.ts.map +1 -1
- package/dist/components/checkbox/component.js.map +1 -1
- package/dist/components/choice-list/component.js +12 -12
- package/dist/components/combobox/component.d.ts.map +1 -1
- package/dist/components/combobox/component.js +121 -121
- package/dist/components/combobox/component.js.map +1 -1
- package/dist/components/combobox/style.css +1 -1
- package/dist/components/data-table/component.d.ts.map +1 -1
- package/dist/components/data-table/component.js +99 -79
- package/dist/components/data-table/component.js.map +1 -1
- package/dist/components/data-table/components/TableBody.d.ts +3 -2
- package/dist/components/data-table/components/TableBody.d.ts.map +1 -1
- package/dist/components/data-table/components/TableBody.js +106 -89
- package/dist/components/data-table/components/TableBody.js.map +1 -1
- package/dist/components/data-table/components/TableHeader.d.ts +3 -1
- package/dist/components/data-table/components/TableHeader.d.ts.map +1 -1
- package/dist/components/data-table/components/TableHeader.js +121 -93
- package/dist/components/data-table/components/TableHeader.js.map +1 -1
- package/dist/components/data-table/components/TablePagination.d.ts.map +1 -1
- package/dist/components/data-table/components/TablePagination.js +36 -31
- package/dist/components/data-table/components/TablePagination.js.map +1 -1
- package/dist/components/data-table/hooks.d.ts.map +1 -1
- package/dist/components/data-table/hooks.js +98 -83
- package/dist/components/data-table/hooks.js.map +1 -1
- package/dist/components/data-table/style.css +1 -1
- package/dist/components/data-table/types.d.ts +1 -1
- package/dist/components/data-table/types.d.ts.map +1 -1
- package/dist/components/data-table/utils.js +37 -30
- package/dist/components/data-table/utils.js.map +1 -1
- package/dist/components/data-table/variant-minimal.css +1 -0
- package/dist/components/data-table/variant-zebra.css +1 -0
- package/dist/components/dialog/Dialog.js +46 -46
- package/dist/components/dialog/Dialog.js.map +1 -1
- package/dist/components/dialog/dialog.css +1 -1
- package/dist/components/dropdown-menu/component.d.ts.map +1 -1
- package/dist/components/dropdown-menu/component.js +121 -144
- package/dist/components/dropdown-menu/component.js.map +1 -1
- package/dist/components/dropdown-menu/index.d.ts +2 -0
- package/dist/components/dropdown-menu/index.d.ts.map +1 -1
- package/dist/components/dropdown-menu/item.d.ts +7 -15
- package/dist/components/dropdown-menu/item.d.ts.map +1 -1
- package/dist/components/dropdown-menu/item.js +132 -81
- package/dist/components/dropdown-menu/item.js.map +1 -1
- package/dist/components/dropdown-menu/radio-group.d.ts +14 -0
- package/dist/components/dropdown-menu/radio-group.d.ts.map +1 -0
- package/dist/components/dropdown-menu/radio-group.js +45 -0
- package/dist/components/dropdown-menu/radio-group.js.map +1 -0
- package/dist/components/dropdown-menu/search-mode.d.ts +4 -0
- package/dist/components/dropdown-menu/search-mode.d.ts.map +1 -0
- package/dist/components/dropdown-menu/search-mode.js +6 -0
- package/dist/components/dropdown-menu/search-mode.js.map +1 -0
- package/dist/components/dropdown-menu/style.css +1 -1
- package/dist/components/dropdown-menu/submenu.d.ts +25 -0
- package/dist/components/dropdown-menu/submenu.d.ts.map +1 -0
- package/dist/components/dropdown-menu/submenu.js +96 -0
- package/dist/components/dropdown-menu/submenu.js.map +1 -0
- package/dist/components/dropdown-menu/types.d.ts +85 -12
- package/dist/components/dropdown-menu/types.d.ts.map +1 -1
- package/dist/components/dropdown-menu/useDropdownMenu.d.ts +4 -8
- package/dist/components/dropdown-menu/useDropdownMenu.d.ts.map +1 -1
- package/dist/components/dropdown-menu/useDropdownMenu.js +108 -81
- package/dist/components/dropdown-menu/useDropdownMenu.js.map +1 -1
- package/dist/components/form/FormItem/ItemHolder.d.ts +6 -5
- package/dist/components/form/FormItem/ItemHolder.d.ts.map +1 -1
- package/dist/components/form/FormItem/ItemHolder.js +32 -29
- package/dist/components/form/FormItem/ItemHolder.js.map +1 -1
- package/dist/components/form/FormItem/index.d.ts +6 -0
- package/dist/components/form/FormItem/index.d.ts.map +1 -1
- package/dist/components/form/FormItem/index.js +138 -127
- package/dist/components/form/FormItem/index.js.map +1 -1
- package/dist/components/form/FormValidationContext.d.ts +5 -0
- package/dist/components/form/FormValidationContext.d.ts.map +1 -0
- package/dist/components/form/FormValidationContext.js +7 -0
- package/dist/components/form/FormValidationContext.js.map +1 -0
- package/dist/components/form/component.d.ts +6 -1
- package/dist/components/form/component.d.ts.map +1 -1
- package/dist/components/form/component.js +30 -20
- package/dist/components/form/component.js.map +1 -1
- package/dist/components/form/formValidationRule.d.ts +19 -0
- package/dist/components/form/formValidationRule.d.ts.map +1 -0
- package/dist/components/form/formValidationRule.js +22 -0
- package/dist/components/form/formValidationRule.js.map +1 -0
- package/dist/components/form/index.d.ts +2 -0
- package/dist/components/form/index.d.ts.map +1 -1
- package/dist/components/form/useFormValidation.d.ts +3 -0
- package/dist/components/form/useFormValidation.d.ts.map +1 -0
- package/dist/components/form/useFormValidation.js +18 -0
- package/dist/components/form/useFormValidation.js.map +1 -0
- package/dist/components/index.d.ts +2 -0
- package/dist/components/index.d.ts.map +1 -1
- package/dist/components/keyboard-shortcut/component.d.ts +2 -0
- package/dist/components/keyboard-shortcut/component.d.ts.map +1 -1
- package/dist/components/keyboard-shortcut/component.js +69 -49
- package/dist/components/keyboard-shortcut/component.js.map +1 -1
- package/dist/components/modal/Modal.d.ts +1 -1
- package/dist/components/modal/Modal.js +9 -9
- package/dist/components/modal/Modal.js.map +1 -1
- package/dist/components/modal/style.css +1 -1
- package/dist/components/select/component.js +29 -29
- package/dist/components/select/component.js.map +1 -1
- package/dist/components/theme-provider/component.d.ts +3 -1
- package/dist/components/theme-provider/component.d.ts.map +1 -1
- package/dist/components/theme-provider/component.js +32 -31
- package/dist/components/theme-provider/component.js.map +1 -1
- package/dist/components/theme-provider/context/index.d.ts +2 -1
- package/dist/components/theme-provider/context/index.d.ts.map +1 -1
- package/dist/components/theme-provider/context/provider.d.ts +2 -3
- package/dist/components/theme-provider/context/provider.d.ts.map +1 -1
- package/dist/components/theme-provider/context/provider.js +13 -6
- package/dist/components/theme-provider/context/provider.js.map +1 -1
- package/dist/components/theme-provider/context/themeStore.d.ts +15 -0
- package/dist/components/theme-provider/context/themeStore.d.ts.map +1 -1
- package/dist/components/theme-provider/context/themeStore.js +10 -9
- package/dist/components/theme-provider/context/themeStore.js.map +1 -1
- package/dist/components/theme-provider/style.css +1 -1
- package/dist/components/tooltip/component.d.ts.map +1 -1
- package/dist/components/tooltip/component.js +23 -12
- package/dist/components/tooltip/component.js.map +1 -1
- package/dist/index.js +273 -258
- package/dist/index.js.map +1 -1
- package/dist/metadata.d.ts +9 -0
- package/dist/metadata.d.ts.map +1 -1
- package/dist/metadata.js +14 -0
- package/dist/metadata.js.map +1 -1
- package/dist/stats.html +1 -1
- package/package.json +6 -6
|
@@ -1,103 +1,131 @@
|
|
|
1
|
-
import { jsx as
|
|
2
|
-
import { flexRender as
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
const
|
|
1
|
+
import { jsx as e, jsxs as r } from "react/jsx-runtime";
|
|
2
|
+
import { flexRender as R } from "@tanstack/react-table";
|
|
3
|
+
import { CaretUpDownIcon as C, CaretUpIcon as N, CaretDownIcon as k, FunnelIcon as A } from "@bioturing/assets";
|
|
4
|
+
import { convertSelectionToAntFormat as I, getRowKey as T, shouldShowIcons as d, getAlignmentClass as y } from "../utils.js";
|
|
5
|
+
import { useCls as H } from "../../utils/antdUtils.js";
|
|
6
|
+
import { clsx as i } from "../../utils/cn.js";
|
|
7
|
+
import { Checkbox as $ } from "../../checkbox/component.js";
|
|
8
|
+
const W = ({
|
|
9
9
|
table: n,
|
|
10
|
-
rowSelectionConfig:
|
|
10
|
+
rowSelectionConfig: c,
|
|
11
11
|
dataSource: o = [],
|
|
12
|
-
rowKey:
|
|
12
|
+
rowKey: m,
|
|
13
|
+
onHeaderRow: z
|
|
13
14
|
}) => {
|
|
14
|
-
const
|
|
15
|
-
return /* @__PURE__ */
|
|
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
|
-
|
|
15
|
+
const l = H();
|
|
16
|
+
return /* @__PURE__ */ e("thead", { className: l("data-table-thead"), children: n.getHeaderGroups().map((a) => {
|
|
17
|
+
const g = z?.(
|
|
18
|
+
a.headers.map((t) => ({
|
|
19
|
+
...t.column.columnDef.meta,
|
|
20
|
+
key: t.column.id,
|
|
21
|
+
title: t.column.columnDef.header,
|
|
22
|
+
dataIndex: t.column.id
|
|
23
|
+
}))
|
|
24
|
+
);
|
|
25
|
+
return /* @__PURE__ */ e("tr", { ...g, children: a.headers.map((t) => /* @__PURE__ */ r(
|
|
26
|
+
"th",
|
|
27
|
+
{
|
|
28
|
+
...t.id === "select" ? {} : g,
|
|
29
|
+
className: i(
|
|
30
|
+
l("data-table-cell"),
|
|
31
|
+
d(t.column) ? l("data-table-column-has-sorters") : "",
|
|
32
|
+
t.id === "select" ? l("data-table-selection-column") : "",
|
|
33
|
+
t.column.getIsResizing?.() ? l("data-table-cell-resizing") : "",
|
|
34
|
+
y(t.column.columnDef.meta?.align)
|
|
35
|
+
),
|
|
36
|
+
scope: "col",
|
|
37
|
+
style: {
|
|
38
|
+
width: t.id === "select" ? c?.columnWidth || 32 : void 0
|
|
39
|
+
// Width is handled by colgroup and CSS variables for performance
|
|
40
|
+
},
|
|
41
|
+
tabIndex: d(t.column) ? 0 : void 0,
|
|
42
|
+
onClick: t.column.getCanSort() ? t.column.getToggleSortingHandler() : void 0,
|
|
43
|
+
children: [
|
|
44
|
+
t.id === "select" ? (
|
|
45
|
+
// Handle selection column header
|
|
46
|
+
(() => {
|
|
47
|
+
if (c?.type === "radio" || c?.hideSelectAll)
|
|
48
|
+
return c.columnTitle || null;
|
|
49
|
+
const { selectedRowKeys: u } = I(
|
|
50
|
+
n.getState().rowSelection,
|
|
51
|
+
o,
|
|
52
|
+
m
|
|
53
|
+
), b = u.length === o.length && o.length > 0, S = u.length > 0 && u.length < o.length;
|
|
54
|
+
return /* @__PURE__ */ e(
|
|
55
|
+
$,
|
|
56
|
+
{
|
|
57
|
+
checked: b,
|
|
58
|
+
indeterminate: S,
|
|
59
|
+
onChange: (w) => {
|
|
60
|
+
const s = w.target.checked;
|
|
61
|
+
if (c?.onSelectAll) {
|
|
62
|
+
const p = n.getState().rowSelection, { selectedRows: x } = I(
|
|
63
|
+
p,
|
|
64
|
+
o,
|
|
65
|
+
m
|
|
66
|
+
), D = s ? o : [], h = s ? o.filter((F, f) => {
|
|
67
|
+
const v = String(T(o[f], f, m));
|
|
68
|
+
return !p[v];
|
|
69
|
+
}) : x;
|
|
70
|
+
c.onSelectAll(
|
|
71
|
+
s,
|
|
72
|
+
D,
|
|
73
|
+
h
|
|
74
|
+
);
|
|
75
|
+
}
|
|
76
|
+
n.toggleAllRowsSelected(s);
|
|
77
|
+
}
|
|
50
78
|
}
|
|
79
|
+
);
|
|
80
|
+
})()
|
|
81
|
+
) : d(t.column) ? /* @__PURE__ */ r("div", { className: l("data-table-column-sorters"), children: [
|
|
82
|
+
/* @__PURE__ */ e("span", { className: l("data-table-column-title"), children: t.isPlaceholder ? null : R(t.column.columnDef.header, t.getContext()) }),
|
|
83
|
+
/* @__PURE__ */ r("div", { className: l("data-table-column-icons"), children: [
|
|
84
|
+
t.column.getCanSort() && /* @__PURE__ */ e(
|
|
85
|
+
"span",
|
|
86
|
+
{
|
|
87
|
+
className: i(
|
|
88
|
+
l("data-table-column-sort-icon"),
|
|
89
|
+
t.column.getIsSorted() ? `${l("data-table-column-sort-icon")}-${t.column.getIsSorted()}` : `${l("data-table-column-sort-icon")}-none`
|
|
90
|
+
),
|
|
91
|
+
children: t.column.getIsSorted() ? t.column.getIsSorted() === "asc" ? /* @__PURE__ */ e(N, { weight: "fill" }) : /* @__PURE__ */ e(k, { weight: "fill" }) : /* @__PURE__ */ e(C, { weight: "fill" })
|
|
92
|
+
}
|
|
93
|
+
),
|
|
94
|
+
t.column.getCanFilter() && /* @__PURE__ */ e(
|
|
95
|
+
"span",
|
|
96
|
+
{
|
|
97
|
+
className: i(
|
|
98
|
+
l("data-table-column-filter-icon"),
|
|
99
|
+
t.column.getFilterValue() ? l("data-table-column-filter-icon-active") : ""
|
|
100
|
+
),
|
|
101
|
+
children: /* @__PURE__ */ e(A, { weight: "fill" })
|
|
102
|
+
}
|
|
103
|
+
)
|
|
104
|
+
] })
|
|
105
|
+
] }) : /* @__PURE__ */ e("span", { className: l("data-table-column-title"), children: t.isPlaceholder ? null : R(t.column.columnDef.header, t.getContext()) }),
|
|
106
|
+
t.column.getCanResize?.() && /* @__PURE__ */ e(
|
|
107
|
+
"div",
|
|
108
|
+
{
|
|
109
|
+
className: i(
|
|
110
|
+
l("data-table-resize-handle"),
|
|
111
|
+
l(`data-table-resize-${n.options.columnResizeDirection || "ltr"}`),
|
|
112
|
+
t.column.getIsResizing?.() ? l("data-table-resize-handle-active") : ""
|
|
113
|
+
),
|
|
114
|
+
onMouseDown: t.getResizeHandler?.(),
|
|
115
|
+
onTouchStart: t.getResizeHandler?.(),
|
|
116
|
+
onDoubleClick: () => t.column.resetSize(),
|
|
117
|
+
style: {
|
|
118
|
+
transform: n.options.columnResizeMode === "onEnd" && t.column.getIsResizing?.() ? `translateX(${((n.options.columnResizeDirection || "ltr") === "rtl" ? -1 : 1) * (n.getState().columnSizingInfo?.deltaOffset ?? 0)}px)` : ""
|
|
51
119
|
}
|
|
52
|
-
);
|
|
53
|
-
})()
|
|
54
|
-
) : u(l.column) ? /* @__PURE__ */ m("div", { className: e("table-column-sorters"), children: [
|
|
55
|
-
/* @__PURE__ */ t("span", { className: e("table-column-title"), children: l.isPlaceholder ? null : g(l.column.columnDef.header, l.getContext()) }),
|
|
56
|
-
/* @__PURE__ */ m("div", { className: e("table-column-icons"), children: [
|
|
57
|
-
l.column.getCanSort() && /* @__PURE__ */ t(
|
|
58
|
-
"span",
|
|
59
|
-
{
|
|
60
|
-
className: c(
|
|
61
|
-
e("table-column-sort-icon"),
|
|
62
|
-
l.column.getIsSorted() ? `${e("table-column-sort-icon")}-${l.column.getIsSorted()}` : `${e("table-column-sort-icon")}-none`
|
|
63
|
-
),
|
|
64
|
-
children: l.column.getIsSorted() ? l.column.getIsSorted() === "asc" ? /* @__PURE__ */ t(z, { weight: "fill" }) : /* @__PURE__ */ t(b, { weight: "fill" }) : /* @__PURE__ */ t(d, { weight: "fill" })
|
|
65
|
-
}
|
|
66
|
-
),
|
|
67
|
-
l.column.getCanFilter() && /* @__PURE__ */ t(
|
|
68
|
-
"span",
|
|
69
|
-
{
|
|
70
|
-
className: c(
|
|
71
|
-
e("table-column-filter-icon"),
|
|
72
|
-
l.column.getFilterValue() ? e("table-column-filter-icon-active") : ""
|
|
73
|
-
),
|
|
74
|
-
children: /* @__PURE__ */ t(I, { weight: "fill" })
|
|
75
|
-
}
|
|
76
|
-
)
|
|
77
|
-
] })
|
|
78
|
-
] }) : /* @__PURE__ */ t("span", { className: e("table-column-title"), children: l.isPlaceholder ? null : g(l.column.columnDef.header, l.getContext()) }),
|
|
79
|
-
l.column.getCanResize?.() && /* @__PURE__ */ t(
|
|
80
|
-
"div",
|
|
81
|
-
{
|
|
82
|
-
className: c(
|
|
83
|
-
e("table-resize-handle"),
|
|
84
|
-
e(`table-resize-${n.options.columnResizeDirection || "ltr"}`),
|
|
85
|
-
l.column.getIsResizing?.() ? e("table-resize-handle-active") : ""
|
|
86
|
-
),
|
|
87
|
-
onMouseDown: l.getResizeHandler?.(),
|
|
88
|
-
onTouchStart: l.getResizeHandler?.(),
|
|
89
|
-
onDoubleClick: () => l.column.resetSize(),
|
|
90
|
-
style: {
|
|
91
|
-
transform: n.options.columnResizeMode === "onEnd" && l.column.getIsResizing?.() ? `translateX(${((n.options.columnResizeDirection || "ltr") === "rtl" ? -1 : 1) * (n.getState().columnSizingInfo?.deltaOffset ?? 0)}px)` : ""
|
|
92
120
|
}
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
121
|
+
)
|
|
122
|
+
]
|
|
123
|
+
},
|
|
124
|
+
t.id
|
|
125
|
+
)) }, a.id);
|
|
126
|
+
}) });
|
|
99
127
|
};
|
|
100
128
|
export {
|
|
101
|
-
|
|
129
|
+
W as TableHeader
|
|
102
130
|
};
|
|
103
131
|
//# sourceMappingURL=TableHeader.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TableHeader.js","sources":["../../../../src/components/data-table/components/TableHeader.tsx"],"sourcesContent":["import { flexRender, type Table, type Header, type HeaderGroup } from \"@tanstack/react-table\";\nimport { Checkbox, type CheckboxChangeEvent } from \"antd\";\nimport { CaretDownIcon, CaretUpIcon, CaretUpDownIcon, FunnelIcon } from \"@bioturing/assets\";\nimport { clsx, useCls } from \"../../utils\";\nimport { getAlignmentClass, shouldShowIcons } from \"../utils\";\nimport { convertSelectionToAntFormat } from \"../utils\";\nimport { type DataTableRowSelection, type RowKey } from \"../types\";\n\n// Extended meta type for column definitions\ninterface ExtendedColumnMeta {\n align?: 'left' | 'center' | 'right';\n width?: string | number;\n fixed?: 'left' | 'right' | boolean;\n ellipsis?: boolean;\n}\n\ninterface TableHeaderProps<RecordType extends Record<string, any> = Record<string, unknown>> {\n table: Table<RecordType>;\n rowSelectionConfig?: DataTableRowSelection<RecordType>;\n dataSource?: RecordType[];\n rowKey?: RowKey | ((record: RecordType, index?: number) => RowKey);\n}\n\nexport const TableHeader = <RecordType extends Record<string, any> = Record<string, unknown>>({ \n table, \n rowSelectionConfig, \n dataSource = [], \n rowKey \n}: TableHeaderProps<RecordType>) => {\n const cls = useCls();\n\n return (\n <thead className={cls(\"table-thead\")}>\n {table.getHeaderGroups().map((headerGroup: HeaderGroup<RecordType>) => (\n <tr key={headerGroup.id}>\n {headerGroup.headers.map((header: Header<RecordType, unknown>) => (\n <th\n key={header.id}\n className={clsx(\n cls(\"table-cell\"),\n shouldShowIcons(header.column) ? cls(\"table-column-has-sorters\") : \"\",\n header.id === 'select' ? cls(\"table-selection-column\") : \"\",\n header.column.getIsResizing?.() ? cls(\"table-cell-resizing\") : \"\",\n getAlignmentClass((header.column.columnDef.meta as ExtendedColumnMeta)?.align)\n )}\n scope=\"col\"\n style={{\n width: header.id === 'select' \n ? rowSelectionConfig?.columnWidth || 32 \n : undefined // Width is handled by colgroup and CSS variables for performance\n }}\n tabIndex={shouldShowIcons(header.column) ? 0 : undefined}\n onClick={header.column.getCanSort() ? header.column.getToggleSortingHandler() : undefined}\n >\n {header.id === 'select' ? (\n // Handle selection column header\n (() => {\n if (rowSelectionConfig?.type === 'radio') {\n return rowSelectionConfig.columnTitle || null;\n }\n \n const { selectedRowKeys } = convertSelectionToAntFormat(\n table.getState().rowSelection,\n dataSource,\n rowKey\n );\n \n return (\n <Checkbox\n checked={selectedRowKeys.length === dataSource.length && dataSource.length > 0}\n indeterminate={selectedRowKeys.length > 0 && selectedRowKeys.length < dataSource.length}\n onChange={(e: CheckboxChangeEvent) => {\n if (e.target.checked) {\n table.toggleAllRowsSelected(true);\n } else {\n table.toggleAllRowsSelected(false);\n }\n }}\n />\n );\n })()\n ) : shouldShowIcons(header.column) ? (\n <div className={cls(\"table-column-sorters\")}>\n <span className={cls(\"table-column-title\")}>\n {header.isPlaceholder\n ? null\n : flexRender(header.column.columnDef.header, header.getContext())}\n </span>\n <div className={cls(\"table-column-icons\")}>\n {header.column.getCanSort() && (\n <span\n className={clsx(\n cls(\"table-column-sort-icon\"),\n header.column.getIsSorted()\n ? `${cls(\"table-column-sort-icon\")}-${header.column.getIsSorted()}`\n : `${cls(\"table-column-sort-icon\")}-none`\n )}\n >\n {!header.column.getIsSorted() ? (\n <CaretUpDownIcon weight=\"fill\" />\n ) : header.column.getIsSorted() === \"asc\" ? (\n <CaretUpIcon weight=\"fill\" />\n ) : (\n <CaretDownIcon weight=\"fill\" />\n )}\n </span>\n )}\n {header.column.getCanFilter() && (\n <span\n className={clsx(\n cls(\"table-column-filter-icon\"),\n header.column.getFilterValue() ? cls(\"table-column-filter-icon-active\") : \"\"\n )}\n >\n <FunnelIcon weight=\"fill\" />\n </span>\n )}\n </div>\n </div>\n ) : (\n <span className={cls(\"table-column-title\")}>\n {header.isPlaceholder\n ? null\n : flexRender(header.column.columnDef.header, header.getContext())}\n </span>\n )}\n \n {/* Column resize handle */}\n {header.column.getCanResize?.() && (\n <div\n className={clsx(\n cls(\"table-resize-handle\"),\n cls(`table-resize-${table.options.columnResizeDirection || 'ltr'}`),\n header.column.getIsResizing?.() ? cls(\"table-resize-handle-active\") : \"\"\n )}\n onMouseDown={header.getResizeHandler?.()}\n onTouchStart={header.getResizeHandler?.()}\n onDoubleClick={() => header.column.resetSize()}\n style={{\n transform: \n table.options.columnResizeMode === 'onEnd' && header.column.getIsResizing?.()\n ? `translateX(${\n ((table.options.columnResizeDirection || 'ltr') === 'rtl' ? -1 : 1) *\n (table.getState().columnSizingInfo?.deltaOffset ?? 0)\n }px)`\n : '',\n }}\n />\n )}\n </th>\n ))}\n </tr>\n ))}\n </thead>\n );\n};"],"names":["TableHeader","table","rowSelectionConfig","dataSource","rowKey","cls","useCls","headerGroup","jsx","header","jsxs","clsx","shouldShowIcons","getAlignmentClass","selectedRowKeys","convertSelectionToAntFormat","Checkbox","e","flexRender","CaretUpIcon","CaretDownIcon","CaretUpDownIcon","FunnelIcon"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"TableHeader.js","sources":["../../../../src/components/data-table/components/TableHeader.tsx"],"sourcesContent":["import { flexRender, type Table, type Header, type HeaderGroup } from \"@tanstack/react-table\";\nimport { Checkbox, type CheckboxChangeEvent } from \"../../checkbox\";\nimport { CaretDownIcon, CaretUpIcon, CaretUpDownIcon, FunnelIcon } from \"@bioturing/assets\";\nimport { clsx, useCls } from \"../../utils\";\nimport { getAlignmentClass, shouldShowIcons } from \"../utils\";\nimport { convertSelectionToAntFormat } from \"../utils\";\nimport { type DataTableRowSelection, type RowKey } from \"../types\";\nimport { getRowKey } from \"../utils\";\nimport { type TableProps as AntTableProps } from \"antd/es/table\";\n\n// Extended meta type for column definitions\ninterface ExtendedColumnMeta {\n align?: \"left\" | \"center\" | \"right\";\n width?: string | number;\n fixed?: \"left\" | \"right\" | boolean;\n ellipsis?: boolean;\n}\n\ninterface TableHeaderProps<RecordType extends Record<string, any> = Record<string, unknown>> {\n table: Table<RecordType>;\n rowSelectionConfig?: DataTableRowSelection<RecordType>;\n dataSource?: RecordType[];\n rowKey?: RowKey | ((record: RecordType, index?: number) => RowKey);\n onHeaderRow?: AntTableProps<RecordType>['onHeaderRow'];\n}\n\nexport const TableHeader = <RecordType extends Record<string, any> = Record<string, unknown>>({\n table,\n rowSelectionConfig,\n dataSource = [],\n rowKey,\n onHeaderRow,\n}: TableHeaderProps<RecordType>) => {\n const cls = useCls();\n\n return (\n <thead className={cls(\"data-table-thead\")}>\n {table.getHeaderGroups().map((headerGroup: HeaderGroup<RecordType>) => {\n const headerRowProps = onHeaderRow?.(\n headerGroup.headers.map((h) => ({\n ...(h.column.columnDef.meta as Record<string, unknown>),\n key: h.column.id,\n title: h.column.columnDef.header as React.ReactNode,\n dataIndex: h.column.id,\n })) as unknown as Parameters<NonNullable<typeof onHeaderRow>>[0]\n );\n\n return (\n <tr key={headerGroup.id} {...headerRowProps}>\n {headerGroup.headers.map((header: Header<RecordType, unknown>) => (\n <th\n key={header.id}\n {...(header.id === \"select\" ? {} : headerRowProps)}\n className={clsx(\n cls(\"data-table-cell\"),\n shouldShowIcons(header.column) ? cls(\"data-table-column-has-sorters\") : \"\",\n header.id === \"select\" ? cls(\"data-table-selection-column\") : \"\",\n header.column.getIsResizing?.() ? cls(\"data-table-cell-resizing\") : \"\",\n getAlignmentClass((header.column.columnDef.meta as ExtendedColumnMeta)?.align),\n )}\n scope=\"col\"\n style={{\n width: header.id === \"select\" ? rowSelectionConfig?.columnWidth || 32 : undefined, // Width is handled by colgroup and CSS variables for performance\n }}\n tabIndex={shouldShowIcons(header.column) ? 0 : undefined}\n onClick={\n header.column.getCanSort() ? header.column.getToggleSortingHandler() : undefined\n }\n >\n {header.id === \"select\" ? (\n // Handle selection column header\n (() => {\n if (rowSelectionConfig?.type === \"radio\") {\n return rowSelectionConfig.columnTitle || null;\n }\n\n if (rowSelectionConfig?.hideSelectAll) {\n return rowSelectionConfig.columnTitle || null;\n }\n\n const { selectedRowKeys } = convertSelectionToAntFormat(\n table.getState().rowSelection,\n dataSource,\n rowKey,\n );\n\n const isAllSelected = selectedRowKeys.length === dataSource.length && dataSource.length > 0;\n const isIndeterminate = selectedRowKeys.length > 0 && selectedRowKeys.length < dataSource.length;\n\n return (\n <Checkbox\n checked={isAllSelected}\n indeterminate={isIndeterminate}\n onChange={(e: CheckboxChangeEvent) => {\n const checked = e.target.checked;\n\n // Capture current state before toggling for onSelectAll callback\n if (rowSelectionConfig?.onSelectAll) {\n const currentSelection = table.getState().rowSelection;\n const { selectedRows: prevSelectedRows } = convertSelectionToAntFormat(\n currentSelection,\n dataSource,\n rowKey,\n );\n\n const newSelectedRows = checked ? dataSource : [];\n const changeRows = checked\n ? dataSource.filter((_, i) => {\n const key = String(getRowKey(dataSource[i], i, rowKey));\n return !currentSelection[key];\n })\n : prevSelectedRows;\n\n rowSelectionConfig.onSelectAll(\n checked,\n newSelectedRows,\n changeRows,\n );\n }\n\n table.toggleAllRowsSelected(checked);\n }}\n />\n );\n })()\n ) : shouldShowIcons(header.column) ? (\n <div className={cls(\"data-table-column-sorters\")}>\n <span className={cls(\"data-table-column-title\")}>\n {header.isPlaceholder\n ? null\n : flexRender(header.column.columnDef.header, header.getContext())}\n </span>\n <div className={cls(\"data-table-column-icons\")}>\n {header.column.getCanSort() && (\n <span\n className={clsx(\n cls(\"data-table-column-sort-icon\"),\n header.column.getIsSorted()\n ? `${cls(\"data-table-column-sort-icon\")}-${header.column.getIsSorted()}`\n : `${cls(\"data-table-column-sort-icon\")}-none`,\n )}\n >\n {!header.column.getIsSorted() ? (\n <CaretUpDownIcon weight=\"fill\" />\n ) : header.column.getIsSorted() === \"asc\" ? (\n <CaretUpIcon weight=\"fill\" />\n ) : (\n <CaretDownIcon weight=\"fill\" />\n )}\n </span>\n )}\n {header.column.getCanFilter() && (\n <span\n className={clsx(\n cls(\"data-table-column-filter-icon\"),\n header.column.getFilterValue()\n ? cls(\"data-table-column-filter-icon-active\")\n : \"\",\n )}\n >\n <FunnelIcon weight=\"fill\" />\n </span>\n )}\n </div>\n </div>\n ) : (\n <span className={cls(\"data-table-column-title\")}>\n {header.isPlaceholder\n ? null\n : flexRender(header.column.columnDef.header, header.getContext())}\n </span>\n )}\n\n {/* Column resize handle */}\n {header.column.getCanResize?.() && (\n <div\n className={clsx(\n cls(\"data-table-resize-handle\"),\n cls(`data-table-resize-${table.options.columnResizeDirection || \"ltr\"}`),\n header.column.getIsResizing?.() ? cls(\"data-table-resize-handle-active\") : \"\",\n )}\n onMouseDown={header.getResizeHandler?.()}\n onTouchStart={header.getResizeHandler?.()}\n onDoubleClick={() => header.column.resetSize()}\n style={{\n transform:\n table.options.columnResizeMode === \"onEnd\" && header.column.getIsResizing?.()\n ? `translateX(${\n ((table.options.columnResizeDirection || \"ltr\") === \"rtl\" ? -1 : 1) *\n (table.getState().columnSizingInfo?.deltaOffset ?? 0)\n }px)`\n : \"\",\n }}\n />\n )}\n </th>\n ))}\n </tr>\n );})}\n </thead>\n );\n};\n"],"names":["TableHeader","table","rowSelectionConfig","dataSource","rowKey","onHeaderRow","cls","useCls","jsx","headerGroup","headerRowProps","h","header","jsxs","clsx","shouldShowIcons","getAlignmentClass","selectedRowKeys","convertSelectionToAntFormat","isAllSelected","isIndeterminate","Checkbox","e","checked","currentSelection","prevSelectedRows","newSelectedRows","changeRows","_","i","key","getRowKey","flexRender","CaretUpIcon","CaretDownIcon","CaretUpDownIcon","FunnelIcon"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TablePagination.d.ts","sourceRoot":"","sources":["../../../../src/components/data-table/components/TablePagination.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAEnD,OAAO,EAAE,KAAK,yBAAyB,EAAE,MAAM,UAAU,CAAC;AAE1D,UAAU,oBAAoB,
|
|
1
|
+
{"version":3,"file":"TablePagination.d.ts","sourceRoot":"","sources":["../../../../src/components/data-table/components/TablePagination.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAEnD,OAAO,EAAE,KAAK,yBAAyB,EAAE,MAAM,UAAU,CAAC;AAE1D,UAAU,oBAAoB,CAAC,UAAU,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IACzF,KAAK,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;IACzB,gBAAgB,CAAC,EAAE,yBAAyB,CAAC;IAC7C,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,eAAO,MAAM,eAAe,GAAI,UAAU,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,0CAI3F,oBAAoB,CAAC,UAAU,CAAC,4CAgDlC,CAAC"}
|
|
@@ -1,41 +1,46 @@
|
|
|
1
1
|
import { jsx as i } from "react/jsx-runtime";
|
|
2
|
-
import { Pagination as
|
|
3
|
-
import { useCls as
|
|
4
|
-
import { clsx as
|
|
5
|
-
const
|
|
6
|
-
table:
|
|
2
|
+
import { Pagination as m } from "antd";
|
|
3
|
+
import { useCls as u } from "../../utils/antdUtils.js";
|
|
4
|
+
import { clsx as g } from "../../utils/cn.js";
|
|
5
|
+
const f = ({
|
|
6
|
+
table: e,
|
|
7
7
|
paginationConfig: o,
|
|
8
8
|
totalCount: n
|
|
9
9
|
}) => {
|
|
10
|
-
const
|
|
11
|
-
if (!o || !
|
|
12
|
-
const c =
|
|
13
|
-
|
|
14
|
-
|
|
10
|
+
const a = u();
|
|
11
|
+
if (!o || !e.getState().pagination) return null;
|
|
12
|
+
const c = e.getState().pagination.pageIndex + 1, r = e.getState().pagination.pageSize, p = o.position?.[0] || "bottomRight", h = (() => {
|
|
13
|
+
switch (p) {
|
|
14
|
+
case "bottomLeft":
|
|
15
|
+
return a("data-table-pagination-left");
|
|
16
|
+
case "bottomCenter":
|
|
17
|
+
return a("data-table-pagination-center");
|
|
18
|
+
case "bottomRight":
|
|
19
|
+
default:
|
|
20
|
+
return a("data-table-pagination-right");
|
|
21
|
+
}
|
|
22
|
+
})();
|
|
23
|
+
return /* @__PURE__ */ i("div", { className: g(a("data-table-pagination"), h), children: /* @__PURE__ */ i(
|
|
24
|
+
m,
|
|
15
25
|
{
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
onShowSizeChange: (r, e) => {
|
|
31
|
-
t.setPageSize(e), t.setPageIndex(0);
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
)
|
|
26
|
+
...o,
|
|
27
|
+
current: c,
|
|
28
|
+
pageSize: r,
|
|
29
|
+
total: n,
|
|
30
|
+
pageSizeOptions: o.pageSizeOptions,
|
|
31
|
+
showSizeChanger: o.showSizeChanger !== !1,
|
|
32
|
+
showQuickJumper: o.showQuickJumper || !1,
|
|
33
|
+
showTotal: o.showTotal || ((s, t) => `${t[0]}-${t[1]} of ${s} items`),
|
|
34
|
+
onChange: (s, t) => {
|
|
35
|
+
e.setPageIndex(s - 1), t && t !== r && e.setPageSize(t);
|
|
36
|
+
},
|
|
37
|
+
onShowSizeChange: (s, t) => {
|
|
38
|
+
e.setPageSize(t), e.setPageIndex(0);
|
|
39
|
+
}
|
|
35
40
|
}
|
|
36
|
-
);
|
|
41
|
+
) });
|
|
37
42
|
};
|
|
38
43
|
export {
|
|
39
|
-
|
|
44
|
+
f as TablePagination
|
|
40
45
|
};
|
|
41
46
|
//# sourceMappingURL=TablePagination.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TablePagination.js","sources":["../../../../src/components/data-table/components/TablePagination.tsx"],"sourcesContent":["import React from \"react\";\nimport { Pagination } from \"antd\";\nimport { type Table } from \"@tanstack/react-table\";\nimport { clsx, useCls } from \"../../utils\";\nimport { type DataTablePaginationConfig } from \"../types\";\n\ninterface TablePaginationProps
|
|
1
|
+
{"version":3,"file":"TablePagination.js","sources":["../../../../src/components/data-table/components/TablePagination.tsx"],"sourcesContent":["import React from \"react\";\nimport { Pagination } from \"antd\";\nimport { type Table } from \"@tanstack/react-table\";\nimport { clsx, useCls } from \"../../utils\";\nimport { type DataTablePaginationConfig } from \"../types\";\n\ninterface TablePaginationProps<RecordType extends Record<string, any> = Record<string, any>> {\n table: Table<RecordType>;\n paginationConfig?: DataTablePaginationConfig;\n totalCount: number;\n}\n\nexport const TablePagination = <RecordType extends Record<string, any> = Record<string, any>>({\n table,\n paginationConfig,\n totalCount,\n}: TablePaginationProps<RecordType>) => {\n const cls = useCls();\n\n if (!paginationConfig || !table.getState().pagination) return null;\n\n const currentPage = table.getState().pagination.pageIndex + 1;\n const pageSize = table.getState().pagination.pageSize;\n\n const position = paginationConfig.position?.[0] || \"bottomRight\";\n const positionClass = (() => {\n switch (position) {\n case \"bottomLeft\":\n return cls(\"data-table-pagination-left\");\n case \"bottomCenter\":\n return cls(\"data-table-pagination-center\");\n case \"bottomRight\":\n default:\n return cls(\"data-table-pagination-right\");\n }\n })();\n\n return (\n <div className={clsx(cls(\"data-table-pagination\"), positionClass)}>\n <Pagination\n {...paginationConfig}\n current={currentPage}\n pageSize={pageSize}\n total={totalCount}\n pageSizeOptions={paginationConfig.pageSizeOptions}\n showSizeChanger={paginationConfig.showSizeChanger !== false}\n showQuickJumper={paginationConfig.showQuickJumper || false}\n showTotal={\n paginationConfig.showTotal ||\n ((total, range) => `${range[0]}-${range[1]} of ${total} items`)\n }\n onChange={(page, newPageSize) => {\n table.setPageIndex(page - 1);\n if (newPageSize && newPageSize !== pageSize) {\n table.setPageSize(newPageSize);\n }\n }}\n onShowSizeChange={(current, size) => {\n table.setPageSize(size);\n table.setPageIndex(0); // Reset to first page when changing page size\n }}\n />\n </div>\n );\n};\n"],"names":["TablePagination","table","paginationConfig","totalCount","cls","useCls","currentPage","pageSize","position","positionClass","jsx","clsx","Pagination","total","range","page","newPageSize","current","size"],"mappings":";;;;AAYO,MAAMA,IAAkB,CAA+D;AAAA,EAC5F,OAAAC;AAAA,EACA,kBAAAC;AAAA,EACA,YAAAC;AACF,MAAwC;AACtC,QAAMC,IAAMC,EAAA;AAEZ,MAAI,CAACH,KAAoB,CAACD,EAAM,SAAA,EAAW,WAAY,QAAO;AAE9D,QAAMK,IAAcL,EAAM,SAAA,EAAW,WAAW,YAAY,GACtDM,IAAWN,EAAM,SAAA,EAAW,WAAW,UAEvCO,IAAWN,EAAiB,WAAW,CAAC,KAAK,eAC7CO,KAAiB,MAAM;AAC3B,YAAQD,GAAA;AAAA,MACN,KAAK;AACH,eAAOJ,EAAI,4BAA4B;AAAA,MACzC,KAAK;AACH,eAAOA,EAAI,8BAA8B;AAAA,MAC3C,KAAK;AAAA,MACL;AACE,eAAOA,EAAI,6BAA6B;AAAA,IAAA;AAAA,EAE9C,GAAA;AAEA,SACE,gBAAAM,EAAC,SAAI,WAAWC,EAAKP,EAAI,uBAAuB,GAAGK,CAAa,GAC9D,UAAA,gBAAAC;AAAA,IAACE;AAAA,IAAA;AAAA,MACE,GAAGV;AAAA,MACJ,SAASI;AAAA,MACT,UAAAC;AAAA,MACA,OAAOJ;AAAA,MACP,iBAAiBD,EAAiB;AAAA,MAClC,iBAAiBA,EAAiB,oBAAoB;AAAA,MACtD,iBAAiBA,EAAiB,mBAAmB;AAAA,MACrD,WACEA,EAAiB,cAChB,CAACW,GAAOC,MAAU,GAAGA,EAAM,CAAC,CAAC,IAAIA,EAAM,CAAC,CAAC,OAAOD,CAAK;AAAA,MAExD,UAAU,CAACE,GAAMC,MAAgB;AAC/B,QAAAf,EAAM,aAAac,IAAO,CAAC,GACvBC,KAAeA,MAAgBT,KACjCN,EAAM,YAAYe,CAAW;AAAA,MAEjC;AAAA,MACA,kBAAkB,CAACC,GAASC,MAAS;AACnC,QAAAjB,EAAM,YAAYiB,CAAI,GACtBjB,EAAM,aAAa,CAAC;AAAA,MACtB;AAAA,IAAA;AAAA,EAAA,GAEJ;AAEJ;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../src/components/data-table/hooks.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,KAAK,cAAc,EAAuB,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../src/components/data-table/hooks.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,KAAK,cAAc,EAAuB,MAAM,SAAS,CAAC;AAQnE;;GAEG;AACH,wBAAgB,YAAY,CAC1B,UAAU,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAChE,KAAK,EAAE,cAAc,CAAC,UAAU,CAAC;;;;;;;;EA6PlC"}
|
|
@@ -1,64 +1,78 @@
|
|
|
1
|
-
import { useState as
|
|
2
|
-
import { useReactTable as
|
|
3
|
-
import { convertColumnsToTanStack as
|
|
4
|
-
function
|
|
1
|
+
import { useState as F, useMemo as P, useEffect as C } from "react";
|
|
2
|
+
import { useReactTable as T, getPaginationRowModel as v, getFilteredRowModel as I, getSortedRowModel as E, getCoreRowModel as L } from "@tanstack/react-table";
|
|
3
|
+
import { convertSelectionToTanStackFormat as p, convertColumnsToTanStack as k, getRowKey as j, convertSelectionToAntFormat as O } from "./utils.js";
|
|
4
|
+
function N(R) {
|
|
5
5
|
const {
|
|
6
|
-
dataSource:
|
|
7
|
-
columns:
|
|
8
|
-
rowSelection:
|
|
9
|
-
pagination:
|
|
10
|
-
loading:
|
|
11
|
-
enableSorting:
|
|
12
|
-
enableFiltering:
|
|
13
|
-
onSortingChange:
|
|
14
|
-
onFilteringChange:
|
|
6
|
+
dataSource: s = [],
|
|
7
|
+
columns: u = [],
|
|
8
|
+
rowSelection: o,
|
|
9
|
+
pagination: l,
|
|
10
|
+
loading: g,
|
|
11
|
+
enableSorting: d = !0,
|
|
12
|
+
enableFiltering: w = !1,
|
|
13
|
+
onSortingChange: y,
|
|
14
|
+
onFilteringChange: h,
|
|
15
15
|
rowKey: S,
|
|
16
|
-
enableColumnResizing:
|
|
17
|
-
columnResizeMode:
|
|
18
|
-
columnResizeDirection:
|
|
19
|
-
onColumnSizingChange:
|
|
20
|
-
} =
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
16
|
+
enableColumnResizing: f = !1,
|
|
17
|
+
columnResizeMode: z = "onChange",
|
|
18
|
+
columnResizeDirection: b = "ltr",
|
|
19
|
+
onColumnSizingChange: M
|
|
20
|
+
} = R, [i, a] = F(() => {
|
|
21
|
+
const e = o?.selectedRowKeys !== void 0 ? o.selectedRowKeys : o?.defaultSelectedRowKeys;
|
|
22
|
+
return {
|
|
23
|
+
sorting: [],
|
|
24
|
+
filtering: [],
|
|
25
|
+
pagination: {
|
|
26
|
+
pageIndex: 0,
|
|
27
|
+
pageSize: l ? l?.defaultPageSize || l?.pageSize || 10 : s.length
|
|
28
|
+
},
|
|
29
|
+
rowSelection: e ? p(
|
|
30
|
+
e
|
|
31
|
+
) : {},
|
|
32
|
+
columnSizing: {}
|
|
33
|
+
};
|
|
34
|
+
}), K = P(() => {
|
|
35
|
+
let e = k(u);
|
|
36
|
+
return o && (e = [{
|
|
32
37
|
id: "select",
|
|
33
|
-
header: ({ table:
|
|
34
|
-
cell: ({ row:
|
|
35
|
-
size: typeof
|
|
38
|
+
header: ({ table: t }) => o.type === "radio" ? o.columnTitle || null : "SELECTION_HEADER",
|
|
39
|
+
cell: ({ row: t }) => "SELECTION_CELL",
|
|
40
|
+
size: typeof o.columnWidth == "number" ? o.columnWidth : typeof o.columnWidth == "string" && parseFloat(o.columnWidth) || 32,
|
|
36
41
|
enableSorting: !1,
|
|
37
42
|
enableHiding: !1,
|
|
38
43
|
meta: {
|
|
39
|
-
fixed:
|
|
44
|
+
fixed: o.fixed,
|
|
40
45
|
isSelectionColumn: !0
|
|
41
46
|
}
|
|
42
47
|
}, ...e]), e;
|
|
43
|
-
}, [
|
|
44
|
-
|
|
45
|
-
if (
|
|
46
|
-
const e =
|
|
47
|
-
|
|
48
|
-
...
|
|
48
|
+
}, [u, o]);
|
|
49
|
+
C(() => {
|
|
50
|
+
if (l === !1) return;
|
|
51
|
+
const e = i.pagination.pageSize, n = Math.max(0, Math.ceil(s.length / e) - 1);
|
|
52
|
+
i.pagination.pageIndex > n && a((t) => ({
|
|
53
|
+
...t,
|
|
49
54
|
pagination: {
|
|
50
|
-
...
|
|
55
|
+
...t.pagination,
|
|
51
56
|
pageIndex: 0
|
|
52
57
|
}
|
|
53
58
|
}));
|
|
54
|
-
}, [
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
59
|
+
}, [s, l, i.pagination.pageSize, i.pagination.pageIndex]), C(() => {
|
|
60
|
+
if (o?.selectedRowKeys === void 0) return;
|
|
61
|
+
const e = p(
|
|
62
|
+
o.selectedRowKeys
|
|
63
|
+
);
|
|
64
|
+
a((n) => {
|
|
65
|
+
const t = Object.keys(n.rowSelection).filter((c) => n.rowSelection[c]).sort(), r = Object.keys(e).filter((c) => e[c]).sort();
|
|
66
|
+
return t.length === r.length && t.every((c, x) => c === r[x]) ? n : { ...n, rowSelection: e };
|
|
67
|
+
});
|
|
68
|
+
}, [o?.selectedRowKeys, s, S]);
|
|
69
|
+
const m = T({
|
|
70
|
+
data: s,
|
|
71
|
+
columns: K,
|
|
72
|
+
getCoreRowModel: L(),
|
|
73
|
+
getSortedRowModel: d ? E() : void 0,
|
|
74
|
+
getFilteredRowModel: w ? I() : void 0,
|
|
75
|
+
getPaginationRowModel: l !== !1 ? v() : void 0,
|
|
62
76
|
// Default column configuration for sizing
|
|
63
77
|
defaultColumn: {
|
|
64
78
|
size: 150,
|
|
@@ -67,66 +81,67 @@ function A(d) {
|
|
|
67
81
|
},
|
|
68
82
|
// State management
|
|
69
83
|
state: {
|
|
70
|
-
sorting:
|
|
71
|
-
columnFilters:
|
|
72
|
-
pagination:
|
|
73
|
-
rowSelection:
|
|
74
|
-
columnSizing:
|
|
84
|
+
sorting: i.sorting,
|
|
85
|
+
columnFilters: i.filtering,
|
|
86
|
+
pagination: i.pagination,
|
|
87
|
+
rowSelection: i.rowSelection,
|
|
88
|
+
columnSizing: f ? i.columnSizing : void 0
|
|
75
89
|
},
|
|
76
90
|
// State update handlers
|
|
77
91
|
onSortingChange: (e) => {
|
|
78
|
-
const n = typeof e == "function" ? e(
|
|
79
|
-
|
|
92
|
+
const n = typeof e == "function" ? e(i.sorting) : e;
|
|
93
|
+
a((t) => ({ ...t, sorting: n })), y?.(n);
|
|
80
94
|
},
|
|
81
95
|
onColumnFiltersChange: (e) => {
|
|
82
|
-
const n = typeof e == "function" ? e(
|
|
83
|
-
|
|
96
|
+
const n = typeof e == "function" ? e(i.filtering) : e;
|
|
97
|
+
a((t) => ({ ...t, filtering: n })), h?.(n);
|
|
84
98
|
},
|
|
85
99
|
onPaginationChange: (e) => {
|
|
86
|
-
if (
|
|
87
|
-
const n = typeof e == "function" ? e(
|
|
88
|
-
|
|
100
|
+
if (l === !1) return;
|
|
101
|
+
const n = typeof e == "function" ? e(i.pagination) : e;
|
|
102
|
+
a((t) => ({ ...t, pagination: n }));
|
|
89
103
|
},
|
|
90
104
|
onRowSelectionChange: (e) => {
|
|
91
|
-
const n = typeof e == "function" ? e(
|
|
92
|
-
if (
|
|
93
|
-
const { selectedRowKeys:
|
|
105
|
+
const n = typeof e == "function" ? e(i.rowSelection) : e;
|
|
106
|
+
if (a((t) => ({ ...t, rowSelection: n })), o?.onChange) {
|
|
107
|
+
const { selectedRowKeys: t, selectedRows: r } = O(
|
|
94
108
|
n,
|
|
95
|
-
|
|
109
|
+
s,
|
|
96
110
|
S
|
|
97
111
|
);
|
|
98
|
-
|
|
112
|
+
o.onChange(t, r);
|
|
99
113
|
}
|
|
100
114
|
},
|
|
101
|
-
onColumnSizingChange:
|
|
102
|
-
const n = typeof e == "function" ? e(
|
|
103
|
-
|
|
104
|
-
...
|
|
115
|
+
onColumnSizingChange: f ? (e) => {
|
|
116
|
+
const n = typeof e == "function" ? e(i.columnSizing) : e;
|
|
117
|
+
a((t) => ({
|
|
118
|
+
...t,
|
|
105
119
|
columnSizing: n
|
|
106
|
-
})),
|
|
120
|
+
})), M?.(n);
|
|
107
121
|
} : void 0,
|
|
108
122
|
// Feature enables
|
|
109
|
-
enableSorting:
|
|
110
|
-
enableFilters:
|
|
111
|
-
enableRowSelection: !!
|
|
112
|
-
|
|
123
|
+
enableSorting: d,
|
|
124
|
+
enableFilters: w,
|
|
125
|
+
enableRowSelection: !!o,
|
|
126
|
+
enableMultiRowSelection: o?.type !== "radio",
|
|
127
|
+
enableColumnResizing: f,
|
|
113
128
|
// Column resizing configuration
|
|
114
|
-
columnResizeMode:
|
|
115
|
-
columnResizeDirection:
|
|
129
|
+
columnResizeMode: z,
|
|
130
|
+
columnResizeDirection: b,
|
|
116
131
|
// Row identification
|
|
117
|
-
getRowId: (e, n) => String(
|
|
132
|
+
getRowId: (e, n) => String(j(e, n, S))
|
|
118
133
|
});
|
|
119
134
|
return {
|
|
120
135
|
table: m,
|
|
121
|
-
isLoading: typeof
|
|
122
|
-
spinProps: typeof
|
|
123
|
-
hasRowSelection: !!
|
|
136
|
+
isLoading: typeof g == "boolean" ? g : typeof g == "object",
|
|
137
|
+
spinProps: typeof g == "object" ? g : {},
|
|
138
|
+
hasRowSelection: !!o,
|
|
124
139
|
hasPagination: m.getPageCount() > 1,
|
|
125
|
-
paginationConfig:
|
|
126
|
-
rowSelectionConfig:
|
|
140
|
+
paginationConfig: l === !1 ? void 0 : l,
|
|
141
|
+
rowSelectionConfig: o
|
|
127
142
|
};
|
|
128
143
|
}
|
|
129
144
|
export {
|
|
130
|
-
|
|
145
|
+
N as useDataTable
|
|
131
146
|
};
|
|
132
147
|
//# sourceMappingURL=hooks.js.map
|