@vuu-ui/vuu-table 0.13.7 → 0.13.9

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,120 +0,0 @@
1
- 'use strict';
2
-
3
- var jsxRuntime = require('react/jsx-runtime');
4
- var styles = require('@salt-ds/styles');
5
- var window = require('@salt-ds/window');
6
- var vuuTableExtras = require('@vuu-ui/vuu-table-extras');
7
- var vuuUtils = require('@vuu-ui/vuu-utils');
8
- var cx = require('clsx');
9
- var react = require('react');
10
- var SortIndicator = require('../column-header-pill/SortIndicator.js');
11
- var ColumnResizer = require('../column-resizing/ColumnResizer.js');
12
- var useTableColumnResize = require('../column-resizing/useTableColumnResize.js');
13
- var useCell = require('../useCell.js');
14
- var core = require('@salt-ds/core');
15
- var HeaderCell$1 = require('./HeaderCell.css.js');
16
-
17
- const classBase = "vuuTableHeaderCell";
18
- const doNothing = () => {
19
- return { ref: { current: null } };
20
- };
21
- const HeaderCell = ({
22
- allowDragColumnHeader = true,
23
- className: classNameProp,
24
- column,
25
- id,
26
- index,
27
- onClick,
28
- onResize,
29
- showColumnHeaderMenus = true,
30
- ...htmlAttributes
31
- }) => {
32
- const targetWindow = window.useWindow();
33
- styles.useComponentCssInjection({
34
- testId: "vuu-header-cell",
35
- css: HeaderCell$1,
36
- window: targetWindow
37
- });
38
- const dragDropSortHook = allowDragColumnHeader ? vuuUtils.useSortable : doNothing;
39
- const { ref: sortableRef } = dragDropSortHook({ id, index });
40
- const { HeaderCellContentRenderer, HeaderCellLabelRenderer } = column;
41
- const rootRef = react.useRef(null);
42
- const { isResizing, ...resizeProps } = useTableColumnResize.useTableColumnResize({
43
- column,
44
- onResize,
45
- rootRef
46
- });
47
- const headerItems = react.useMemo(() => {
48
- const sortIndicator = /* @__PURE__ */ jsxRuntime.jsx(SortIndicator.SortIndicator, { column });
49
- const columnLabel = HeaderCellLabelRenderer ? /* @__PURE__ */ jsxRuntime.jsx(
50
- HeaderCellLabelRenderer,
51
- {
52
- className: `${classBase}-label`,
53
- column
54
- }
55
- ) : /* @__PURE__ */ jsxRuntime.jsx("div", { className: `${classBase}-label`, children: column.label ?? column.name });
56
- const columnContent = HeaderCellContentRenderer ? [/* @__PURE__ */ jsxRuntime.jsx(HeaderCellContentRenderer, { column }, "content")] : [];
57
- if (showColumnHeaderMenus) {
58
- const menuPermissions = showColumnHeaderMenus === true ? void 0 : showColumnHeaderMenus;
59
- const columnMenu = /* @__PURE__ */ jsxRuntime.jsx(vuuTableExtras.ColumnMenu, { column, menuPermissions });
60
- if (column.align === "right") {
61
- return [sortIndicator, columnLabel, columnContent, columnMenu];
62
- } else {
63
- return [columnMenu, columnLabel, sortIndicator, columnContent];
64
- }
65
- } else {
66
- if (column.align === "right") {
67
- return [sortIndicator, columnLabel, columnContent];
68
- } else {
69
- return [columnLabel, sortIndicator, columnContent];
70
- }
71
- }
72
- }, [
73
- HeaderCellContentRenderer,
74
- HeaderCellLabelRenderer,
75
- column,
76
- showColumnHeaderMenus
77
- ]);
78
- const handleClick = react.useCallback(
79
- (evt) => {
80
- !isResizing && onClick?.(evt);
81
- },
82
- [isResizing, onClick]
83
- );
84
- const handleKeyDown = react.useCallback(
85
- (evt) => {
86
- if (evt.key === "Enter") {
87
- onClick?.(evt);
88
- }
89
- },
90
- [onClick]
91
- );
92
- const { className, style } = useCell.useCell(column, classBase, true);
93
- return /* @__PURE__ */ jsxRuntime.jsxs(
94
- "div",
95
- {
96
- ...htmlAttributes,
97
- "aria-colindex": column.ariaColIndex,
98
- "aria-label": `${column.label ?? column.name} column header`,
99
- className: cx(className, classNameProp, {
100
- [`${classBase}-resizing`]: isResizing,
101
- [`${classBase}-noMenu`]: showColumnHeaderMenus === false
102
- }),
103
- "data-column-name": column.name,
104
- "data-index": index,
105
- id,
106
- onClick: handleClick,
107
- onKeyDown: handleKeyDown,
108
- ref: core.useForkRef(rootRef, sortableRef),
109
- role: "columnheader",
110
- style,
111
- children: [
112
- ...headerItems,
113
- column.resizeable !== false ? /* @__PURE__ */ jsxRuntime.jsx(ColumnResizer.ColumnResizer, { ...resizeProps }) : null
114
- ]
115
- }
116
- );
117
- };
118
-
119
- exports.HeaderCell = HeaderCell;
120
- //# sourceMappingURL=HeaderCell.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"HeaderCell.js","sources":["../../src/header-cell/HeaderCell.tsx"],"sourcesContent":["import { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { ColumnMenu } from \"@vuu-ui/vuu-table-extras\";\nimport { HeaderCellProps } from \"@vuu-ui/vuu-table-types\";\nimport { useSortable } from \"@vuu-ui/vuu-utils\";\nimport cx from \"clsx\";\nimport {\n KeyboardEventHandler,\n MouseEventHandler,\n useCallback,\n useMemo,\n useRef,\n} from \"react\";\nimport { SortIndicator } from \"../column-header-pill\";\nimport { ColumnResizer, useTableColumnResize } from \"../column-resizing\";\nimport { useCell } from \"../useCell\";\n\nimport { useForkRef } from \"@salt-ds/core\";\nimport headerCellCss from \"./HeaderCell.css\";\n\nconst classBase = \"vuuTableHeaderCell\";\n\nconst doNothing = () => {\n // dummy hook\n return { ref: { current: null } };\n};\n\nexport const HeaderCell = ({\n allowDragColumnHeader = true,\n className: classNameProp,\n column,\n id,\n index,\n onClick,\n onResize,\n showColumnHeaderMenus = true,\n ...htmlAttributes\n}: HeaderCellProps) => {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"vuu-header-cell\",\n css: headerCellCss,\n window: targetWindow,\n });\n const dragDropSortHook = allowDragColumnHeader ? useSortable : doNothing;\n const { ref: sortableRef } = dragDropSortHook({ id, index });\n const { HeaderCellContentRenderer, HeaderCellLabelRenderer } = column;\n const rootRef = useRef<HTMLDivElement>(null);\n const { isResizing, ...resizeProps } = useTableColumnResize({\n column,\n onResize,\n rootRef,\n });\n\n const headerItems = useMemo(() => {\n const sortIndicator = <SortIndicator column={column} />;\n const columnLabel = HeaderCellLabelRenderer ? (\n <HeaderCellLabelRenderer\n className={`${classBase}-label`}\n column={column}\n />\n ) : (\n <div className={`${classBase}-label`}>{column.label ?? column.name}</div>\n );\n const columnContent = HeaderCellContentRenderer\n ? [<HeaderCellContentRenderer column={column} key=\"content\" />]\n : [];\n\n if (showColumnHeaderMenus) {\n const menuPermissions =\n showColumnHeaderMenus === true ? undefined : showColumnHeaderMenus;\n const columnMenu = (\n <ColumnMenu column={column} menuPermissions={menuPermissions} />\n );\n\n if (column.align === \"right\") {\n return [sortIndicator, columnLabel, columnContent, columnMenu];\n } else {\n return [columnMenu, columnLabel, sortIndicator, columnContent];\n }\n } else {\n if (column.align === \"right\") {\n return [sortIndicator, columnLabel, columnContent];\n } else {\n return [columnLabel, sortIndicator, columnContent];\n }\n }\n }, [\n HeaderCellContentRenderer,\n HeaderCellLabelRenderer,\n column,\n showColumnHeaderMenus,\n ]);\n\n const handleClick = useCallback<MouseEventHandler<HTMLDivElement>>(\n (evt) => {\n !isResizing && onClick?.(evt);\n },\n [isResizing, onClick],\n );\n\n const handleKeyDown = useCallback<KeyboardEventHandler<HTMLDivElement>>(\n (evt) => {\n if (evt.key === \"Enter\") {\n onClick?.(evt);\n }\n },\n [onClick],\n );\n\n const { className, style } = useCell(column, classBase, true);\n\n return (\n <div\n {...htmlAttributes}\n aria-colindex={column.ariaColIndex}\n aria-label={`${column.label ?? column.name} column header`}\n className={cx(className, classNameProp, {\n [`${classBase}-resizing`]: isResizing,\n [`${classBase}-noMenu`]: showColumnHeaderMenus === false,\n })}\n data-column-name={column.name}\n data-index={index}\n id={id}\n onClick={handleClick}\n onKeyDown={handleKeyDown}\n ref={useForkRef<HTMLDivElement>(rootRef, sortableRef)}\n role=\"columnheader\"\n style={style}\n >\n {...headerItems}\n {column.resizeable !== false ? <ColumnResizer {...resizeProps} /> : null}\n </div>\n );\n};\n"],"names":["useWindow","useComponentCssInjection","headerCellCss","useSortable","useRef","useTableColumnResize","useMemo","jsx","SortIndicator","ColumnMenu","useCallback","useCell","jsxs","useForkRef","ColumnResizer"],"mappings":"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"}
@@ -1,6 +0,0 @@
1
- 'use strict';
2
-
3
- var paginationControlCss = ".vuuPaginationControl {\n align-items: center;\n display: flex;\n height: var(--vuuPaginationControl-height, auto);\n justify-content: flex-end;\n padding: 0 var(--salt-spacing-100);\n .saltButton {\n .saltIcon {\n display: block !important;\n }\n }\n}\n";
4
-
5
- module.exports = paginationControlCss;
6
- //# sourceMappingURL=PaginationControl.css.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"PaginationControl.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -1,38 +0,0 @@
1
- 'use strict';
2
-
3
- var jsxRuntime = require('react/jsx-runtime');
4
- var styles = require('@salt-ds/styles');
5
- var window = require('@salt-ds/window');
6
- var core = require('@salt-ds/core');
7
- var cx = require('clsx');
8
- var usePagination = require('./usePagination.js');
9
- var PaginationControl$1 = require('./PaginationControl.css.js');
10
- var react = require('react');
11
-
12
- const classBase = "vuuPaginationControl";
13
- const PaginationControl = react.forwardRef(function PaginationControl2({ className, dataSource, ...htmlAttributes }, forwardedRef) {
14
- const targetWindow = window.useWindow();
15
- styles.useComponentCssInjection({
16
- testId: "vuu-table",
17
- css: PaginationControl$1,
18
- window: targetWindow
19
- });
20
- const { onPageChange, pageCount } = usePagination.usePagination({
21
- dataSource
22
- });
23
- return /* @__PURE__ */ jsxRuntime.jsx(
24
- "div",
25
- {
26
- ...htmlAttributes,
27
- className: cx(classBase, className),
28
- ref: forwardedRef,
29
- children: /* @__PURE__ */ jsxRuntime.jsxs(core.Pagination, { count: pageCount, onPageChange, children: [
30
- /* @__PURE__ */ jsxRuntime.jsx(core.GoToInput, {}),
31
- /* @__PURE__ */ jsxRuntime.jsx(core.Paginator, {})
32
- ] })
33
- }
34
- );
35
- });
36
-
37
- exports.PaginationControl = PaginationControl;
38
- //# sourceMappingURL=PaginationControl.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"PaginationControl.js","sources":["../../src/pagination/PaginationControl.tsx"],"sourcesContent":["import { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { GoToInput, Pagination, Paginator } from \"@salt-ds/core\";\nimport cx from \"clsx\";\nimport { usePagination } from \"./usePagination\";\n\nimport paginationControlCss from \"./PaginationControl.css\";\nimport { HtmlHTMLAttributes, forwardRef } from \"react\";\nimport { DataSource } from \"@vuu-ui/vuu-data-types\";\n\nconst classBase = \"vuuPaginationControl\";\n\nexport interface PaginationControlProps\n extends HtmlHTMLAttributes<HTMLDivElement> {\n dataSource: DataSource;\n}\n\nexport const PaginationControl = forwardRef<\n HTMLDivElement,\n PaginationControlProps\n>(function PaginationControl(\n { className, dataSource, ...htmlAttributes },\n forwardedRef,\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"vuu-table\",\n css: paginationControlCss,\n window: targetWindow,\n });\n\n const { onPageChange, pageCount } = usePagination({\n dataSource,\n });\n\n return (\n <div\n {...htmlAttributes}\n className={cx(classBase, className)}\n ref={forwardedRef}\n >\n <Pagination count={pageCount} onPageChange={onPageChange}>\n <GoToInput />\n <Paginator />\n </Pagination>\n </div>\n );\n});\n"],"names":["forwardRef","PaginationControl","useWindow","useComponentCssInjection","paginationControlCss","usePagination","jsx","jsxs","Pagination","GoToInput","Paginator"],"mappings":";;;;;;;;;;;AAUA,MAAM,SAAY,GAAA,sBAAA;AAOL,MAAA,iBAAA,GAAoBA,gBAG/B,CAAA,SAASC,kBACT,CAAA,EAAE,WAAW,UAAY,EAAA,GAAG,cAAe,EAAA,EAC3C,YACA,EAAA;AACA,EAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,WAAA;AAAA,IACR,GAAK,EAAAC,mBAAA;AAAA,IACL,MAAQ,EAAA;AAAA,GACT,CAAA;AAED,EAAA,MAAM,EAAE,YAAA,EAAc,SAAU,EAAA,GAAIC,2BAAc,CAAA;AAAA,IAChD;AAAA,GACD,CAAA;AAED,EACE,uBAAAC,cAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACE,GAAG,cAAA;AAAA,MACJ,SAAA,EAAW,EAAG,CAAA,SAAA,EAAW,SAAS,CAAA;AAAA,MAClC,GAAK,EAAA,YAAA;AAAA,MAEL,QAAC,kBAAAC,eAAA,CAAAC,eAAA,EAAA,EAAW,KAAO,EAAA,SAAA,EAAW,YAC5B,EAAA,QAAA,EAAA;AAAA,wBAAAF,cAAA,CAACG,cAAU,EAAA,EAAA,CAAA;AAAA,uCACVC,cAAU,EAAA,EAAA;AAAA,OACb,EAAA;AAAA;AAAA,GACF;AAEJ,CAAC;;;;"}
@@ -1,36 +0,0 @@
1
- 'use strict';
2
-
3
- var react = require('react');
4
- var vuuUtils = require('@vuu-ui/vuu-utils');
5
-
6
- const getPageCount = (dataSource) => {
7
- const { range, size } = dataSource;
8
- const pageSize = range.to - range.from;
9
- if (pageSize > 0) {
10
- return Math.ceil(size / pageSize);
11
- } else {
12
- return 0;
13
- }
14
- };
15
- const usePagination = ({ dataSource }) => {
16
- const [pageCount, setPageCount] = react.useState(getPageCount(dataSource));
17
- react.useMemo(() => {
18
- dataSource.on("page-count", (n) => setPageCount(n));
19
- }, [dataSource]);
20
- const handlePageChange = react.useCallback(
21
- (_evt, page) => {
22
- const { range } = dataSource;
23
- const pageSize = range.to - range.from;
24
- const firstRow = pageSize * (page - 1);
25
- dataSource.range = vuuUtils.Range(firstRow, firstRow + pageSize);
26
- },
27
- [dataSource]
28
- );
29
- return {
30
- onPageChange: handlePageChange,
31
- pageCount
32
- };
33
- };
34
-
35
- exports.usePagination = usePagination;
36
- //# sourceMappingURL=usePagination.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"usePagination.js","sources":["../../src/pagination/usePagination.ts"],"sourcesContent":["import { SyntheticEvent, useCallback, useMemo, useState } from \"react\";\nimport { DataSource } from \"@vuu-ui/vuu-data-types\";\nimport { Range } from \"@vuu-ui/vuu-utils\";\n\nexport interface PaginationHookProps {\n dataSource: DataSource;\n}\n\nconst getPageCount = (dataSource: DataSource) => {\n const { range, size } = dataSource;\n const pageSize = range.to - range.from;\n if (pageSize > 0) {\n return Math.ceil(size / pageSize);\n } else {\n return 0;\n }\n};\n\nexport const usePagination = ({ dataSource }: PaginationHookProps) => {\n const [pageCount, setPageCount] = useState<number>(getPageCount(dataSource));\n\n useMemo(() => {\n dataSource.on(\"page-count\", (n: number) => setPageCount(n));\n }, [dataSource]);\n\n const handlePageChange = useCallback(\n (_evt: SyntheticEvent, page: number) => {\n const { range } = dataSource;\n const pageSize = range.to - range.from;\n const firstRow = pageSize * (page - 1);\n dataSource.range = Range(firstRow, firstRow + pageSize);\n },\n [dataSource],\n );\n\n return {\n onPageChange: handlePageChange,\n pageCount,\n };\n};\n"],"names":["useState","useMemo","useCallback","Range"],"mappings":";;;;;AAQA,MAAM,YAAA,GAAe,CAAC,UAA2B,KAAA;AAC/C,EAAM,MAAA,EAAE,KAAO,EAAA,IAAA,EAAS,GAAA,UAAA;AACxB,EAAM,MAAA,QAAA,GAAW,KAAM,CAAA,EAAA,GAAK,KAAM,CAAA,IAAA;AAClC,EAAA,IAAI,WAAW,CAAG,EAAA;AAChB,IAAO,OAAA,IAAA,CAAK,IAAK,CAAA,IAAA,GAAO,QAAQ,CAAA;AAAA,GAC3B,MAAA;AACL,IAAO,OAAA,CAAA;AAAA;AAEX,CAAA;AAEO,MAAM,aAAgB,GAAA,CAAC,EAAE,UAAA,EAAsC,KAAA;AACpE,EAAA,MAAM,CAAC,SAAW,EAAA,YAAY,IAAIA,cAAiB,CAAA,YAAA,CAAa,UAAU,CAAC,CAAA;AAE3E,EAAAC,aAAA,CAAQ,MAAM;AACZ,IAAA,UAAA,CAAW,GAAG,YAAc,EAAA,CAAC,CAAc,KAAA,YAAA,CAAa,CAAC,CAAC,CAAA;AAAA,GAC5D,EAAG,CAAC,UAAU,CAAC,CAAA;AAEf,EAAA,MAAM,gBAAmB,GAAAC,iBAAA;AAAA,IACvB,CAAC,MAAsB,IAAiB,KAAA;AACtC,MAAM,MAAA,EAAE,OAAU,GAAA,UAAA;AAClB,MAAM,MAAA,QAAA,GAAW,KAAM,CAAA,EAAA,GAAK,KAAM,CAAA,IAAA;AAClC,MAAM,MAAA,QAAA,GAAW,YAAY,IAAO,GAAA,CAAA,CAAA;AACpC,MAAA,UAAA,CAAW,KAAQ,GAAAC,cAAA,CAAM,QAAU,EAAA,QAAA,GAAW,QAAQ,CAAA;AAAA,KACxD;AAAA,IACA,CAAC,UAAU;AAAA,GACb;AAEA,EAAO,OAAA;AAAA,IACL,YAAc,EAAA,gBAAA;AAAA,IACd;AAAA,GACF;AACF;;;;"}
@@ -1,6 +0,0 @@
1
- 'use strict';
2
-
3
- var tableCellCss = ".vuuTableCell {\n border-right-color: var(--cell-borderColor);\n border-right-style: solid;\n border-right-width: 1px;\n /* unfortunately inline-flex doesn't play nice with text-overflow ellipsis */\n display: inline-block;\n white-space: nowrap;\n height: 100%;\n overflow: hidden;\n padding: var(--vuuTableCell-padding, 0 11px 0 12px);\n text-overflow: ellipsis;\n vertical-align: top;\n}\n\n.vuuTableCell-right {\n text-align: right;\n}\n\n.vuuTableCell-editable {\n align-items: center;\n display: inline-flex;\n text-overflow: unset;\n}\n\n.vuuTableCell:focus {\n outline: var(\n --vuuTableCell-outline,\n solid var(--salt-focused-outlineColor) 2px\n );\n outline-offset: -2px;\n /** This is to achieve a white background to outline dashes */\n box-shadow: inset 0 0 0 var(--cell-outline-width) white;\n border-bottom: none;\n}\n\n.vuuTableRow-selected .vuuTableCell:not(.vuuTableCell-editable):focus {\n outline: var(\n --vuuTableCell-outline,\n solid var(--salt-focused-outlineColor) 2px\n );\n\n &:has(.vuuCheckboxRowSelector) {\n outline: none;\n }\n}\n.vuuTableCell-editable:focus {\n outline: none;\n}\n";
4
-
5
- module.exports = tableCellCss;
6
- //# sourceMappingURL=TableCell.css.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"TableCell.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -1,95 +0,0 @@
1
- 'use strict';
2
-
3
- var jsxRuntime = require('react/jsx-runtime');
4
- var vuuUtils = require('@vuu-ui/vuu-utils');
5
- var styles = require('@salt-ds/styles');
6
- var window = require('@salt-ds/window');
7
- var react = require('react');
8
- var useCell = require('../useCell.js');
9
- var useHighlighting = require('../useHighlighting.js');
10
- var TableCell$1 = require('./TableCell.css.js');
11
-
12
- const classBase = "vuuTableCell";
13
- const TableCell = ({
14
- column,
15
- columnMap,
16
- onClick,
17
- onDataEdited,
18
- row,
19
- searchPattern = ""
20
- }) => {
21
- const targetWindow = window.useWindow();
22
- styles.useComponentCssInjection({
23
- testId: "vuu-table-cell",
24
- css: TableCell$1,
25
- window: targetWindow
26
- });
27
- const [hasError, setHasError] = react.useState(false);
28
- const { className, style } = useCell.useCell(column, classBase, false, hasError);
29
- const { ariaColIndex, CellRenderer, valueFormatter } = column;
30
- const dataIdx = columnMap[column.name];
31
- const handleDataItemEdited = react.useCallback(
32
- (editState, editPhase) => {
33
- if (editPhase === "commit") {
34
- const { serverDataType = "string" } = column;
35
- if (onDataEdited) {
36
- const typedValue = vuuUtils.getTypedValue(
37
- String(editState.value),
38
- serverDataType,
39
- true
40
- );
41
- return onDataEdited({
42
- ...editState,
43
- row,
44
- columnName: column.name,
45
- value: typedValue
46
- });
47
- } else {
48
- throw Error(
49
- "TableCell onDataEdited prop not supplied for an editable cell"
50
- );
51
- }
52
- } else {
53
- setHasError(editState.isValid === false);
54
- onDataEdited({
55
- ...editState,
56
- row,
57
- columnName: column.name
58
- });
59
- return void 0;
60
- }
61
- },
62
- [column, onDataEdited, row]
63
- );
64
- const handleClick = react.useCallback(
65
- (evt) => {
66
- onClick?.(evt, column);
67
- },
68
- [column, onClick]
69
- );
70
- const value = valueFormatter(row[dataIdx]);
71
- const valueWithHighlighting = useHighlighting.useHighlighting(value, searchPattern);
72
- return /* @__PURE__ */ jsxRuntime.jsx(
73
- "div",
74
- {
75
- "aria-colindex": ariaColIndex,
76
- className,
77
- onClick: onClick ? handleClick : void 0,
78
- role: "cell",
79
- style,
80
- children: CellRenderer ? /* @__PURE__ */ jsxRuntime.jsx(
81
- CellRenderer,
82
- {
83
- column,
84
- columnMap,
85
- onEdit: handleDataItemEdited,
86
- row,
87
- searchPattern
88
- }
89
- ) : valueWithHighlighting
90
- }
91
- );
92
- };
93
-
94
- exports.TableCell = TableCell;
95
- //# sourceMappingURL=TableCell.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"TableCell.js","sources":["../../src/table-cell/TableCell.tsx"],"sourcesContent":["import type {\n DataItemEditHandler,\n TableCellProps,\n} from \"@vuu-ui/vuu-table-types\";\nimport { getTypedValue } from \"@vuu-ui/vuu-utils\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { MouseEventHandler, useCallback, useState } from \"react\";\nimport { useCell } from \"../useCell\";\nimport { useHighlighting } from \"../useHighlighting\";\n\nimport tableCellCss from \"./TableCell.css\";\n\nconst classBase = \"vuuTableCell\";\n\nexport const TableCell = ({\n column,\n columnMap,\n onClick,\n onDataEdited,\n row,\n searchPattern = \"\",\n}: TableCellProps) => {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"vuu-table-cell\",\n css: tableCellCss,\n window: targetWindow,\n });\n\n const [hasError, setHasError] = useState(false);\n\n const { className, style } = useCell(column, classBase, false, hasError);\n const { ariaColIndex, CellRenderer, valueFormatter } = column;\n const dataIdx = columnMap[column.name];\n\n const handleDataItemEdited = useCallback<DataItemEditHandler>(\n (editState, editPhase) => {\n if (editPhase === \"commit\") {\n const { serverDataType = \"string\" } = column;\n if (onDataEdited) {\n const typedValue = getTypedValue(\n String(editState.value),\n serverDataType,\n true,\n );\n return onDataEdited({\n ...editState,\n row,\n columnName: column.name,\n value: typedValue,\n });\n } else {\n throw Error(\n \"TableCell onDataEdited prop not supplied for an editable cell\",\n );\n }\n } else {\n setHasError(editState.isValid === false);\n onDataEdited({\n ...editState,\n row,\n columnName: column.name,\n });\n return undefined;\n }\n },\n [column, onDataEdited, row],\n );\n\n const handleClick = useCallback<MouseEventHandler>(\n (evt) => {\n onClick?.(evt, column);\n },\n [column, onClick],\n );\n\n const value = valueFormatter(row[dataIdx]);\n const valueWithHighlighting = useHighlighting(value, searchPattern);\n\n return (\n <div\n aria-colindex={ariaColIndex}\n className={className}\n onClick={onClick ? handleClick : undefined}\n role=\"cell\"\n style={style}\n >\n {CellRenderer ? (\n <CellRenderer\n column={column}\n columnMap={columnMap}\n onEdit={handleDataItemEdited}\n row={row}\n searchPattern={searchPattern}\n />\n ) : (\n valueWithHighlighting\n )}\n </div>\n );\n};\n"],"names":["useWindow","useComponentCssInjection","tableCellCss","useState","useCell","useCallback","getTypedValue","useHighlighting","jsx"],"mappings":";;;;;;;;;;;AAaA,MAAM,SAAY,GAAA,cAAA;AAEX,MAAM,YAAY,CAAC;AAAA,EACxB,MAAA;AAAA,EACA,SAAA;AAAA,EACA,OAAA;AAAA,EACA,YAAA;AAAA,EACA,GAAA;AAAA,EACA,aAAgB,GAAA;AAClB,CAAsB,KAAA;AACpB,EAAA,MAAM,eAAeA,gBAAU,EAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,gBAAA;AAAA,IACR,GAAK,EAAAC,WAAA;AAAA,IACL,MAAQ,EAAA;AAAA,GACT,CAAA;AAED,EAAA,MAAM,CAAC,QAAA,EAAU,WAAW,CAAA,GAAIC,eAAS,KAAK,CAAA;AAE9C,EAAM,MAAA,EAAE,WAAW,KAAM,EAAA,GAAIC,gBAAQ,MAAQ,EAAA,SAAA,EAAW,OAAO,QAAQ,CAAA;AACvE,EAAA,MAAM,EAAE,YAAA,EAAc,YAAc,EAAA,cAAA,EAAmB,GAAA,MAAA;AACvD,EAAM,MAAA,OAAA,GAAU,SAAU,CAAA,MAAA,CAAO,IAAI,CAAA;AAErC,EAAA,MAAM,oBAAuB,GAAAC,iBAAA;AAAA,IAC3B,CAAC,WAAW,SAAc,KAAA;AACxB,MAAA,IAAI,cAAc,QAAU,EAAA;AAC1B,QAAM,MAAA,EAAE,cAAiB,GAAA,QAAA,EAAa,GAAA,MAAA;AACtC,QAAA,IAAI,YAAc,EAAA;AAChB,UAAA,MAAM,UAAa,GAAAC,sBAAA;AAAA,YACjB,MAAA,CAAO,UAAU,KAAK,CAAA;AAAA,YACtB,cAAA;AAAA,YACA;AAAA,WACF;AACA,UAAA,OAAO,YAAa,CAAA;AAAA,YAClB,GAAG,SAAA;AAAA,YACH,GAAA;AAAA,YACA,YAAY,MAAO,CAAA,IAAA;AAAA,YACnB,KAAO,EAAA;AAAA,WACR,CAAA;AAAA,SACI,MAAA;AACL,UAAM,MAAA,KAAA;AAAA,YACJ;AAAA,WACF;AAAA;AACF,OACK,MAAA;AACL,QAAY,WAAA,CAAA,SAAA,CAAU,YAAY,KAAK,CAAA;AACvC,QAAa,YAAA,CAAA;AAAA,UACX,GAAG,SAAA;AAAA,UACH,GAAA;AAAA,UACA,YAAY,MAAO,CAAA;AAAA,SACpB,CAAA;AACD,QAAO,OAAA,KAAA,CAAA;AAAA;AACT,KACF;AAAA,IACA,CAAC,MAAQ,EAAA,YAAA,EAAc,GAAG;AAAA,GAC5B;AAEA,EAAA,MAAM,WAAc,GAAAD,iBAAA;AAAA,IAClB,CAAC,GAAQ,KAAA;AACP,MAAA,OAAA,GAAU,KAAK,MAAM,CAAA;AAAA,KACvB;AAAA,IACA,CAAC,QAAQ,OAAO;AAAA,GAClB;AAEA,EAAA,MAAM,KAAQ,GAAA,cAAA,CAAe,GAAI,CAAA,OAAO,CAAC,CAAA;AACzC,EAAM,MAAA,qBAAA,GAAwBE,+BAAgB,CAAA,KAAA,EAAO,aAAa,CAAA;AAElE,EACE,uBAAAC,cAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,eAAe,EAAA,YAAA;AAAA,MACf,SAAA;AAAA,MACA,OAAA,EAAS,UAAU,WAAc,GAAA,KAAA,CAAA;AAAA,MACjC,IAAK,EAAA,MAAA;AAAA,MACL,KAAA;AAAA,MAEC,QACC,EAAA,YAAA,mBAAAA,cAAA;AAAA,QAAC,YAAA;AAAA,QAAA;AAAA,UACC,MAAA;AAAA,UACA,SAAA;AAAA,UACA,MAAQ,EAAA,oBAAA;AAAA,UACR,GAAA;AAAA,UACA;AAAA;AAAA,OAGF,GAAA;AAAA;AAAA,GAEJ;AAEJ;;;;"}
@@ -1,6 +0,0 @@
1
- 'use strict';
2
-
3
- var tableGroupCellCss = ".vuuTableGroupCell.vuuTableCell {\n --group-cell-spacer-width: 20px;\n align-items: center;\n border-right-color: var(\n --vuuTableGroupCell-borderColor,\n var(--salt-separable-tertiary-borderColor)\n );\n border-right-style: solid;\n border-right-width: 1px;\n\n cursor: pointer;\n display: inline-flex;\n line-height: 16px;\n\n .vuuIcon {\n --vuu-icon-height: 20px;\n --vuu-icon-width: 20px;\n margin-right: var(--salt-spacing-100);\n min-width: 20px;\n }\n\n .vuuTableGroupCell-toggle {\n --vuu-icon-height: 16px;\n --vuu-icon-size: 7px;\n --vuu-icon-width: 8px;\n margin-right: 4px;\n transition: transform 0.25s;\n transform: var(--toggle-icon-transform);\n }\n\n .vuuTableGroupCell-label {\n overflow: hidden;\n text-overflow: ellipsis;\n }\n}\n\n[aria-level=\"2\"] {\n --indent: 1;\n}\n[aria-level=\"3\"] {\n --indent: 2;\n}\n[aria-level=\"4\"] {\n --indent: 3;\n}\n[aria-level=\"5\"] {\n --indent: 4;\n}\n[aria-level=\"6\"] {\n --indent: 5;\n}\n[aria-level=\"7\"] {\n --indent: 6;\n}\n[aria-level=\"8\"] {\n --indent: 7;\n}\n[aria-level=\"9\"] {\n --indent: 8;\n}\n[aria-level=\"10\"] {\n --indent: 9;\n}\n\n.vuuTableGroupCell-spacer {\n display: inline-block;\n min-width: calc(var(--indent, 0) * var(--group-cell-spacer-width));\n}\n\n.vuuTreeTable {\n .vuuTableGroupCell.vuuTableCell {\n border-right: none;\n } \n}";
4
-
5
- module.exports = tableGroupCellCss;
6
- //# sourceMappingURL=TableGroupCell.css.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"TableGroupCell.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -1,66 +0,0 @@
1
- 'use strict';
2
-
3
- var jsxRuntime = require('react/jsx-runtime');
4
- var vuuUiControls = require('@vuu-ui/vuu-ui-controls');
5
- var vuuUtils = require('@vuu-ui/vuu-utils');
6
- var styles = require('@salt-ds/styles');
7
- var window = require('@salt-ds/window');
8
- var cx = require('clsx');
9
- var react = require('react');
10
- var useCell = require('../useCell.js');
11
- var TableCell = require('./TableCell.css.js');
12
- var TableGroupCell$1 = require('./TableGroupCell.css.js');
13
- var useHighlighting = require('../useHighlighting.js');
14
-
15
- const { COUNT, IS_EXPANDED, IS_LEAF } = vuuUtils.metadataKeys;
16
- const classBase = "vuuTableGroupCell";
17
- const TableGroupCell = ({
18
- column,
19
- columnMap,
20
- onClick,
21
- row,
22
- searchPattern = ""
23
- }) => {
24
- const targetWindow = window.useWindow();
25
- styles.useComponentCssInjection({
26
- testId: "vuu-table-cell",
27
- css: TableCell,
28
- window: targetWindow
29
- });
30
- styles.useComponentCssInjection({
31
- testId: "vuu-table-group-cell",
32
- css: TableGroupCell$1,
33
- window: targetWindow
34
- });
35
- const { columns } = column;
36
- const value = vuuUtils.getGroupValue(columns, row, columnMap);
37
- const valueWithHighlighting = useHighlighting.useHighlighting(value || "", searchPattern);
38
- const icon = vuuUtils.getGroupIcon(columns, row);
39
- const { className, style } = useCell.useCell(column, classBase);
40
- const handleClick = react.useCallback(
41
- (evt) => {
42
- onClick?.(evt, column);
43
- },
44
- [column, onClick]
45
- );
46
- const { [COUNT]: count, [IS_EXPANDED]: isExpanded, [IS_LEAF]: isLeaf } = row;
47
- return /* @__PURE__ */ jsxRuntime.jsxs(
48
- "div",
49
- {
50
- "aria-colindex": 1,
51
- className: cx(className, "vuuTableCell"),
52
- role: "cell",
53
- style,
54
- onClick: isLeaf ? void 0 : handleClick,
55
- children: [
56
- /* @__PURE__ */ jsxRuntime.jsx("span", { className: `${classBase}-spacer` }),
57
- isLeaf || count == 0 ? null : /* @__PURE__ */ jsxRuntime.jsx(vuuUiControls.ToggleIconButton, { isExpanded }),
58
- icon ? /* @__PURE__ */ jsxRuntime.jsx(vuuUiControls.Icon, { name: icon }) : null,
59
- /* @__PURE__ */ jsxRuntime.jsx("span", { className: `${classBase}-label`, children: valueWithHighlighting })
60
- ]
61
- }
62
- );
63
- };
64
-
65
- exports.TableGroupCell = TableGroupCell;
66
- //# sourceMappingURL=TableGroupCell.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"TableGroupCell.js","sources":["../../src/table-cell/TableGroupCell.tsx"],"sourcesContent":["import { GroupColumnDescriptor, TableCellProps } from \"@vuu-ui/vuu-table-types\";\nimport { Icon, ToggleIconButton } from \"@vuu-ui/vuu-ui-controls\";\nimport { getGroupIcon, getGroupValue, metadataKeys } from \"@vuu-ui/vuu-utils\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport cx from \"clsx\";\nimport { MouseEvent, useCallback } from \"react\";\nimport { useCell } from \"../useCell\";\n\nimport tableCellCss from \"./TableCell.css\";\nimport tableGroupCellCss from \"./TableGroupCell.css\";\nimport { useHighlighting } from \"../useHighlighting\";\n\nconst { COUNT, IS_EXPANDED, IS_LEAF } = metadataKeys;\n\nconst classBase = \"vuuTableGroupCell\";\n\nexport const TableGroupCell = ({\n column,\n columnMap,\n onClick,\n row,\n searchPattern = \"\",\n}: TableCellProps) => {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"vuu-table-cell\",\n css: tableCellCss,\n window: targetWindow,\n });\n useComponentCssInjection({\n testId: \"vuu-table-group-cell\",\n css: tableGroupCellCss,\n window: targetWindow,\n });\n\n const { columns } = column as GroupColumnDescriptor;\n const value = getGroupValue(columns, row, columnMap);\n const valueWithHighlighting = useHighlighting(value || \"\", searchPattern);\n\n const icon = getGroupIcon(columns, row);\n const { className, style } = useCell(column, classBase);\n\n const handleClick = useCallback(\n (evt: MouseEvent<HTMLDivElement>) => {\n onClick?.(evt, column);\n },\n [column, onClick],\n );\n\n const { [COUNT]: count, [IS_EXPANDED]: isExpanded, [IS_LEAF]: isLeaf } = row;\n\n return (\n <div\n aria-colindex={1}\n className={cx(className, \"vuuTableCell\")}\n role=\"cell\"\n style={style}\n onClick={isLeaf ? undefined : handleClick}\n >\n <span className={`${classBase}-spacer`} />\n {isLeaf || count == 0 ? null : (\n <ToggleIconButton isExpanded={isExpanded} />\n )}\n {icon ? <Icon name={icon} /> : null}\n <span className={`${classBase}-label`}>{valueWithHighlighting}</span>\n </div>\n );\n};\n"],"names":["metadataKeys","useWindow","useComponentCssInjection","tableCellCss","tableGroupCellCss","getGroupValue","useHighlighting","getGroupIcon","useCell","useCallback","jsxs","jsx","ToggleIconButton","Icon"],"mappings":";;;;;;;;;;;;;;AAaA,MAAM,EAAE,KAAA,EAAO,WAAa,EAAA,OAAA,EAAY,GAAAA,qBAAA;AAExC,MAAM,SAAY,GAAA,mBAAA;AAEX,MAAM,iBAAiB,CAAC;AAAA,EAC7B,MAAA;AAAA,EACA,SAAA;AAAA,EACA,OAAA;AAAA,EACA,GAAA;AAAA,EACA,aAAgB,GAAA;AAClB,CAAsB,KAAA;AACpB,EAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,gBAAA;AAAA,IACR,GAAK,EAAAC,SAAA;AAAA,IACL,MAAQ,EAAA;AAAA,GACT,CAAA;AACD,EAAyBD,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,sBAAA;AAAA,IACR,GAAK,EAAAE,gBAAA;AAAA,IACL,MAAQ,EAAA;AAAA,GACT,CAAA;AAED,EAAM,MAAA,EAAE,SAAY,GAAA,MAAA;AACpB,EAAA,MAAM,KAAQ,GAAAC,sBAAA,CAAc,OAAS,EAAA,GAAA,EAAK,SAAS,CAAA;AACnD,EAAA,MAAM,qBAAwB,GAAAC,+BAAA,CAAgB,KAAS,IAAA,EAAA,EAAI,aAAa,CAAA;AAExE,EAAM,MAAA,IAAA,GAAOC,qBAAa,CAAA,OAAA,EAAS,GAAG,CAAA;AACtC,EAAA,MAAM,EAAE,SAAW,EAAA,KAAA,EAAU,GAAAC,eAAA,CAAQ,QAAQ,SAAS,CAAA;AAEtD,EAAA,MAAM,WAAc,GAAAC,iBAAA;AAAA,IAClB,CAAC,GAAoC,KAAA;AACnC,MAAA,OAAA,GAAU,KAAK,MAAM,CAAA;AAAA,KACvB;AAAA,IACA,CAAC,QAAQ,OAAO;AAAA,GAClB;AAEA,EAAA,MAAM,EAAE,CAAC,KAAK,GAAG,KAAO,EAAA,CAAC,WAAW,GAAG,UAAY,EAAA,CAAC,OAAO,GAAG,QAAW,GAAA,GAAA;AAEzE,EACE,uBAAAC,eAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,eAAe,EAAA,CAAA;AAAA,MACf,SAAA,EAAW,EAAG,CAAA,SAAA,EAAW,cAAc,CAAA;AAAA,MACvC,IAAK,EAAA,MAAA;AAAA,MACL,KAAA;AAAA,MACA,OAAA,EAAS,SAAS,KAAY,CAAA,GAAA,WAAA;AAAA,MAE9B,QAAA,EAAA;AAAA,wBAAAC,cAAA,CAAC,MAAK,EAAA,EAAA,SAAA,EAAW,CAAG,EAAA,SAAS,CAAW,OAAA,CAAA,EAAA,CAAA;AAAA,QACvC,UAAU,KAAS,IAAA,CAAA,GAAI,IACtB,mBAAAA,cAAA,CAACC,kCAAiB,UAAwB,EAAA,CAAA;AAAA,QAE3C,IAAO,mBAAAD,cAAA,CAACE,kBAAK,EAAA,EAAA,IAAA,EAAM,MAAM,CAAK,GAAA,IAAA;AAAA,uCAC9B,MAAK,EAAA,EAAA,SAAA,EAAW,CAAG,EAAA,SAAS,UAAW,QAAsB,EAAA,qBAAA,EAAA;AAAA;AAAA;AAAA,GAChE;AAEJ;;;;"}
@@ -1,35 +0,0 @@
1
- 'use strict';
2
-
3
- var vuuUtils = require('@vuu-ui/vuu-utils');
4
-
5
- const updateTableConfig = (config, action) => {
6
- switch (action.type) {
7
- case "col-size": {
8
- const { columns: runtimeColumns, width } = action;
9
- const isFit = config.columnLayout === "fit";
10
- return {
11
- ...config,
12
- columnLayout: isFit ? "manual" : config.columnLayout,
13
- columns: config.columns.map((col) => {
14
- if (isFit) {
15
- return col.name === action.column.name ? { ...col, width } : col.width ? col : { ...col, width: vuuUtils.getRuntimeColumnWidth(col, runtimeColumns) };
16
- } else {
17
- return col.name === action.column.name ? { ...col, width: action.width } : col;
18
- }
19
- })
20
- };
21
- }
22
- case "column-prop":
23
- return {
24
- ...config,
25
- columns: config.columns.map(
26
- (col) => col.name === action.column.name ? { ...col, [action.property]: action.value } : col
27
- )
28
- };
29
- default:
30
- return config;
31
- }
32
- };
33
-
34
- exports.updateTableConfig = updateTableConfig;
35
- //# sourceMappingURL=table-config.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"table-config.js","sources":["../src/table-config.ts"],"sourcesContent":["import {\n ColumnDescriptor,\n RuntimeColumnDescriptor,\n TableConfig,\n} from \"@vuu-ui/vuu-table-types\";\nimport { getRuntimeColumnWidth } from \"@vuu-ui/vuu-utils\";\n\nexport type MoveColumnTableConfigAction = {\n type: \"col-move\";\n column: ColumnDescriptor;\n fromIndex: number;\n toIndex: number;\n};\n\nexport type ResizeColumnTableConfigAction = {\n type: \"col-size\";\n column: ColumnDescriptor;\n columns: RuntimeColumnDescriptor[];\n width: number;\n};\n\nexport type SubscribeColumnTableConfigAction = {\n type: \"subscribed\";\n column: ColumnDescriptor;\n value: boolean;\n};\n\nexport type UpdateColumnPropertyTableConfigAction = {\n type: \"column-prop\";\n column: ColumnDescriptor;\n property: keyof ColumnDescriptor;\n value: boolean | number | string;\n};\n\nexport type TableConfigAction =\n | MoveColumnTableConfigAction\n | ResizeColumnTableConfigAction\n | UpdateColumnPropertyTableConfigAction;\n\nexport const updateTableConfig = (\n config: TableConfig,\n action: TableConfigAction,\n): TableConfig => {\n switch (action.type) {\n case \"col-size\": {\n const { columns: runtimeColumns, width } = action;\n const isFit = config.columnLayout === \"fit\";\n return {\n ...config,\n columnLayout: isFit ? \"manual\" : config.columnLayout,\n columns: config.columns.map((col) => {\n if (isFit) {\n // When user resizes a column and 'fit' column layout is in effect,\n // column layout becomes 'manual' and all columns are set to\n // their current widths (unless subsequently resized by user).\n return col.name === action.column.name\n ? { ...col, width }\n : col.width\n ? col\n : { ...col, width: getRuntimeColumnWidth(col, runtimeColumns) };\n } else {\n return col.name === action.column.name\n ? { ...col, width: action.width }\n : col;\n }\n }),\n };\n }\n case \"column-prop\":\n return {\n ...config,\n columns: config.columns.map((col) =>\n col.name === action.column.name\n ? { ...col, [action.property]: action.value }\n : col,\n ),\n };\n\n default:\n return config;\n }\n};\n"],"names":["getRuntimeColumnWidth"],"mappings":";;;;AAuCa,MAAA,iBAAA,GAAoB,CAC/B,MAAA,EACA,MACgB,KAAA;AAChB,EAAA,QAAQ,OAAO,IAAM;AAAA,IACnB,KAAK,UAAY,EAAA;AACf,MAAA,MAAM,EAAE,OAAA,EAAS,cAAgB,EAAA,KAAA,EAAU,GAAA,MAAA;AAC3C,MAAM,MAAA,KAAA,GAAQ,OAAO,YAAiB,KAAA,KAAA;AACtC,MAAO,OAAA;AAAA,QACL,GAAG,MAAA;AAAA,QACH,YAAA,EAAc,KAAQ,GAAA,QAAA,GAAW,MAAO,CAAA,YAAA;AAAA,QACxC,OAAS,EAAA,MAAA,CAAO,OAAQ,CAAA,GAAA,CAAI,CAAC,GAAQ,KAAA;AACnC,UAAA,IAAI,KAAO,EAAA;AAIT,YAAO,OAAA,GAAA,CAAI,SAAS,MAAO,CAAA,MAAA,CAAO,OAC9B,EAAE,GAAG,KAAK,KAAM,EAAA,GAChB,IAAI,KACF,GAAA,GAAA,GACA,EAAE,GAAG,GAAA,EAAK,OAAOA,8BAAsB,CAAA,GAAA,EAAK,cAAc,CAAE,EAAA;AAAA,WAC7D,MAAA;AACL,YAAO,OAAA,GAAA,CAAI,IAAS,KAAA,MAAA,CAAO,MAAO,CAAA,IAAA,GAC9B,EAAE,GAAG,GAAK,EAAA,KAAA,EAAO,MAAO,CAAA,KAAA,EACxB,GAAA,GAAA;AAAA;AACN,SACD;AAAA,OACH;AAAA;AACF,IACA,KAAK,aAAA;AACH,MAAO,OAAA;AAAA,QACL,GAAG,MAAA;AAAA,QACH,OAAA,EAAS,OAAO,OAAQ,CAAA,GAAA;AAAA,UAAI,CAAC,GAC3B,KAAA,GAAA,CAAI,IAAS,KAAA,MAAA,CAAO,OAAO,IACvB,GAAA,EAAE,GAAG,GAAA,EAAK,CAAC,MAAO,CAAA,QAAQ,GAAG,MAAA,CAAO,OACpC,GAAA;AAAA;AACN,OACF;AAAA,IAEF;AACE,MAAO,OAAA,MAAA;AAAA;AAEb;;;;"}