@vuu-ui/vuu-table 0.13.7 → 0.13.8

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 (269) hide show
  1. package/cjs/index.js +5236 -61
  2. package/cjs/index.js.map +1 -1
  3. package/esm/index.js +5205 -26
  4. package/esm/index.js.map +1 -1
  5. package/package.json +10 -10
  6. package/cjs/CellFocusState.js +0 -45
  7. package/cjs/CellFocusState.js.map +0 -1
  8. package/cjs/Row.css.js +0 -6
  9. package/cjs/Row.css.js.map +0 -1
  10. package/cjs/Row.js +0 -151
  11. package/cjs/Row.js.map +0 -1
  12. package/cjs/Table.css.js +0 -6
  13. package/cjs/Table.css.js.map +0 -1
  14. package/cjs/Table.js +0 -433
  15. package/cjs/Table.js.map +0 -1
  16. package/cjs/VirtualColSpan.js +0 -19
  17. package/cjs/VirtualColSpan.js.map +0 -1
  18. package/cjs/bulk-edit/BulkEditDialog.js +0 -57
  19. package/cjs/bulk-edit/BulkEditDialog.js.map +0 -1
  20. package/cjs/bulk-edit/BulkEditPanel.css.js +0 -6
  21. package/cjs/bulk-edit/BulkEditPanel.css.js.map +0 -1
  22. package/cjs/bulk-edit/BulkEditPanel.js +0 -72
  23. package/cjs/bulk-edit/BulkEditPanel.js.map +0 -1
  24. package/cjs/bulk-edit/BulkEditRow.css.js +0 -6
  25. package/cjs/bulk-edit/BulkEditRow.css.js.map +0 -1
  26. package/cjs/bulk-edit/BulkEditRow.js +0 -81
  27. package/cjs/bulk-edit/BulkEditRow.js.map +0 -1
  28. package/cjs/bulk-edit/useBulkEditPanel.js +0 -101
  29. package/cjs/bulk-edit/useBulkEditPanel.js.map +0 -1
  30. package/cjs/bulk-edit/useBulkEditRow.js +0 -144
  31. package/cjs/bulk-edit/useBulkEditRow.js.map +0 -1
  32. package/cjs/cell-block/CellBlock.css.js +0 -6
  33. package/cjs/cell-block/CellBlock.css.js.map +0 -1
  34. package/cjs/cell-block/CellBlock.js +0 -45
  35. package/cjs/cell-block/CellBlock.js.map +0 -1
  36. package/cjs/cell-block/cellblock-utils.js +0 -125
  37. package/cjs/cell-block/cellblock-utils.js.map +0 -1
  38. package/cjs/cell-block/useCellBlockSelection.js +0 -254
  39. package/cjs/cell-block/useCellBlockSelection.js.map +0 -1
  40. package/cjs/cell-renderers/checkbox-cell/CheckboxCell.css.js +0 -6
  41. package/cjs/cell-renderers/checkbox-cell/CheckboxCell.css.js.map +0 -1
  42. package/cjs/cell-renderers/checkbox-cell/CheckboxCell.js +0 -68
  43. package/cjs/cell-renderers/checkbox-cell/CheckboxCell.js.map +0 -1
  44. package/cjs/cell-renderers/checkbox-row-selector/CheckboxRowSelectorCell.css.js +0 -6
  45. package/cjs/cell-renderers/checkbox-row-selector/CheckboxRowSelectorCell.css.js.map +0 -1
  46. package/cjs/cell-renderers/checkbox-row-selector/CheckboxRowSelectorCell.js +0 -33
  47. package/cjs/cell-renderers/checkbox-row-selector/CheckboxRowSelectorCell.js.map +0 -1
  48. package/cjs/cell-renderers/input-cell/InputCell.css.js +0 -6
  49. package/cjs/cell-renderers/input-cell/InputCell.css.js.map +0 -1
  50. package/cjs/cell-renderers/input-cell/InputCell.js +0 -52
  51. package/cjs/cell-renderers/input-cell/InputCell.js.map +0 -1
  52. package/cjs/cell-renderers/toggle-cell/ToggleCell.css.js +0 -6
  53. package/cjs/cell-renderers/toggle-cell/ToggleCell.css.js.map +0 -1
  54. package/cjs/cell-renderers/toggle-cell/ToggleCell.js +0 -67
  55. package/cjs/cell-renderers/toggle-cell/ToggleCell.js.map +0 -1
  56. package/cjs/column-header-pill/ColumnHeaderPill.css.js +0 -6
  57. package/cjs/column-header-pill/ColumnHeaderPill.css.js.map +0 -1
  58. package/cjs/column-header-pill/ColumnHeaderPill.js +0 -53
  59. package/cjs/column-header-pill/ColumnHeaderPill.js.map +0 -1
  60. package/cjs/column-header-pill/GroupColumnPill.css.js +0 -6
  61. package/cjs/column-header-pill/GroupColumnPill.css.js.map +0 -1
  62. package/cjs/column-header-pill/GroupColumnPill.js +0 -29
  63. package/cjs/column-header-pill/GroupColumnPill.js.map +0 -1
  64. package/cjs/column-header-pill/SortIndicator.css.js +0 -6
  65. package/cjs/column-header-pill/SortIndicator.css.js.map +0 -1
  66. package/cjs/column-header-pill/SortIndicator.js +0 -27
  67. package/cjs/column-header-pill/SortIndicator.js.map +0 -1
  68. package/cjs/column-resizing/ColumnResizer.css.js +0 -6
  69. package/cjs/column-resizing/ColumnResizer.css.js.map +0 -1
  70. package/cjs/column-resizing/ColumnResizer.js +0 -82
  71. package/cjs/column-resizing/ColumnResizer.js.map +0 -1
  72. package/cjs/column-resizing/useTableColumnResize.js +0 -55
  73. package/cjs/column-resizing/useTableColumnResize.js.map +0 -1
  74. package/cjs/header-cell/GroupHeaderCell.css.js +0 -6
  75. package/cjs/header-cell/GroupHeaderCell.css.js.map +0 -1
  76. package/cjs/header-cell/GroupHeaderCell.js +0 -127
  77. package/cjs/header-cell/GroupHeaderCell.js.map +0 -1
  78. package/cjs/header-cell/HeaderCell.css.js +0 -6
  79. package/cjs/header-cell/HeaderCell.css.js.map +0 -1
  80. package/cjs/header-cell/HeaderCell.js +0 -120
  81. package/cjs/header-cell/HeaderCell.js.map +0 -1
  82. package/cjs/pagination/PaginationControl.css.js +0 -6
  83. package/cjs/pagination/PaginationControl.css.js.map +0 -1
  84. package/cjs/pagination/PaginationControl.js +0 -38
  85. package/cjs/pagination/PaginationControl.js.map +0 -1
  86. package/cjs/pagination/usePagination.js +0 -36
  87. package/cjs/pagination/usePagination.js.map +0 -1
  88. package/cjs/table-cell/TableCell.css.js +0 -6
  89. package/cjs/table-cell/TableCell.css.js.map +0 -1
  90. package/cjs/table-cell/TableCell.js +0 -95
  91. package/cjs/table-cell/TableCell.js.map +0 -1
  92. package/cjs/table-cell/TableGroupCell.css.js +0 -6
  93. package/cjs/table-cell/TableGroupCell.css.js.map +0 -1
  94. package/cjs/table-cell/TableGroupCell.js +0 -66
  95. package/cjs/table-cell/TableGroupCell.js.map +0 -1
  96. package/cjs/table-config.js +0 -35
  97. package/cjs/table-config.js.map +0 -1
  98. package/cjs/table-dom-utils.js +0 -202
  99. package/cjs/table-dom-utils.js.map +0 -1
  100. package/cjs/table-header/HeaderProvider.js +0 -18
  101. package/cjs/table-header/HeaderProvider.js.map +0 -1
  102. package/cjs/table-header/TableHeader.js +0 -166
  103. package/cjs/table-header/TableHeader.js.map +0 -1
  104. package/cjs/table-header/useTableHeader.js +0 -85
  105. package/cjs/table-header/useTableHeader.js.map +0 -1
  106. package/cjs/useCell.js +0 -28
  107. package/cjs/useCell.js.map +0 -1
  108. package/cjs/useCellEditing.js +0 -79
  109. package/cjs/useCellEditing.js.map +0 -1
  110. package/cjs/useCellFocus.js +0 -115
  111. package/cjs/useCellFocus.js.map +0 -1
  112. package/cjs/useControlledTableNavigation.js +0 -46
  113. package/cjs/useControlledTableNavigation.js.map +0 -1
  114. package/cjs/useDataSource.js +0 -146
  115. package/cjs/useDataSource.js.map +0 -1
  116. package/cjs/useEditableCell.js +0 -32
  117. package/cjs/useEditableCell.js.map +0 -1
  118. package/cjs/useHighlighting.js +0 -33
  119. package/cjs/useHighlighting.js.map +0 -1
  120. package/cjs/useKeyboardNavigation.js +0 -318
  121. package/cjs/useKeyboardNavigation.js.map +0 -1
  122. package/cjs/useMeasuredHeight.js +0 -41
  123. package/cjs/useMeasuredHeight.js.map +0 -1
  124. package/cjs/useRowClassNameGenerators.js +0 -34
  125. package/cjs/useRowClassNameGenerators.js.map +0 -1
  126. package/cjs/useSelection.js +0 -74
  127. package/cjs/useSelection.js.map +0 -1
  128. package/cjs/useTable.js +0 -727
  129. package/cjs/useTable.js.map +0 -1
  130. package/cjs/useTableContextMenu.js +0 -59
  131. package/cjs/useTableContextMenu.js.map +0 -1
  132. package/cjs/useTableModel.js +0 -383
  133. package/cjs/useTableModel.js.map +0 -1
  134. package/cjs/useTableScroll.js +0 -446
  135. package/cjs/useTableScroll.js.map +0 -1
  136. package/cjs/useTableViewport.js +0 -137
  137. package/cjs/useTableViewport.js.map +0 -1
  138. package/esm/CellFocusState.js +0 -43
  139. package/esm/CellFocusState.js.map +0 -1
  140. package/esm/Row.css.js +0 -4
  141. package/esm/Row.css.js.map +0 -1
  142. package/esm/Row.js +0 -148
  143. package/esm/Row.js.map +0 -1
  144. package/esm/Table.css.js +0 -4
  145. package/esm/Table.css.js.map +0 -1
  146. package/esm/Table.js +0 -431
  147. package/esm/Table.js.map +0 -1
  148. package/esm/VirtualColSpan.js +0 -17
  149. package/esm/VirtualColSpan.js.map +0 -1
  150. package/esm/bulk-edit/BulkEditDialog.js +0 -55
  151. package/esm/bulk-edit/BulkEditDialog.js.map +0 -1
  152. package/esm/bulk-edit/BulkEditPanel.css.js +0 -4
  153. package/esm/bulk-edit/BulkEditPanel.css.js.map +0 -1
  154. package/esm/bulk-edit/BulkEditPanel.js +0 -70
  155. package/esm/bulk-edit/BulkEditPanel.js.map +0 -1
  156. package/esm/bulk-edit/BulkEditRow.css.js +0 -4
  157. package/esm/bulk-edit/BulkEditRow.css.js.map +0 -1
  158. package/esm/bulk-edit/BulkEditRow.js +0 -79
  159. package/esm/bulk-edit/BulkEditRow.js.map +0 -1
  160. package/esm/bulk-edit/useBulkEditPanel.js +0 -99
  161. package/esm/bulk-edit/useBulkEditPanel.js.map +0 -1
  162. package/esm/bulk-edit/useBulkEditRow.js +0 -142
  163. package/esm/bulk-edit/useBulkEditRow.js.map +0 -1
  164. package/esm/cell-block/CellBlock.css.js +0 -4
  165. package/esm/cell-block/CellBlock.css.js.map +0 -1
  166. package/esm/cell-block/CellBlock.js +0 -43
  167. package/esm/cell-block/CellBlock.js.map +0 -1
  168. package/esm/cell-block/cellblock-utils.js +0 -116
  169. package/esm/cell-block/cellblock-utils.js.map +0 -1
  170. package/esm/cell-block/useCellBlockSelection.js +0 -252
  171. package/esm/cell-block/useCellBlockSelection.js.map +0 -1
  172. package/esm/cell-renderers/checkbox-cell/CheckboxCell.css.js +0 -4
  173. package/esm/cell-renderers/checkbox-cell/CheckboxCell.css.js.map +0 -1
  174. package/esm/cell-renderers/checkbox-cell/CheckboxCell.js +0 -66
  175. package/esm/cell-renderers/checkbox-cell/CheckboxCell.js.map +0 -1
  176. package/esm/cell-renderers/checkbox-row-selector/CheckboxRowSelectorCell.css.js +0 -4
  177. package/esm/cell-renderers/checkbox-row-selector/CheckboxRowSelectorCell.css.js.map +0 -1
  178. package/esm/cell-renderers/checkbox-row-selector/CheckboxRowSelectorCell.js +0 -31
  179. package/esm/cell-renderers/checkbox-row-selector/CheckboxRowSelectorCell.js.map +0 -1
  180. package/esm/cell-renderers/input-cell/InputCell.css.js +0 -4
  181. package/esm/cell-renderers/input-cell/InputCell.css.js.map +0 -1
  182. package/esm/cell-renderers/input-cell/InputCell.js +0 -50
  183. package/esm/cell-renderers/input-cell/InputCell.js.map +0 -1
  184. package/esm/cell-renderers/toggle-cell/ToggleCell.css.js +0 -4
  185. package/esm/cell-renderers/toggle-cell/ToggleCell.css.js.map +0 -1
  186. package/esm/cell-renderers/toggle-cell/ToggleCell.js +0 -65
  187. package/esm/cell-renderers/toggle-cell/ToggleCell.js.map +0 -1
  188. package/esm/column-header-pill/ColumnHeaderPill.css.js +0 -4
  189. package/esm/column-header-pill/ColumnHeaderPill.css.js.map +0 -1
  190. package/esm/column-header-pill/ColumnHeaderPill.js +0 -51
  191. package/esm/column-header-pill/ColumnHeaderPill.js.map +0 -1
  192. package/esm/column-header-pill/GroupColumnPill.css.js +0 -4
  193. package/esm/column-header-pill/GroupColumnPill.css.js.map +0 -1
  194. package/esm/column-header-pill/GroupColumnPill.js +0 -27
  195. package/esm/column-header-pill/GroupColumnPill.js.map +0 -1
  196. package/esm/column-header-pill/SortIndicator.css.js +0 -4
  197. package/esm/column-header-pill/SortIndicator.css.js.map +0 -1
  198. package/esm/column-header-pill/SortIndicator.js +0 -25
  199. package/esm/column-header-pill/SortIndicator.js.map +0 -1
  200. package/esm/column-resizing/ColumnResizer.css.js +0 -4
  201. package/esm/column-resizing/ColumnResizer.css.js.map +0 -1
  202. package/esm/column-resizing/ColumnResizer.js +0 -80
  203. package/esm/column-resizing/ColumnResizer.js.map +0 -1
  204. package/esm/column-resizing/useTableColumnResize.js +0 -53
  205. package/esm/column-resizing/useTableColumnResize.js.map +0 -1
  206. package/esm/header-cell/GroupHeaderCell.css.js +0 -4
  207. package/esm/header-cell/GroupHeaderCell.css.js.map +0 -1
  208. package/esm/header-cell/GroupHeaderCell.js +0 -125
  209. package/esm/header-cell/GroupHeaderCell.js.map +0 -1
  210. package/esm/header-cell/HeaderCell.css.js +0 -4
  211. package/esm/header-cell/HeaderCell.css.js.map +0 -1
  212. package/esm/header-cell/HeaderCell.js +0 -118
  213. package/esm/header-cell/HeaderCell.js.map +0 -1
  214. package/esm/pagination/PaginationControl.css.js +0 -4
  215. package/esm/pagination/PaginationControl.css.js.map +0 -1
  216. package/esm/pagination/PaginationControl.js +0 -36
  217. package/esm/pagination/PaginationControl.js.map +0 -1
  218. package/esm/pagination/usePagination.js +0 -34
  219. package/esm/pagination/usePagination.js.map +0 -1
  220. package/esm/table-cell/TableCell.css.js +0 -4
  221. package/esm/table-cell/TableCell.css.js.map +0 -1
  222. package/esm/table-cell/TableCell.js +0 -93
  223. package/esm/table-cell/TableCell.js.map +0 -1
  224. package/esm/table-cell/TableGroupCell.css.js +0 -4
  225. package/esm/table-cell/TableGroupCell.css.js.map +0 -1
  226. package/esm/table-cell/TableGroupCell.js +0 -64
  227. package/esm/table-cell/TableGroupCell.js.map +0 -1
  228. package/esm/table-config.js +0 -33
  229. package/esm/table-config.js.map +0 -1
  230. package/esm/table-dom-utils.js +0 -184
  231. package/esm/table-dom-utils.js.map +0 -1
  232. package/esm/table-header/HeaderProvider.js +0 -15
  233. package/esm/table-header/HeaderProvider.js.map +0 -1
  234. package/esm/table-header/TableHeader.js +0 -164
  235. package/esm/table-header/TableHeader.js.map +0 -1
  236. package/esm/table-header/useTableHeader.js +0 -83
  237. package/esm/table-header/useTableHeader.js.map +0 -1
  238. package/esm/useCell.js +0 -26
  239. package/esm/useCell.js.map +0 -1
  240. package/esm/useCellEditing.js +0 -77
  241. package/esm/useCellEditing.js.map +0 -1
  242. package/esm/useCellFocus.js +0 -113
  243. package/esm/useCellFocus.js.map +0 -1
  244. package/esm/useControlledTableNavigation.js +0 -43
  245. package/esm/useControlledTableNavigation.js.map +0 -1
  246. package/esm/useDataSource.js +0 -144
  247. package/esm/useDataSource.js.map +0 -1
  248. package/esm/useEditableCell.js +0 -30
  249. package/esm/useEditableCell.js.map +0 -1
  250. package/esm/useHighlighting.js +0 -31
  251. package/esm/useHighlighting.js.map +0 -1
  252. package/esm/useKeyboardNavigation.js +0 -314
  253. package/esm/useKeyboardNavigation.js.map +0 -1
  254. package/esm/useMeasuredHeight.js +0 -39
  255. package/esm/useMeasuredHeight.js.map +0 -1
  256. package/esm/useRowClassNameGenerators.js +0 -32
  257. package/esm/useRowClassNameGenerators.js.map +0 -1
  258. package/esm/useSelection.js +0 -72
  259. package/esm/useSelection.js.map +0 -1
  260. package/esm/useTable.js +0 -725
  261. package/esm/useTable.js.map +0 -1
  262. package/esm/useTableContextMenu.js +0 -56
  263. package/esm/useTableContextMenu.js.map +0 -1
  264. package/esm/useTableModel.js +0 -381
  265. package/esm/useTableModel.js.map +0 -1
  266. package/esm/useTableScroll.js +0 -443
  267. package/esm/useTableScroll.js.map +0 -1
  268. package/esm/useTableViewport.js +0 -135
  269. package/esm/useTableViewport.js.map +0 -1
@@ -1,184 +0,0 @@
1
- const headerCellQuery = (colIdx) => `.vuuTable-col-headers .vuuTableHeaderCell[aria-colindex='${colIdx}']`;
2
- const dataCellQuery = (ariaRowIdx, ariaColIdx) => `.vuuTable-table [aria-rowindex='${ariaRowIdx}'] > [aria-colindex='${ariaColIdx}']`;
3
- const getLevelUp = (containerRef, cellPos) => {
4
- const cell = getTableCell(containerRef, cellPos);
5
- let row = cell?.parentElement;
6
- const level = parseInt(row?.ariaLevel ?? "1");
7
- if (level > 1) {
8
- const targetLevel = `${level - 1}`;
9
- while (row !== null && row.ariaLevel !== targetLevel) {
10
- row = row.previousElementSibling;
11
- }
12
- if (row) {
13
- const nextRowIndex = parseInt(row.ariaRowIndex ?? "- 1");
14
- if (nextRowIndex !== -1) {
15
- return [nextRowIndex, 1];
16
- }
17
- }
18
- }
19
- return cellPos;
20
- };
21
- const getTableCell = (containerRef, [rowIdx, colIdx]) => {
22
- const cssQuery = dataCellQuery(rowIdx, colIdx);
23
- const cell = containerRef.current?.querySelector(cssQuery);
24
- if (cellIsEditable(cell)) {
25
- const focusableContent = cell.querySelector(
26
- `button,input[type="checkbox"]`
27
- );
28
- return focusableContent || cell;
29
- } else {
30
- return cell;
31
- }
32
- };
33
- const getHeaderCell = (containerRef, columnName) => containerRef.current?.querySelector(
34
- `.vuuTableHeaderCell[data-column-name="${columnName}"]`
35
- );
36
- const getFocusedCell = (el) => {
37
- if (el?.role == "cell" || el?.role === "columnheader") {
38
- return el;
39
- } else {
40
- return el?.closest(
41
- "[role='columnHeader'],[role='cell']"
42
- );
43
- }
44
- };
45
- const cellIsEditable = (cell) => cell?.classList.contains("vuuTableCell-editable");
46
- const cellDropdownShowing = (cell) => {
47
- if (cellIsEditable(cell)) {
48
- return cell?.querySelector('.saltDropdown[aria-expanded="true"]') !== null;
49
- }
50
- return false;
51
- };
52
- const cellIsGroupCell = (cell) => cell?.classList.contains("vuuTableGroupCell");
53
- const rowIsExpanded = (cell) => {
54
- switch (cell.parentElement?.ariaExpanded) {
55
- case "true":
56
- return true;
57
- case "false":
58
- return false;
59
- default:
60
- return void 0;
61
- }
62
- };
63
- const cellIsTextInput = (cell) => cell.querySelector(".vuuTableInputCell") !== null;
64
- const getAriaRowIndex = (rowElement) => {
65
- const rowIndex = rowElement?.ariaRowIndex;
66
- if (rowIndex != null) {
67
- const index = parseInt(rowIndex);
68
- if (!isNaN(index)) {
69
- return index;
70
- }
71
- }
72
- return -1;
73
- };
74
- const getAriaColIndex = (cellElement) => {
75
- const colIndex = cellElement?.ariaColIndex;
76
- if (colIndex != null) {
77
- const index = parseInt(colIndex);
78
- if (!isNaN(index)) {
79
- return index;
80
- }
81
- }
82
- return -1;
83
- };
84
- const getRowElementByAriaIndex = (container, rowIndex) => {
85
- if (rowIndex === -1) {
86
- return null;
87
- } else {
88
- const activeRow = container.querySelector(
89
- `[aria-rowindex="${rowIndex}"]`
90
- );
91
- if (activeRow) {
92
- return activeRow;
93
- } else {
94
- throw Error(
95
- `getRowElementAtIndex no row found for index index ${rowIndex}`
96
- );
97
- }
98
- }
99
- };
100
- const getAriaCellPos = (tableCell) => {
101
- const focusedRow = tableCell.closest("[role='row']");
102
- return [getAriaRowIndex(focusedRow), getAriaColIndex(tableCell)];
103
- };
104
- const closestRow = (el) => el.closest('[role="row"]');
105
- const closestRowIndex = (el) => getAriaRowIndex(closestRow(el));
106
- function getNextCellPos(key, [rowIdx, colIdx], columnCount, maxRowIndex) {
107
- if (key === "ArrowUp") {
108
- if (rowIdx > -1) {
109
- return [rowIdx - 1, colIdx];
110
- } else {
111
- return [rowIdx, colIdx];
112
- }
113
- } else if (key === "ArrowDown") {
114
- if (rowIdx === -1) {
115
- return [1, colIdx];
116
- } else if (rowIdx === maxRowIndex) {
117
- return [rowIdx, colIdx];
118
- } else {
119
- return [rowIdx + 1, colIdx];
120
- }
121
- } else if (key === "ArrowRight") {
122
- if (colIdx < columnCount) {
123
- return [rowIdx, colIdx + 1];
124
- } else {
125
- return [rowIdx, colIdx];
126
- }
127
- } else if (key === "ArrowLeft") {
128
- if (colIdx > 1) {
129
- return [rowIdx, colIdx - 1];
130
- } else {
131
- return [rowIdx, colIdx];
132
- }
133
- }
134
- return [rowIdx, colIdx];
135
- }
136
- const getTreeNodeOperation = (containerRef, navigationStyle, cellPos, key, shiftKey) => {
137
- const cell = getTableCell(containerRef, cellPos);
138
- if (navigationStyle === "cell" && !cellIsGroupCell(cell)) {
139
- return void 0;
140
- }
141
- if (navigationStyle == "cell" && !shiftKey) {
142
- return void 0;
143
- }
144
- if (cellIsGroupCell(cell)) {
145
- const isExpanded = rowIsExpanded(cell);
146
- if (isExpanded === true) {
147
- if (key === "ArrowLeft") {
148
- return "collapse";
149
- }
150
- } else if (isExpanded === false) {
151
- if (key === "ArrowRight") {
152
- return "expand";
153
- } else if (key === "ArrowLeft") {
154
- return "level-up";
155
- }
156
- } else if (key === "ArrowLeft") {
157
- return "level-up";
158
- }
159
- }
160
- };
161
- const NO_SCROLL_NECESSARY = [void 0, void 0];
162
- const howFarIsRowOutsideViewport = (rowEl, totalHeaderHeight, contentContainer = rowEl.closest(".vuuTable-contentContainer")) => {
163
- if (contentContainer) {
164
- const viewport = contentContainer?.getBoundingClientRect();
165
- const upperBoundary = viewport.top + totalHeaderHeight;
166
- const row = rowEl.getBoundingClientRect();
167
- if (row) {
168
- if (row.bottom > viewport.bottom) {
169
- return ["down", row.bottom - viewport.bottom];
170
- } else if (row.top < upperBoundary) {
171
- return ["up", row.top - upperBoundary];
172
- } else {
173
- return NO_SCROLL_NECESSARY;
174
- }
175
- } else {
176
- throw Error("Whats going on, row not found");
177
- }
178
- } else {
179
- throw Error("Whats going on, scrollbar container not found");
180
- }
181
- };
182
-
183
- export { cellDropdownShowing, cellIsEditable, cellIsTextInput, closestRowIndex, dataCellQuery, getAriaCellPos, getAriaColIndex, getAriaRowIndex, getFocusedCell, getHeaderCell, getLevelUp, getNextCellPos, getRowElementByAriaIndex, getTableCell, getTreeNodeOperation, headerCellQuery, howFarIsRowOutsideViewport };
184
- //# sourceMappingURL=table-dom-utils.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"table-dom-utils.js","sources":["../src/table-dom-utils.ts"],"sourcesContent":["import { RefObject } from \"react\";\nimport { ScrollDirection } from \"./useTableScroll\";\nimport type { ArrowKey, PageKey } from \"@vuu-ui/vuu-utils\";\nimport type { CellPos } from \"@vuu-ui/vuu-table-types\";\n\nexport type NavigationKey = PageKey | ArrowKey;\n\nexport const headerCellQuery = (colIdx: number) =>\n `.vuuTable-col-headers .vuuTableHeaderCell[aria-colindex='${colIdx}']`;\n\nexport const dataCellQuery = (ariaRowIdx: number, ariaColIdx: number) =>\n `.vuuTable-table [aria-rowindex='${ariaRowIdx}'] > [aria-colindex='${ariaColIdx}']`;\n\nexport const getLevelUp = (\n containerRef: RefObject<HTMLElement | null>,\n cellPos: CellPos,\n): CellPos => {\n const cell = getTableCell(containerRef, cellPos);\n let row = cell?.parentElement;\n const level = parseInt(row?.ariaLevel ?? \"1\");\n if (level > 1) {\n const targetLevel = `${level - 1}`;\n while (row !== null && row.ariaLevel !== targetLevel) {\n row = row.previousElementSibling as HTMLElement;\n }\n if (row) {\n const nextRowIndex = parseInt(row.ariaRowIndex ?? \"- 1\");\n if (nextRowIndex !== -1) {\n return [nextRowIndex, 1];\n }\n }\n }\n return cellPos;\n};\nexport const getTableCell = (\n containerRef: RefObject<HTMLElement | null>,\n [rowIdx, colIdx]: CellPos,\n) => {\n const cssQuery = dataCellQuery(rowIdx, colIdx);\n const cell = containerRef.current?.querySelector(cssQuery) as HTMLDivElement;\n\n if (cellIsEditable(cell)) {\n // Dropdown gets focus, Input does not\n const focusableContent = cell.querySelector(\n `button,input[type=\"checkbox\"]`,\n ) as HTMLElement;\n return focusableContent || cell;\n } else {\n return cell;\n }\n};\n\nexport const getHeaderCell = (\n containerRef: RefObject<HTMLElement | null>,\n columnName: string,\n) =>\n containerRef.current?.querySelector(\n `.vuuTableHeaderCell[data-column-name=\"${columnName}\"]`,\n ) as HTMLDivElement | null;\n\nexport const getFocusedCell = (el: HTMLElement | Element | null) => {\n if (el?.role == \"cell\" || el?.role === \"columnheader\") {\n return el as HTMLDivElement;\n } else {\n return el?.closest(\n \"[role='columnHeader'],[role='cell']\",\n ) as HTMLDivElement | null;\n }\n};\n\nexport const cellIsEditable = (cell: HTMLDivElement | null) =>\n cell?.classList.contains(\"vuuTableCell-editable\");\n\nexport const cellDropdownShowing = (cell: HTMLDivElement | null) => {\n if (cellIsEditable(cell)) {\n return cell?.querySelector('.saltDropdown[aria-expanded=\"true\"]') !== null;\n }\n return false;\n};\n\nconst cellIsGroupCell = (cell: HTMLElement | null) =>\n cell?.classList.contains(\"vuuTableGroupCell\");\n\nconst rowIsExpanded = (cell: HTMLElement) => {\n switch (cell.parentElement?.ariaExpanded) {\n case \"true\":\n return true;\n case \"false\":\n return false;\n default:\n return undefined;\n }\n};\n\nexport const cellIsTextInput = (cell: HTMLElement) =>\n cell.querySelector(\".vuuTableInputCell\") !== null;\n\nexport const getAriaRowIndex = (rowElement: HTMLElement | null) => {\n const rowIndex = rowElement?.ariaRowIndex;\n if (rowIndex != null) {\n const index = parseInt(rowIndex);\n if (!isNaN(index)) {\n return index;\n }\n }\n return -1;\n};\n\nexport const getAriaColIndex = (cellElement: HTMLElement | null) => {\n const colIndex = cellElement?.ariaColIndex;\n if (colIndex != null) {\n const index = parseInt(colIndex);\n if (!isNaN(index)) {\n return index;\n }\n }\n return -1;\n};\n\nexport const getRowElementByAriaIndex = (\n container: HTMLDivElement | EventTarget,\n rowIndex: number,\n) => {\n if (rowIndex === -1) {\n return null;\n } else {\n const activeRow = (container as HTMLElement).querySelector(\n `[aria-rowindex=\"${rowIndex}\"]`,\n ) as HTMLElement;\n\n if (activeRow) {\n return activeRow;\n } else {\n throw Error(\n `getRowElementAtIndex no row found for index index ${rowIndex}`,\n );\n }\n }\n};\n\nexport const getIndexFromCellElement = (cellElement: HTMLElement | null) =>\n getAriaColIndex(cellElement);\n\nexport const getAriaCellPos = (tableCell: HTMLDivElement): CellPos => {\n const focusedRow = tableCell.closest(\"[role='row']\") as HTMLElement;\n return [getAriaRowIndex(focusedRow), getAriaColIndex(tableCell)];\n};\n\nconst closestRow = (el: HTMLElement) =>\n el.closest('[role=\"row\"]') as HTMLElement;\n\nexport const closestRowIndex = (el: HTMLElement) =>\n getAriaRowIndex(closestRow(el));\n\nexport function getNextCellPos(\n key: ArrowKey,\n [rowIdx, colIdx]: CellPos,\n columnCount: number,\n maxRowIndex: number,\n): CellPos {\n if (key === \"ArrowUp\") {\n if (rowIdx > -1) {\n return [rowIdx - 1, colIdx];\n } else {\n return [rowIdx, colIdx];\n }\n } else if (key === \"ArrowDown\") {\n if (rowIdx === -1) {\n return [1, colIdx];\n } else if (rowIdx === maxRowIndex) {\n return [rowIdx, colIdx];\n } else {\n return [rowIdx + 1, colIdx];\n }\n } else if (key === \"ArrowRight\") {\n if (colIdx < columnCount) {\n return [rowIdx, colIdx + 1];\n } else {\n return [rowIdx, colIdx];\n }\n } else if (key === \"ArrowLeft\") {\n if (colIdx > 1) {\n return [rowIdx, colIdx - 1];\n } else {\n return [rowIdx, colIdx];\n }\n }\n return [rowIdx, colIdx];\n}\n\nexport type TreeNodeOperation = \"expand\" | \"collapse\" | \"level-up\";\n\nexport const getTreeNodeOperation = (\n containerRef: RefObject<HTMLElement | null>,\n navigationStyle: \"cell\" | \"tree\",\n cellPos: CellPos,\n key: NavigationKey,\n shiftKey: boolean,\n): TreeNodeOperation | undefined => {\n const cell = getTableCell(containerRef, cellPos);\n if (navigationStyle === \"cell\" && !cellIsGroupCell(cell)) {\n return undefined;\n }\n if (navigationStyle == \"cell\" && !shiftKey) {\n return undefined;\n }\n if (cellIsGroupCell(cell)) {\n const isExpanded = rowIsExpanded(cell);\n if (isExpanded === true) {\n if (key === \"ArrowLeft\") {\n return \"collapse\";\n }\n } else if (isExpanded === false) {\n if (key === \"ArrowRight\") {\n return \"expand\";\n } else if (key === \"ArrowLeft\") {\n return \"level-up\";\n }\n } else if (key === \"ArrowLeft\") {\n return \"level-up\";\n }\n }\n};\n\nconst NO_SCROLL_NECESSARY = [undefined, undefined] as const;\n\nexport const howFarIsRowOutsideViewport = (\n rowEl: HTMLElement,\n totalHeaderHeight: number,\n contentContainer = rowEl.closest(\".vuuTable-contentContainer\"),\n): readonly [ScrollDirection | undefined, number | undefined] => {\n //TODO lots of scope for optimisation here\n if (contentContainer) {\n // TODO take totalHeaderHeight into consideration\n const viewport = contentContainer?.getBoundingClientRect();\n const upperBoundary = viewport.top + totalHeaderHeight;\n const row = rowEl.getBoundingClientRect();\n if (row) {\n if (row.bottom > viewport.bottom) {\n return [\"down\", row.bottom - viewport.bottom];\n } else if (row.top < upperBoundary) {\n return [\"up\", row.top - upperBoundary];\n } else {\n return NO_SCROLL_NECESSARY;\n }\n } else {\n throw Error(\"Whats going on, row not found\");\n }\n } else {\n throw Error(\"Whats going on, scrollbar container not found\");\n }\n};\n"],"names":[],"mappings":"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"}
@@ -1,15 +0,0 @@
1
- import { jsx } from 'react/jsx-runtime';
2
- import { createContext, useContext } from 'react';
3
-
4
- const HeaderContext = createContext({ columns: [] });
5
- const HeaderProvider = ({
6
- children,
7
- columns,
8
- virtualColSpan
9
- }) => {
10
- return /* @__PURE__ */ jsx(HeaderContext.Provider, { value: { columns, virtualColSpan }, children });
11
- };
12
- const useHeaderProps = () => useContext(HeaderContext);
13
-
14
- export { HeaderProvider, useHeaderProps };
15
- //# sourceMappingURL=HeaderProvider.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"HeaderProvider.js","sources":["../../src/table-header/HeaderProvider.tsx"],"sourcesContent":["import { BaseRowProps } from \"@vuu-ui/vuu-table-types\";\nimport { createContext, FC, ReactNode, useContext } from \"react\";\n\nconst HeaderContext = createContext<BaseRowProps>({ columns: [] });\n\nexport const HeaderProvider: FC<BaseRowProps & { children: ReactNode }> = ({\n children,\n columns,\n virtualColSpan,\n}) => {\n return (\n <HeaderContext.Provider value={{ columns, virtualColSpan }}>\n {children}\n </HeaderContext.Provider>\n );\n};\n\nexport const useHeaderProps = () => useContext(HeaderContext);\n"],"names":[],"mappings":";;;AAGA,MAAM,gBAAgB,aAA4B,CAAA,EAAE,OAAS,EAAA,IAAI,CAAA;AAE1D,MAAM,iBAA6D,CAAC;AAAA,EACzE,QAAA;AAAA,EACA,OAAA;AAAA,EACA;AACF,CAAM,KAAA;AACJ,EACE,uBAAA,GAAA,CAAC,cAAc,QAAd,EAAA,EAAuB,OAAO,EAAE,OAAA,EAAS,cAAe,EAAA,EACtD,QACH,EAAA,CAAA;AAEJ;AAEa,MAAA,cAAA,GAAiB,MAAM,UAAA,CAAW,aAAa;;;;"}
@@ -1,164 +0,0 @@
1
- import { jsx, jsxs } from 'react/jsx-runtime';
2
- import { isNotHidden, DragDropProvider, RestrictToHorizontalAxis, KeyboardSensor, PointerSensor, isGroupColumn, DragOverlay } from '@vuu-ui/vuu-utils';
3
- import { memo, useMemo, isValidElement, cloneElement } from 'react';
4
- import { GroupHeaderCell } from '../header-cell/GroupHeaderCell.js';
5
- import { HeaderCell } from '../header-cell/HeaderCell.js';
6
- import { HeaderProvider } from './HeaderProvider.js';
7
- import { useTableHeader } from './useTableHeader.js';
8
-
9
- const isHeaderElement = (h) => isValidElement(h);
10
- const TableHeader = memo(
11
- ({
12
- allowDragColumnHeader,
13
- classBase = "vuuTable",
14
- columns,
15
- customHeader,
16
- headings,
17
- onHeightMeasured,
18
- onMoveColumn,
19
- onMoveGroupColumn,
20
- onRemoveGroupColumn,
21
- onResizeColumn,
22
- onSortColumn,
23
- showColumnHeaderMenus,
24
- tableConfig,
25
- tableId,
26
- virtualColSpan = 0
27
- }) => {
28
- const [customHeaders, customHeaderCount] = useMemo(() => {
29
- const offset = headings.length;
30
- const createElement = (Component, index) => /* @__PURE__ */ jsx(
31
- Component,
32
- {
33
- ariaRowIndex: offset + index + 2,
34
- ariaRole: "row",
35
- columns,
36
- virtualColSpan
37
- },
38
- index
39
- );
40
- const enrichElementWithAria = (el, rowIndex) => {
41
- const offset2 = headings.length;
42
- return cloneElement(el, {
43
- "aria-rowindex": rowIndex + offset2 + 2,
44
- ariaRole: "row"
45
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
46
- });
47
- };
48
- if (customHeader === void 0) {
49
- return [null, 0];
50
- } else if (Array.isArray(customHeader)) {
51
- const header = /* @__PURE__ */ jsx(HeaderProvider, { columns, virtualColSpan, children: customHeader.map(
52
- (header2, i) => isHeaderElement(header2) ? enrichElementWithAria(header2, i) : createElement(header2, i)
53
- ) });
54
- return [header, customHeader.length];
55
- } else if (isHeaderElement(customHeader)) {
56
- const header = /* @__PURE__ */ jsx(HeaderProvider, { columns, virtualColSpan, children: enrichElementWithAria(customHeader, 0) });
57
- return [header, 1];
58
- } else {
59
- return [createElement(customHeader, 0), 1];
60
- }
61
- }, [columns, customHeader, headings.length, virtualColSpan]);
62
- const { dragColumn, onClick, onDragEnd, onDragStart, setContainerRef } = useTableHeader({
63
- columns,
64
- customHeaderCount,
65
- headings,
66
- onHeightMeasured,
67
- onMoveColumn,
68
- onSortColumn,
69
- tableConfig
70
- });
71
- const visibleColumns = columns.filter(isNotHidden);
72
- return /* @__PURE__ */ jsxs(
73
- "div",
74
- {
75
- className: `${classBase}-col-headings`,
76
- ref: setContainerRef,
77
- role: "rowgroup",
78
- children: [
79
- headings.map((colHeaders, i) => /* @__PURE__ */ jsx(
80
- "div",
81
- {
82
- className: "vuuTable-heading",
83
- role: "row",
84
- "aria-rowindex": i + 1,
85
- children: colHeaders.map(({ label, width }, j) => /* @__PURE__ */ jsx("div", { className: "vuuTable-headingCell", style: { width }, children: label }, j))
86
- },
87
- i
88
- )),
89
- /* @__PURE__ */ jsxs(
90
- DragDropProvider,
91
- {
92
- onDragEnd,
93
- onDragStart,
94
- modifiers: [RestrictToHorizontalAxis],
95
- sensors: [
96
- KeyboardSensor.configure({
97
- keyboardCodes: {
98
- start: ["Space"],
99
- cancel: ["Escape"],
100
- end: ["Space", "Enter"],
101
- left: ["ArrowLeft"],
102
- right: ["ArrowRight"],
103
- up: [],
104
- down: []
105
- }
106
- }),
107
- PointerSensor
108
- ],
109
- children: [
110
- /* @__PURE__ */ jsx(
111
- "div",
112
- {
113
- className: `${classBase}-col-headers`,
114
- role: "row",
115
- "aria-rowindex": headings.length + 1,
116
- children: visibleColumns.map(
117
- (col, i) => isGroupColumn(col) ? /* @__PURE__ */ jsx(
118
- GroupHeaderCell,
119
- {
120
- column: col,
121
- id: `${tableId}-${col.name}`,
122
- onMoveColumn: onMoveGroupColumn,
123
- onRemoveColumn: onRemoveGroupColumn,
124
- onResize: onResizeColumn
125
- },
126
- col.name
127
- ) : /* @__PURE__ */ jsx(
128
- HeaderCell,
129
- {
130
- allowDragColumnHeader,
131
- column: col,
132
- index: i,
133
- id: `${tableId}-${col.name}`,
134
- onClick,
135
- onResize: onResizeColumn,
136
- showColumnHeaderMenus
137
- },
138
- col.name
139
- )
140
- )
141
- }
142
- ),
143
- /* @__PURE__ */ jsx(DragOverlay, { children: dragColumn ? /* @__PURE__ */ jsx("div", { id: dragColumn.id, className: "DragColumn", children: /* @__PURE__ */ jsx(
144
- HeaderCell,
145
- {
146
- column: dragColumn.column,
147
- className: "vuuDragging",
148
- id: `${tableId}-${dragColumn.id}-dragging`,
149
- index: -1
150
- }
151
- ) }) : null })
152
- ]
153
- }
154
- ),
155
- customHeaders
156
- ]
157
- }
158
- );
159
- }
160
- );
161
- TableHeader.displayName = "TableHeader";
162
-
163
- export { TableHeader };
164
- //# sourceMappingURL=TableHeader.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"TableHeader.js","sources":["../../src/table-header/TableHeader.tsx"],"sourcesContent":["import { VuuSortType } from \"@vuu-ui/vuu-protocol-types\";\nimport {\n DragDropProvider,\n DragOverlay,\n KeyboardSensor,\n PointerSensor,\n RestrictToHorizontalAxis,\n} from \"@vuu-ui/vuu-utils\";\nimport {\n ColumnDescriptor,\n ColumnMoveHandler,\n CustomHeader,\n CustomHeaderComponent,\n CustomHeaderElement,\n RuntimeColumnDescriptor,\n ShowColumnHeaderMenus,\n TableColumnResizeHandler,\n TableConfig,\n TableHeadings,\n} from \"@vuu-ui/vuu-table-types\";\nimport { isGroupColumn, isNotHidden } from \"@vuu-ui/vuu-utils\";\nimport {\n cloneElement,\n isValidElement,\n memo,\n ReactElement,\n useMemo,\n} from \"react\";\nimport { GroupHeaderCell, HeaderCell } from \"../header-cell\";\nimport { HeaderProvider } from \"./HeaderProvider\";\nimport { useTableHeader } from \"./useTableHeader\";\n\nexport type ColumnSortHandler = (\n column: ColumnDescriptor,\n addToExistingSort: boolean,\n sortType?: VuuSortType,\n) => void;\n\nconst isHeaderElement = (h: CustomHeader): h is CustomHeaderElement =>\n isValidElement(h);\n\nexport interface TableHeaderProps {\n allowDragColumnHeader: boolean;\n classBase?: string;\n columns: RuntimeColumnDescriptor[];\n customHeader?: CustomHeader | CustomHeader[];\n headings: TableHeadings;\n onHeightMeasured: (height: number, count: number) => void;\n onResizeColumn: TableColumnResizeHandler;\n onMoveColumn: ColumnMoveHandler;\n onMoveGroupColumn: (columns: ColumnDescriptor[]) => void;\n onRemoveGroupColumn: (column: RuntimeColumnDescriptor) => void;\n onSortColumn: ColumnSortHandler;\n showColumnHeaderMenus?: ShowColumnHeaderMenus;\n tableConfig: TableConfig;\n tableId: string;\n virtualColSpan?: number;\n}\n\nexport const TableHeader = memo(\n ({\n allowDragColumnHeader,\n classBase = \"vuuTable\",\n columns,\n customHeader,\n headings,\n onHeightMeasured,\n onMoveColumn,\n onMoveGroupColumn,\n onRemoveGroupColumn,\n onResizeColumn,\n onSortColumn,\n showColumnHeaderMenus,\n tableConfig,\n tableId,\n virtualColSpan = 0,\n }: TableHeaderProps) => {\n const [customHeaders, customHeaderCount] = useMemo<\n [ReactElement | ReactElement[] | null, number]\n >(() => {\n const offset = headings.length;\n const createElement = (\n Component: CustomHeaderComponent,\n index: number,\n ) => (\n <Component\n ariaRowIndex={offset + index + 2}\n ariaRole=\"row\"\n columns={columns}\n key={index}\n virtualColSpan={virtualColSpan}\n />\n );\n\n const enrichElementWithAria = (el: ReactElement, rowIndex: number) => {\n const offset = headings.length;\n return cloneElement(el, {\n \"aria-rowindex\": rowIndex + offset + 2,\n ariaRole: \"row\",\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } as any);\n };\n\n if (customHeader === undefined) {\n return [null, 0];\n } else if (Array.isArray(customHeader)) {\n const header = (\n <HeaderProvider columns={columns} virtualColSpan={virtualColSpan}>\n {customHeader.map((header, i) =>\n isHeaderElement(header)\n ? enrichElementWithAria(header, i)\n : createElement(header, i),\n )}\n </HeaderProvider>\n );\n return [header, customHeader.length];\n } else if (isHeaderElement(customHeader)) {\n // TODO rowIndex and role\n const header = (\n <HeaderProvider columns={columns} virtualColSpan={virtualColSpan}>\n {enrichElementWithAria(customHeader, 0)}\n </HeaderProvider>\n );\n return [header, 1];\n } else {\n return [createElement(customHeader, 0), 1];\n }\n }, [columns, customHeader, headings.length, virtualColSpan]);\n\n const { dragColumn, onClick, onDragEnd, onDragStart, setContainerRef } =\n useTableHeader({\n columns,\n customHeaderCount,\n headings,\n onHeightMeasured,\n onMoveColumn,\n onSortColumn,\n tableConfig,\n });\n\n const visibleColumns = columns.filter(isNotHidden);\n\n return (\n <div\n className={`${classBase}-col-headings`}\n ref={setContainerRef}\n role=\"rowgroup\"\n >\n {headings.map((colHeaders, i) => (\n <div\n className=\"vuuTable-heading\"\n key={i}\n role=\"row\"\n aria-rowindex={i + 1}\n >\n {colHeaders.map(({ label, width }, j) => (\n <div key={j} className=\"vuuTable-headingCell\" style={{ width }}>\n {label}\n </div>\n ))}\n </div>\n ))}\n <DragDropProvider // whats the difference between this and DnDContext\n onDragEnd={onDragEnd}\n onDragStart={onDragStart}\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n //@ts-ignore typing error from dnd-kit\n modifiers={[RestrictToHorizontalAxis]}\n sensors={[\n KeyboardSensor.configure({\n keyboardCodes: {\n start: [\"Space\"],\n cancel: [\"Escape\"],\n end: [\"Space\", \"Enter\"],\n left: [\"ArrowLeft\"],\n right: [\"ArrowRight\"],\n up: [],\n down: [],\n },\n }),\n PointerSensor,\n ]}\n >\n <div\n className={`${classBase}-col-headers`}\n role=\"row\"\n aria-rowindex={headings.length + 1}\n >\n {/* {virtualColSpan > 0 ? (\n <div\n role=\"cell\"\n className=\"vuuTableCell\"\n style={{ width: virtualColSpan }}\n />\n ) : null} */}\n {visibleColumns.map((col, i) =>\n isGroupColumn(col) ? (\n <GroupHeaderCell\n column={col}\n id={`${tableId}-${col.name}`}\n key={col.name}\n onMoveColumn={onMoveGroupColumn}\n onRemoveColumn={onRemoveGroupColumn}\n onResize={onResizeColumn}\n />\n ) : (\n <HeaderCell\n allowDragColumnHeader={allowDragColumnHeader}\n column={col}\n index={i}\n id={`${tableId}-${col.name}`}\n key={col.name}\n onClick={onClick}\n onResize={onResizeColumn}\n showColumnHeaderMenus={showColumnHeaderMenus}\n />\n ),\n )}\n </div>\n <DragOverlay>\n {dragColumn ? (\n <div id={dragColumn.id} className=\"DragColumn\">\n <HeaderCell\n column={dragColumn.column}\n className=\"vuuDragging\"\n id={`${tableId}-${dragColumn.id}-dragging`}\n index={-1}\n />\n </div>\n ) : null}\n </DragOverlay>\n </DragDropProvider>\n {customHeaders}\n </div>\n );\n },\n);\nTableHeader.displayName = \"TableHeader\";\n"],"names":["offset","header"],"mappings":"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"}
@@ -1,83 +0,0 @@
1
- import { reorderColumnItems, queryClosest, visibleColumnAtIndex } from '@vuu-ui/vuu-utils';
2
- import { useRef, useState, useCallback } from 'react';
3
- import { useMeasuredHeight } from '../useMeasuredHeight.js';
4
- import { useForkRef } from '@salt-ds/core';
5
-
6
- const useTableHeader = ({
7
- columns,
8
- customHeaderCount,
9
- headings,
10
- onHeightMeasured,
11
- onMoveColumn,
12
- onSortColumn
13
- }) => {
14
- const containerRef = useRef(null);
15
- const scrollingContainerRef = useRef(null);
16
- const [dragColumn, setDragColumn] = useState(null);
17
- const handleHeightMeasured = useCallback(
18
- (height) => {
19
- onHeightMeasured(height, customHeaderCount + headings.length + 1);
20
- },
21
- [customHeaderCount, headings, onHeightMeasured]
22
- );
23
- const { measuredRef: rowRef } = useMeasuredHeight({
24
- onHeightMeasured: handleHeightMeasured
25
- });
26
- const setContainerRef = useCallback((el) => {
27
- containerRef.current = el;
28
- if (el) {
29
- scrollingContainerRef.current = el.closest(".vuuTable-contentContainer");
30
- } else {
31
- scrollingContainerRef.current = null;
32
- }
33
- }, []);
34
- const handleDragStart = useCallback(
35
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
36
- (evt) => {
37
- const element = evt.operation.source;
38
- const columnName = element.id.split("-").at(-1);
39
- const column = columns.find((col) => col.name === columnName);
40
- if (column === void 0) {
41
- throw Error(`[useTableHeader] No column '${columnName}'`);
42
- }
43
- setDragColumn({ column, id: element.id });
44
- },
45
- [columns]
46
- );
47
- const handleDragEnd = useCallback(() => {
48
- setTimeout(() => {
49
- const listItems = containerRef.current?.querySelectorAll(
50
- ".vuuTableHeaderCell"
51
- );
52
- if (listItems && dragColumn?.column) {
53
- const orderedColumnNames = Array.from(listItems).map(
54
- ({ dataset }) => dataset.columnName
55
- );
56
- onMoveColumn(
57
- dragColumn?.column.name,
58
- reorderColumnItems(columns, orderedColumnNames)
59
- );
60
- }
61
- }, 300);
62
- }, [columns, dragColumn, onMoveColumn]);
63
- const handleColumnHeaderClick = useCallback(
64
- (evt) => {
65
- const headerCell = queryClosest(evt.target, ".vuuTableHeaderCell");
66
- const colIdx = parseInt(headerCell?.dataset.index ?? "-1");
67
- const column = visibleColumnAtIndex(columns, colIdx);
68
- const isAdditive = evt.shiftKey;
69
- column && onSortColumn(column, isAdditive);
70
- },
71
- [columns, onSortColumn]
72
- );
73
- return {
74
- dragColumn,
75
- onClick: handleColumnHeaderClick,
76
- onDragEnd: handleDragEnd,
77
- onDragStart: handleDragStart,
78
- setContainerRef: useForkRef(setContainerRef, rowRef)
79
- };
80
- };
81
-
82
- export { useTableHeader };
83
- //# sourceMappingURL=useTableHeader.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"useTableHeader.js","sources":["../../src/table-header/useTableHeader.ts"],"sourcesContent":["import {\n ColumnDescriptor,\n RuntimeColumnDescriptor,\n TableHeadings,\n} from \"@vuu-ui/vuu-table-types\";\nimport {\n queryClosest,\n reorderColumnItems,\n visibleColumnAtIndex,\n} from \"@vuu-ui/vuu-utils\";\nimport { RefCallback, useCallback, useRef, useState } from \"react\";\nimport { TableHeaderProps } from \"./TableHeader\";\nimport { useMeasuredHeight } from \"../useMeasuredHeight\";\nimport { useForkRef } from \"@salt-ds/core\";\n\nexport interface TableHeaderHookProps\n extends Pick<\n TableHeaderProps,\n \"columns\" | \"onMoveColumn\" | \"onSortColumn\" | \"tableConfig\"\n > {\n customHeaderCount: number;\n headings: TableHeadings;\n label?: string;\n onHeightMeasured: (height: number, customHeaderCount: number) => void;\n onMoveColumn: (columnName: string, columns: ColumnDescriptor[]) => void;\n onSortColumn: (column: ColumnDescriptor, addToExistingSort: boolean) => void;\n}\n\nexport type DragColumn = {\n id: string;\n column: RuntimeColumnDescriptor;\n};\n\nexport const useTableHeader = ({\n columns,\n customHeaderCount,\n headings,\n onHeightMeasured,\n onMoveColumn,\n onSortColumn,\n}: TableHeaderHookProps) => {\n const containerRef = useRef<HTMLDivElement | null>(null);\n const scrollingContainerRef = useRef<HTMLDivElement | null>(null);\n const [dragColumn, setDragColumn] = useState<DragColumn | null>(null);\n\n const handleHeightMeasured = useCallback(\n (height: number) => {\n onHeightMeasured(height, customHeaderCount + headings.length + 1);\n },\n [customHeaderCount, headings, onHeightMeasured],\n );\n\n const { measuredRef: rowRef } = useMeasuredHeight({\n onHeightMeasured: handleHeightMeasured,\n });\n\n const setContainerRef = useCallback<RefCallback<HTMLDivElement>>((el) => {\n containerRef.current = el;\n if (el) {\n scrollingContainerRef.current = el.closest(\".vuuTable-contentContainer\");\n } else {\n scrollingContainerRef.current = null;\n }\n }, []);\n\n // const handleDropColumnHeader = useCallback(\n // ({ fromIndex: moveFrom, toIndex: moveTo }: DropOptions) => {\n // const column = columns[moveFrom];\n // // columns are what get rendered, so these are the columns that\n // // the drop operation relates to. We must translate these into\n // // columns within the table config. Grouping complicates this\n // // as the group columns are not present in columns but ARE in\n // // config.columns\n // const orderedColumns = moveColumnTo(columns, column, moveTo);\n\n // const ofColumn =\n // ({ name }: ColumnDescriptor) =>\n // (col: ColumnDescriptor) =>\n // col.name === name;\n\n // const targetIndex = orderedColumns.findIndex(ofColumn(column));\n // const nextColumn = orderedColumns[targetIndex + 1];\n // const insertPos = nextColumn\n // ? tableConfig.columns.findIndex(ofColumn(nextColumn))\n // : -1;\n\n // if (moveTo > moveFrom && insertPos !== -1) {\n // onMoveColumn(\n // dragColumn?.column?.name,\n // moveColumnTo(tableConfig.columns, column, insertPos - 1),\n // );\n // } else {\n // onMoveColumn(moveColumnTo(tableConfig.columns, column, insertPos));\n // }\n // },\n // [columns, onMoveColumn, tableConfig.columns],\n // );\n\n const handleDragStart = useCallback(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (evt: any) => {\n const element = evt.operation.source as HTMLDivElement;\n const columnName = element.id.split(\"-\").at(-1);\n const column = columns.find((col) => col.name === columnName);\n if (column === undefined) {\n throw Error(`[useTableHeader] No column '${columnName}'`);\n }\n setDragColumn({ column, id: element.id });\n },\n [columns],\n );\n\n const handleDragEnd = useCallback(() => {\n setTimeout(() => {\n const listItems = containerRef.current?.querySelectorAll<HTMLDivElement>(\n \".vuuTableHeaderCell\",\n );\n\n if (listItems && dragColumn?.column) {\n const orderedColumnNames = Array.from<HTMLDivElement>(listItems).map(\n ({ dataset }) => dataset.columnName as string,\n );\n onMoveColumn(\n dragColumn?.column.name,\n reorderColumnItems(columns, orderedColumnNames),\n );\n }\n }, 300);\n }, [columns, dragColumn, onMoveColumn]);\n\n const handleColumnHeaderClick = useCallback(\n (evt: React.MouseEvent | React.KeyboardEvent) => {\n const headerCell = queryClosest(evt.target, \".vuuTableHeaderCell\");\n const colIdx = parseInt(headerCell?.dataset.index ?? \"-1\");\n const column = visibleColumnAtIndex(columns, colIdx);\n const isAdditive = evt.shiftKey;\n column && onSortColumn(column, isAdditive);\n },\n [columns, onSortColumn],\n );\n\n return {\n dragColumn,\n onClick: handleColumnHeaderClick,\n onDragEnd: handleDragEnd,\n onDragStart: handleDragStart,\n setContainerRef: useForkRef(setContainerRef, rowRef),\n };\n};\n"],"names":[],"mappings":"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"}
package/esm/useCell.js DELETED
@@ -1,26 +0,0 @@
1
- import { getColumnStyle } from '@vuu-ui/vuu-utils';
2
- import cx from 'clsx';
3
- import { useMemo } from 'react';
4
-
5
- const useCell = (column, classBase, isHeader, hasError) => (
6
- // TODO measure perf without the memo, might not be worth the cost
7
- useMemo(() => {
8
- const className = cx(classBase, column.className, {
9
- vuuPinFloating: column.pin === "floating",
10
- vuuPinLeft: column.pin === "left",
11
- vuuPinRight: column.pin === "right",
12
- vuuEndPin: isHeader && column.endPin,
13
- [`${classBase}-editable`]: column.editable,
14
- [`${classBase}-right`]: column.align === "right",
15
- [`${classBase}-error`]: hasError
16
- });
17
- const style = getColumnStyle(column);
18
- return {
19
- className,
20
- style
21
- };
22
- }, [classBase, column, isHeader, hasError])
23
- );
24
-
25
- export { useCell };
26
- //# sourceMappingURL=useCell.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"useCell.js","sources":["../src/useCell.ts"],"sourcesContent":["import { RuntimeColumnDescriptor } from \"@vuu-ui/vuu-table-types\";\nimport { getColumnStyle } from \"@vuu-ui/vuu-utils\";\nimport cx from \"clsx\";\nimport { useMemo } from \"react\";\n\nexport const useCell = (\n column: RuntimeColumnDescriptor,\n classBase: string,\n isHeader?: boolean,\n hasError?: boolean,\n) =>\n // TODO measure perf without the memo, might not be worth the cost\n useMemo(() => {\n const className = cx(classBase, column.className, {\n vuuPinFloating: column.pin === \"floating\",\n vuuPinLeft: column.pin === \"left\",\n vuuPinRight: column.pin === \"right\",\n vuuEndPin: isHeader && column.endPin,\n [`${classBase}-editable`]: column.editable,\n [`${classBase}-right`]: column.align === \"right\",\n [`${classBase}-error`]: hasError,\n });\n\n const style = getColumnStyle(column);\n return {\n className,\n style,\n };\n }, [classBase, column, isHeader, hasError]);\n"],"names":[],"mappings":";;;;AAKO,MAAM,OAAU,GAAA,CACrB,MACA,EAAA,SAAA,EACA,QACA,EAAA,QAAA;AAAA;AAAA,EAGA,QAAQ,MAAM;AACZ,IAAA,MAAM,SAAY,GAAA,EAAA,CAAG,SAAW,EAAA,MAAA,CAAO,SAAW,EAAA;AAAA,MAChD,cAAA,EAAgB,OAAO,GAAQ,KAAA,UAAA;AAAA,MAC/B,UAAA,EAAY,OAAO,GAAQ,KAAA,MAAA;AAAA,MAC3B,WAAA,EAAa,OAAO,GAAQ,KAAA,OAAA;AAAA,MAC5B,SAAA,EAAW,YAAY,MAAO,CAAA,MAAA;AAAA,MAC9B,CAAC,CAAA,EAAG,SAAS,CAAA,SAAA,CAAW,GAAG,MAAO,CAAA,QAAA;AAAA,MAClC,CAAC,CAAG,EAAA,SAAS,CAAQ,MAAA,CAAA,GAAG,OAAO,KAAU,KAAA,OAAA;AAAA,MACzC,CAAC,CAAA,EAAG,SAAS,CAAA,MAAA,CAAQ,GAAG;AAAA,KACzB,CAAA;AAED,IAAM,MAAA,KAAA,GAAQ,eAAe,MAAM,CAAA;AACnC,IAAO,OAAA;AAAA,MACL,SAAA;AAAA,MACA;AAAA,KACF;AAAA,KACC,CAAC,SAAA,EAAW,MAAQ,EAAA,QAAA,EAAU,QAAQ,CAAC;AAAA;;;;"}
@@ -1,77 +0,0 @@
1
- import { isCharacterKey } from '@vuu-ui/vuu-utils';
2
- import { useCallback } from 'react';
3
- import { cellIsTextInput } from './table-dom-utils.js';
4
-
5
- const useCellEditing = ({ navigate }) => {
6
- const commitHandler = useCallback(() => {
7
- navigate();
8
- }, [navigate]);
9
- const editInput = useCallback(
10
- (evt) => {
11
- const cellEl = evt.target;
12
- const input = cellEl.matches("input") ? cellEl : cellEl.querySelector("input");
13
- if (input) {
14
- input.focus();
15
- input.select();
16
- }
17
- },
18
- []
19
- );
20
- const focusInput = useCallback(
21
- (evt) => {
22
- const cellEl = evt.target;
23
- const input = cellEl.querySelector("input");
24
- if (input) {
25
- input.focus();
26
- input.select();
27
- }
28
- },
29
- []
30
- );
31
- const handleKeyDown = useCallback(
32
- (e) => {
33
- const el = e.target;
34
- if (cellIsTextInput(el)) {
35
- if (isCharacterKey(e.key)) {
36
- editInput(e);
37
- } else if (e.key === "Enter") {
38
- focusInput(e);
39
- }
40
- }
41
- },
42
- [editInput, focusInput]
43
- );
44
- const handleDoubleClick = useCallback(
45
- (e) => {
46
- const el = e.target;
47
- if (el.matches("input") || el.querySelector("input")) {
48
- editInput(e);
49
- e.stopPropagation();
50
- }
51
- },
52
- [editInput]
53
- );
54
- const handleBlur = useCallback(
55
- (e) => {
56
- const el = e.target;
57
- el.removeEventListener("vuu-commit", commitHandler, true);
58
- },
59
- [commitHandler]
60
- );
61
- const handleFocus = useCallback(
62
- (e) => {
63
- const el = e.target;
64
- el.addEventListener("vuu-commit", commitHandler, true);
65
- },
66
- [commitHandler]
67
- );
68
- return {
69
- onBlur: handleBlur,
70
- onDoubleClick: handleDoubleClick,
71
- onFocus: handleFocus,
72
- onKeyDown: handleKeyDown
73
- };
74
- };
75
-
76
- export { useCellEditing };
77
- //# sourceMappingURL=useCellEditing.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"useCellEditing.js","sources":["../src/useCellEditing.ts"],"sourcesContent":["import { isCharacterKey } from \"@vuu-ui/vuu-utils\";\nimport {\n FocusEventHandler,\n KeyboardEvent as ReactKeyboardEvent,\n MouseEvent,\n useCallback,\n} from \"react\";\nimport { cellIsTextInput } from \"./table-dom-utils\";\n\nexport interface CellEditingHookProps {\n navigate: () => void;\n}\n\nexport const useCellEditing = ({ navigate }: CellEditingHookProps) => {\n const commitHandler = useCallback(() => {\n navigate();\n }, [navigate]);\n\n const editInput = useCallback(\n (evt: MouseEvent<HTMLElement> | ReactKeyboardEvent<HTMLElement>) => {\n const cellEl = evt.target as HTMLDivElement;\n const input = cellEl.matches(\"input\")\n ? (cellEl as HTMLInputElement)\n : cellEl.querySelector(\"input\");\n\n if (input) {\n input.focus();\n input.select();\n }\n },\n [],\n );\n\n const focusInput = useCallback(\n (evt: MouseEvent<HTMLElement> | ReactKeyboardEvent<HTMLElement>) => {\n const cellEl = evt.target as HTMLDivElement;\n const input = cellEl.querySelector(\"input\");\n if (input) {\n input.focus();\n input.select();\n }\n },\n [],\n );\n\n const handleKeyDown = useCallback(\n (e: ReactKeyboardEvent<HTMLElement>) => {\n const el = e.target as HTMLElement;\n if (cellIsTextInput(el)) {\n if (isCharacterKey(e.key)) {\n editInput(e);\n } else if (e.key === \"Enter\") {\n focusInput(e);\n }\n }\n },\n [editInput, focusInput],\n );\n\n const handleDoubleClick = useCallback(\n (e: MouseEvent<HTMLElement>) => {\n const el = e.target as HTMLElement;\n if (el.matches(\"input\") || el.querySelector(\"input\")) {\n editInput(e);\n e.stopPropagation();\n }\n },\n [editInput],\n );\n\n const handleBlur = useCallback<FocusEventHandler>(\n (e) => {\n const el = e.target as HTMLElement;\n el.removeEventListener(\"vuu-commit\", commitHandler, true);\n },\n [commitHandler],\n );\n\n const handleFocus = useCallback<FocusEventHandler>(\n (e) => {\n const el = e.target as HTMLElement;\n el.addEventListener(\"vuu-commit\", commitHandler, true);\n },\n [commitHandler],\n );\n\n return {\n onBlur: handleBlur,\n onDoubleClick: handleDoubleClick,\n onFocus: handleFocus,\n onKeyDown: handleKeyDown,\n };\n};\n"],"names":[],"mappings":";;;;AAaO,MAAM,cAAiB,GAAA,CAAC,EAAE,QAAA,EAAqC,KAAA;AACpE,EAAM,MAAA,aAAA,GAAgB,YAAY,MAAM;AACtC,IAAS,QAAA,EAAA;AAAA,GACX,EAAG,CAAC,QAAQ,CAAC,CAAA;AAEb,EAAA,MAAM,SAAY,GAAA,WAAA;AAAA,IAChB,CAAC,GAAmE,KAAA;AAClE,MAAA,MAAM,SAAS,GAAI,CAAA,MAAA;AACnB,MAAM,MAAA,KAAA,GAAQ,OAAO,OAAQ,CAAA,OAAO,IAC/B,MACD,GAAA,MAAA,CAAO,cAAc,OAAO,CAAA;AAEhC,MAAA,IAAI,KAAO,EAAA;AACT,QAAA,KAAA,CAAM,KAAM,EAAA;AACZ,QAAA,KAAA,CAAM,MAAO,EAAA;AAAA;AACf,KACF;AAAA,IACA;AAAC,GACH;AAEA,EAAA,MAAM,UAAa,GAAA,WAAA;AAAA,IACjB,CAAC,GAAmE,KAAA;AAClE,MAAA,MAAM,SAAS,GAAI,CAAA,MAAA;AACnB,MAAM,MAAA,KAAA,GAAQ,MAAO,CAAA,aAAA,CAAc,OAAO,CAAA;AAC1C,MAAA,IAAI,KAAO,EAAA;AACT,QAAA,KAAA,CAAM,KAAM,EAAA;AACZ,QAAA,KAAA,CAAM,MAAO,EAAA;AAAA;AACf,KACF;AAAA,IACA;AAAC,GACH;AAEA,EAAA,MAAM,aAAgB,GAAA,WAAA;AAAA,IACpB,CAAC,CAAuC,KAAA;AACtC,MAAA,MAAM,KAAK,CAAE,CAAA,MAAA;AACb,MAAI,IAAA,eAAA,CAAgB,EAAE,CAAG,EAAA;AACvB,QAAI,IAAA,cAAA,CAAe,CAAE,CAAA,GAAG,CAAG,EAAA;AACzB,UAAA,SAAA,CAAU,CAAC,CAAA;AAAA,SACb,MAAA,IAAW,CAAE,CAAA,GAAA,KAAQ,OAAS,EAAA;AAC5B,UAAA,UAAA,CAAW,CAAC,CAAA;AAAA;AACd;AACF,KACF;AAAA,IACA,CAAC,WAAW,UAAU;AAAA,GACxB;AAEA,EAAA,MAAM,iBAAoB,GAAA,WAAA;AAAA,IACxB,CAAC,CAA+B,KAAA;AAC9B,MAAA,MAAM,KAAK,CAAE,CAAA,MAAA;AACb,MAAA,IAAI,GAAG,OAAQ,CAAA,OAAO,KAAK,EAAG,CAAA,aAAA,CAAc,OAAO,CAAG,EAAA;AACpD,QAAA,SAAA,CAAU,CAAC,CAAA;AACX,QAAA,CAAA,CAAE,eAAgB,EAAA;AAAA;AACpB,KACF;AAAA,IACA,CAAC,SAAS;AAAA,GACZ;AAEA,EAAA,MAAM,UAAa,GAAA,WAAA;AAAA,IACjB,CAAC,CAAM,KAAA;AACL,MAAA,MAAM,KAAK,CAAE,CAAA,MAAA;AACb,MAAG,EAAA,CAAA,mBAAA,CAAoB,YAAc,EAAA,aAAA,EAAe,IAAI,CAAA;AAAA,KAC1D;AAAA,IACA,CAAC,aAAa;AAAA,GAChB;AAEA,EAAA,MAAM,WAAc,GAAA,WAAA;AAAA,IAClB,CAAC,CAAM,KAAA;AACL,MAAA,MAAM,KAAK,CAAE,CAAA,MAAA;AACb,MAAG,EAAA,CAAA,gBAAA,CAAiB,YAAc,EAAA,aAAA,EAAe,IAAI,CAAA;AAAA,KACvD;AAAA,IACA,CAAC,aAAa;AAAA,GAChB;AAEA,EAAO,OAAA;AAAA,IACL,MAAQ,EAAA,UAAA;AAAA,IACR,aAAe,EAAA,iBAAA;AAAA,IACf,OAAS,EAAA,WAAA;AAAA,IACT,SAAW,EAAA;AAAA,GACb;AACF;;;;"}