@bioturing/components 0.46.4 → 0.47.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.
Files changed (95) hide show
  1. package/dist/components/base-menu/component.js +19 -21
  2. package/dist/components/base-menu/component.js.map +1 -1
  3. package/dist/components/base-menu/index.js +12 -7
  4. package/dist/components/base-menu/index.js.map +1 -1
  5. package/dist/components/checkbox/component.d.ts +2 -2
  6. package/dist/components/checkbox/component.d.ts.map +1 -1
  7. package/dist/components/checkbox/component.js.map +1 -1
  8. package/dist/components/choice-list/component.js +12 -12
  9. package/dist/components/data-table/component.d.ts.map +1 -1
  10. package/dist/components/data-table/component.js +73 -64
  11. package/dist/components/data-table/component.js.map +1 -1
  12. package/dist/components/data-table/components/TableBody.d.ts +1 -1
  13. package/dist/components/data-table/components/TableBody.d.ts.map +1 -1
  14. package/dist/components/data-table/components/TableBody.js +62 -53
  15. package/dist/components/data-table/components/TableBody.js.map +1 -1
  16. package/dist/components/data-table/components/TableHeader.d.ts +1 -1
  17. package/dist/components/data-table/components/TableHeader.d.ts.map +1 -1
  18. package/dist/components/data-table/components/TableHeader.js +46 -46
  19. package/dist/components/data-table/components/TableHeader.js.map +1 -1
  20. package/dist/components/data-table/components/TablePagination.d.ts.map +1 -1
  21. package/dist/components/data-table/components/TablePagination.js +22 -28
  22. package/dist/components/data-table/components/TablePagination.js.map +1 -1
  23. package/dist/components/data-table/hooks.d.ts.map +1 -1
  24. package/dist/components/data-table/hooks.js +15 -14
  25. package/dist/components/data-table/hooks.js.map +1 -1
  26. package/dist/components/data-table/style.css +1 -1
  27. package/dist/components/data-table/types.d.ts +1 -1
  28. package/dist/components/data-table/types.d.ts.map +1 -1
  29. package/dist/components/data-table/variant-minimal.css +1 -0
  30. package/dist/components/data-table/variant-zebra.css +1 -0
  31. package/dist/components/dialog/Dialog.js +46 -46
  32. package/dist/components/dialog/Dialog.js.map +1 -1
  33. package/dist/components/dialog/dialog.css +1 -1
  34. package/dist/components/form/FormItem/ItemHolder.d.ts +6 -5
  35. package/dist/components/form/FormItem/ItemHolder.d.ts.map +1 -1
  36. package/dist/components/form/FormItem/ItemHolder.js +32 -29
  37. package/dist/components/form/FormItem/ItemHolder.js.map +1 -1
  38. package/dist/components/form/FormItem/index.d.ts +6 -0
  39. package/dist/components/form/FormItem/index.d.ts.map +1 -1
  40. package/dist/components/form/FormItem/index.js +138 -127
  41. package/dist/components/form/FormItem/index.js.map +1 -1
  42. package/dist/components/form/FormValidationContext.d.ts +5 -0
  43. package/dist/components/form/FormValidationContext.d.ts.map +1 -0
  44. package/dist/components/form/FormValidationContext.js +7 -0
  45. package/dist/components/form/FormValidationContext.js.map +1 -0
  46. package/dist/components/form/component.d.ts +6 -1
  47. package/dist/components/form/component.d.ts.map +1 -1
  48. package/dist/components/form/component.js +30 -20
  49. package/dist/components/form/component.js.map +1 -1
  50. package/dist/components/form/formValidationRule.d.ts +19 -0
  51. package/dist/components/form/formValidationRule.d.ts.map +1 -0
  52. package/dist/components/form/formValidationRule.js +22 -0
  53. package/dist/components/form/formValidationRule.js.map +1 -0
  54. package/dist/components/form/index.d.ts +2 -0
  55. package/dist/components/form/index.d.ts.map +1 -1
  56. package/dist/components/form/useFormValidation.d.ts +3 -0
  57. package/dist/components/form/useFormValidation.d.ts.map +1 -0
  58. package/dist/components/form/useFormValidation.js +18 -0
  59. package/dist/components/form/useFormValidation.js.map +1 -0
  60. package/dist/components/index.d.ts +2 -0
  61. package/dist/components/index.d.ts.map +1 -1
  62. package/dist/components/keyboard-shortcut/component.d.ts +2 -0
  63. package/dist/components/keyboard-shortcut/component.d.ts.map +1 -1
  64. package/dist/components/keyboard-shortcut/component.js +69 -49
  65. package/dist/components/keyboard-shortcut/component.js.map +1 -1
  66. package/dist/components/modal/Modal.d.ts +1 -1
  67. package/dist/components/modal/Modal.js +9 -9
  68. package/dist/components/modal/Modal.js.map +1 -1
  69. package/dist/components/modal/style.css +1 -1
  70. package/dist/components/theme-provider/component.d.ts +3 -1
  71. package/dist/components/theme-provider/component.d.ts.map +1 -1
  72. package/dist/components/theme-provider/component.js +32 -31
  73. package/dist/components/theme-provider/component.js.map +1 -1
  74. package/dist/components/theme-provider/context/index.d.ts +2 -1
  75. package/dist/components/theme-provider/context/index.d.ts.map +1 -1
  76. package/dist/components/theme-provider/context/provider.d.ts +2 -3
  77. package/dist/components/theme-provider/context/provider.d.ts.map +1 -1
  78. package/dist/components/theme-provider/context/provider.js +13 -6
  79. package/dist/components/theme-provider/context/provider.js.map +1 -1
  80. package/dist/components/theme-provider/context/themeStore.d.ts +15 -0
  81. package/dist/components/theme-provider/context/themeStore.d.ts.map +1 -1
  82. package/dist/components/theme-provider/context/themeStore.js +10 -9
  83. package/dist/components/theme-provider/context/themeStore.js.map +1 -1
  84. package/dist/components/theme-provider/style.css +1 -1
  85. package/dist/components/tooltip/component.d.ts.map +1 -1
  86. package/dist/components/tooltip/component.js +23 -12
  87. package/dist/components/tooltip/component.js.map +1 -1
  88. package/dist/index.js +286 -275
  89. package/dist/index.js.map +1 -1
  90. package/dist/metadata.d.ts +9 -0
  91. package/dist/metadata.d.ts.map +1 -1
  92. package/dist/metadata.js +14 -0
  93. package/dist/metadata.js.map +1 -1
  94. package/dist/stats.html +1 -1
  95. package/package.json +6 -6
@@ -1,101 +1,110 @@
1
- import { jsxs as x, jsx as t } from "react/jsx-runtime";
1
+ import { jsxs as x, jsx as a } from "react/jsx-runtime";
2
2
  import { flexRender as f } from "@tanstack/react-table";
3
- import { Checkbox as k } from "antd";
4
- import { convertSelectionToAntFormat as h, getAlignmentClass as w } from "../utils.js";
3
+ import { convertSelectionToAntFormat as h, getAlignmentClass as k } from "../utils.js";
5
4
  import { Empty as S } from "../../empty/component.js";
6
- import { useCls as y } from "../../utils/antdUtils.js";
5
+ import { Radio as w } from "../../radio/component.js";
6
+ import { useCls as v } from "../../utils/antdUtils.js";
7
7
  import { clsx as g } from "../../utils/cn.js";
8
- const j = ({
8
+ import { Checkbox as y } from "../../checkbox/component.js";
9
+ const G = ({
9
10
  table: c,
10
- dataSource: a,
11
+ dataSource: l,
11
12
  emptyDescription: p,
12
- hasRowSelection: b,
13
- onRowClick: u,
14
- rowSelectionConfig: s,
15
- rowKey: m
13
+ hasRowSelection: u,
14
+ onRowClick: b,
15
+ rowSelectionConfig: r,
16
+ rowKey: i
16
17
  }) => {
17
- const d = y();
18
- return /* @__PURE__ */ x("tbody", { className: d("table-tbody"), children: [
19
- /* @__PURE__ */ t(
18
+ const t = v();
19
+ return /* @__PURE__ */ x("tbody", { className: t("data-table-tbody"), children: [
20
+ /* @__PURE__ */ a(
20
21
  "tr",
21
22
  {
22
23
  "aria-hidden": "true",
23
- className: d("table-measure-row"),
24
+ className: t("data-table-measure-row"),
24
25
  style: { height: "0px", fontSize: "0px" },
25
- children: c.getHeaderGroups()[0]?.headers.map((o) => /* @__PURE__ */ t(
26
+ children: c.getHeaderGroups()[0]?.headers.map((d) => /* @__PURE__ */ a(
26
27
  "td",
27
28
  {
29
+ className: t("data-table-measure-cell"),
28
30
  style: {
29
31
  padding: "0px",
30
32
  border: "0px",
31
33
  height: "0px",
32
- width: o.id === "select" ? 32 : o.column.columnDef.meta?.width
34
+ width: d.id === "select" ? 32 : d.column.columnDef.meta?.width
33
35
  },
34
- children: /* @__PURE__ */ t("div", { style: { height: "0px", overflow: "hidden" }, children: " " })
36
+ children: /* @__PURE__ */ a("div", { className: t("data-table-measure-cell-content"), children: " " })
35
37
  },
36
- o.id
38
+ d.id
37
39
  ))
38
40
  }
39
41
  ),
40
- a.length === 0 ? /* @__PURE__ */ t("tr", { children: /* @__PURE__ */ t("td", { colSpan: c.getHeaderGroups()[0]?.headers.length || 1, children: /* @__PURE__ */ t(S, { description: p }) }) }) : c.getRowModel().rows.map((o) => /* @__PURE__ */ t(
42
+ l.length === 0 ? /* @__PURE__ */ a("tr", { className: t("data-table-placeholder"), children: /* @__PURE__ */ a("td", { colSpan: c.getHeaderGroups()[0]?.headers.length || 1, children: /* @__PURE__ */ a(S, { description: p }) }) }) : c.getRowModel().rows.map((d) => /* @__PURE__ */ a(
41
43
  "tr",
42
44
  {
43
45
  className: g(
44
- d("table-row"),
45
- d("table-row-level-0"),
46
- o.getIsSelected() ? d("table-row-selected") : ""
46
+ t("data-table-row"),
47
+ t("data-table-row-level-0"),
48
+ d.getIsSelected() ? t("data-table-row-selected") : ""
47
49
  ),
48
- "data-row-key": o.id,
49
- "data-selectable": b ? "true" : "false",
50
- onClick: () => u?.(o),
51
- children: o.getVisibleCells().map((e) => /* @__PURE__ */ t(
50
+ "data-row-key": d.id,
51
+ "data-selectable": u ? "true" : "false",
52
+ onClick: () => b?.(d),
53
+ children: d.getVisibleCells().map((e) => /* @__PURE__ */ a(
52
54
  "td",
53
55
  {
54
56
  className: g(
55
- d("table-cell"),
56
- e.column.id === "select" ? d("table-selection-column") : "",
57
- w(e.column.columnDef.meta?.align)
57
+ t("data-table-cell"),
58
+ e.column.id === "select" ? t("data-table-selection-column") : "",
59
+ k(e.column.columnDef.meta?.align)
58
60
  ),
59
61
  children: e.column.id === "select" ? (
60
62
  // Handle selection column cells
61
63
  (() => {
62
- const l = e.row.original, n = s?.getCheckboxProps?.(l) || {};
63
- return s?.type === "radio" ? /* @__PURE__ */ t(
64
- "input",
64
+ const s = e.row.original, m = r?.getCheckboxProps?.(s) || {};
65
+ return r?.type === "radio" ? /* @__PURE__ */ a(
66
+ w,
65
67
  {
66
- type: "radio",
67
- name: "table-radio",
68
68
  checked: e.row.getIsSelected(),
69
69
  disabled: !e.row.getCanSelect(),
70
- onChange: (r) => {
71
- if (e.row.toggleSelected(r.target.checked), s.onSelect) {
72
- const { selectedRows: i } = h(
70
+ onChange: (o) => {
71
+ if (e.row.toggleSelected(o.target.checked), r.onSelect) {
72
+ const { selectedRows: n } = h(
73
73
  c.getState().rowSelection,
74
- a,
75
- m
74
+ l,
75
+ i
76
+ );
77
+ r.onSelect(
78
+ s,
79
+ o.target.checked,
80
+ n,
81
+ o.nativeEvent
76
82
  );
77
- s.onSelect(l, r.target.checked, i, r.nativeEvent);
78
83
  }
79
84
  },
80
- disabled: n.disabled,
81
- className: n.className
85
+ ...m
82
86
  }
83
- ) : /* @__PURE__ */ t(
84
- k,
87
+ ) : /* @__PURE__ */ a(
88
+ y,
85
89
  {
86
90
  checked: e.row.getIsSelected(),
87
91
  disabled: !e.row.getCanSelect(),
88
- onChange: (r) => {
89
- if (e.row.toggleSelected(r.target.checked), s?.onSelect) {
90
- const { selectedRows: i } = h(
92
+ onChange: (o) => {
93
+ if (e.row.toggleSelected(o.target.checked), r?.onSelect) {
94
+ const { selectedRows: n } = h(
91
95
  c.getState().rowSelection,
92
- a,
93
- m
96
+ l,
97
+ i
98
+ );
99
+ r.onSelect(
100
+ s,
101
+ o.target.checked,
102
+ n,
103
+ o.nativeEvent
94
104
  );
95
- s.onSelect(l, r.target.checked, i, r.nativeEvent);
96
105
  }
97
106
  },
98
- ...n
107
+ ...m
99
108
  }
100
109
  );
101
110
  })()
@@ -104,11 +113,11 @@ const j = ({
104
113
  e.id
105
114
  ))
106
115
  },
107
- o.id
116
+ d.id
108
117
  ))
109
118
  ] });
110
119
  };
111
120
  export {
112
- j as TableBody
121
+ G as TableBody
113
122
  };
114
123
  //# sourceMappingURL=TableBody.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TableBody.js","sources":["../../../../src/components/data-table/components/TableBody.tsx"],"sourcesContent":["import React from \"react\";\nimport { flexRender, type Table, type Row, type Cell, type Header } from \"@tanstack/react-table\";\nimport { Checkbox, type CheckboxChangeEvent } from \"antd\";\nimport { clsx, useCls } from \"../../utils\";\nimport { getAlignmentClass } from \"../utils\";\nimport { convertSelectionToAntFormat } from \"../utils\";\nimport { type DataTableRowSelection, type RowKey } from \"../types\";\nimport Empty from \"../../empty/component\";\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 TableBodyProps<RecordType extends Record<string, any> = Record<string, unknown>> {\n table: Table<RecordType>;\n dataSource: RecordType[];\n emptyDescription?: React.ReactNode;\n hasRowSelection?: boolean;\n onRowClick?: (row: Row<RecordType>) => void;\n rowSelectionConfig?: DataTableRowSelection<RecordType>;\n rowKey?: RowKey | ((record: RecordType, index?: number) => RowKey);\n}\n\nexport const TableBody = <RecordType extends Record<string, any> = Record<string, unknown>>({ \n table, \n dataSource, \n emptyDescription, \n hasRowSelection, \n onRowClick,\n rowSelectionConfig,\n rowKey\n}: TableBodyProps<RecordType>) => {\n const cls = useCls();\n\n return (\n <tbody className={cls(\"table-tbody\")}>\n {/* Measure row for Ant Design compatibility */}\n <tr \n aria-hidden=\"true\" \n className={cls(\"table-measure-row\")}\n style={{ height: \"0px\", fontSize: \"0px\" }}\n >\n {table.getHeaderGroups()[0]?.headers.map((header: Header<RecordType, unknown>) => (\n <td \n key={header.id}\n style={{ \n padding: \"0px\", \n border: \"0px\", \n height: \"0px\",\n width: header.id === 'select' ? 32 : (header.column.columnDef.meta as ExtendedColumnMeta)?.width\n }}\n >\n <div style={{ height: \"0px\", overflow: \"hidden\" }}>\n &nbsp;\n </div>\n </td>\n ))}\n </tr>\n \n {dataSource.length === 0 ? (\n <tr>\n <td colSpan={table.getHeaderGroups()[0]?.headers.length || 1}>\n <Empty description={emptyDescription} />\n </td>\n </tr>\n ) : (\n table.getRowModel().rows.map((row: Row<RecordType>) => (\n <tr\n key={row.id}\n className={clsx(\n cls(\"table-row\"),\n cls(\"table-row-level-0\"),\n row.getIsSelected() ? cls(\"table-row-selected\") : \"\"\n )}\n data-row-key={row.id}\n data-selectable={hasRowSelection ? \"true\" : \"false\"}\n onClick={() => onRowClick?.(row)}\n >\n {row.getVisibleCells().map((cell: Cell<RecordType, unknown>) => (\n <td \n key={cell.id} \n className={clsx(\n cls(\"table-cell\"),\n cell.column.id === 'select' ? cls(\"table-selection-column\") : \"\",\n getAlignmentClass((cell.column.columnDef.meta as ExtendedColumnMeta)?.align)\n )}\n >\n {cell.column.id === 'select' ? (\n // Handle selection column cells\n (() => {\n const record = cell.row.original;\n const checkboxProps = rowSelectionConfig?.getCheckboxProps?.(record) || {};\n \n if (rowSelectionConfig?.type === 'radio') {\n return (\n <input\n type=\"radio\"\n name=\"table-radio\"\n checked={cell.row.getIsSelected()}\n disabled={!cell.row.getCanSelect()}\n onChange={(e: React.ChangeEvent<HTMLInputElement>) => {\n cell.row.toggleSelected(e.target.checked);\n if (rowSelectionConfig.onSelect) {\n const { selectedRows } = convertSelectionToAntFormat(\n table.getState().rowSelection,\n dataSource,\n rowKey\n );\n rowSelectionConfig.onSelect(record, e.target.checked, selectedRows, e.nativeEvent);\n }\n }}\n {...({ disabled: checkboxProps.disabled, className: checkboxProps.className } as React.InputHTMLAttributes<HTMLInputElement>)}\n />\n );\n }\n \n return (\n <Checkbox\n checked={cell.row.getIsSelected()}\n disabled={!cell.row.getCanSelect()}\n onChange={(e: CheckboxChangeEvent) => {\n cell.row.toggleSelected(e.target.checked);\n if (rowSelectionConfig?.onSelect) {\n const { selectedRows } = convertSelectionToAntFormat(\n table.getState().rowSelection,\n dataSource,\n rowKey\n );\n rowSelectionConfig.onSelect(record, e.target.checked, selectedRows, e.nativeEvent);\n }\n }}\n {...checkboxProps}\n />\n );\n })()\n ) : (\n flexRender(cell.column.columnDef.cell, cell.getContext())\n )}\n </td>\n ))}\n </tr>\n ))\n )}\n </tbody>\n );\n};"],"names":["TableBody","table","dataSource","emptyDescription","hasRowSelection","onRowClick","rowSelectionConfig","rowKey","cls","useCls","jsxs","jsx","header","Empty","row","clsx","cell","getAlignmentClass","record","checkboxProps","e","selectedRows","convertSelectionToAntFormat","Checkbox","flexRender"],"mappings":"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"}
1
+ {"version":3,"file":"TableBody.js","sources":["../../../../src/components/data-table/components/TableBody.tsx"],"sourcesContent":["import React from \"react\";\nimport { flexRender, type Table, type Row, type Cell, type Header } from \"@tanstack/react-table\";\nimport { Checkbox, type CheckboxChangeEvent } from \"../../checkbox\";\nimport { Radio, type RadioChangeEvent } from \"../../radio\";\nimport { clsx, useCls } from \"../../utils\";\nimport { getAlignmentClass } from \"../utils\";\nimport { convertSelectionToAntFormat } from \"../utils\";\nimport { type DataTableRowSelection, type RowKey } from \"../types\";\nimport Empty from \"../../empty/component\";\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 TableBodyProps<RecordType extends Record<string, any> = Record<string, unknown>> {\n table: Table<RecordType>;\n dataSource: RecordType[];\n emptyDescription?: React.ReactNode;\n hasRowSelection?: boolean;\n onRowClick?: (row: Row<RecordType>) => void;\n rowSelectionConfig?: DataTableRowSelection<RecordType>;\n rowKey?: RowKey | ((record: RecordType, index?: number) => RowKey);\n}\n\nexport const TableBody = <RecordType extends Record<string, any> = Record<string, unknown>>({\n table,\n dataSource,\n emptyDescription,\n hasRowSelection,\n onRowClick,\n rowSelectionConfig,\n rowKey,\n}: TableBodyProps<RecordType>) => {\n const cls = useCls();\n\n return (\n <tbody className={cls(\"data-table-tbody\")}>\n {/* Measure row for Ant Design compatibility */}\n <tr\n aria-hidden=\"true\"\n className={cls(\"data-table-measure-row\")}\n style={{ height: \"0px\", fontSize: \"0px\" }}\n >\n {table.getHeaderGroups()[0]?.headers.map((header: Header<RecordType, unknown>) => (\n <td\n key={header.id}\n className={cls(\"data-table-measure-cell\")}\n style={{\n padding: \"0px\",\n border: \"0px\",\n height: \"0px\",\n width:\n header.id === \"select\"\n ? 32\n : (header.column.columnDef.meta as ExtendedColumnMeta)?.width,\n }}\n >\n <div className={cls(\"data-table-measure-cell-content\")}>&nbsp;</div>\n </td>\n ))}\n </tr>\n\n {dataSource.length === 0 ? (\n <tr className={cls(\"data-table-placeholder\")}>\n <td colSpan={table.getHeaderGroups()[0]?.headers.length || 1}>\n <Empty description={emptyDescription} />\n </td>\n </tr>\n ) : (\n table.getRowModel().rows.map((row: Row<RecordType>) => (\n <tr\n key={row.id}\n className={clsx(\n cls(\"data-table-row\"),\n cls(\"data-table-row-level-0\"),\n row.getIsSelected() ? cls(\"data-table-row-selected\") : \"\",\n )}\n data-row-key={row.id}\n data-selectable={hasRowSelection ? \"true\" : \"false\"}\n onClick={() => onRowClick?.(row)}\n >\n {row.getVisibleCells().map((cell: Cell<RecordType, unknown>) => (\n <td\n key={cell.id}\n className={clsx(\n cls(\"data-table-cell\"),\n cell.column.id === \"select\" ? cls(\"data-table-selection-column\") : \"\",\n getAlignmentClass((cell.column.columnDef.meta as ExtendedColumnMeta)?.align),\n )}\n >\n {cell.column.id === \"select\"\n ? // Handle selection column cells\n (() => {\n const record = cell.row.original;\n const checkboxProps = rowSelectionConfig?.getCheckboxProps?.(record) || {};\n\n if (rowSelectionConfig?.type === \"radio\") {\n return (\n <Radio\n checked={cell.row.getIsSelected()}\n disabled={!cell.row.getCanSelect()}\n onChange={(e: RadioChangeEvent) => {\n cell.row.toggleSelected(e.target.checked);\n if (rowSelectionConfig.onSelect) {\n const { selectedRows } = convertSelectionToAntFormat(\n table.getState().rowSelection,\n dataSource,\n rowKey,\n );\n rowSelectionConfig.onSelect(\n record,\n e.target.checked,\n selectedRows,\n e.nativeEvent,\n );\n }\n }}\n {...checkboxProps}\n />\n );\n }\n\n return (\n <Checkbox\n checked={cell.row.getIsSelected()}\n disabled={!cell.row.getCanSelect()}\n onChange={(e: CheckboxChangeEvent) => {\n cell.row.toggleSelected(e.target.checked);\n if (rowSelectionConfig?.onSelect) {\n const { selectedRows } = convertSelectionToAntFormat(\n table.getState().rowSelection,\n dataSource,\n rowKey,\n );\n rowSelectionConfig.onSelect(\n record,\n e.target.checked,\n selectedRows,\n e.nativeEvent,\n );\n }\n }}\n {...checkboxProps}\n />\n );\n })()\n : flexRender(cell.column.columnDef.cell, cell.getContext())}\n </td>\n ))}\n </tr>\n ))\n )}\n </tbody>\n );\n};\n"],"names":["TableBody","table","dataSource","emptyDescription","hasRowSelection","onRowClick","rowSelectionConfig","rowKey","cls","useCls","jsxs","jsx","header","Empty","row","clsx","cell","getAlignmentClass","record","checkboxProps","Radio","e","selectedRows","convertSelectionToAntFormat","Checkbox","flexRender"],"mappings":";;;;;;;;AA4BO,MAAMA,IAAY,CAAmE;AAAA,EAC1F,OAAAC;AAAA,EACA,YAAAC;AAAA,EACA,kBAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,YAAAC;AAAA,EACA,oBAAAC;AAAA,EACA,QAAAC;AACF,MAAkC;AAChC,QAAMC,IAAMC,EAAA;AAEZ,SACE,gBAAAC,EAAC,SAAA,EAAM,WAAWF,EAAI,kBAAkB,GAEtC,UAAA;AAAA,IAAA,gBAAAG;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,eAAY;AAAA,QACZ,WAAWH,EAAI,wBAAwB;AAAA,QACvC,OAAO,EAAE,QAAQ,OAAO,UAAU,MAAA;AAAA,QAEjC,UAAAP,EAAM,kBAAkB,CAAC,GAAG,QAAQ,IAAI,CAACW,MACxC,gBAAAD;AAAA,UAAC;AAAA,UAAA;AAAA,YAEC,WAAWH,EAAI,yBAAyB;AAAA,YACxC,OAAO;AAAA,cACL,SAAS;AAAA,cACT,QAAQ;AAAA,cACR,QAAQ;AAAA,cACR,OACEI,EAAO,OAAO,WACV,KACCA,EAAO,OAAO,UAAU,MAA6B;AAAA,YAAA;AAAA,YAG9D,4BAAC,OAAA,EAAI,WAAWJ,EAAI,iCAAiC,GAAG,UAAA,IAAA,CAAM;AAAA,UAAA;AAAA,UAZzDI,EAAO;AAAA,QAAA,CAcf;AAAA,MAAA;AAAA,IAAA;AAAA,IAGFV,EAAW,WAAW,IACrB,gBAAAS,EAAC,QAAG,WAAWH,EAAI,wBAAwB,GACzC,UAAA,gBAAAG,EAAC,MAAA,EAAG,SAASV,EAAM,kBAAkB,CAAC,GAAG,QAAQ,UAAU,GACzD,UAAA,gBAAAU,EAACE,GAAA,EAAM,aAAaV,EAAA,CAAkB,EAAA,CACxC,EAAA,CACF,IAEAF,EAAM,YAAA,EAAc,KAAK,IAAI,CAACa,MAC5B,gBAAAH;AAAA,MAAC;AAAA,MAAA;AAAA,QAEC,WAAWI;AAAA,UACTP,EAAI,gBAAgB;AAAA,UACpBA,EAAI,wBAAwB;AAAA,UAC5BM,EAAI,cAAA,IAAkBN,EAAI,yBAAyB,IAAI;AAAA,QAAA;AAAA,QAEzD,gBAAcM,EAAI;AAAA,QAClB,mBAAiBV,IAAkB,SAAS;AAAA,QAC5C,SAAS,MAAMC,IAAaS,CAAG;AAAA,QAE9B,UAAAA,EAAI,gBAAA,EAAkB,IAAI,CAACE,MAC1B,gBAAAL;AAAA,UAAC;AAAA,UAAA;AAAA,YAEC,WAAWI;AAAA,cACTP,EAAI,iBAAiB;AAAA,cACrBQ,EAAK,OAAO,OAAO,WAAWR,EAAI,6BAA6B,IAAI;AAAA,cACnES,EAAmBD,EAAK,OAAO,UAAU,MAA6B,KAAK;AAAA,YAAA;AAAA,YAG5E,UAAAA,EAAK,OAAO,OAAO;AAAA;AAAA,eAEf,MAAM;AACL,sBAAME,IAASF,EAAK,IAAI,UAClBG,IAAgBb,GAAoB,mBAAmBY,CAAM,KAAK,CAAA;AAExE,uBAAIZ,GAAoB,SAAS,UAE7B,gBAAAK;AAAA,kBAACS;AAAA,kBAAA;AAAA,oBACC,SAASJ,EAAK,IAAI,cAAA;AAAA,oBAClB,UAAU,CAACA,EAAK,IAAI,aAAA;AAAA,oBACpB,UAAU,CAACK,MAAwB;AAEjC,0BADAL,EAAK,IAAI,eAAeK,EAAE,OAAO,OAAO,GACpCf,EAAmB,UAAU;AAC/B,8BAAM,EAAE,cAAAgB,MAAiBC;AAAA,0BACvBtB,EAAM,WAAW;AAAA,0BACjBC;AAAA,0BACAK;AAAA,wBAAA;AAEF,wBAAAD,EAAmB;AAAA,0BACjBY;AAAA,0BACAG,EAAE,OAAO;AAAA,0BACTC;AAAA,0BACAD,EAAE;AAAA,wBAAA;AAAA,sBAEN;AAAA,oBACF;AAAA,oBACC,GAAGF;AAAA,kBAAA;AAAA,gBAAA,IAMR,gBAAAR;AAAA,kBAACa;AAAA,kBAAA;AAAA,oBACC,SAASR,EAAK,IAAI,cAAA;AAAA,oBAClB,UAAU,CAACA,EAAK,IAAI,aAAA;AAAA,oBACpB,UAAU,CAACK,MAA2B;AAEpC,0BADAL,EAAK,IAAI,eAAeK,EAAE,OAAO,OAAO,GACpCf,GAAoB,UAAU;AAChC,8BAAM,EAAE,cAAAgB,MAAiBC;AAAA,0BACvBtB,EAAM,WAAW;AAAA,0BACjBC;AAAA,0BACAK;AAAA,wBAAA;AAEF,wBAAAD,EAAmB;AAAA,0BACjBY;AAAA,0BACAG,EAAE,OAAO;AAAA,0BACTC;AAAA,0BACAD,EAAE;AAAA,wBAAA;AAAA,sBAEN;AAAA,oBACF;AAAA,oBACC,GAAGF;AAAA,kBAAA;AAAA,gBAAA;AAAA,cAGV,GAAA;AAAA,gBACAM,EAAWT,EAAK,OAAO,UAAU,MAAMA,EAAK,YAAY;AAAA,UAAA;AAAA,UA/DvDA,EAAK;AAAA,QAAA,CAiEb;AAAA,MAAA;AAAA,MA7EIF,EAAI;AAAA,IAAA,CA+EZ;AAAA,EAAA,GAEL;AAEJ;"}
@@ -6,6 +6,6 @@ interface TableHeaderProps<RecordType extends Record<string, any> = Record<strin
6
6
  dataSource?: RecordType[];
7
7
  rowKey?: RowKey | ((record: RecordType, index?: number) => RowKey);
8
8
  }
9
- export declare const TableHeader: <RecordType extends Record<string, any> = Record<string, unknown>>({ table, rowSelectionConfig, dataSource, rowKey }: TableHeaderProps<RecordType>) => import("react/jsx-runtime").JSX.Element;
9
+ export declare const TableHeader: <RecordType extends Record<string, any> = Record<string, unknown>>({ table, rowSelectionConfig, dataSource, rowKey, }: TableHeaderProps<RecordType>) => import("react/jsx-runtime").JSX.Element;
10
10
  export {};
11
11
  //# sourceMappingURL=TableHeader.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"TableHeader.d.ts","sourceRoot":"","sources":["../../../../src/components/data-table/components/TableHeader.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAc,KAAK,KAAK,EAAiC,MAAM,uBAAuB,CAAC;AAM9F,OAAO,EAAE,KAAK,qBAAqB,EAAE,KAAK,MAAM,EAAE,MAAM,UAAU,CAAC;AAUnE,UAAU,gBAAgB,CAAC,UAAU,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IACzF,KAAK,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;IACzB,kBAAkB,CAAC,EAAE,qBAAqB,CAAC,UAAU,CAAC,CAAC;IACvD,UAAU,CAAC,EAAE,UAAU,EAAE,CAAC;IAC1B,MAAM,CAAC,EAAE,MAAM,GAAG,CAAC,CAAC,MAAM,EAAE,UAAU,EAAE,KAAK,CAAC,EAAE,MAAM,KAAK,MAAM,CAAC,CAAC;CACpE;AAED,eAAO,MAAM,WAAW,GAAI,UAAU,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,mDAK3F,gBAAgB,CAAC,UAAU,CAAC,4CA+H9B,CAAC"}
1
+ {"version":3,"file":"TableHeader.d.ts","sourceRoot":"","sources":["../../../../src/components/data-table/components/TableHeader.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAc,KAAK,KAAK,EAAiC,MAAM,uBAAuB,CAAC;AAM9F,OAAO,EAAE,KAAK,qBAAqB,EAAE,KAAK,MAAM,EAAE,MAAM,UAAU,CAAC;AAUnE,UAAU,gBAAgB,CAAC,UAAU,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IACzF,KAAK,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;IACzB,kBAAkB,CAAC,EAAE,qBAAqB,CAAC,UAAU,CAAC,CAAC;IACvD,UAAU,CAAC,EAAE,UAAU,EAAE,CAAC;IAC1B,MAAM,CAAC,EAAE,MAAM,GAAG,CAAC,CAAC,MAAM,EAAE,UAAU,EAAE,KAAK,CAAC,EAAE,MAAM,KAAK,MAAM,CAAC,CAAC;CACpE;AAED,eAAO,MAAM,WAAW,GAAI,UAAU,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,oDAK3F,gBAAgB,CAAC,UAAU,CAAC,4CAqI9B,CAAC"}
@@ -1,101 +1,101 @@
1
- import { jsx as t, jsxs as m } from "react/jsx-runtime";
2
- import { flexRender as g } from "@tanstack/react-table";
3
- import { Checkbox as p } from "antd";
4
- import { CaretUpDownIcon as d, CaretUpIcon as z, CaretDownIcon as b, FunnelIcon as I } from "@bioturing/assets";
5
- import { convertSelectionToAntFormat as C, shouldShowIcons as u, getAlignmentClass as R } from "../utils.js";
6
- import { useCls as S } from "../../utils/antdUtils.js";
1
+ import { jsx as e, jsxs as a } from "react/jsx-runtime";
2
+ import { flexRender as r } from "@tanstack/react-table";
3
+ import { CaretUpDownIcon as f, CaretUpIcon as p, CaretDownIcon as z, FunnelIcon as b } from "@bioturing/assets";
4
+ import { convertSelectionToAntFormat as I, shouldShowIcons as m, getAlignmentClass as C } from "../utils.js";
5
+ import { useCls as R } from "../../utils/antdUtils.js";
7
6
  import { clsx as c } from "../../utils/cn.js";
7
+ import { Checkbox as S } from "../../checkbox/component.js";
8
8
  const H = ({
9
9
  table: n,
10
10
  rowSelectionConfig: s,
11
11
  dataSource: o = [],
12
- rowKey: a
12
+ rowKey: g
13
13
  }) => {
14
- const e = S();
15
- return /* @__PURE__ */ t("thead", { className: e("table-thead"), children: n.getHeaderGroups().map((r) => /* @__PURE__ */ t("tr", { children: r.headers.map((l) => /* @__PURE__ */ m(
14
+ const l = R();
15
+ return /* @__PURE__ */ e("thead", { className: l("data-table-thead"), children: n.getHeaderGroups().map((u) => /* @__PURE__ */ e("tr", { children: u.headers.map((t) => /* @__PURE__ */ a(
16
16
  "th",
17
17
  {
18
18
  className: c(
19
- e("table-cell"),
20
- u(l.column) ? e("table-column-has-sorters") : "",
21
- l.id === "select" ? e("table-selection-column") : "",
22
- l.column.getIsResizing?.() ? e("table-cell-resizing") : "",
23
- R(l.column.columnDef.meta?.align)
19
+ l("data-table-cell"),
20
+ m(t.column) ? l("data-table-column-has-sorters") : "",
21
+ t.id === "select" ? l("data-table-selection-column") : "",
22
+ t.column.getIsResizing?.() ? l("data-table-cell-resizing") : "",
23
+ C(t.column.columnDef.meta?.align)
24
24
  ),
25
25
  scope: "col",
26
26
  style: {
27
- width: l.id === "select" ? s?.columnWidth || 32 : void 0
27
+ width: t.id === "select" ? s?.columnWidth || 32 : void 0
28
28
  // Width is handled by colgroup and CSS variables for performance
29
29
  },
30
- tabIndex: u(l.column) ? 0 : void 0,
31
- onClick: l.column.getCanSort() ? l.column.getToggleSortingHandler() : void 0,
30
+ tabIndex: m(t.column) ? 0 : void 0,
31
+ onClick: t.column.getCanSort() ? t.column.getToggleSortingHandler() : void 0,
32
32
  children: [
33
- l.id === "select" ? (
33
+ t.id === "select" ? (
34
34
  // Handle selection column header
35
35
  (() => {
36
36
  if (s?.type === "radio")
37
37
  return s.columnTitle || null;
38
- const { selectedRowKeys: i } = C(
38
+ const { selectedRowKeys: i } = I(
39
39
  n.getState().rowSelection,
40
40
  o,
41
- a
41
+ g
42
42
  );
43
- return /* @__PURE__ */ t(
44
- p,
43
+ return /* @__PURE__ */ e(
44
+ S,
45
45
  {
46
46
  checked: i.length === o.length && o.length > 0,
47
47
  indeterminate: i.length > 0 && i.length < o.length,
48
- onChange: (f) => {
49
- f.target.checked ? n.toggleAllRowsSelected(!0) : n.toggleAllRowsSelected(!1);
48
+ onChange: (d) => {
49
+ d.target.checked ? n.toggleAllRowsSelected(!0) : n.toggleAllRowsSelected(!1);
50
50
  }
51
51
  }
52
52
  );
53
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(
54
+ ) : m(t.column) ? /* @__PURE__ */ a("div", { className: l("data-table-column-sorters"), children: [
55
+ /* @__PURE__ */ e("span", { className: l("data-table-column-title"), children: t.isPlaceholder ? null : r(t.column.columnDef.header, t.getContext()) }),
56
+ /* @__PURE__ */ a("div", { className: l("data-table-column-icons"), children: [
57
+ t.column.getCanSort() && /* @__PURE__ */ e(
58
58
  "span",
59
59
  {
60
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`
61
+ l("data-table-column-sort-icon"),
62
+ t.column.getIsSorted() ? `${l("data-table-column-sort-icon")}-${t.column.getIsSorted()}` : `${l("data-table-column-sort-icon")}-none`
63
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" })
64
+ children: t.column.getIsSorted() ? t.column.getIsSorted() === "asc" ? /* @__PURE__ */ e(p, { weight: "fill" }) : /* @__PURE__ */ e(z, { weight: "fill" }) : /* @__PURE__ */ e(f, { weight: "fill" })
65
65
  }
66
66
  ),
67
- l.column.getCanFilter() && /* @__PURE__ */ t(
67
+ t.column.getCanFilter() && /* @__PURE__ */ e(
68
68
  "span",
69
69
  {
70
70
  className: c(
71
- e("table-column-filter-icon"),
72
- l.column.getFilterValue() ? e("table-column-filter-icon-active") : ""
71
+ l("data-table-column-filter-icon"),
72
+ t.column.getFilterValue() ? l("data-table-column-filter-icon-active") : ""
73
73
  ),
74
- children: /* @__PURE__ */ t(I, { weight: "fill" })
74
+ children: /* @__PURE__ */ e(b, { weight: "fill" })
75
75
  }
76
76
  )
77
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(
78
+ ] }) : /* @__PURE__ */ e("span", { className: l("data-table-column-title"), children: t.isPlaceholder ? null : r(t.column.columnDef.header, t.getContext()) }),
79
+ t.column.getCanResize?.() && /* @__PURE__ */ e(
80
80
  "div",
81
81
  {
82
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") : ""
83
+ l("data-table-resize-handle"),
84
+ l(`data-table-resize-${n.options.columnResizeDirection || "ltr"}`),
85
+ t.column.getIsResizing?.() ? l("data-table-resize-handle-active") : ""
86
86
  ),
87
- onMouseDown: l.getResizeHandler?.(),
88
- onTouchStart: l.getResizeHandler?.(),
89
- onDoubleClick: () => l.column.resetSize(),
87
+ onMouseDown: t.getResizeHandler?.(),
88
+ onTouchStart: t.getResizeHandler?.(),
89
+ onDoubleClick: () => t.column.resetSize(),
90
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)` : ""
91
+ transform: n.options.columnResizeMode === "onEnd" && t.column.getIsResizing?.() ? `translateX(${((n.options.columnResizeDirection || "ltr") === "rtl" ? -1 : 1) * (n.getState().columnSizingInfo?.deltaOffset ?? 0)}px)` : ""
92
92
  }
93
93
  }
94
94
  )
95
95
  ]
96
96
  },
97
- l.id
98
- )) }, r.id)) });
97
+ t.id
98
+ )) }, u.id)) });
99
99
  };
100
100
  export {
101
101
  H as TableHeader
@@ -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\";\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(\"data-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(\"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 const { selectedRowKeys } = convertSelectionToAntFormat(\n table.getState().rowSelection,\n dataSource,\n rowKey,\n );\n\n return (\n <Checkbox\n checked={\n selectedRowKeys.length === dataSource.length && dataSource.length > 0\n }\n indeterminate={\n selectedRowKeys.length > 0 && selectedRowKeys.length < dataSource.length\n }\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(\"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","cls","useCls","headerGroup","jsx","header","jsxs","clsx","shouldShowIcons","getAlignmentClass","selectedRowKeys","convertSelectionToAntFormat","Checkbox","e","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,CAC5B,UAAU,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAE5D,KAAK,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;IACzB,gBAAgB,CAAC,EAAE,yBAAyB,CAAC;IAC7C,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,eAAO,MAAM,eAAe,GAC1B,UAAU,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAC5D,0CAIC,oBAAoB,CAAC,UAAU,CAAC,4CAoClC,CAAC"}
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,4CAkClC,CAAC"}
@@ -2,40 +2,34 @@ import { jsx as i } from "react/jsx-runtime";
2
2
  import { Pagination as h } from "antd";
3
3
  import { useCls as g } from "../../utils/antdUtils.js";
4
4
  import { clsx as m } from "../../utils/cn.js";
5
- const x = ({
5
+ const d = ({
6
6
  table: t,
7
- paginationConfig: o,
7
+ paginationConfig: a,
8
8
  totalCount: n
9
9
  }) => {
10
- const s = g();
11
- if (!o || !t.getState().pagination) return null;
12
- const c = t.getState().pagination.pageIndex + 1, a = t.getState().pagination.pageSize;
13
- return /* @__PURE__ */ i(
14
- "div",
10
+ const r = g();
11
+ if (!a || !t.getState().pagination) return null;
12
+ const c = t.getState().pagination.pageIndex + 1, s = t.getState().pagination.pageSize;
13
+ return /* @__PURE__ */ i("div", { className: m(r("data-table-pagination"), r("data-table-pagination-right")), children: /* @__PURE__ */ i(
14
+ h,
15
15
  {
16
- className: m(s("table-pagination"), s("table-pagination-right")),
17
- children: /* @__PURE__ */ i(
18
- h,
19
- {
20
- ...o,
21
- current: c,
22
- pageSize: a,
23
- total: n,
24
- showSizeChanger: o.showSizeChanger !== !1,
25
- showQuickJumper: o.showQuickJumper || !1,
26
- showTotal: o.showTotal || ((r, e) => `${e[0]}-${e[1]} of ${r} items`),
27
- onChange: (r, e) => {
28
- t.setPageIndex(r - 1), e && e !== a && t.setPageSize(e);
29
- },
30
- onShowSizeChange: (r, e) => {
31
- t.setPageSize(e), t.setPageIndex(0);
32
- }
33
- }
34
- )
16
+ ...a,
17
+ current: c,
18
+ pageSize: s,
19
+ total: n,
20
+ showSizeChanger: a.showSizeChanger !== !1,
21
+ showQuickJumper: a.showQuickJumper || !1,
22
+ showTotal: a.showTotal || ((o, e) => `${e[0]}-${e[1]} of ${o} items`),
23
+ onChange: (o, e) => {
24
+ t.setPageIndex(o - 1), e && e !== s && t.setPageSize(e);
25
+ },
26
+ onShowSizeChange: (o, e) => {
27
+ t.setPageSize(e), t.setPageIndex(0);
28
+ }
35
29
  }
36
- );
30
+ ) });
37
31
  };
38
32
  export {
39
- x as TablePagination
33
+ d as TablePagination
40
34
  };
41
35
  //# 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<\n RecordType extends Record<string, any> = Record<string, any>\n> {\n table: Table<RecordType>;\n paginationConfig?: DataTablePaginationConfig;\n totalCount: number;\n}\n\nexport const TablePagination = <\n RecordType extends Record<string, any> = Record<string, any>\n>({\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 return (\n <div\n className={clsx(cls(\"table-pagination\"), cls(\"table-pagination-right\"))}\n >\n <Pagination\n {...paginationConfig}\n current={currentPage}\n pageSize={pageSize}\n total={totalCount}\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","jsx","clsx","Pagination","total","range","page","newPageSize","current","size"],"mappings":";;;;AAcO,MAAMA,IAAkB,CAE7B;AAAA,EACA,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;AAE7C,SACE,gBAAAO;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAWC,EAAKL,EAAI,kBAAkB,GAAGA,EAAI,wBAAwB,CAAC;AAAA,MAEtE,UAAA,gBAAAI;AAAA,QAACE;AAAA,QAAA;AAAA,UACE,GAAGR;AAAA,UACJ,SAASI;AAAA,UACT,UAAAC;AAAA,UACA,OAAOJ;AAAA,UACP,iBAAiBD,EAAiB,oBAAoB;AAAA,UACtD,iBAAiBA,EAAiB,mBAAmB;AAAA,UACrD,WACEA,EAAiB,cAChB,CAACS,GAAOC,MAAU,GAAGA,EAAM,CAAC,CAAC,IAAIA,EAAM,CAAC,CAAC,OAAOD,CAAK;AAAA,UAExD,UAAU,CAACE,GAAMC,MAAgB;AAC/B,YAAAb,EAAM,aAAaY,IAAO,CAAC,GACvBC,KAAeA,MAAgBP,KACjCN,EAAM,YAAYa,CAAW;AAAA,UAEjC;AAAA,UACA,kBAAkB,CAACC,GAASC,MAAS;AACnC,YAAAf,EAAM,YAAYe,CAAI,GACtBf,EAAM,aAAa,CAAC;AAAA,UACtB;AAAA,QAAA;AAAA,MAAA;AAAA,IACF;AAAA,EAAA;AAGN;"}
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 return (\n <div className={clsx(cls(\"data-table-pagination\"), cls(\"data-table-pagination-right\"))}>\n <Pagination\n {...paginationConfig}\n current={currentPage}\n pageSize={pageSize}\n total={totalCount}\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","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;AAE7C,SACE,gBAAAO,EAAC,OAAA,EAAI,WAAWC,EAAKL,EAAI,uBAAuB,GAAGA,EAAI,6BAA6B,CAAC,GACnF,UAAA,gBAAAI;AAAA,IAACE;AAAA,IAAA;AAAA,MACE,GAAGR;AAAA,MACJ,SAASI;AAAA,MACT,UAAAC;AAAA,MACA,OAAOJ;AAAA,MACP,iBAAiBD,EAAiB,oBAAoB;AAAA,MACtD,iBAAiBA,EAAiB,mBAAmB;AAAA,MACrD,WACEA,EAAiB,cAChB,CAACS,GAAOC,MAAU,GAAGA,EAAM,CAAC,CAAC,IAAIA,EAAM,CAAC,CAAC,OAAOD,CAAK;AAAA,MAExD,UAAU,CAACE,GAAMC,MAAgB;AAC/B,QAAAb,EAAM,aAAaY,IAAO,CAAC,GACvBC,KAAeA,MAAgBP,KACjCN,EAAM,YAAYa,CAAW;AAAA,MAEjC;AAAA,MACA,kBAAkB,CAACC,GAASC,MAAS;AACnC,QAAAf,EAAM,YAAYe,CAAI,GACtBf,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;AAOnE;;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;;;;;;;;EAkNlC"}
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;AAOnE;;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;;;;;;;;EAmNlC"}