@vuu-ui/vuu-table 0.8.33 → 0.8.34

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 (180) hide show
  1. package/cjs/Row.css +115 -0
  2. package/cjs/Row.js +115 -0
  3. package/cjs/Row.js.map +1 -0
  4. package/cjs/Table.css +151 -0
  5. package/cjs/Table.js +276 -0
  6. package/cjs/Table.js.map +1 -0
  7. package/cjs/cell-renderers/checkbox-cell/CheckboxCell.css +5 -0
  8. package/cjs/cell-renderers/checkbox-cell/CheckboxCell.js +33 -0
  9. package/cjs/cell-renderers/checkbox-cell/CheckboxCell.js.map +1 -0
  10. package/cjs/cell-renderers/input-cell/InputCell.css +31 -0
  11. package/cjs/cell-renderers/input-cell/InputCell.js +49 -0
  12. package/cjs/cell-renderers/input-cell/InputCell.js.map +1 -0
  13. package/cjs/cell-renderers/toggle-cell/ToggleCell.css +32 -0
  14. package/cjs/cell-renderers/toggle-cell/ToggleCell.js +59 -0
  15. package/cjs/cell-renderers/toggle-cell/ToggleCell.js.map +1 -0
  16. package/cjs/column-header-pill/ColumnHeaderPill.css +30 -0
  17. package/cjs/column-header-pill/ColumnHeaderPill.js +44 -0
  18. package/cjs/column-header-pill/ColumnHeaderPill.js.map +1 -0
  19. package/cjs/column-header-pill/GroupColumnPill.css +7 -0
  20. package/cjs/column-header-pill/GroupColumnPill.js +20 -0
  21. package/cjs/column-header-pill/GroupColumnPill.js.map +1 -0
  22. package/cjs/column-header-pill/SortIndicator.css +7 -0
  23. package/cjs/column-header-pill/SortIndicator.js +18 -0
  24. package/cjs/column-header-pill/SortIndicator.js.map +1 -0
  25. package/cjs/column-menu/ColumnMenu.css +21 -0
  26. package/cjs/column-menu/ColumnMenu.js +21 -0
  27. package/cjs/column-menu/ColumnMenu.js.map +1 -0
  28. package/cjs/column-resizing/ColumnResizer.css +28 -0
  29. package/cjs/column-resizing/ColumnResizer.js +63 -0
  30. package/cjs/column-resizing/ColumnResizer.js.map +1 -0
  31. package/cjs/column-resizing/useTableColumnResize.js +55 -0
  32. package/cjs/column-resizing/useTableColumnResize.js.map +1 -0
  33. package/cjs/context-menu/buildContextMenuDescriptors.js +214 -0
  34. package/cjs/context-menu/buildContextMenuDescriptors.js.map +1 -0
  35. package/cjs/context-menu/useHandleTableContextMenu.js +81 -0
  36. package/cjs/context-menu/useHandleTableContextMenu.js.map +1 -0
  37. package/cjs/header-cell/GroupHeaderCell.css +65 -0
  38. package/cjs/header-cell/GroupHeaderCell.js +108 -0
  39. package/cjs/header-cell/GroupHeaderCell.js.map +1 -0
  40. package/cjs/header-cell/HeaderCell.css +146 -0
  41. package/cjs/header-cell/HeaderCell.js +100 -0
  42. package/cjs/header-cell/HeaderCell.js.map +1 -0
  43. package/cjs/index.js.map +1 -0
  44. package/cjs/moving-window.js +61 -0
  45. package/cjs/moving-window.js.map +1 -0
  46. package/cjs/table-cell/TableCell.css +41 -0
  47. package/cjs/table-cell/TableCell.js +63 -0
  48. package/cjs/table-cell/TableCell.js.map +1 -0
  49. package/cjs/table-cell/TableGroupCell.css +26 -0
  50. package/cjs/table-cell/TableGroupCell.js +45 -0
  51. package/cjs/table-cell/TableGroupCell.js.map +1 -0
  52. package/cjs/table-config.js +25 -0
  53. package/cjs/table-config.js.map +1 -0
  54. package/cjs/table-dom-utils.js +60 -0
  55. package/cjs/table-dom-utils.js.map +1 -0
  56. package/cjs/table-header/TableHeader.js +87 -0
  57. package/cjs/table-header/TableHeader.js.map +1 -0
  58. package/cjs/table-header/useTableHeader.js +72 -0
  59. package/cjs/table-header/useTableHeader.js.map +1 -0
  60. package/cjs/useCell.js +28 -0
  61. package/cjs/useCell.js.map +1 -0
  62. package/cjs/useCellEditing.js +79 -0
  63. package/cjs/useCellEditing.js.map +1 -0
  64. package/cjs/useControlledTableNavigation.js +43 -0
  65. package/cjs/useControlledTableNavigation.js.map +1 -0
  66. package/cjs/useDataSource.js +104 -0
  67. package/cjs/useDataSource.js.map +1 -0
  68. package/cjs/useInitialValue.js +11 -0
  69. package/cjs/useInitialValue.js.map +1 -0
  70. package/cjs/useKeyboardNavigation.js +304 -0
  71. package/cjs/useKeyboardNavigation.js.map +1 -0
  72. package/cjs/useRowClassNameGenerators.js +34 -0
  73. package/cjs/useRowClassNameGenerators.js.map +1 -0
  74. package/cjs/useRowHeight.js +43 -0
  75. package/cjs/useRowHeight.js.map +1 -0
  76. package/cjs/useSelection.js +64 -0
  77. package/cjs/useSelection.js.map +1 -0
  78. package/cjs/useTable.js +553 -0
  79. package/cjs/useTable.js.map +1 -0
  80. package/cjs/useTableAndColumnSettings.js +128 -0
  81. package/cjs/useTableAndColumnSettings.js.map +1 -0
  82. package/cjs/useTableContextMenu.js +42 -0
  83. package/cjs/useTableContextMenu.js.map +1 -0
  84. package/cjs/useTableModel.js +297 -0
  85. package/cjs/useTableModel.js.map +1 -0
  86. package/cjs/useTableScroll.js +396 -0
  87. package/cjs/useTableScroll.js.map +1 -0
  88. package/cjs/useTableViewport.js +122 -0
  89. package/cjs/useTableViewport.js.map +1 -0
  90. package/esm/Row.css +115 -0
  91. package/esm/Row.js +112 -0
  92. package/esm/Row.js.map +1 -0
  93. package/esm/Table.css +151 -0
  94. package/esm/Table.js +274 -0
  95. package/esm/Table.js.map +1 -0
  96. package/esm/cell-renderers/checkbox-cell/CheckboxCell.css +5 -0
  97. package/esm/cell-renderers/checkbox-cell/CheckboxCell.js +31 -0
  98. package/esm/cell-renderers/checkbox-cell/CheckboxCell.js.map +1 -0
  99. package/esm/cell-renderers/input-cell/InputCell.css +31 -0
  100. package/esm/cell-renderers/input-cell/InputCell.js +47 -0
  101. package/esm/cell-renderers/input-cell/InputCell.js.map +1 -0
  102. package/esm/cell-renderers/toggle-cell/ToggleCell.css +32 -0
  103. package/esm/cell-renderers/toggle-cell/ToggleCell.js +57 -0
  104. package/esm/cell-renderers/toggle-cell/ToggleCell.js.map +1 -0
  105. package/esm/column-header-pill/ColumnHeaderPill.css +30 -0
  106. package/esm/column-header-pill/ColumnHeaderPill.js +42 -0
  107. package/esm/column-header-pill/ColumnHeaderPill.js.map +1 -0
  108. package/esm/column-header-pill/GroupColumnPill.css +7 -0
  109. package/esm/column-header-pill/GroupColumnPill.js +18 -0
  110. package/esm/column-header-pill/GroupColumnPill.js.map +1 -0
  111. package/esm/column-header-pill/SortIndicator.css +7 -0
  112. package/esm/column-header-pill/SortIndicator.js +16 -0
  113. package/esm/column-header-pill/SortIndicator.js.map +1 -0
  114. package/esm/column-menu/ColumnMenu.css +21 -0
  115. package/esm/column-menu/ColumnMenu.js +19 -0
  116. package/esm/column-menu/ColumnMenu.js.map +1 -0
  117. package/esm/column-resizing/ColumnResizer.css +28 -0
  118. package/esm/column-resizing/ColumnResizer.js +61 -0
  119. package/esm/column-resizing/ColumnResizer.js.map +1 -0
  120. package/esm/column-resizing/useTableColumnResize.js +53 -0
  121. package/esm/column-resizing/useTableColumnResize.js.map +1 -0
  122. package/esm/context-menu/buildContextMenuDescriptors.js +212 -0
  123. package/esm/context-menu/buildContextMenuDescriptors.js.map +1 -0
  124. package/esm/context-menu/useHandleTableContextMenu.js +79 -0
  125. package/esm/context-menu/useHandleTableContextMenu.js.map +1 -0
  126. package/esm/header-cell/GroupHeaderCell.css +65 -0
  127. package/esm/header-cell/GroupHeaderCell.js +106 -0
  128. package/esm/header-cell/GroupHeaderCell.js.map +1 -0
  129. package/esm/header-cell/HeaderCell.css +146 -0
  130. package/esm/header-cell/HeaderCell.js +98 -0
  131. package/esm/header-cell/HeaderCell.js.map +1 -0
  132. package/esm/index.js +14 -0
  133. package/esm/index.js.map +1 -0
  134. package/esm/moving-window.js +59 -0
  135. package/esm/moving-window.js.map +1 -0
  136. package/esm/table-cell/TableCell.css +41 -0
  137. package/esm/table-cell/TableCell.js +61 -0
  138. package/esm/table-cell/TableCell.js.map +1 -0
  139. package/esm/table-cell/TableGroupCell.css +26 -0
  140. package/esm/table-cell/TableGroupCell.js +43 -0
  141. package/esm/table-cell/TableGroupCell.js.map +1 -0
  142. package/esm/table-config.js +23 -0
  143. package/esm/table-config.js.map +1 -0
  144. package/esm/table-dom-utils.js +51 -0
  145. package/esm/table-dom-utils.js.map +1 -0
  146. package/esm/table-header/TableHeader.js +85 -0
  147. package/esm/table-header/TableHeader.js.map +1 -0
  148. package/esm/table-header/useTableHeader.js +70 -0
  149. package/esm/table-header/useTableHeader.js.map +1 -0
  150. package/esm/useCell.js +26 -0
  151. package/esm/useCell.js.map +1 -0
  152. package/esm/useCellEditing.js +77 -0
  153. package/esm/useCellEditing.js.map +1 -0
  154. package/esm/useControlledTableNavigation.js +41 -0
  155. package/esm/useControlledTableNavigation.js.map +1 -0
  156. package/esm/useDataSource.js +101 -0
  157. package/esm/useDataSource.js.map +1 -0
  158. package/esm/useInitialValue.js +9 -0
  159. package/esm/useInitialValue.js.map +1 -0
  160. package/esm/useKeyboardNavigation.js +300 -0
  161. package/esm/useKeyboardNavigation.js.map +1 -0
  162. package/esm/useRowClassNameGenerators.js +32 -0
  163. package/esm/useRowClassNameGenerators.js.map +1 -0
  164. package/esm/useRowHeight.js +41 -0
  165. package/esm/useRowHeight.js.map +1 -0
  166. package/esm/useSelection.js +62 -0
  167. package/esm/useSelection.js.map +1 -0
  168. package/esm/useTable.js +551 -0
  169. package/esm/useTable.js.map +1 -0
  170. package/esm/useTableAndColumnSettings.js +126 -0
  171. package/esm/useTableAndColumnSettings.js.map +1 -0
  172. package/esm/useTableContextMenu.js +40 -0
  173. package/esm/useTableContextMenu.js.map +1 -0
  174. package/esm/useTableModel.js +293 -0
  175. package/esm/useTableModel.js.map +1 -0
  176. package/esm/useTableScroll.js +393 -0
  177. package/esm/useTableScroll.js.map +1 -0
  178. package/esm/useTableViewport.js +120 -0
  179. package/esm/useTableViewport.js.map +1 -0
  180. package/package.json +10 -8
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useTableColumnResize.js","sources":["../../src/column-resizing/useTableColumnResize.tsx"],"sourcesContent":["import {\n Heading,\n ResizePhase,\n RuntimeColumnDescriptor,\n} from \"@vuu-ui/vuu-table-types\";\nimport { RefObject, useCallback, useRef, useState } from \"react\";\n\nexport type ResizeHandler = (evt: MouseEvent, moveBy: number) => void;\nexport interface CellResizeHookProps {\n column: RuntimeColumnDescriptor | Heading;\n onResize?: (phase: ResizePhase, columnName: string, width?: number) => void;\n rootRef: RefObject<HTMLDivElement>;\n}\n\nexport interface CellResizeHookResult {\n isResizing: boolean;\n onDrag: (evt: MouseEvent, moveBy: number, totalDistanceMoved: number) => void;\n onDragStart: (evt: React.MouseEvent) => void;\n onDragEnd: (evt: MouseEvent) => void;\n}\n\nexport const useTableColumnResize = ({\n column,\n onResize,\n rootRef,\n}: CellResizeHookProps): CellResizeHookResult => {\n const widthRef = useRef({ start: 0, now: 0 });\n\n const [isResizing, setResizing] = useState(false);\n const { name } = column;\n\n const handleResizeStart = useCallback(() => {\n if (onResize && rootRef.current) {\n const { current: width } = widthRef;\n const { width: measuredWidth } = rootRef.current.getBoundingClientRect();\n width.start = width.now = Math.round(measuredWidth);\n setResizing(true);\n onResize?.(\"begin\", name);\n }\n }, [name, onResize, rootRef]);\n\n const handleResize = useCallback(\n (_evt: MouseEvent, moveBy: number, totalDistanceMoved) => {\n if (rootRef.current) {\n if (onResize) {\n const { current: width } = widthRef;\n const newWidth = width.start + totalDistanceMoved;\n if (newWidth !== width.now && newWidth > 0) {\n onResize(\"resize\", name, newWidth);\n width.now = newWidth;\n }\n }\n }\n },\n [name, onResize, rootRef]\n );\n\n const handleResizeEnd = useCallback(() => {\n if (onResize) {\n const { current: width } = widthRef;\n onResize(\"end\", name, width.now);\n setTimeout(() => {\n // clickHandler in HeaderCell checks isResizing before firing. Because onMouseUp\n // fires before click, we need to delay setting isResizing back to false, just\n // long enough that the click ghandler will have fired.\n setResizing(false);\n }, 80);\n }\n }, [name, onResize]);\n\n return {\n isResizing,\n onDrag: handleResize,\n onDragStart: handleResizeStart,\n onDragEnd: handleResizeEnd,\n };\n};\n"],"names":[],"mappings":";;AAqBO,MAAM,uBAAuB,CAAC;AAAA,EACnC,MAAA;AAAA,EACA,QAAA;AAAA,EACA,OAAA;AACF,CAAiD,KAAA;AAC/C,EAAA,MAAM,WAAW,MAAO,CAAA,EAAE,OAAO,CAAG,EAAA,GAAA,EAAK,GAAG,CAAA,CAAA;AAE5C,EAAA,MAAM,CAAC,UAAA,EAAY,WAAW,CAAA,GAAI,SAAS,KAAK,CAAA,CAAA;AAChD,EAAM,MAAA,EAAE,MAAS,GAAA,MAAA,CAAA;AAEjB,EAAM,MAAA,iBAAA,GAAoB,YAAY,MAAM;AAC1C,IAAI,IAAA,QAAA,IAAY,QAAQ,OAAS,EAAA;AAC/B,MAAM,MAAA,EAAE,OAAS,EAAA,KAAA,EAAU,GAAA,QAAA,CAAA;AAC3B,MAAA,MAAM,EAAE,KAAO,EAAA,aAAA,EAAkB,GAAA,OAAA,CAAQ,QAAQ,qBAAsB,EAAA,CAAA;AACvE,MAAA,KAAA,CAAM,KAAQ,GAAA,KAAA,CAAM,GAAM,GAAA,IAAA,CAAK,MAAM,aAAa,CAAA,CAAA;AAClD,MAAA,WAAA,CAAY,IAAI,CAAA,CAAA;AAChB,MAAA,QAAA,GAAW,SAAS,IAAI,CAAA,CAAA;AAAA,KAC1B;AAAA,GACC,EAAA,CAAC,IAAM,EAAA,QAAA,EAAU,OAAO,CAAC,CAAA,CAAA;AAE5B,EAAA,MAAM,YAAe,GAAA,WAAA;AAAA,IACnB,CAAC,IAAkB,EAAA,MAAA,EAAgB,kBAAuB,KAAA;AACxD,MAAA,IAAI,QAAQ,OAAS,EAAA;AACnB,QAAA,IAAI,QAAU,EAAA;AACZ,UAAM,MAAA,EAAE,OAAS,EAAA,KAAA,EAAU,GAAA,QAAA,CAAA;AAC3B,UAAM,MAAA,QAAA,GAAW,MAAM,KAAQ,GAAA,kBAAA,CAAA;AAC/B,UAAA,IAAI,QAAa,KAAA,KAAA,CAAM,GAAO,IAAA,QAAA,GAAW,CAAG,EAAA;AAC1C,YAAS,QAAA,CAAA,QAAA,EAAU,MAAM,QAAQ,CAAA,CAAA;AACjC,YAAA,KAAA,CAAM,GAAM,GAAA,QAAA,CAAA;AAAA,WACd;AAAA,SACF;AAAA,OACF;AAAA,KACF;AAAA,IACA,CAAC,IAAM,EAAA,QAAA,EAAU,OAAO,CAAA;AAAA,GAC1B,CAAA;AAEA,EAAM,MAAA,eAAA,GAAkB,YAAY,MAAM;AACxC,IAAA,IAAI,QAAU,EAAA;AACZ,MAAM,MAAA,EAAE,OAAS,EAAA,KAAA,EAAU,GAAA,QAAA,CAAA;AAC3B,MAAS,QAAA,CAAA,KAAA,EAAO,IAAM,EAAA,KAAA,CAAM,GAAG,CAAA,CAAA;AAC/B,MAAA,UAAA,CAAW,MAAM;AAIf,QAAA,WAAA,CAAY,KAAK,CAAA,CAAA;AAAA,SAChB,EAAE,CAAA,CAAA;AAAA,KACP;AAAA,GACC,EAAA,CAAC,IAAM,EAAA,QAAQ,CAAC,CAAA,CAAA;AAEnB,EAAO,OAAA;AAAA,IACL,UAAA;AAAA,IACA,MAAQ,EAAA,YAAA;AAAA,IACR,WAAa,EAAA,iBAAA;AAAA,IACb,SAAW,EAAA,eAAA;AAAA,GACb,CAAA;AACF;;;;"}
@@ -0,0 +1,212 @@
1
+ import { isNumericColumn } from '@vuu-ui/vuu-utils';
2
+
3
+ const buildContextMenuDescriptors = (dataSource) => (location, options) => {
4
+ const descriptors = [];
5
+ if (dataSource === void 0) {
6
+ return descriptors;
7
+ }
8
+ if (location === "header" || location === "column-menu") {
9
+ descriptors.push(
10
+ ...buildSortMenuItems(options, dataSource)
11
+ );
12
+ descriptors.push(
13
+ ...buildGroupMenuItems(options, dataSource)
14
+ );
15
+ descriptors.push(
16
+ ...buildAggregationMenuItems(options, dataSource)
17
+ );
18
+ descriptors.push(...buildColumnDisplayMenuItems(options));
19
+ descriptors.push({
20
+ action: "column-settings",
21
+ icon: "cog",
22
+ label: `Column Settings`,
23
+ options
24
+ });
25
+ descriptors.push({
26
+ action: "table-settings",
27
+ icon: "cog",
28
+ label: `DataGrid Settings`,
29
+ options
30
+ });
31
+ }
32
+ return descriptors;
33
+ };
34
+ function buildSortMenuItems(options, { sort: { sortDefs } }) {
35
+ const { column } = options;
36
+ const menuItems = [];
37
+ if (column === void 0) {
38
+ return menuItems;
39
+ }
40
+ const hasSort = sortDefs.length > 0;
41
+ if (column.sorted === "A") {
42
+ menuItems.push({
43
+ label: "Reverse Sort (DSC)",
44
+ action: "sort-dsc",
45
+ options
46
+ });
47
+ } else if (column.sorted === "D") {
48
+ menuItems.push({
49
+ label: "Reverse Sort (ASC)",
50
+ action: "sort-asc",
51
+ options
52
+ });
53
+ } else if (typeof column.sorted === "number") {
54
+ if (column.sorted > 0) {
55
+ menuItems.push({
56
+ label: "Reverse Sort (DSC)",
57
+ action: "sort-add-dsc",
58
+ options
59
+ });
60
+ } else {
61
+ menuItems.push({
62
+ label: "Reverse Sort (ASC)",
63
+ action: "sort-add-asc",
64
+ options
65
+ });
66
+ }
67
+ if (hasSort && Math.abs(column.sorted) < sortDefs.length) {
68
+ menuItems.push({
69
+ label: "Remove from sort",
70
+ action: "sort-remove",
71
+ options
72
+ });
73
+ }
74
+ menuItems.push({
75
+ label: "New Sort",
76
+ children: [
77
+ { label: "Ascending", action: "sort-asc", options },
78
+ { label: "Descending", action: "sort-dsc", options }
79
+ ]
80
+ });
81
+ } else if (hasSort) {
82
+ menuItems.push({
83
+ label: "Add to sort",
84
+ children: [
85
+ { label: "Ascending", action: "sort-add-asc", options },
86
+ { label: "Descending", action: "sort-add-dsc", options }
87
+ ]
88
+ });
89
+ menuItems.push({
90
+ label: "New Sort",
91
+ children: [
92
+ { label: "Ascending", action: "sort-asc", options },
93
+ { label: "Descending", action: "sort-dsc", options }
94
+ ]
95
+ });
96
+ } else {
97
+ menuItems.push({
98
+ label: "Sort",
99
+ children: [
100
+ { label: "Ascending", action: "sort-asc", options },
101
+ { label: "Descending", action: "sort-dsc", options }
102
+ ]
103
+ });
104
+ }
105
+ return menuItems;
106
+ }
107
+ function buildAggregationMenuItems(options, dataSource) {
108
+ const { column } = options;
109
+ if (column === void 0 || dataSource.groupBy.length === 0) {
110
+ return [];
111
+ }
112
+ const { name, label = name } = column;
113
+ return [
114
+ {
115
+ label: `Aggregate ${label}`,
116
+ children: [
117
+ { label: "Count", action: "agg-count", options },
118
+ { label: "Distinct", action: "agg-distinct", options }
119
+ ].concat(
120
+ isNumericColumn(column) ? [
121
+ { label: "Sum", action: "agg-sum", options },
122
+ { label: "Avg", action: "agg-avg", options },
123
+ { label: "High", action: "agg-high", options },
124
+ { label: "Low", action: "agg-low", options }
125
+ ] : []
126
+ )
127
+ }
128
+ ];
129
+ }
130
+ const pinColumn = (options, pinLocation) => ({
131
+ label: `Pin ${pinLocation}`,
132
+ action: `column-pin-${pinLocation}`,
133
+ options
134
+ });
135
+ const pinLeft = (options) => pinColumn(options, "left");
136
+ const pinFloating = (options) => pinColumn(options, "floating");
137
+ const pinRight = (options) => pinColumn(options, "right");
138
+ function buildColumnDisplayMenuItems(options) {
139
+ const { column } = options;
140
+ if (column === void 0) {
141
+ return [];
142
+ }
143
+ const { pin } = column;
144
+ const menuItems = [
145
+ {
146
+ label: `Hide column`,
147
+ action: "column-hide",
148
+ options
149
+ },
150
+ {
151
+ label: `Remove column`,
152
+ action: "column-remove",
153
+ options
154
+ }
155
+ ];
156
+ if (pin === void 0) {
157
+ menuItems.push({
158
+ label: `Pin column`,
159
+ children: [pinLeft(options), pinFloating(options), pinRight(options)]
160
+ });
161
+ } else if (pin === "left") {
162
+ menuItems.push(
163
+ { label: "Unpin column", action: "column-unpin", options },
164
+ {
165
+ label: `Pin column`,
166
+ children: [pinFloating(options), pinRight(options)]
167
+ }
168
+ );
169
+ } else if (pin === "right") {
170
+ menuItems.push(
171
+ { label: "Unpin column", action: "column-unpin", options },
172
+ {
173
+ label: `Pin column`,
174
+ children: [pinLeft(options), pinFloating(options)]
175
+ }
176
+ );
177
+ } else if (pin === "floating") {
178
+ menuItems.push(
179
+ { label: "Unpin column", action: "column-unpin", options },
180
+ {
181
+ label: `Pin column`,
182
+ children: [pinLeft(options), pinRight(options)]
183
+ }
184
+ );
185
+ }
186
+ return menuItems;
187
+ }
188
+ function buildGroupMenuItems(options, { groupBy }) {
189
+ const { column } = options;
190
+ const menuItems = [];
191
+ if (column === void 0) {
192
+ return menuItems;
193
+ }
194
+ const { name, label = name } = column;
195
+ if (groupBy.length === 0) {
196
+ menuItems.push({
197
+ label: `Group by ${label}`,
198
+ action: "group",
199
+ options
200
+ });
201
+ } else {
202
+ menuItems.push({
203
+ label: `Add ${label} to group by`,
204
+ action: "group-add",
205
+ options
206
+ });
207
+ }
208
+ return menuItems;
209
+ }
210
+
211
+ export { buildContextMenuDescriptors };
212
+ //# sourceMappingURL=buildContextMenuDescriptors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buildContextMenuDescriptors.js","sources":["../../src/context-menu/buildContextMenuDescriptors.ts"],"sourcesContent":["import {\n ContextMenuItemDescriptor,\n DataSource,\n MenuBuilder,\n} from \"@vuu-ui/vuu-data-types\";\nimport { RuntimeColumnDescriptor, PinLocation } from \"@vuu-ui/vuu-table-types\";\nimport { isNumericColumn } from \"@vuu-ui/vuu-utils\";\n\nexport type ContextMenuLocation = \"header\" | \"filter\" | \"grid\";\n\ntype MaybeColumn = { column?: RuntimeColumnDescriptor };\n\nexport const buildContextMenuDescriptors =\n (dataSource?: DataSource): MenuBuilder =>\n (location, options) => {\n const descriptors: ContextMenuItemDescriptor[] = [];\n if (dataSource === undefined) {\n return descriptors;\n }\n //TODO which should it be ?\n if (location === \"header\" || location === \"column-menu\") {\n descriptors.push(\n ...buildSortMenuItems(options as MaybeColumn, dataSource)\n );\n descriptors.push(\n ...buildGroupMenuItems(options as MaybeColumn, dataSource)\n );\n descriptors.push(\n ...buildAggregationMenuItems(options as MaybeColumn, dataSource)\n );\n descriptors.push(...buildColumnDisplayMenuItems(options as MaybeColumn));\n descriptors.push({\n action: \"column-settings\",\n icon: \"cog\",\n label: `Column Settings`,\n options,\n });\n descriptors.push({\n action: \"table-settings\",\n icon: \"cog\",\n label: `DataGrid Settings`,\n options,\n });\n }\n\n // if (options?.selectedRowCount){\n // // TODO pass the table name\n // const rpcActions = getRpcActions();\n // for (let {label, method} of rpcActions){\n // descriptors.push({action: Action.RpcCall, label, options: {method}})\n // }\n // }\n\n return descriptors;\n };\n\nfunction buildSortMenuItems(\n options: MaybeColumn,\n { sort: { sortDefs } }: DataSource\n): ContextMenuItemDescriptor[] {\n const { column } = options;\n const menuItems: ContextMenuItemDescriptor[] = [];\n if (column === undefined) {\n return menuItems;\n }\n\n const hasSort = sortDefs.length > 0;\n\n if (column.sorted === \"A\") {\n menuItems.push({\n label: \"Reverse Sort (DSC)\",\n action: \"sort-dsc\",\n options,\n });\n } else if (column.sorted === \"D\") {\n menuItems.push({\n label: \"Reverse Sort (ASC)\",\n action: \"sort-asc\",\n options,\n });\n } else if (typeof column.sorted === \"number\") {\n if (column.sorted > 0) {\n menuItems.push({\n label: \"Reverse Sort (DSC)\",\n action: \"sort-add-dsc\",\n options,\n });\n } else {\n menuItems.push({\n label: \"Reverse Sort (ASC)\",\n action: \"sort-add-asc\",\n options,\n });\n }\n\n // removing the last column from a sort would be a no-op, so pointless\n if (hasSort && Math.abs(column.sorted) < sortDefs.length) {\n menuItems.push({\n label: \"Remove from sort\",\n action: \"sort-remove\",\n options,\n });\n }\n\n menuItems.push({\n label: \"New Sort\",\n children: [\n { label: \"Ascending\", action: \"sort-asc\", options },\n { label: \"Descending\", action: \"sort-dsc\", options },\n ],\n });\n } else if (hasSort) {\n menuItems.push({\n label: \"Add to sort\",\n children: [\n { label: \"Ascending\", action: \"sort-add-asc\", options },\n { label: \"Descending\", action: \"sort-add-dsc\", options },\n ],\n });\n menuItems.push({\n label: \"New Sort\",\n children: [\n { label: \"Ascending\", action: \"sort-asc\", options },\n { label: \"Descending\", action: \"sort-dsc\", options },\n ],\n });\n } else {\n menuItems.push({\n label: \"Sort\",\n children: [\n { label: \"Ascending\", action: \"sort-asc\", options },\n { label: \"Descending\", action: \"sort-dsc\", options },\n ],\n });\n }\n return menuItems;\n}\n\nfunction buildAggregationMenuItems(\n options: MaybeColumn,\n dataSource: DataSource\n): ContextMenuItemDescriptor[] {\n const { column } = options;\n if (column === undefined || dataSource.groupBy.length === 0) {\n return [];\n }\n const { name, label = name } = column;\n\n return [\n {\n label: `Aggregate ${label}`,\n children: [\n { label: \"Count\", action: \"agg-count\", options },\n { label: \"Distinct\", action: \"agg-distinct\", options },\n ].concat(\n isNumericColumn(column)\n ? [\n { label: \"Sum\", action: \"agg-sum\", options },\n { label: \"Avg\", action: \"agg-avg\", options },\n { label: \"High\", action: \"agg-high\", options },\n { label: \"Low\", action: \"agg-low\", options },\n ]\n : []\n ),\n },\n ];\n}\n\nconst pinColumn = (options: unknown, pinLocation: PinLocation) =>\n ({\n label: `Pin ${pinLocation}`,\n action: `column-pin-${pinLocation}`,\n options,\n } as ContextMenuItemDescriptor);\n\nconst pinLeft = (options: unknown) => pinColumn(options, \"left\");\nconst pinFloating = (options: unknown) => pinColumn(options, \"floating\");\nconst pinRight = (options: unknown) => pinColumn(options, \"right\");\n\nfunction buildColumnDisplayMenuItems(\n options: MaybeColumn\n): ContextMenuItemDescriptor[] {\n const { column } = options;\n if (column === undefined) {\n return [];\n }\n const { pin } = column;\n\n const menuItems: ContextMenuItemDescriptor[] = [\n {\n label: `Hide column`,\n action: \"column-hide\",\n options,\n },\n {\n label: `Remove column`,\n action: \"column-remove\",\n options,\n },\n ];\n\n if (pin === undefined) {\n menuItems.push({\n label: `Pin column`,\n children: [pinLeft(options), pinFloating(options), pinRight(options)],\n });\n } else if (pin === \"left\") {\n menuItems.push(\n { label: \"Unpin column\", action: \"column-unpin\", options },\n {\n label: `Pin column`,\n children: [pinFloating(options), pinRight(options)],\n }\n );\n } else if (pin === \"right\") {\n menuItems.push(\n { label: \"Unpin column\", action: \"column-unpin\", options },\n {\n label: `Pin column`,\n children: [pinLeft(options), pinFloating(options)],\n }\n );\n } else if (pin === \"floating\") {\n menuItems.push(\n { label: \"Unpin column\", action: \"column-unpin\", options },\n {\n label: `Pin column`,\n children: [pinLeft(options), pinRight(options)],\n }\n );\n }\n\n return menuItems;\n}\n\nfunction buildGroupMenuItems(\n options: MaybeColumn,\n { groupBy }: DataSource\n): ContextMenuItemDescriptor[] {\n const { column } = options;\n const menuItems: ContextMenuItemDescriptor[] = [];\n if (column === undefined) {\n return menuItems;\n }\n\n const { name, label = name } = column;\n\n if (groupBy.length === 0) {\n menuItems.push({\n label: `Group by ${label}`,\n action: \"group\",\n options,\n });\n } else {\n menuItems.push({\n label: `Add ${label} to group by`,\n action: \"group-add\",\n options,\n });\n }\n\n return menuItems;\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,79 @@
1
+ import { setAggregations, addGroupColumn, addSortColumn, setSortColumn, removeColumnFromFilter, AggregationType } from '@vuu-ui/vuu-utils';
2
+
3
+ const removeFilterColumn = (dataSourceFilter, column) => {
4
+ if (dataSourceFilter.filterStruct && column) {
5
+ const [filterStruct, filter] = removeColumnFromFilter(
6
+ column,
7
+ dataSourceFilter.filterStruct
8
+ );
9
+ return {
10
+ filter,
11
+ filterStruct
12
+ };
13
+ } else {
14
+ return dataSourceFilter;
15
+ }
16
+ };
17
+ const { Average, Count, Distinct, High, Low, Sum } = AggregationType;
18
+ const useHandleTableContextMenu = ({
19
+ dataSource,
20
+ onPersistentColumnOperation
21
+ }) => {
22
+ const handleContextMenuAction = (action) => {
23
+ const gridOptions = action.options;
24
+ if (gridOptions.column && dataSource) {
25
+ const { column } = gridOptions;
26
+ switch (action.menuId) {
27
+ case "sort-asc":
28
+ return dataSource.sort = setSortColumn(dataSource.sort, column, "A"), true;
29
+ case "sort-dsc":
30
+ return dataSource.sort = setSortColumn(dataSource.sort, column, "D"), true;
31
+ case "sort-add-asc":
32
+ return dataSource.sort = addSortColumn(dataSource.sort, column, "A"), true;
33
+ case "sort-add-dsc":
34
+ return dataSource.sort = addSortColumn(dataSource.sort, column, "D"), true;
35
+ case "group":
36
+ return dataSource.groupBy = addGroupColumn(dataSource.groupBy, column), true;
37
+ case "group-add":
38
+ return dataSource.groupBy = addGroupColumn(dataSource.groupBy, column), true;
39
+ case "column-hide":
40
+ return onPersistentColumnOperation({ type: "hideColumns", columns: [column] }), true;
41
+ case "column-remove":
42
+ return dataSource.columns = dataSource.columns.filter((name) => name !== column.name), true;
43
+ case "filter-remove-column":
44
+ return dataSource.filter = removeFilterColumn(dataSource.filter, column), true;
45
+ case "remove-filters":
46
+ return dataSource.filter = { filter: "" }, true;
47
+ case "agg-avg":
48
+ return dataSource.aggregations = setAggregations(dataSource.aggregations, column, Average), true;
49
+ case "agg-high":
50
+ return dataSource.aggregations = setAggregations(dataSource.aggregations, column, High), true;
51
+ case "agg-low":
52
+ return dataSource.aggregations = setAggregations(dataSource.aggregations, column, Low), true;
53
+ case "agg-count":
54
+ return dataSource.aggregations = setAggregations(dataSource.aggregations, column, Count), true;
55
+ case "agg-distinct":
56
+ return dataSource.aggregations = setAggregations(dataSource.aggregations, column, Distinct), true;
57
+ case "agg-sum":
58
+ return dataSource.aggregations = setAggregations(dataSource.aggregations, column, Sum), true;
59
+ case "column-pin-floating":
60
+ return onPersistentColumnOperation({ type: "pinColumn", column, pin: "floating" }), true;
61
+ case "column-pin-left":
62
+ return onPersistentColumnOperation({ type: "pinColumn", column, pin: "left" }), true;
63
+ case "column-pin-right":
64
+ return onPersistentColumnOperation({ type: "pinColumn", column, pin: "right" }), true;
65
+ case "column-unpin":
66
+ return onPersistentColumnOperation({ type: "pinColumn", column, pin: void 0 }), true;
67
+ case "column-settings":
68
+ return onPersistentColumnOperation({ type: "columnSettings", column }), true;
69
+ case "table-settings":
70
+ return onPersistentColumnOperation({ type: "tableSettings" }), true;
71
+ }
72
+ }
73
+ return false;
74
+ };
75
+ return handleContextMenuAction;
76
+ };
77
+
78
+ export { useHandleTableContextMenu };
79
+ //# sourceMappingURL=useHandleTableContextMenu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useHandleTableContextMenu.js","sources":["../../src/context-menu/useHandleTableContextMenu.ts"],"sourcesContent":["/* eslint-disable no-sequences */\nimport { RuntimeColumnDescriptor } from \"@vuu-ui/vuu-table-types\";\nimport { Filter } from \"@vuu-ui/vuu-filter-types\";\nimport { removeColumnFromFilter } from \"@vuu-ui/vuu-utils\";\nimport { VuuFilter } from \"@vuu-ui/vuu-protocol-types\";\nimport {\n DataSource,\n DataSourceFilter,\n MenuActionHandler,\n} from \"@vuu-ui/vuu-data-types\";\nimport { PersistentColumnAction } from \"../useTableModel\";\nimport {\n addGroupColumn,\n addSortColumn,\n AggregationType,\n setAggregations,\n setSortColumn,\n} from \"@vuu-ui/vuu-utils\";\n\nexport interface ContextMenuOptions {\n column?: RuntimeColumnDescriptor;\n filter?: Filter;\n sort?: VuuFilter;\n}\nexport interface ContextMenuHookProps {\n dataSource?: DataSource;\n /**\n * A persistent Column Operation is any manipulation of a table column that should be\n * persisted across user sessions. e.g. if user pins a column, column should still be\n * pinned next time user opens app.\n */\n onPersistentColumnOperation: (action: PersistentColumnAction) => void;\n}\n\nconst removeFilterColumn = (\n dataSourceFilter: DataSourceFilter,\n column: RuntimeColumnDescriptor\n) => {\n if (dataSourceFilter.filterStruct && column) {\n const [filterStruct, filter] = removeColumnFromFilter(\n column,\n dataSourceFilter.filterStruct\n );\n return {\n filter,\n filterStruct,\n };\n } else {\n return dataSourceFilter;\n }\n};\n\nconst { Average, Count, Distinct, High, Low, Sum } = AggregationType;\n\nexport const useHandleTableContextMenu = ({\n dataSource,\n onPersistentColumnOperation,\n}: ContextMenuHookProps) => {\n /** return {boolean} used by caller to determine whether to forward to additional installed context menu handlers */\n const handleContextMenuAction: MenuActionHandler = (action): boolean => {\n const gridOptions = action.options as ContextMenuOptions;\n if (gridOptions.column && dataSource) {\n const { column } = gridOptions;\n // prettier-ignore\n switch(action.menuId){\n case \"sort-asc\": return (dataSource.sort = setSortColumn(dataSource.sort, column, \"A\")), true;\n case \"sort-dsc\": return (dataSource.sort = setSortColumn(dataSource.sort, column, \"D\")), true;\n case \"sort-add-asc\": return (dataSource.sort = addSortColumn(dataSource.sort, column, \"A\")), true;\n case \"sort-add-dsc\": return (dataSource.sort = addSortColumn(dataSource.sort, column, \"D\")), true;\n case \"group\": return (dataSource.groupBy = addGroupColumn(dataSource.groupBy, column)), true;\n case \"group-add\": return (dataSource.groupBy = addGroupColumn(dataSource.groupBy, column)), true;\n case \"column-hide\": return onPersistentColumnOperation({type: \"hideColumns\", columns: [column]}), true;\n case \"column-remove\": return (dataSource.columns = dataSource.columns.filter(name => name !== column.name)), true\n case \"filter-remove-column\": return (dataSource.filter = removeFilterColumn(dataSource.filter, column)), true;\n case \"remove-filters\": return (dataSource.filter = {filter:\"\"}), true;\n case \"agg-avg\": return dataSource.aggregations = (setAggregations(dataSource.aggregations, column, Average)), true;\n case \"agg-high\": return dataSource.aggregations = (setAggregations(dataSource.aggregations, column, High)), true;\n case \"agg-low\": return dataSource.aggregations = (setAggregations(dataSource.aggregations, column, Low)), true;\n case \"agg-count\": return dataSource.aggregations = (setAggregations(dataSource.aggregations, column, Count)), true;\n case \"agg-distinct\": return dataSource.aggregations = (setAggregations(dataSource.aggregations, column, Distinct)), true;\n case \"agg-sum\": return dataSource.aggregations = (setAggregations(dataSource.aggregations, column, Sum)), true;\n case \"column-pin-floating\": return onPersistentColumnOperation({type: \"pinColumn\", column, pin: \"floating\"}), true;\n case \"column-pin-left\": return onPersistentColumnOperation({type: \"pinColumn\", column, pin: \"left\"}), true;\n case \"column-pin-right\": return onPersistentColumnOperation({type: \"pinColumn\", column, pin: \"right\"}), true;\n case \"column-unpin\": return onPersistentColumnOperation({type: \"pinColumn\", column, pin: undefined}), true\n case \"column-settings\": return onPersistentColumnOperation({type: \"columnSettings\", column}), true\n case \"table-settings\": return onPersistentColumnOperation({type: \"tableSettings\"}), true\n default:\n }\n }\n return false;\n };\n\n return handleContextMenuAction;\n};\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,65 @@
1
+
2
+ .vuu-theme {
3
+ --svg-spinner: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><path fill="rgb(38, 112, 169)" d="M73,50c0-12.7-10.3-23-23-23S27,37.3,27,50 M30.9,50c0-10.5,8.5-19.1,19.1-19.1S69.1,39.5,69.1,50"><animateTransform attributeName="transform" attributeType="XML" type="rotate" dur="1s" from="0 50 50" to="360 50 50" repeatCount="indefinite" /></path></svg>');
4
+ }
5
+
6
+ .vuuTableGroupHeaderCell {
7
+ --vuuColumnHeaderPill-margin: 0;
8
+ --cell-align: 'flex-start';
9
+ text-align: left;
10
+ background: var(--dataTable-background);
11
+ cursor: default;
12
+ height: var(--vuuTableHeaderHeight);
13
+ /* ensure header row sits atop everything else when scrolling down */
14
+ }
15
+
16
+
17
+ .vuuTableGroupHeaderCell-inner {
18
+ align-items: center;
19
+ display: flex;
20
+ gap: 4px;
21
+ height: 100%;
22
+ padding-left: 1px;
23
+ }
24
+
25
+ .vuuTableGroupHeaderCell-col {
26
+ align-items: center;
27
+ background-color: inherit;
28
+ display: inline-flex;
29
+ flex: 0 1 auto;
30
+ height: calc(var(--vuuTableHeaderHeight) - 2px);
31
+ justify-content: space-between;
32
+ padding-right: 8px;
33
+ position: relative;
34
+ }
35
+
36
+ .vuuTableGroupHeaderCell-label {
37
+ align-items: center;
38
+ display: flex;
39
+ flex: 0 0 auto;
40
+ }
41
+
42
+ .vuuTableGroupHeaderCell-close {
43
+ --vuu-icon-height: 18px;
44
+ --vuu-icon-width: 18px;
45
+ cursor: pointer;
46
+ left: 3px;
47
+ }
48
+
49
+ .vuuTableGroupHeaderCell-resizing {
50
+ --columnResizer-color: var(--salt-color-blue-500);
51
+ --columnResizer-height: var(--table-height);
52
+ --columnResizer-width: 2px;
53
+ }
54
+ .vuuTableGroupHeaderCell-pending {
55
+ --pending-content: '';
56
+ }
57
+
58
+ .vuuTableGroupHeaderCell-col:has(+ .vuuColumnResizer):after {
59
+ content: var(--pending-content);
60
+ width: 24px;
61
+ height:24px;
62
+ background-image: var(--svg-spinner);
63
+ background-repeat: no-repeat;
64
+ background-size: cover;
65
+ }
@@ -0,0 +1,106 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { useRef, useState, useCallback, createElement } from 'react';
3
+ import { OverflowContainer } from '@vuu-ui/vuu-ui-controls';
4
+ import { useLayoutEffectSkipFirst } from '@vuu-ui/vuu-utils';
5
+ import cx from 'clsx';
6
+ import { ColumnHeaderPill } from '../column-header-pill/ColumnHeaderPill.js';
7
+ import { GroupColumnPill } from '../column-header-pill/GroupColumnPill.js';
8
+ import { ColumnResizer } from '../column-resizing/ColumnResizer.js';
9
+ import { useTableColumnResize } from '../column-resizing/useTableColumnResize.js';
10
+ import { useCell } from '../useCell.js';
11
+
12
+ const classBase = "vuuTableGroupHeaderCell";
13
+ const switchIfChanged = (columns, newColumns) => {
14
+ if (columns === newColumns) {
15
+ return columns;
16
+ } else {
17
+ return newColumns;
18
+ }
19
+ };
20
+ const GroupHeaderCell = ({
21
+ column: groupColumn,
22
+ className: classNameProp,
23
+ onMoveColumn,
24
+ onRemoveColumn,
25
+ onResize,
26
+ ...htmlAttributes
27
+ }) => {
28
+ const rootRef = useRef(null);
29
+ const { isResizing, ...resizeProps } = useTableColumnResize({
30
+ column: groupColumn,
31
+ onResize,
32
+ rootRef
33
+ });
34
+ const [columns, setColumns] = useState(groupColumn.columns);
35
+ const { className, style } = useCell(groupColumn, classBase, true);
36
+ const columnPillProps = columns.length > 1 ? {
37
+ removable: true,
38
+ onRemove: onRemoveColumn
39
+ } : void 0;
40
+ const handleMoveItem = useCallback(
41
+ (fromIndex, toIndex) => {
42
+ setColumns((cols) => {
43
+ const newCols = cols.slice();
44
+ const [tab] = newCols.splice(fromIndex, 1);
45
+ if (toIndex === -1) {
46
+ const result = newCols.concat(tab);
47
+ onMoveColumn?.(result);
48
+ return result;
49
+ } else {
50
+ newCols.splice(toIndex, 0, tab);
51
+ onMoveColumn?.(newCols);
52
+ return newCols;
53
+ }
54
+ });
55
+ },
56
+ [onMoveColumn]
57
+ );
58
+ useLayoutEffectSkipFirst(() => {
59
+ setColumns((cols) => switchIfChanged(cols, groupColumn.columns));
60
+ }, [groupColumn.columns]);
61
+ return /* @__PURE__ */ jsxs(
62
+ "div",
63
+ {
64
+ ...htmlAttributes,
65
+ className: cx(className, classNameProp, {
66
+ [`${classBase}-pending`]: groupColumn.groupConfirmed === false
67
+ }),
68
+ ref: rootRef,
69
+ role: "columnheader",
70
+ style,
71
+ children: [
72
+ /* @__PURE__ */ jsx(
73
+ OverflowContainer,
74
+ {
75
+ allowDragDrop: true,
76
+ className: `${classBase}-inner`,
77
+ onMoveItem: handleMoveItem,
78
+ overflowPosition: "start",
79
+ children: columns.map((column) => {
80
+ return /* @__PURE__ */ createElement(
81
+ GroupColumnPill,
82
+ {
83
+ ...columnPillProps,
84
+ column,
85
+ key: column.name
86
+ }
87
+ );
88
+ })
89
+ }
90
+ ),
91
+ /* @__PURE__ */ jsx(
92
+ ColumnHeaderPill,
93
+ {
94
+ column: groupColumn,
95
+ removable: true,
96
+ onRemove: onRemoveColumn
97
+ }
98
+ ),
99
+ groupColumn.resizeable !== false ? /* @__PURE__ */ jsx(ColumnResizer, { ...resizeProps }) : null
100
+ ]
101
+ }
102
+ );
103
+ };
104
+
105
+ export { GroupHeaderCell };
106
+ //# sourceMappingURL=GroupHeaderCell.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GroupHeaderCell.js","sources":["../../src/header-cell/GroupHeaderCell.tsx"],"sourcesContent":["import { OverflowContainer } from \"@vuu-ui/vuu-ui-controls\";\nimport {\n ColumnDescriptor,\n GroupColumnDescriptor,\n HeaderCellProps,\n RuntimeColumnDescriptor,\n} from \"@vuu-ui/vuu-table-types\";\nimport { useLayoutEffectSkipFirst } from \"@vuu-ui/vuu-utils\";\nimport cx from \"clsx\";\nimport { useCallback, useRef, useState } from \"react\";\nimport { ColumnHeaderPill, GroupColumnPill } from \"../column-header-pill\";\nimport { ColumnResizer, useTableColumnResize } from \"../column-resizing\";\nimport { useCell } from \"../useCell\";\n\nimport \"./GroupHeaderCell.css\";\n\nconst classBase = \"vuuTableGroupHeaderCell\";\n\nconst switchIfChanged = (\n columns: RuntimeColumnDescriptor[],\n newColumns: RuntimeColumnDescriptor[]\n) => {\n if (columns === newColumns) {\n return columns;\n } else {\n return newColumns;\n }\n};\n\nexport interface GroupHeaderCellProps\n extends Omit<HeaderCellProps, \"onDragStart\" | \"onDrag\" | \"onDragEnd\"> {\n column: GroupColumnDescriptor;\n onMoveColumn?: (columns: ColumnDescriptor[]) => void;\n onRemoveColumn: (column: RuntimeColumnDescriptor) => void;\n}\n\nexport const GroupHeaderCell = ({\n column: groupColumn,\n className: classNameProp,\n onMoveColumn,\n onRemoveColumn,\n onResize,\n ...htmlAttributes\n}: GroupHeaderCellProps) => {\n const rootRef = useRef<HTMLTableCellElement>(null);\n const { isResizing, ...resizeProps } = useTableColumnResize({\n column: groupColumn,\n onResize,\n rootRef,\n });\n\n const [columns, setColumns] = useState(groupColumn.columns);\n const { className, style } = useCell(groupColumn, classBase, true);\n const columnPillProps =\n columns.length > 1\n ? {\n removable: true,\n onRemove: onRemoveColumn,\n }\n : undefined;\n\n const handleMoveItem = useCallback(\n (fromIndex, toIndex) => {\n setColumns((cols) => {\n const newCols = cols.slice();\n const [tab] = newCols.splice(fromIndex, 1);\n if (toIndex === -1) {\n const result = newCols.concat(tab);\n onMoveColumn?.(result);\n return result;\n } else {\n newCols.splice(toIndex, 0, tab);\n onMoveColumn?.(newCols);\n return newCols;\n }\n });\n },\n [onMoveColumn]\n );\n\n useLayoutEffectSkipFirst(() => {\n setColumns((cols) => switchIfChanged(cols, groupColumn.columns));\n }, [groupColumn.columns]);\n\n return (\n <div\n {...htmlAttributes}\n className={cx(className, classNameProp, {\n [`${classBase}-pending`]: groupColumn.groupConfirmed === false,\n })}\n ref={rootRef}\n role=\"columnheader\"\n style={style}\n >\n <OverflowContainer\n allowDragDrop\n className={`${classBase}-inner`}\n onMoveItem={handleMoveItem}\n overflowPosition=\"start\"\n >\n {columns.map((column) => {\n return (\n <GroupColumnPill\n {...columnPillProps}\n column={column}\n key={column.name}\n />\n );\n })}\n </OverflowContainer>\n <ColumnHeaderPill\n column={groupColumn}\n removable\n onRemove={onRemoveColumn}\n />\n\n {groupColumn.resizeable !== false ? (\n <ColumnResizer {...resizeProps} />\n ) : null}\n </div>\n );\n};\n"],"names":[],"mappings":"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"}