@economic/taco 2.0.0-alpha.173 → 2.0.0-alpha.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (164) hide show
  1. package/dist/components/Provider/Localization.d.ts +114 -1
  2. package/dist/components/Table2/Table2.d.ts +130 -0
  3. package/dist/components/Table2/components/BatchActionsMenu.d.ts +10 -0
  4. package/dist/components/Table2/components/ColumnSettingsButton.d.ts +6 -0
  5. package/dist/components/Table2/components/EditModeButton.d.ts +8 -0
  6. package/dist/components/Table2/components/RowDensityButton.d.ts +7 -0
  7. package/dist/components/Table2/components/Search.d.ts +3 -0
  8. package/dist/components/Table2/components/ShortcutsGuideButton.d.ts +7 -0
  9. package/dist/components/Table2/components/column/Base.d.ts +14 -0
  10. package/dist/components/Table2/components/column/Cell.d.ts +15 -0
  11. package/dist/components/Table2/components/column/Footer.d.ts +9 -0
  12. package/dist/components/Table2/components/column/Header.d.ts +11 -0
  13. package/dist/components/Table2/components/column/Indicator.d.ts +17 -0
  14. package/dist/components/Table2/components/column/ValidationError.d.ts +5 -0
  15. package/dist/components/Table2/components/column/utils.d.ts +3 -0
  16. package/dist/components/Table2/components/filters/FiltersButton.d.ts +7 -0
  17. package/dist/components/Table2/components/filters/components/Column.d.ts +11 -0
  18. package/dist/components/Table2/components/filters/components/ColumnFilter.d.ts +10 -0
  19. package/dist/components/Table2/components/filters/components/Comparator.d.ts +11 -0
  20. package/dist/components/Table2/components/filters/components/EmptyFilter.d.ts +13 -0
  21. package/dist/components/Table2/components/filters/components/InferredControl.d.ts +10 -0
  22. package/dist/components/Table2/components/row/Context.d.ts +24 -0
  23. package/dist/components/Table2/components/row/ExpandedRow.d.ts +6 -0
  24. package/dist/components/Table2/components/row/Row.d.ts +2 -0
  25. package/dist/components/Table2/hooks/listeners/useActiveCellStateListener.d.ts +3 -0
  26. package/dist/components/Table2/hooks/listeners/useActiveRowStateListener.d.ts +3 -0
  27. package/dist/components/Table2/hooks/listeners/useColumnOffsetStateListener.d.ts +3 -0
  28. package/dist/components/Table2/hooks/listeners/useFilterStateListener.d.ts +3 -0
  29. package/dist/components/Table2/hooks/listeners/useRowSelectionListener.d.ts +3 -0
  30. package/dist/components/Table2/hooks/listeners/useSettingsStateListener.d.ts +3 -0
  31. package/dist/components/Table2/hooks/useActiveCell.d.ts +26 -0
  32. package/dist/components/Table2/hooks/useActiveRow.d.ts +10 -0
  33. package/dist/components/Table2/hooks/useColumnDefinitions.d.ts +37 -0
  34. package/dist/components/Table2/hooks/useEditMode.d.ts +28 -0
  35. package/dist/components/Table2/hooks/useGridTemplate.d.ts +2 -0
  36. package/dist/components/Table2/hooks/useTable.d.ts +46 -0
  37. package/dist/components/Table2/hooks/useTableShortcuts.d.ts +2 -0
  38. package/dist/components/Table2/hooks/useVirtualiser.d.ts +23 -0
  39. package/dist/components/Table2/types.d.ts +148 -0
  40. package/dist/components/Table2/utilities/cell.d.ts +14 -0
  41. package/dist/components/Table2/utilities/columns.d.ts +16 -0
  42. package/dist/components/Table2/utilities/filterFn.d.ts +3 -0
  43. package/dist/components/Table3/Table3.d.ts +3 -2
  44. package/dist/components/Table3/components/columns/cell/DisplayCell.d.ts +2 -2
  45. package/dist/components/Table3/components/columns/footer/Footer.d.ts +2 -2
  46. package/dist/components/Table3/components/columns/header/Header.d.ts +3 -3
  47. package/dist/components/Table3/components/columns/header/SortIndicator.d.ts +3 -3
  48. package/dist/components/Table3/components/columns/styles.d.ts +2 -2
  49. package/dist/components/Table3/hooks/useTable.d.ts +3 -3
  50. package/dist/components/Table3/hooks/useTableDataLoader.d.ts +23 -0
  51. package/dist/components/Table3/types.d.ts +18 -19
  52. package/dist/esm/packages/taco/src/components/Provider/Localization.js +110 -0
  53. package/dist/esm/packages/taco/src/components/Provider/Localization.js.map +1 -1
  54. package/dist/esm/packages/taco/src/components/Table2/Table2.js +422 -0
  55. package/dist/esm/packages/taco/src/components/Table2/Table2.js.map +1 -0
  56. package/dist/esm/packages/taco/src/components/Table2/components/BatchActionsMenu.js +83 -0
  57. package/dist/esm/packages/taco/src/components/Table2/components/BatchActionsMenu.js.map +1 -0
  58. package/dist/esm/packages/taco/src/components/Table2/components/ColumnSettingsButton.js +116 -0
  59. package/dist/esm/packages/taco/src/components/Table2/components/ColumnSettingsButton.js.map +1 -0
  60. package/dist/esm/packages/taco/src/components/Table2/components/EditModeButton.js +81 -0
  61. package/dist/esm/packages/taco/src/components/Table2/components/EditModeButton.js.map +1 -0
  62. package/dist/esm/packages/taco/src/components/Table2/components/RowDensityButton.js +47 -0
  63. package/dist/esm/packages/taco/src/components/Table2/components/RowDensityButton.js.map +1 -0
  64. package/dist/esm/packages/taco/src/components/Table2/components/Search.js +62 -0
  65. package/dist/esm/packages/taco/src/components/Table2/components/Search.js.map +1 -0
  66. package/dist/esm/packages/taco/src/components/Table2/components/column/Base.js +32 -0
  67. package/dist/esm/packages/taco/src/components/Table2/components/column/Base.js.map +1 -0
  68. package/dist/esm/packages/taco/src/components/Table2/components/column/Cell.js +600 -0
  69. package/dist/esm/packages/taco/src/components/Table2/components/column/Cell.js.map +1 -0
  70. package/dist/esm/packages/taco/src/components/Table2/components/column/Footer.js +32 -0
  71. package/dist/esm/packages/taco/src/components/Table2/components/column/Footer.js.map +1 -0
  72. package/dist/esm/packages/taco/src/components/Table2/components/column/Header.js +243 -0
  73. package/dist/esm/packages/taco/src/components/Table2/components/column/Header.js.map +1 -0
  74. package/dist/esm/packages/taco/src/components/Table2/components/column/Indicator.js +73 -0
  75. package/dist/esm/packages/taco/src/components/Table2/components/column/Indicator.js.map +1 -0
  76. package/dist/esm/packages/taco/src/components/Table2/components/column/ValidationError.js +30 -0
  77. package/dist/esm/packages/taco/src/components/Table2/components/column/ValidationError.js.map +1 -0
  78. package/dist/esm/packages/taco/src/components/Table2/components/column/utils.js +39 -0
  79. package/dist/esm/packages/taco/src/components/Table2/components/column/utils.js.map +1 -0
  80. package/dist/esm/packages/taco/src/components/Table2/components/filters/FiltersButton.js +155 -0
  81. package/dist/esm/packages/taco/src/components/Table2/components/filters/FiltersButton.js.map +1 -0
  82. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/Column.js +31 -0
  83. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/Column.js.map +1 -0
  84. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/ColumnFilter.js +129 -0
  85. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/ColumnFilter.js.map +1 -0
  86. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/Comparator.js +68 -0
  87. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/Comparator.js.map +1 -0
  88. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/EmptyFilter.js +63 -0
  89. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/EmptyFilter.js.map +1 -0
  90. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/InferredControl.js +99 -0
  91. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/InferredControl.js.map +1 -0
  92. package/dist/esm/packages/taco/src/components/Table2/components/row/Context.js +58 -0
  93. package/dist/esm/packages/taco/src/components/Table2/components/row/Context.js.map +1 -0
  94. package/dist/esm/packages/taco/src/components/Table2/components/row/ExpandedRow.js +36 -0
  95. package/dist/esm/packages/taco/src/components/Table2/components/row/ExpandedRow.js.map +1 -0
  96. package/dist/esm/packages/taco/src/components/Table2/components/row/Row.js +43 -0
  97. package/dist/esm/packages/taco/src/components/Table2/components/row/Row.js.map +1 -0
  98. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useActiveRowStateListener.js +19 -0
  99. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useActiveRowStateListener.js.map +1 -0
  100. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useColumnOffsetStateListener.js +28 -0
  101. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useColumnOffsetStateListener.js.map +1 -0
  102. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useFilterStateListener.js +12 -0
  103. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useFilterStateListener.js.map +1 -0
  104. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useRowSelectionListener.js +18 -0
  105. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useRowSelectionListener.js.map +1 -0
  106. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useSettingsStateListener.js +25 -0
  107. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useSettingsStateListener.js.map +1 -0
  108. package/dist/esm/packages/taco/src/components/Table2/hooks/useActiveRow.js +33 -0
  109. package/dist/esm/packages/taco/src/components/Table2/hooks/useActiveRow.js.map +1 -0
  110. package/dist/esm/packages/taco/src/components/Table2/hooks/useColumnDefinitions.js +122 -0
  111. package/dist/esm/packages/taco/src/components/Table2/hooks/useColumnDefinitions.js.map +1 -0
  112. package/dist/esm/packages/taco/src/components/Table2/hooks/useEditMode.js +112 -0
  113. package/dist/esm/packages/taco/src/components/Table2/hooks/useEditMode.js.map +1 -0
  114. package/dist/esm/packages/taco/src/components/Table2/hooks/useGridTemplate.js +34 -0
  115. package/dist/esm/packages/taco/src/components/Table2/hooks/useGridTemplate.js.map +1 -0
  116. package/dist/esm/packages/taco/src/components/Table2/hooks/useTable.js +222 -0
  117. package/dist/esm/packages/taco/src/components/Table2/hooks/useTable.js.map +1 -0
  118. package/dist/esm/packages/taco/src/components/Table2/hooks/useTableShortcuts.js +46 -0
  119. package/dist/esm/packages/taco/src/components/Table2/hooks/useTableShortcuts.js.map +1 -0
  120. package/dist/esm/packages/taco/src/components/Table2/hooks/useVirtualiser.js +48 -0
  121. package/dist/esm/packages/taco/src/components/Table2/hooks/useVirtualiser.js.map +1 -0
  122. package/dist/esm/packages/taco/src/components/Table2/types.js +18 -0
  123. package/dist/esm/packages/taco/src/components/Table2/types.js.map +1 -0
  124. package/dist/esm/packages/taco/src/components/Table2/utilities/cell.js +41 -0
  125. package/dist/esm/packages/taco/src/components/Table2/utilities/cell.js.map +1 -0
  126. package/dist/esm/packages/taco/src/components/Table2/utilities/columns.js +387 -0
  127. package/dist/esm/packages/taco/src/components/Table2/utilities/columns.js.map +1 -0
  128. package/dist/esm/packages/taco/src/components/Table2/utilities/filterFn.js +100 -0
  129. package/dist/esm/packages/taco/src/components/Table2/utilities/filterFn.js.map +1 -0
  130. package/dist/esm/packages/taco/src/components/Table3/Table3.js +1 -1
  131. package/dist/esm/packages/taco/src/components/Table3/Table3.js.map +1 -1
  132. package/dist/esm/packages/taco/src/components/Table3/components/columns/cell/DisplayCell.js +4 -1
  133. package/dist/esm/packages/taco/src/components/Table3/components/columns/cell/DisplayCell.js.map +1 -1
  134. package/dist/esm/packages/taco/src/components/Table3/components/columns/cell/EditingCell.js +4 -1
  135. package/dist/esm/packages/taco/src/components/Table3/components/columns/cell/EditingCell.js.map +1 -1
  136. package/dist/esm/packages/taco/src/components/Table3/components/columns/footer/Footer.js.map +1 -1
  137. package/dist/esm/packages/taco/src/components/Table3/components/columns/header/Header.js.map +1 -1
  138. package/dist/esm/packages/taco/src/components/Table3/components/columns/header/SortIndicator.js.map +1 -1
  139. package/dist/esm/packages/taco/src/components/Table3/components/columns/styles.js.map +1 -1
  140. package/dist/esm/packages/taco/src/components/Table3/components/toolbar/ColumnSettings.js +2 -2
  141. package/dist/esm/packages/taco/src/components/Table3/components/toolbar/PrintButton/PrintIFrame.js +4 -3
  142. package/dist/esm/packages/taco/src/components/Table3/components/toolbar/PrintButton/PrintIFrame.js.map +1 -1
  143. package/dist/esm/packages/taco/src/components/Table3/hooks/useConvertChildrenToColumns.js.map +1 -1
  144. package/dist/esm/packages/taco/src/components/Table3/hooks/useTable.js.map +1 -1
  145. package/dist/esm/packages/taco/src/components/Table3/hooks/{useTableData.js → useTableDataLoader.js} +3 -3
  146. package/dist/esm/packages/taco/src/components/Table3/hooks/useTableDataLoader.js.map +1 -0
  147. package/dist/esm/packages/taco/src/components/Table3/types.js.map +1 -1
  148. package/dist/esm/packages/taco/src/components/Truncate/Truncate.js +32 -0
  149. package/dist/esm/packages/taco/src/components/Truncate/Truncate.js.map +1 -0
  150. package/dist/esm/packages/taco/src/index.js +3 -2
  151. package/dist/esm/packages/taco/src/index.js.map +1 -1
  152. package/dist/esm/packages/taco/src/utils/dom.js +2 -1
  153. package/dist/esm/packages/taco/src/utils/dom.js.map +1 -1
  154. package/dist/esm/packages/taco/src/utils/hooks/useTruncated.js +20 -0
  155. package/dist/esm/packages/taco/src/utils/hooks/useTruncated.js.map +1 -0
  156. package/dist/index.d.ts +1 -0
  157. package/dist/taco.cjs.development.js +4023 -362
  158. package/dist/taco.cjs.development.js.map +1 -1
  159. package/dist/taco.cjs.production.min.js +1 -1
  160. package/dist/taco.cjs.production.min.js.map +1 -1
  161. package/package.json +2 -3
  162. package/types.json +2220 -377
  163. package/dist/components/Table3/hooks/useTableData.d.ts +0 -23
  164. package/dist/esm/packages/taco/src/components/Table3/hooks/useTableData.js.map +0 -1
@@ -0,0 +1,99 @@
1
+ import React__default from 'react';
2
+ import { Input } from '../../../../Input/Input.js';
3
+ import { Datepicker } from '../../../../Datepicker/Datepicker.js';
4
+ import { Switch } from '../../../../Switch/Switch.js';
5
+ import { Table2FilterComparator } from '../../../types.js';
6
+
7
+ const InferredControl = ({
8
+ column,
9
+ comparator,
10
+ value
11
+ }) => {
12
+ var _column$columnDef$met2, _column$columnDef$met3;
13
+ const ariaLabel = column.columnDef.header;
14
+ if (comparator === Table2FilterComparator.IsEmpty || comparator === Table2FilterComparator.IsNotEmpty) {
15
+ return null;
16
+ }
17
+ if (comparator === Table2FilterComparator.IsBetween) {
18
+ var _column$columnDef$met;
19
+ const fromValue = Array.isArray(value) ? value[0] : undefined;
20
+ const toValue = Array.isArray(value) ? value[1] : undefined;
21
+ if (((_column$columnDef$met = column.columnDef.meta) === null || _column$columnDef$met === void 0 ? void 0 : _column$columnDef$met.dataType) === 'datetime') {
22
+ return /*#__PURE__*/React__default.createElement("div", {
23
+ className: "flex flex-grow items-center gap-2"
24
+ }, /*#__PURE__*/React__default.createElement(Datepicker, {
25
+ "aria-label": ariaLabel,
26
+ onChange: event => column.setFilterValue(currentValue => ({
27
+ ...currentValue,
28
+ value: [event.detail, toValue]
29
+ })),
30
+ value: fromValue
31
+ }), /*#__PURE__*/React__default.createElement(Datepicker, {
32
+ "aria-label": ariaLabel,
33
+ onChange: event => column.setFilterValue(currentValue => ({
34
+ ...currentValue,
35
+ value: [fromValue, event.detail]
36
+ })),
37
+ value: toValue
38
+ }));
39
+ }
40
+ return /*#__PURE__*/React__default.createElement("div", {
41
+ className: "flex flex-grow items-center gap-2"
42
+ }, /*#__PURE__*/React__default.createElement(Input, {
43
+ "aria-label": ariaLabel,
44
+ className: "flex-grow",
45
+ placeholder: "from",
46
+ onChange: event => {
47
+ const value = parseInt(event.target.value);
48
+ column.setFilterValue(currentValue => ({
49
+ ...currentValue,
50
+ value: [isNaN(value) ? undefined : value, toValue]
51
+ }));
52
+ },
53
+ value: fromValue !== null && fromValue !== void 0 ? fromValue : ''
54
+ }), /*#__PURE__*/React__default.createElement(Input, {
55
+ className: "flex-grow",
56
+ placeholder: "to",
57
+ onChange: event => {
58
+ const value = parseInt(event.target.value);
59
+ column.setFilterValue(currentValue => ({
60
+ ...currentValue,
61
+ value: [fromValue, isNaN(value) ? undefined : value]
62
+ }));
63
+ },
64
+ value: toValue !== null && toValue !== void 0 ? toValue : ''
65
+ }));
66
+ }
67
+ if (((_column$columnDef$met2 = column.columnDef.meta) === null || _column$columnDef$met2 === void 0 ? void 0 : _column$columnDef$met2.dataType) === 'datetime') {
68
+ return /*#__PURE__*/React__default.createElement(Datepicker, {
69
+ "aria-label": ariaLabel,
70
+ onChange: event => column.setFilterValue(currentValue => ({
71
+ ...currentValue,
72
+ value: event.detail
73
+ })),
74
+ value: value
75
+ });
76
+ } else if (((_column$columnDef$met3 = column.columnDef.meta) === null || _column$columnDef$met3 === void 0 ? void 0 : _column$columnDef$met3.dataType) === 'boolean') {
77
+ return /*#__PURE__*/React__default.createElement(Switch, {
78
+ "aria-label": ariaLabel,
79
+ onChange: checked => column.setFilterValue(currentValue => ({
80
+ ...currentValue,
81
+ value: checked
82
+ })),
83
+ checked: value
84
+ });
85
+ }
86
+ return /*#__PURE__*/React__default.createElement(Input, {
87
+ "aria-label": ariaLabel,
88
+ className: "flex-grow",
89
+ onChange: event => column.setFilterValue(currentValue => ({
90
+ ...currentValue,
91
+ value: event.target.value
92
+ })),
93
+ required: true,
94
+ value: value !== null && value !== void 0 ? value : ''
95
+ });
96
+ };
97
+
98
+ export { InferredControl };
99
+ //# sourceMappingURL=InferredControl.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InferredControl.js","sources":["../../../../../../../../../../src/components/Table2/components/filters/components/InferredControl.tsx"],"sourcesContent":["import React from 'react';\nimport { Column as RTColumn } from '@tanstack/react-table';\nimport { Input } from '../../../../Input/Input';\nimport { Table2FilterComparator } from '../../../types';\nimport { Datepicker } from '../../../../Datepicker/Datepicker';\nimport { Switch } from '../../../../Switch/Switch';\n\ntype InferredControlProps = {\n column: RTColumn<any, any>;\n comparator: Table2FilterComparator;\n value: any | any[];\n};\n\nexport const InferredControl = ({ column, comparator, value }: InferredControlProps) => {\n const ariaLabel = column.columnDef.header as string | undefined;\n\n if (comparator === Table2FilterComparator.IsEmpty || comparator === Table2FilterComparator.IsNotEmpty) {\n return null;\n }\n\n if (comparator === Table2FilterComparator.IsBetween) {\n const fromValue = Array.isArray(value) ? value[0] : undefined;\n const toValue = Array.isArray(value) ? value[1] : undefined;\n\n if (column.columnDef.meta?.dataType === 'datetime') {\n return (\n <div className=\"flex flex-grow items-center gap-2\">\n <Datepicker\n aria-label={ariaLabel}\n onChange={event =>\n column.setFilterValue(currentValue => ({\n ...currentValue,\n value: [(event as any).detail, toValue],\n }))\n }\n value={fromValue}\n />\n <Datepicker\n aria-label={ariaLabel}\n onChange={event =>\n column.setFilterValue(currentValue => ({\n ...currentValue,\n value: [fromValue, (event as any).detail],\n }))\n }\n value={toValue}\n />\n </div>\n );\n }\n\n return (\n <div className=\"flex flex-grow items-center gap-2\">\n <Input\n aria-label={ariaLabel}\n className=\"flex-grow\"\n placeholder=\"from\"\n onChange={event => {\n const value = parseInt(event.target.value);\n column.setFilterValue(currentValue => ({\n ...currentValue,\n value: [isNaN(value) ? undefined : value, toValue],\n }));\n }}\n value={fromValue ?? ''}\n />\n <Input\n className=\"flex-grow\"\n placeholder=\"to\"\n onChange={event => {\n const value = parseInt(event.target.value);\n column.setFilterValue(currentValue => ({\n ...currentValue,\n value: [fromValue, isNaN(value) ? undefined : value],\n }));\n }}\n value={toValue ?? ''}\n />\n </div>\n );\n }\n\n if (column.columnDef.meta?.dataType === 'datetime') {\n return (\n <Datepicker\n aria-label={ariaLabel}\n onChange={event =>\n column.setFilterValue(currentValue => ({\n ...currentValue,\n value: (event as any).detail,\n }))\n }\n value={value}\n />\n );\n } else if (column.columnDef.meta?.dataType === 'boolean') {\n return (\n <Switch\n aria-label={ariaLabel}\n onChange={checked =>\n column.setFilterValue(currentValue => ({\n ...currentValue,\n value: checked,\n }))\n }\n checked={value}\n />\n );\n }\n\n return (\n <Input\n aria-label={ariaLabel}\n className=\"flex-grow\"\n onChange={event =>\n column.setFilterValue(currentValue => ({\n ...currentValue,\n value: event.target.value,\n }))\n }\n required\n value={value ?? ''}\n />\n );\n};\n"],"names":["InferredControl","column","comparator","value","ariaLabel","columnDef","header","Table2FilterComparator","IsEmpty","IsNotEmpty","IsBetween","fromValue","Array","isArray","undefined","toValue","meta","dataType","React","className","Datepicker","onChange","event","setFilterValue","currentValue","detail","Input","placeholder","parseInt","target","isNaN","Switch","checked","required"],"mappings":"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"}
@@ -0,0 +1,58 @@
1
+ import React__default from 'react';
2
+
3
+ const RowContext = /*#__PURE__*/React__default.createContext({
4
+ isActive: false,
5
+ editMode: {
6
+ validationErrors: null,
7
+ setValidationErrors: () => undefined,
8
+ rowMoveReason: {},
9
+ setRowMoveReason: () => undefined
10
+ },
11
+ rowIndex: undefined,
12
+ isHovered: false,
13
+ setIsHovered: () => undefined
14
+ });
15
+ const RowContextProvider = ({
16
+ isActiveRow,
17
+ children,
18
+ meta,
19
+ rowIndex
20
+ }) => {
21
+ // we use non-css hovered state to determine whether to render actions or not, for performance
22
+ const [isHovered, setIsHovered] = React__default.useState(false);
23
+ // editing specific functionality
24
+ const [validationErrors, setValidationErrors] = React__default.useState(null);
25
+ const [rowMoveReason, setRowMoveReason] = React__default.useState({});
26
+ // This effect aims to focus the first focussable cell when edit mode is turned on.
27
+ React__default.useEffect(() => {
28
+ var _meta$tableRef$curren;
29
+ const isFocusInsideTable = (_meta$tableRef$curren = meta.tableRef.current) === null || _meta$tableRef$curren === void 0 ? void 0 : _meta$tableRef$curren.contains(document.activeElement);
30
+ // If the foucs is outside the table i.e., table action popups, search etc., then don't focus the first cell.
31
+ if (isActiveRow && isFocusInsideTable) {
32
+ meta.editMode.moveToFirstColumn(meta.focussableColumnIndexes);
33
+ }
34
+ // We are intentionally not adding activeRow to the depency variable so that everytime active row is changed,
35
+ // first focussable cell is not focussed.
36
+ }, [meta.editMode.isEditing, meta.focussableColumnIndexes]);
37
+ const context = React__default.useMemo(() => {
38
+ return {
39
+ isActive: isActiveRow,
40
+ editMode: {
41
+ validationErrors,
42
+ setValidationErrors,
43
+ rowMoveReason,
44
+ setRowMoveReason
45
+ },
46
+ rowIndex,
47
+ isHovered,
48
+ setIsHovered
49
+ };
50
+ }, [isActiveRow, isHovered, rowMoveReason, validationErrors, rowIndex]);
51
+ return /*#__PURE__*/React__default.createElement(RowContext.Provider, {
52
+ value: context
53
+ }, children);
54
+ };
55
+ const useRowContext = () => React__default.useContext(RowContext);
56
+
57
+ export { RowContext, RowContextProvider, useRowContext };
58
+ //# sourceMappingURL=Context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Context.js","sources":["../../../../../../../../../src/components/Table2/components/row/Context.tsx"],"sourcesContent":["import React from 'react';\nimport { SaveHandlerErrorResponse } from '../../types';\nimport { IndicatorReason } from '../column/Indicator';\n\ntype RowContextValue = {\n // we store this here because the \"real\" row index comes from the virtualiser,\n // and that isn't accessible in some places we need it - like the row actions column\n isActive: boolean;\n editMode: {\n validationErrors: SaveHandlerErrorResponse;\n setValidationErrors: React.Dispatch<React.SetStateAction<SaveHandlerErrorResponse>>;\n rowMoveReason: Record<string, IndicatorReason | null>;\n setRowMoveReason: React.Dispatch<React.SetStateAction<Record<string, IndicatorReason | null>>>;\n };\n rowIndex?: number;\n isHovered: boolean;\n setIsHovered: React.Dispatch<React.SetStateAction<boolean>>;\n};\n\nexport const RowContext = React.createContext<RowContextValue>({\n isActive: false,\n editMode: {\n validationErrors: null,\n setValidationErrors: () => undefined,\n rowMoveReason: {},\n setRowMoveReason: () => undefined,\n },\n rowIndex: undefined,\n isHovered: false,\n setIsHovered: () => undefined,\n});\n\nexport const RowContextProvider = ({ isActiveRow, children, meta, rowIndex }) => {\n // we use non-css hovered state to determine whether to render actions or not, for performance\n const [isHovered, setIsHovered] = React.useState(false);\n\n // editing specific functionality\n const [validationErrors, setValidationErrors] = React.useState<SaveHandlerErrorResponse | null>(null);\n const [rowMoveReason, setRowMoveReason] = React.useState<Record<string, IndicatorReason | null>>({});\n\n // This effect aims to focus the first focussable cell when edit mode is turned on.\n React.useEffect(() => {\n const isFocusInsideTable = meta.tableRef.current?.contains(document.activeElement);\n\n // If the foucs is outside the table i.e., table action popups, search etc., then don't focus the first cell.\n if (isActiveRow && isFocusInsideTable) {\n meta.editMode.moveToFirstColumn(meta.focussableColumnIndexes);\n }\n // We are intentionally not adding activeRow to the depency variable so that everytime active row is changed,\n // first focussable cell is not focussed.\n }, [meta.editMode.isEditing, meta.focussableColumnIndexes]);\n\n const context = React.useMemo(() => {\n return {\n isActive: isActiveRow,\n editMode: {\n validationErrors,\n setValidationErrors,\n rowMoveReason,\n setRowMoveReason,\n },\n rowIndex,\n isHovered,\n setIsHovered,\n };\n }, [isActiveRow, isHovered, rowMoveReason, validationErrors, rowIndex]);\n\n return <RowContext.Provider value={context}>{children}</RowContext.Provider>;\n};\n\nexport const useRowContext = () => React.useContext(RowContext);\n"],"names":["RowContext","React","createContext","isActive","editMode","validationErrors","setValidationErrors","undefined","rowMoveReason","setRowMoveReason","rowIndex","isHovered","setIsHovered","RowContextProvider","isActiveRow","children","meta","useState","useEffect","isFocusInsideTable","tableRef","current","contains","document","activeElement","moveToFirstColumn","focussableColumnIndexes","isEditing","context","useMemo","Provider","value","useRowContext","useContext"],"mappings":";;MAmBaA,UAAU,gBAAGC,cAAK,CAACC,aAAa,CAAkB;EAC3DC,QAAQ,EAAE,KAAK;EACfC,QAAQ,EAAE;IACNC,gBAAgB,EAAE,IAAI;IACtBC,mBAAmB,EAAE,MAAMC,SAAS;IACpCC,aAAa,EAAE,EAAE;IACjBC,gBAAgB,EAAE,MAAMF;GAC3B;EACDG,QAAQ,EAAEH,SAAS;EACnBI,SAAS,EAAE,KAAK;EAChBC,YAAY,EAAE,MAAML;CACvB;MAEYM,kBAAkB,GAAG,CAAC;EAAEC,WAAW;EAAEC,QAAQ;EAAEC,IAAI;EAAEN;CAAU;;EAExE,MAAM,CAACC,SAAS,EAAEC,YAAY,CAAC,GAAGX,cAAK,CAACgB,QAAQ,CAAC,KAAK,CAAC;;EAGvD,MAAM,CAACZ,gBAAgB,EAAEC,mBAAmB,CAAC,GAAGL,cAAK,CAACgB,QAAQ,CAAkC,IAAI,CAAC;EACrG,MAAM,CAACT,aAAa,EAAEC,gBAAgB,CAAC,GAAGR,cAAK,CAACgB,QAAQ,CAAyC,EAAE,CAAC;;EAGpGhB,cAAK,CAACiB,SAAS,CAAC;;IACZ,MAAMC,kBAAkB,4BAAGH,IAAI,CAACI,QAAQ,CAACC,OAAO,0DAArB,sBAAuBC,QAAQ,CAACC,QAAQ,CAACC,aAAa,CAAC;;IAGlF,IAAIV,WAAW,IAAIK,kBAAkB,EAAE;MACnCH,IAAI,CAACZ,QAAQ,CAACqB,iBAAiB,CAACT,IAAI,CAACU,uBAAuB,CAAC;;;;GAIpE,EAAE,CAACV,IAAI,CAACZ,QAAQ,CAACuB,SAAS,EAAEX,IAAI,CAACU,uBAAuB,CAAC,CAAC;EAE3D,MAAME,OAAO,GAAG3B,cAAK,CAAC4B,OAAO,CAAC;IAC1B,OAAO;MACH1B,QAAQ,EAAEW,WAAW;MACrBV,QAAQ,EAAE;QACNC,gBAAgB;QAChBC,mBAAmB;QACnBE,aAAa;QACbC;OACH;MACDC,QAAQ;MACRC,SAAS;MACTC;KACH;GACJ,EAAE,CAACE,WAAW,EAAEH,SAAS,EAAEH,aAAa,EAAEH,gBAAgB,EAAEK,QAAQ,CAAC,CAAC;EAEvE,oBAAOT,6BAACD,UAAU,CAAC8B,QAAQ;IAACC,KAAK,EAAEH;KAAUb,QAAQ,CAAuB;AAChF;MAEaiB,aAAa,GAAG,MAAM/B,cAAK,CAACgC,UAAU,CAACjC,UAAU;;;;"}
@@ -0,0 +1,36 @@
1
+ import React__default from 'react';
2
+
3
+ const ExpandedRow = ({
4
+ index,
5
+ setSize,
6
+ ...props
7
+ }) => {
8
+ const ref = React__default.useRef(null);
9
+ React__default.useEffect(() => {
10
+ if (ref.current) {
11
+ var _ref$current;
12
+ const height = (_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.getBoundingClientRect().height;
13
+ setSize(sizes => {
14
+ if (height !== sizes[index]) {
15
+ var _ref$current2;
16
+ return {
17
+ ...sizes,
18
+ [index]: (_ref$current2 = ref.current) === null || _ref$current2 === void 0 ? void 0 : _ref$current2.getBoundingClientRect().height
19
+ };
20
+ }
21
+ return sizes;
22
+ });
23
+ }
24
+ }, []);
25
+ if (props.children === null || props.children === undefined) {
26
+ return null;
27
+ }
28
+ return /*#__PURE__*/React__default.createElement("div", Object.assign({
29
+ className: "border-grey-300 bg-grey-50 col-span-full border-b p-4"
30
+ }, props, {
31
+ ref: ref
32
+ }));
33
+ };
34
+
35
+ export { ExpandedRow };
36
+ //# sourceMappingURL=ExpandedRow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ExpandedRow.js","sources":["../../../../../../../../../src/components/Table2/components/row/ExpandedRow.tsx"],"sourcesContent":["import React from 'react';\n\nexport const ExpandedRow = ({ index, setSize, ...props }) => {\n const ref = React.useRef<HTMLDivElement>(null);\n\n React.useEffect(() => {\n if (ref.current) {\n const height = ref.current?.getBoundingClientRect().height;\n\n setSize(sizes => {\n if (height !== sizes[index]) {\n return { ...sizes, [index]: ref.current?.getBoundingClientRect().height };\n }\n\n return sizes;\n });\n }\n }, []);\n\n if (props.children === null || props.children === undefined) {\n return null;\n }\n\n return <div className=\"border-grey-300 bg-grey-50 col-span-full border-b p-4\" {...props} ref={ref} />;\n};\n"],"names":["ExpandedRow","index","setSize","props","ref","React","useRef","useEffect","current","height","getBoundingClientRect","sizes","children","undefined","className"],"mappings":";;MAEaA,WAAW,GAAG,CAAC;EAAEC,KAAK;EAAEC,OAAO;EAAE,GAAGC;CAAO;EACpD,MAAMC,GAAG,GAAGC,cAAK,CAACC,MAAM,CAAiB,IAAI,CAAC;EAE9CD,cAAK,CAACE,SAAS,CAAC;IACZ,IAAIH,GAAG,CAACI,OAAO,EAAE;MAAA;MACb,MAAMC,MAAM,mBAAGL,GAAG,CAACI,OAAO,iDAAX,aAAaE,qBAAqB,EAAE,CAACD,MAAM;MAE1DP,OAAO,CAACS,KAAK;QACT,IAAIF,MAAM,KAAKE,KAAK,CAACV,KAAK,CAAC,EAAE;UAAA;UACzB,OAAO;YAAE,GAAGU,KAAK;YAAE,CAACV,KAAK,oBAAGG,GAAG,CAACI,OAAO,kDAAX,cAAaE,qBAAqB,EAAE,CAACD;WAAQ;;QAG7E,OAAOE,KAAK;OACf,CAAC;;GAET,EAAE,EAAE,CAAC;EAEN,IAAIR,KAAK,CAACS,QAAQ,KAAK,IAAI,IAAIT,KAAK,CAACS,QAAQ,KAAKC,SAAS,EAAE;IACzD,OAAO,IAAI;;EAGf,oBAAOR;IAAKS,SAAS,EAAC;KAA4DX,KAAK;IAAEC,GAAG,EAAEA;KAAO;AACzG;;;;"}
@@ -0,0 +1,43 @@
1
+ import React__default from 'react';
2
+ import { useDropTarget } from '../../../../utils/hooks/useDropTarget.js';
3
+ import { RowContextProvider, useRowContext } from './Context.js';
4
+
5
+ const InternalRow = ({
6
+ onRowDrop,
7
+ row,
8
+ rowIndex,
9
+ table,
10
+ ...props
11
+ }) => {
12
+ const {
13
+ setIsHovered
14
+ } = useRowContext();
15
+ const meta = table.options.meta;
16
+ const isActiveRow = meta.activeRowIndex === rowIndex;
17
+ const isDragging = meta.dragging[row.id];
18
+ const [, dropTargetProps] = useDropTarget(event => onRowDrop(event, row.original));
19
+ const attributes = {
20
+ ...props,
21
+ ...(typeof onRowDrop === 'function' ? dropTargetProps : undefined),
22
+ 'aria-current': isActiveRow ? true : undefined,
23
+ 'aria-grabbed': isDragging ? true : undefined,
24
+ 'data-row-index': rowIndex,
25
+ draggable: meta.enableRowDragging ? true : undefined,
26
+ onMouseEnter: () => setIsHovered(true),
27
+ onMouseLeave: () => setIsHovered(false),
28
+ role: 'row'
29
+ };
30
+ return /*#__PURE__*/React__default.createElement("div", Object.assign({}, attributes));
31
+ };
32
+ const Row = props => {
33
+ const meta = props.table.options.meta;
34
+ const isActiveRow = meta.activeRowIndex === props.rowIndex;
35
+ return /*#__PURE__*/React__default.createElement(RowContextProvider, {
36
+ isActiveRow: isActiveRow,
37
+ meta: props.table.options.meta,
38
+ rowIndex: props.rowIndex
39
+ }, /*#__PURE__*/React__default.createElement(InternalRow, Object.assign({}, props)));
40
+ };
41
+
42
+ export { Row };
43
+ //# sourceMappingURL=Row.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Row.js","sources":["../../../../../../../../../src/components/Table2/components/row/Row.tsx"],"sourcesContent":["import React from 'react';\nimport { TableMeta } from '@tanstack/react-table';\nimport { RowContextProvider, useRowContext } from './Context';\nimport { useDropTarget } from '../../../../utils/hooks/useDropTarget';\n\nconst InternalRow = ({ onRowDrop, row, rowIndex, table, ...props }) => {\n const { setIsHovered } = useRowContext();\n\n const meta = table.options.meta as TableMeta<any>;\n const isActiveRow = meta.activeRowIndex === rowIndex;\n const isDragging = meta.dragging[row.id];\n\n const [, dropTargetProps] = useDropTarget(event => onRowDrop(event, row.original));\n\n const attributes = {\n ...props,\n ...(typeof onRowDrop === 'function' ? dropTargetProps : undefined),\n 'aria-current': isActiveRow ? true : undefined,\n 'aria-grabbed': isDragging ? true : undefined,\n 'data-row-index': rowIndex,\n draggable: meta.enableRowDragging ? true : undefined,\n onMouseEnter: () => setIsHovered(true),\n onMouseLeave: () => setIsHovered(false),\n role: 'row',\n };\n\n return <div {...attributes} />;\n};\n\nexport const Row = props => {\n const meta = props.table.options.meta as TableMeta<any>;\n const isActiveRow = meta.activeRowIndex === props.rowIndex;\n\n return (\n <RowContextProvider isActiveRow={isActiveRow} meta={props.table.options.meta} rowIndex={props.rowIndex}>\n <InternalRow {...props} />\n </RowContextProvider>\n );\n};\n"],"names":["InternalRow","onRowDrop","row","rowIndex","table","props","setIsHovered","useRowContext","meta","options","isActiveRow","activeRowIndex","isDragging","dragging","id","dropTargetProps","useDropTarget","event","original","attributes","undefined","draggable","enableRowDragging","onMouseEnter","onMouseLeave","role","React","Row","RowContextProvider"],"mappings":";;;;AAKA,MAAMA,WAAW,GAAG,CAAC;EAAEC,SAAS;EAAEC,GAAG;EAAEC,QAAQ;EAAEC,KAAK;EAAE,GAAGC;CAAO;EAC9D,MAAM;IAAEC;GAAc,GAAGC,aAAa,EAAE;EAExC,MAAMC,IAAI,GAAGJ,KAAK,CAACK,OAAO,CAACD,IAAsB;EACjD,MAAME,WAAW,GAAGF,IAAI,CAACG,cAAc,KAAKR,QAAQ;EACpD,MAAMS,UAAU,GAAGJ,IAAI,CAACK,QAAQ,CAACX,GAAG,CAACY,EAAE,CAAC;EAExC,MAAM,GAAGC,eAAe,CAAC,GAAGC,aAAa,CAACC,KAAK,IAAIhB,SAAS,CAACgB,KAAK,EAAEf,GAAG,CAACgB,QAAQ,CAAC,CAAC;EAElF,MAAMC,UAAU,GAAG;IACf,GAAGd,KAAK;IACR,IAAI,OAAOJ,SAAS,KAAK,UAAU,GAAGc,eAAe,GAAGK,SAAS,CAAC;IAClE,cAAc,EAAEV,WAAW,GAAG,IAAI,GAAGU,SAAS;IAC9C,cAAc,EAAER,UAAU,GAAG,IAAI,GAAGQ,SAAS;IAC7C,gBAAgB,EAAEjB,QAAQ;IAC1BkB,SAAS,EAAEb,IAAI,CAACc,iBAAiB,GAAG,IAAI,GAAGF,SAAS;IACpDG,YAAY,EAAE,MAAMjB,YAAY,CAAC,IAAI,CAAC;IACtCkB,YAAY,EAAE,MAAMlB,YAAY,CAAC,KAAK,CAAC;IACvCmB,IAAI,EAAE;GACT;EAED,oBAAOC,sDAASP,UAAU,EAAI;AAClC,CAAC;MAEYQ,GAAG,GAAGtB,KAAK;EACpB,MAAMG,IAAI,GAAGH,KAAK,CAACD,KAAK,CAACK,OAAO,CAACD,IAAsB;EACvD,MAAME,WAAW,GAAGF,IAAI,CAACG,cAAc,KAAKN,KAAK,CAACF,QAAQ;EAE1D,oBACIuB,6BAACE,kBAAkB;IAAClB,WAAW,EAAEA,WAAW;IAAEF,IAAI,EAAEH,KAAK,CAACD,KAAK,CAACK,OAAO,CAACD,IAAI;IAAEL,QAAQ,EAAEE,KAAK,CAACF;kBAC1FuB,6BAAC1B,WAAW,oBAAKK,KAAK,EAAI,CACT;AAE7B;;;;"}
@@ -0,0 +1,19 @@
1
+ import React__default from 'react';
2
+
3
+ const useActiveRowStateListener = (table, rows, activeRowIndex) => {
4
+ const meta = table.options.meta;
5
+ React__default.useEffect(() => {
6
+ if (meta.editMode.isEditing && meta.shouldPauseSortingAndFiltering) {
7
+ meta.setShouldPauseSortingAndFiltering(false);
8
+ }
9
+ }, [activeRowIndex.activeRowIndex]);
10
+ // if a filter would exclude the active row, reset it to 0
11
+ React__default.useEffect(() => {
12
+ if (activeRowIndex.activeRowIndex > rows.length - 1) {
13
+ meta.setActiveRowIndex(rows.length ? rows.length - 1 : 0);
14
+ }
15
+ }, [table.getState().columnFilters, rows.length]);
16
+ };
17
+
18
+ export { useActiveRowStateListener };
19
+ //# sourceMappingURL=useActiveRowStateListener.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useActiveRowStateListener.js","sources":["../../../../../../../../../src/components/Table2/hooks/listeners/useActiveRowStateListener.ts"],"sourcesContent":["import React from 'react';\nimport { Row as RTRow, Table as RTTable, TableMeta } from '@tanstack/react-table';\nimport { useActiveRow } from '../useActiveRow';\n\nexport const useActiveRowStateListener = <TType = any>(\n table: RTTable<any>,\n rows: RTRow<any>[],\n activeRowIndex: useActiveRow<TType>\n) => {\n const meta = table.options.meta as TableMeta<any>;\n\n React.useEffect(() => {\n if (meta.editMode.isEditing && meta.shouldPauseSortingAndFiltering) {\n meta.setShouldPauseSortingAndFiltering(false);\n }\n }, [activeRowIndex.activeRowIndex]);\n\n // if a filter would exclude the active row, reset it to 0\n React.useEffect(() => {\n if (activeRowIndex.activeRowIndex > rows.length - 1) {\n meta.setActiveRowIndex(rows.length ? rows.length - 1 : 0);\n }\n }, [table.getState().columnFilters, rows.length]);\n};\n"],"names":["useActiveRowStateListener","table","rows","activeRowIndex","meta","options","React","useEffect","editMode","isEditing","shouldPauseSortingAndFiltering","setShouldPauseSortingAndFiltering","length","setActiveRowIndex","getState","columnFilters"],"mappings":";;MAIaA,yBAAyB,GAAG,CACrCC,KAAmB,EACnBC,IAAkB,EAClBC,cAAmC;EAEnC,MAAMC,IAAI,GAAGH,KAAK,CAACI,OAAO,CAACD,IAAsB;EAEjDE,cAAK,CAACC,SAAS,CAAC;IACZ,IAAIH,IAAI,CAACI,QAAQ,CAACC,SAAS,IAAIL,IAAI,CAACM,8BAA8B,EAAE;MAChEN,IAAI,CAACO,iCAAiC,CAAC,KAAK,CAAC;;GAEpD,EAAE,CAACR,cAAc,CAACA,cAAc,CAAC,CAAC;;EAGnCG,cAAK,CAACC,SAAS,CAAC;IACZ,IAAIJ,cAAc,CAACA,cAAc,GAAGD,IAAI,CAACU,MAAM,GAAG,CAAC,EAAE;MACjDR,IAAI,CAACS,iBAAiB,CAACX,IAAI,CAACU,MAAM,GAAGV,IAAI,CAACU,MAAM,GAAG,CAAC,GAAG,CAAC,CAAC;;GAEhE,EAAE,CAACX,KAAK,CAACa,QAAQ,EAAE,CAACC,aAAa,EAAEb,IAAI,CAACU,MAAM,CAAC,CAAC;AACrD;;;;"}
@@ -0,0 +1,28 @@
1
+ import React__default from 'react';
2
+
3
+ // frozen columns have position sticky, and because we support more than one of them
4
+ // we must set a 'left' css value. this hook listens to changes on state that will
5
+ // affect the left offset (resize, visibility, freezing) and updates offsets based on width
6
+ const useColumnOffsetStateListener = (table, setColumnOffsets) => {
7
+ const {
8
+ columnOrder,
9
+ columnSizing,
10
+ columnSizingInfo,
11
+ columnVisibility
12
+ } = table.getState();
13
+ const {
14
+ frozenColumnsCount
15
+ } = table.options.meta;
16
+ React__default.useEffect(() => {
17
+ const offsets = {};
18
+ // store left offsets for each visible column
19
+ table.getVisibleLeafColumns().reduce((offset, column) => {
20
+ offsets[column.id] = offset;
21
+ return offset + column.getSize();
22
+ }, 0);
23
+ setColumnOffsets(offsets);
24
+ }, [columnOrder, columnSizing, columnSizingInfo, columnVisibility, frozenColumnsCount]);
25
+ };
26
+
27
+ export { useColumnOffsetStateListener };
28
+ //# sourceMappingURL=useColumnOffsetStateListener.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useColumnOffsetStateListener.js","sources":["../../../../../../../../../src/components/Table2/hooks/listeners/useColumnOffsetStateListener.ts"],"sourcesContent":["import React from 'react';\nimport { Table as RTTable, OnChangeFn, TableMeta } from '@tanstack/react-table';\nimport { ColumnOffsetState } from '../../types';\n\n// frozen columns have position sticky, and because we support more than one of them\n// we must set a 'left' css value. this hook listens to changes on state that will\n// affect the left offset (resize, visibility, freezing) and updates offsets based on width\nexport const useColumnOffsetStateListener = (table: RTTable<any>, setColumnOffsets: OnChangeFn<ColumnOffsetState>) => {\n const { columnOrder, columnSizing, columnSizingInfo, columnVisibility } = table.getState();\n const { frozenColumnsCount } = table.options.meta as TableMeta<any>;\n\n React.useEffect(() => {\n const offsets = {};\n\n // store left offsets for each visible column\n table.getVisibleLeafColumns().reduce((offset, column) => {\n offsets[column.id] = offset;\n return offset + column.getSize();\n }, 0);\n\n setColumnOffsets(offsets);\n }, [columnOrder, columnSizing, columnSizingInfo, columnVisibility, frozenColumnsCount]);\n};\n"],"names":["useColumnOffsetStateListener","table","setColumnOffsets","columnOrder","columnSizing","columnSizingInfo","columnVisibility","getState","frozenColumnsCount","options","meta","React","useEffect","offsets","getVisibleLeafColumns","reduce","offset","column","id","getSize"],"mappings":";;AAIA;AACA;AACA;MACaA,4BAA4B,GAAG,CAACC,KAAmB,EAAEC,gBAA+C;EAC7G,MAAM;IAAEC,WAAW;IAAEC,YAAY;IAAEC,gBAAgB;IAAEC;GAAkB,GAAGL,KAAK,CAACM,QAAQ,EAAE;EAC1F,MAAM;IAAEC;GAAoB,GAAGP,KAAK,CAACQ,OAAO,CAACC,IAAsB;EAEnEC,cAAK,CAACC,SAAS,CAAC;IACZ,MAAMC,OAAO,GAAG,EAAE;;IAGlBZ,KAAK,CAACa,qBAAqB,EAAE,CAACC,MAAM,CAAC,CAACC,MAAM,EAAEC,MAAM;MAChDJ,OAAO,CAACI,MAAM,CAACC,EAAE,CAAC,GAAGF,MAAM;MAC3B,OAAOA,MAAM,GAAGC,MAAM,CAACE,OAAO,EAAE;KACnC,EAAE,CAAC,CAAC;IAELjB,gBAAgB,CAACW,OAAO,CAAC;GAC5B,EAAE,CAACV,WAAW,EAAEC,YAAY,EAAEC,gBAAgB,EAAEC,gBAAgB,EAAEE,kBAAkB,CAAC,CAAC;AAC3F;;;;"}
@@ -0,0 +1,12 @@
1
+ import React__default from 'react';
2
+
3
+ const useFilterStateListener = (table, onRowSelect) => {
4
+ React__default.useEffect(() => {
5
+ if (onRowSelect) {
6
+ table.resetRowSelection();
7
+ }
8
+ }, [table.getState().columnFilters, table.getState().globalFilter]);
9
+ };
10
+
11
+ export { useFilterStateListener };
12
+ //# sourceMappingURL=useFilterStateListener.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useFilterStateListener.js","sources":["../../../../../../../../../src/components/Table2/hooks/listeners/useFilterStateListener.ts"],"sourcesContent":["import React from 'react';\nimport { Table as RTTable } from '@tanstack/react-table';\nimport { RowSelectionHandler } from '../../types';\n\nexport const useFilterStateListener = <TType = any>(table: RTTable<TType>, onRowSelect: RowSelectionHandler | undefined) => {\n React.useEffect(() => {\n if (onRowSelect) {\n table.resetRowSelection();\n }\n }, [table.getState().columnFilters, table.getState().globalFilter]);\n};\n"],"names":["useFilterStateListener","table","onRowSelect","React","useEffect","resetRowSelection","getState","columnFilters","globalFilter"],"mappings":";;MAIaA,sBAAsB,GAAG,CAAcC,KAAqB,EAAEC,WAA4C;EACnHC,cAAK,CAACC,SAAS,CAAC;IACZ,IAAIF,WAAW,EAAE;MACbD,KAAK,CAACI,iBAAiB,EAAE;;GAEhC,EAAE,CAACJ,KAAK,CAACK,QAAQ,EAAE,CAACC,aAAa,EAAEN,KAAK,CAACK,QAAQ,EAAE,CAACE,YAAY,CAAC,CAAC;AACvE;;;;"}
@@ -0,0 +1,18 @@
1
+ import React__default from 'react';
2
+
3
+ const useRowSelectionListener = (table, onRowSelect) => {
4
+ React__default.useEffect(() => {
5
+ if (onRowSelect) {
6
+ if (table.options.enableMultiRowSelection) {
7
+ const rows = table.getSelectedRowModel().rows.map(row => row.original);
8
+ onRowSelect(rows, table.getIsAllRowsSelected());
9
+ } else {
10
+ var _table$getSelectedRow, _table$getSelectedRow2;
11
+ onRowSelect((_table$getSelectedRow = (_table$getSelectedRow2 = table.getSelectedRowModel().rows[0]) === null || _table$getSelectedRow2 === void 0 ? void 0 : _table$getSelectedRow2.original) !== null && _table$getSelectedRow !== void 0 ? _table$getSelectedRow : undefined, false);
12
+ }
13
+ }
14
+ }, [table.getState().rowSelection]);
15
+ };
16
+
17
+ export { useRowSelectionListener };
18
+ //# sourceMappingURL=useRowSelectionListener.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useRowSelectionListener.js","sources":["../../../../../../../../../src/components/Table2/hooks/listeners/useRowSelectionListener.ts"],"sourcesContent":["import React from 'react';\nimport { Table as RTTable } from '@tanstack/react-table';\nimport { RowSelectionHandler } from '../../types';\n\nexport const useRowSelectionListener = <TType = any>(table: RTTable<any>, onRowSelect: RowSelectionHandler | undefined) => {\n React.useEffect(() => {\n if (onRowSelect) {\n if (table.options.enableMultiRowSelection) {\n const rows = table.getSelectedRowModel().rows.map(row => row.original) as TType[];\n\n onRowSelect(rows, table.getIsAllRowsSelected());\n } else {\n onRowSelect(table.getSelectedRowModel().rows[0]?.original ?? undefined, false);\n }\n }\n }, [table.getState().rowSelection]);\n};\n"],"names":["useRowSelectionListener","table","onRowSelect","React","useEffect","options","enableMultiRowSelection","rows","getSelectedRowModel","map","row","original","getIsAllRowsSelected","undefined","getState","rowSelection"],"mappings":";;MAIaA,uBAAuB,GAAG,CAAcC,KAAmB,EAAEC,WAA4C;EAClHC,cAAK,CAACC,SAAS,CAAC;IACZ,IAAIF,WAAW,EAAE;MACb,IAAID,KAAK,CAACI,OAAO,CAACC,uBAAuB,EAAE;QACvC,MAAMC,IAAI,GAAGN,KAAK,CAACO,mBAAmB,EAAE,CAACD,IAAI,CAACE,GAAG,CAACC,GAAG,IAAIA,GAAG,CAACC,QAAQ,CAAY;QAEjFT,WAAW,CAACK,IAAI,EAAEN,KAAK,CAACW,oBAAoB,EAAE,CAAC;OAClD,MAAM;QAAA;QACHV,WAAW,oDAACD,KAAK,CAACO,mBAAmB,EAAE,CAACD,IAAI,CAAC,CAAC,CAAC,2DAAnC,uBAAqCI,QAAQ,yEAAIE,SAAS,EAAE,KAAK,CAAC;;;GAGzF,EAAE,CAACZ,KAAK,CAACa,QAAQ,EAAE,CAACC,YAAY,CAAC,CAAC;AACvC;;;;"}
@@ -0,0 +1,25 @@
1
+ import React__default from 'react';
2
+
3
+ const useSettingsStateListener = (table, onChangeSettings) => {
4
+ const meta = table.options.meta;
5
+ const state = table.getState();
6
+ React__default.useEffect(() => {
7
+ let handler;
8
+ if (typeof onChangeSettings === 'function') {
9
+ handler = setTimeout(() => onChangeSettings({
10
+ columnFilters: state.columnFilters,
11
+ columnOrder: state.columnOrder,
12
+ columnSizing: state.columnSizing,
13
+ columnVisibility: state.columnVisibility,
14
+ frozenColumnCount: meta.frozenColumnsCount,
15
+ globalFilter: state.globalFilter,
16
+ rowDensity: meta.rowDensity,
17
+ sorting: state.sorting
18
+ }), 250);
19
+ }
20
+ return () => clearTimeout(handler);
21
+ }, [state.columnFilters, state.columnOrder, meta.frozenColumnsCount, state.columnSizing, state.columnVisibility, state.globalFilter, meta.rowDensity, state.sorting]);
22
+ };
23
+
24
+ export { useSettingsStateListener };
25
+ //# sourceMappingURL=useSettingsStateListener.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useSettingsStateListener.js","sources":["../../../../../../../../../src/components/Table2/hooks/listeners/useSettingsStateListener.ts"],"sourcesContent":["import React from 'react';\nimport { Table as RTTable, TableMeta } from '@tanstack/react-table';\nimport { SettingsHandler } from '../../types';\n\nexport const useSettingsStateListener = (table: RTTable<any>, onChangeSettings: SettingsHandler | undefined) => {\n const meta = table.options.meta as TableMeta<any>;\n const state = table.getState();\n\n React.useEffect(() => {\n let handler;\n\n if (typeof onChangeSettings === 'function') {\n handler = setTimeout(\n () =>\n onChangeSettings({\n columnFilters: state.columnFilters,\n columnOrder: state.columnOrder,\n columnSizing: state.columnSizing,\n columnVisibility: state.columnVisibility,\n frozenColumnCount: meta.frozenColumnsCount,\n globalFilter: state.globalFilter,\n rowDensity: meta.rowDensity,\n sorting: state.sorting,\n }),\n 250\n );\n }\n\n return () => clearTimeout(handler);\n }, [\n state.columnFilters,\n state.columnOrder,\n meta.frozenColumnsCount,\n state.columnSizing,\n state.columnVisibility,\n state.globalFilter,\n meta.rowDensity,\n state.sorting,\n ]);\n};\n"],"names":["useSettingsStateListener","table","onChangeSettings","meta","options","state","getState","React","useEffect","handler","setTimeout","columnFilters","columnOrder","columnSizing","columnVisibility","frozenColumnCount","frozenColumnsCount","globalFilter","rowDensity","sorting","clearTimeout"],"mappings":";;MAIaA,wBAAwB,GAAG,CAACC,KAAmB,EAAEC,gBAA6C;EACvG,MAAMC,IAAI,GAAGF,KAAK,CAACG,OAAO,CAACD,IAAsB;EACjD,MAAME,KAAK,GAAGJ,KAAK,CAACK,QAAQ,EAAE;EAE9BC,cAAK,CAACC,SAAS,CAAC;IACZ,IAAIC,OAAO;IAEX,IAAI,OAAOP,gBAAgB,KAAK,UAAU,EAAE;MACxCO,OAAO,GAAGC,UAAU,CAChB,MACIR,gBAAgB,CAAC;QACbS,aAAa,EAAEN,KAAK,CAACM,aAAa;QAClCC,WAAW,EAAEP,KAAK,CAACO,WAAW;QAC9BC,YAAY,EAAER,KAAK,CAACQ,YAAY;QAChCC,gBAAgB,EAAET,KAAK,CAACS,gBAAgB;QACxCC,iBAAiB,EAAEZ,IAAI,CAACa,kBAAkB;QAC1CC,YAAY,EAAEZ,KAAK,CAACY,YAAY;QAChCC,UAAU,EAAEf,IAAI,CAACe,UAAU;QAC3BC,OAAO,EAAEd,KAAK,CAACc;OAClB,CAAC,EACN,GAAG,CACN;;IAGL,OAAO,MAAMC,YAAY,CAACX,OAAO,CAAC;GACrC,EAAE,CACCJ,KAAK,CAACM,aAAa,EACnBN,KAAK,CAACO,WAAW,EACjBT,IAAI,CAACa,kBAAkB,EACvBX,KAAK,CAACQ,YAAY,EAClBR,KAAK,CAACS,gBAAgB,EACtBT,KAAK,CAACY,YAAY,EAClBd,IAAI,CAACe,UAAU,EACfb,KAAK,CAACc,OAAO,CAChB,CAAC;AACN;;;;"}
@@ -0,0 +1,33 @@
1
+ import React__default from 'react';
2
+
3
+ const useActiveRow = (defaultActiveRowIndex = 0) => {
4
+ const [activeRowIndex, _setActiveRow] = React__default.useState(defaultActiveRowIndex);
5
+ const moveActiveRow = (direction, rows, callback) => {
6
+ _setActiveRow(rowIndex => {
7
+ const nextRowIndex = getNextIndex(direction, rowIndex, rows.length);
8
+ if (callback) {
9
+ callback(nextRowIndex);
10
+ }
11
+ return nextRowIndex;
12
+ });
13
+ };
14
+ // output
15
+ const moveToPreviousRow = (rows, callback) => moveActiveRow(-1, rows, callback);
16
+ const moveToNextRow = (rows, callback) => moveActiveRow(1, rows, callback);
17
+ const setActiveRowIndex = rowIndex => _setActiveRow(rowIndex);
18
+ return {
19
+ activeRowIndex,
20
+ setActiveRowIndex,
21
+ moveToPreviousRow,
22
+ moveToNextRow
23
+ };
24
+ };
25
+ const getNextIndex = (direction, currentIndex, length) => {
26
+ if (direction === -1) {
27
+ return currentIndex - 1 > 0 ? currentIndex - 1 : 0;
28
+ }
29
+ return currentIndex + 1 < length ? currentIndex + 1 : currentIndex;
30
+ };
31
+
32
+ export { useActiveRow };
33
+ //# sourceMappingURL=useActiveRow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useActiveRow.js","sources":["../../../../../../../../src/components/Table2/hooks/useActiveRow.ts"],"sourcesContent":["import React from 'react';\nimport { Row as TRow } from '@tanstack/react-table';\n\n/*\n Note: We have to use row id as the identifier for the row, index isn't good enough\n\n If new rows are added (e.g. by polling of data) and we use index, then the active row\n could change to a different row, this is really bad if the user is editing a row.\n \n Using row id allows us to always stay on the same row. We have to store index though to make\n arrow key navigation performant (otherwise we have to findIndex the entire row array each time).\n*/\n\nexport type ActiveRowHandler = (rowIndex: number) => void;\nexport type ActiveRowMoveHandler<TType = any> = (rows: TRow<TType>[], callback?: (index: number) => void) => void;\n\nexport type useActiveRow<TType = any> = {\n activeRowIndex: number;\n setActiveRowIndex: ActiveRowHandler;\n moveToPreviousRow: ActiveRowMoveHandler<TType>;\n moveToNextRow: ActiveRowMoveHandler<TType>;\n};\n\nexport const useActiveRow = <TType = any>(defaultActiveRowIndex = 0): useActiveRow<TType> => {\n const [activeRowIndex, _setActiveRow] = React.useState<number>(defaultActiveRowIndex);\n\n const moveActiveRow = (direction: -1 | 1, rows: TRow<TType>[], callback?: (index: number) => void) => {\n _setActiveRow(rowIndex => {\n const nextRowIndex = getNextIndex(direction, rowIndex, rows.length);\n if (callback) {\n callback(nextRowIndex);\n }\n return nextRowIndex;\n });\n };\n\n // output\n const moveToPreviousRow = (rows: TRow<TType>[], callback?: (index: number) => void) => moveActiveRow(-1, rows, callback);\n const moveToNextRow = (rows: TRow<TType>[], callback?: (index: number) => void) => moveActiveRow(1, rows, callback);\n const setActiveRowIndex = (rowIndex: number) => _setActiveRow(rowIndex);\n\n return {\n activeRowIndex,\n setActiveRowIndex,\n moveToPreviousRow,\n moveToNextRow,\n };\n};\n\nconst getNextIndex = (direction: -1 | 1, currentIndex: number, length: number) => {\n if (direction === -1) {\n return currentIndex - 1 > 0 ? currentIndex - 1 : 0;\n }\n\n return currentIndex + 1 < length ? currentIndex + 1 : currentIndex;\n};\n"],"names":["useActiveRow","defaultActiveRowIndex","activeRowIndex","_setActiveRow","React","useState","moveActiveRow","direction","rows","callback","rowIndex","nextRowIndex","getNextIndex","length","moveToPreviousRow","moveToNextRow","setActiveRowIndex","currentIndex"],"mappings":";;MAuBaA,YAAY,GAAG,CAAcC,qBAAqB,GAAG,CAAC;EAC/D,MAAM,CAACC,cAAc,EAAEC,aAAa,CAAC,GAAGC,cAAK,CAACC,QAAQ,CAASJ,qBAAqB,CAAC;EAErF,MAAMK,aAAa,GAAG,CAACC,SAAiB,EAAEC,IAAmB,EAAEC,QAAkC;IAC7FN,aAAa,CAACO,QAAQ;MAClB,MAAMC,YAAY,GAAGC,YAAY,CAACL,SAAS,EAAEG,QAAQ,EAAEF,IAAI,CAACK,MAAM,CAAC;MACnE,IAAIJ,QAAQ,EAAE;QACVA,QAAQ,CAACE,YAAY,CAAC;;MAE1B,OAAOA,YAAY;KACtB,CAAC;GACL;;EAGD,MAAMG,iBAAiB,GAAG,CAACN,IAAmB,EAAEC,QAAkC,KAAKH,aAAa,CAAC,CAAC,CAAC,EAAEE,IAAI,EAAEC,QAAQ,CAAC;EACxH,MAAMM,aAAa,GAAG,CAACP,IAAmB,EAAEC,QAAkC,KAAKH,aAAa,CAAC,CAAC,EAAEE,IAAI,EAAEC,QAAQ,CAAC;EACnH,MAAMO,iBAAiB,GAAIN,QAAgB,IAAKP,aAAa,CAACO,QAAQ,CAAC;EAEvE,OAAO;IACHR,cAAc;IACdc,iBAAiB;IACjBF,iBAAiB;IACjBC;GACH;AACL;AAEA,MAAMH,YAAY,GAAG,CAACL,SAAiB,EAAEU,YAAoB,EAAEJ,MAAc;EACzE,IAAIN,SAAS,KAAK,CAAC,CAAC,EAAE;IAClB,OAAOU,YAAY,GAAG,CAAC,GAAG,CAAC,GAAGA,YAAY,GAAG,CAAC,GAAG,CAAC;;EAGtD,OAAOA,YAAY,GAAG,CAAC,GAAGJ,MAAM,GAAGI,YAAY,GAAG,CAAC,GAAGA,YAAY;AACtE,CAAC;;;;"}
@@ -0,0 +1,122 @@
1
+ import React__default from 'react';
2
+ import { useLocalization } from '../../Provider/Localization.js';
3
+ import { createColumnHelper } from '@tanstack/react-table';
4
+ import { createRowExpansionColumn, createRowSelectionColumn, createRowDraggableColumn, createRowActionsColumn, MIN_COLUMN_SIZE } from '../utilities/columns.js';
5
+
6
+ function useColumnDefinitions(children, options, tableRef) {
7
+ const {
8
+ texts
9
+ } = useLocalization();
10
+ const lastSelectedRowIndex = React__default.useRef();
11
+ const columnHelper = createColumnHelper();
12
+ return React__default.useMemo(() => {
13
+ var _options$actionsForRo;
14
+ let internalFrozenColumnCount = 0;
15
+ // cannot be typed correctly until https://github.com/TanStack/table/discussions/4530 is resolved
16
+ const columns = [];
17
+ const defaultColumnSizing = {};
18
+ const defaultColumnVisibility = {};
19
+ const defaultSorting = [];
20
+ const footers = {};
21
+ React__default.Children.toArray(children).filter(child => !!child).forEach(child => {
22
+ if ( /*#__PURE__*/React__default.isValidElement(child)) {
23
+ var _child$props$minWidth;
24
+ const defaultWidth = child.props.defaultWidth === 'grow' ? '1fr' : child.props.defaultWidth;
25
+ if (defaultWidth) {
26
+ defaultColumnSizing[child.props.accessor] = defaultWidth;
27
+ }
28
+ if (child.props.defaultHidden && options.enableColumnHiding) {
29
+ defaultColumnVisibility[child.props.accessor] = false;
30
+ }
31
+ if (child.props.sort !== undefined) {
32
+ defaultSorting.push({
33
+ id: child.props.accessor,
34
+ desc: child.props.sort === 'desc'
35
+ });
36
+ }
37
+ if (child.props.footer) {
38
+ footers[child.props.accessor] = child.props.footer;
39
+ }
40
+ columns.push({
41
+ accessorKey: child.props.accessor,
42
+ id: child.props.accessor,
43
+ cell: props => {
44
+ var _value;
45
+ let value = props.getValue();
46
+ if (typeof child.props.renderer === 'function') {
47
+ value = child.props.renderer(value, props.row.original);
48
+ }
49
+ if (typeof value === 'string' || typeof value === 'number') {
50
+ return /*#__PURE__*/React__default.createElement("span", {
51
+ className: "truncate"
52
+ }, value);
53
+ }
54
+ return (_value = value) !== null && _value !== void 0 ? _value : null;
55
+ },
56
+ header: child.props.header,
57
+ meta: {
58
+ align: child.props.align,
59
+ className: child.props.className,
60
+ control: child.props.control,
61
+ dataType: child.props.dataType,
62
+ defaultWidth,
63
+ disableReordering: child.props.disableReordering,
64
+ menu: child.props.menu,
65
+ tooltip: child.props.tooltip
66
+ },
67
+ enableHiding: !child.props.disableHiding,
68
+ // filtering
69
+ enableColumnFilter: !child.props.disableFiltering,
70
+ filterFn: options.enableColumnFiltering && !child.props.disableFiltering ? 'tacoFilter' : undefined,
71
+ // sizing
72
+ enableResizing: !child.props.disableResizing,
73
+ minSize: (_child$props$minWidth = child.props.minWidth) !== null && _child$props$minWidth !== void 0 ? _child$props$minWidth : MIN_COLUMN_SIZE,
74
+ size: child.props.defaultWidth,
75
+ // sorting
76
+ enableSorting: !child.props.disableSorting,
77
+ sortingFn: getSortingFn(child.props.dataType, child.props.sortFn),
78
+ sortDescFirst: false,
79
+ sortUndefined: 1
80
+ });
81
+ }
82
+ });
83
+ if (options.enableRowExpansion && options.expandedRowRenderer) {
84
+ columns.unshift(columnHelper.display(createRowExpansionColumn(options.expandedRowRenderer, texts)));
85
+ internalFrozenColumnCount++;
86
+ }
87
+ if (options.enableRowSelection) {
88
+ columns.unshift(columnHelper.display(createRowSelectionColumn(options.enableMultipleRowSelection, lastSelectedRowIndex, options.onRowDrag, tableRef, texts)));
89
+ internalFrozenColumnCount++;
90
+ }
91
+ if (options.onRowDrag) {
92
+ columns.unshift(columnHelper.display(createRowDraggableColumn(options.onRowDrag, texts)));
93
+ internalFrozenColumnCount++;
94
+ }
95
+ if ((_options$actionsForRo = options.actionsForRow) !== null && _options$actionsForRo !== void 0 && _options$actionsForRo.length) {
96
+ columns.push(columnHelper.display(createRowActionsColumn(options.actionsForRow, options.actionsForRowLength, texts)));
97
+ }
98
+ return {
99
+ columns,
100
+ internalFrozenColumnCount,
101
+ defaultColumnSizing,
102
+ defaultColumnVisibility,
103
+ defaultSorting,
104
+ footers
105
+ };
106
+ }, [children]);
107
+ }
108
+ function getSortingFn(dataType, customFn) {
109
+ if (typeof customFn === 'function') {
110
+ return (rowA, rowB, columnId) => customFn(rowA.original, rowB.original, columnId);
111
+ }
112
+ if (customFn) {
113
+ return customFn;
114
+ }
115
+ if (dataType && dataType !== 'boolean') {
116
+ return dataType;
117
+ }
118
+ return 'auto';
119
+ }
120
+
121
+ export { useColumnDefinitions };
122
+ //# sourceMappingURL=useColumnDefinitions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useColumnDefinitions.js","sources":["../../../../../../../../src/components/Table2/hooks/useColumnDefinitions.tsx"],"sourcesContent":["import React from 'react';\nimport {\n createColumnHelper,\n ColumnSort,\n ColumnSizingState,\n Row,\n RowData,\n VisibilityState,\n SortingFnOption,\n Table,\n} from '@tanstack/react-table';\nimport {\n CellAlignment,\n ColumnDataType,\n RowDragHandler,\n RowExpansionRenderer,\n SortFn,\n Table2Children,\n Table2ColumnControlRenderer,\n Table2ColumnFooterRenderer,\n Table2ColumnHeaderMenu,\n Table2ColumnProps,\n Table2RowActionRenderer,\n} from '../types';\nimport {\n createRowActionsColumn,\n createRowDraggableColumn,\n createRowExpansionColumn,\n createRowSelectionColumn,\n MIN_COLUMN_SIZE,\n} from '../utilities/columns';\nimport { useLocalization } from '../../Provider/Localization';\n\ndeclare module '@tanstack/table-core' {\n interface ColumnMeta<TData extends RowData, TValue> {\n align?: CellAlignment;\n className?: string | ((row: Row<TData>, table: Table<TData>) => string);\n control?: Table2ColumnControlRenderer;\n dataType?: ColumnDataType;\n disableReordering?: boolean;\n defaultWidth?: number | 'grow';\n headerClassName?: string;\n menu?: Table2ColumnHeaderMenu;\n tooltip?: string;\n }\n}\n\ntype useColumnDefinitionsOptions<TType> = {\n actionsForRow: Table2RowActionRenderer<TType>[];\n actionsForRowLength: number;\n enableColumnFiltering: boolean;\n enableColumnHiding: boolean;\n enableColumnFreezing: boolean;\n enableRowExpansion: boolean;\n enableRowSelection: boolean;\n enableMultipleRowSelection: boolean;\n expandedRowRenderer?: RowExpansionRenderer<TType>;\n onRowDrag?: RowDragHandler<TType>;\n};\n\nexport function useColumnDefinitions<TType = any>(\n children: Table2Children,\n options: useColumnDefinitionsOptions<TType>,\n tableRef: React.RefObject<HTMLDivElement>\n) {\n const { texts } = useLocalization();\n const lastSelectedRowIndex = React.useRef<number>();\n const columnHelper = createColumnHelper<TType>();\n\n return React.useMemo(() => {\n let internalFrozenColumnCount = 0;\n // cannot be typed correctly until https://github.com/TanStack/table/discussions/4530 is resolved\n const columns: any[] = [];\n const defaultColumnSizing: ColumnSizingState = {};\n const defaultColumnVisibility: VisibilityState = {};\n const defaultSorting: ColumnSort[] = [];\n const footers: Record<string, Table2ColumnFooterRenderer> = {};\n\n (React.Children.toArray(children) as React.ReactElement<Table2ColumnProps<TType>>[])\n .filter((child: any) => !!child)\n .forEach(child => {\n if (React.isValidElement(child)) {\n const defaultWidth = child.props.defaultWidth === 'grow' ? '1fr' : child.props.defaultWidth;\n\n if (defaultWidth) {\n defaultColumnSizing[child.props.accessor] = defaultWidth as any;\n }\n\n if (child.props.defaultHidden && options.enableColumnHiding) {\n defaultColumnVisibility[child.props.accessor] = false;\n }\n\n if (child.props.sort !== undefined) {\n defaultSorting.push({\n id: child.props.accessor,\n desc: child.props.sort === 'desc',\n });\n }\n\n if (child.props.footer) {\n footers[child.props.accessor] = child.props.footer;\n }\n\n columns.push({\n accessorKey: child.props.accessor,\n id: child.props.accessor,\n cell: props => {\n let value = props.getValue();\n\n if (typeof child.props.renderer === 'function') {\n value = child.props.renderer(value, props.row.original);\n }\n\n if (typeof value === 'string' || typeof value === 'number') {\n return <span className=\"truncate\">{value}</span>;\n }\n\n return value ?? null;\n },\n header: child.props.header,\n meta: {\n align: child.props.align,\n className: child.props.className,\n control: child.props.control,\n dataType: child.props.dataType,\n defaultWidth,\n disableReordering: child.props.disableReordering,\n menu: child.props.menu,\n tooltip: child.props.tooltip,\n },\n enableHiding: !child.props.disableHiding,\n // filtering\n enableColumnFilter: !child.props.disableFiltering,\n filterFn:\n options.enableColumnFiltering && !child.props.disableFiltering ? ('tacoFilter' as any) : undefined,\n // sizing\n enableResizing: !child.props.disableResizing,\n minSize: child.props.minWidth ?? MIN_COLUMN_SIZE,\n size: child.props.defaultWidth,\n // sorting\n enableSorting: !child.props.disableSorting,\n sortingFn: getSortingFn<TType>(child.props.dataType, child.props.sortFn),\n sortDescFirst: false,\n sortUndefined: 1,\n });\n }\n });\n\n if (options.enableRowExpansion && options.expandedRowRenderer) {\n columns.unshift(columnHelper.display(createRowExpansionColumn(options.expandedRowRenderer, texts)));\n internalFrozenColumnCount++;\n }\n\n if (options.enableRowSelection) {\n columns.unshift(\n columnHelper.display(\n createRowSelectionColumn(\n options.enableMultipleRowSelection,\n lastSelectedRowIndex,\n options.onRowDrag,\n tableRef,\n texts\n )\n )\n );\n internalFrozenColumnCount++;\n }\n\n if (options.onRowDrag) {\n columns.unshift(columnHelper.display(createRowDraggableColumn(options.onRowDrag, texts)));\n internalFrozenColumnCount++;\n }\n\n if (options.actionsForRow?.length) {\n columns.push(columnHelper.display(createRowActionsColumn(options.actionsForRow, options.actionsForRowLength, texts)));\n }\n\n return { columns, internalFrozenColumnCount, defaultColumnSizing, defaultColumnVisibility, defaultSorting, footers };\n }, [children]);\n}\n\nfunction getSortingFn<TType>(dataType?: ColumnDataType, customFn?: SortFn<TType>): SortingFnOption<TType> {\n if (typeof customFn === 'function') {\n return (rowA, rowB, columnId) => customFn(rowA.original, rowB.original, columnId);\n }\n\n if (customFn) {\n return customFn;\n }\n\n if (dataType && dataType !== 'boolean') {\n return dataType;\n }\n\n return 'auto';\n}\n"],"names":["useColumnDefinitions","children","options","tableRef","texts","useLocalization","lastSelectedRowIndex","React","useRef","columnHelper","createColumnHelper","useMemo","internalFrozenColumnCount","columns","defaultColumnSizing","defaultColumnVisibility","defaultSorting","footers","Children","toArray","filter","child","forEach","isValidElement","defaultWidth","props","accessor","defaultHidden","enableColumnHiding","sort","undefined","push","id","desc","footer","accessorKey","cell","value","getValue","renderer","row","original","className","header","meta","align","control","dataType","disableReordering","menu","tooltip","enableHiding","disableHiding","enableColumnFilter","disableFiltering","filterFn","enableColumnFiltering","enableResizing","disableResizing","minSize","minWidth","MIN_COLUMN_SIZE","size","enableSorting","disableSorting","sortingFn","getSortingFn","sortFn","sortDescFirst","sortUndefined","enableRowExpansion","expandedRowRenderer","unshift","display","createRowExpansionColumn","enableRowSelection","createRowSelectionColumn","enableMultipleRowSelection","onRowDrag","createRowDraggableColumn","actionsForRow","length","createRowActionsColumn","actionsForRowLength","customFn","rowA","rowB","columnId"],"mappings":"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"}