@fluentui/react-table 9.0.0-rc.4 → 9.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (396) hide show
  1. package/CHANGELOG.json +124 -8
  2. package/CHANGELOG.md +44 -9
  3. package/dist/index.d.ts +114 -3
  4. package/lib/TableResizeHandle.js +2 -0
  5. package/lib/TableResizeHandle.js.map +1 -0
  6. package/lib/components/DataGrid/DataGrid.types.js.map +1 -1
  7. package/lib/components/DataGrid/index.js +1 -0
  8. package/lib/components/DataGrid/index.js.map +1 -1
  9. package/lib/components/DataGrid/useDataGrid.js +16 -4
  10. package/lib/components/DataGrid/useDataGrid.js.map +1 -1
  11. package/lib/components/DataGrid/useDataGridContextValues.js +2 -1
  12. package/lib/components/DataGrid/useDataGridContextValues.js.map +1 -1
  13. package/lib/components/DataGridCell/useDataGridCell.js +5 -0
  14. package/lib/components/DataGridCell/useDataGridCell.js.map +1 -1
  15. package/lib/components/DataGridHeaderCell/useDataGridHeaderCell.js +3 -0
  16. package/lib/components/DataGridHeaderCell/useDataGridHeaderCell.js.map +1 -1
  17. package/lib/components/DataGridHeaderCell/useDataGridHeaderCellStyles.js +5 -1
  18. package/lib/components/DataGridHeaderCell/useDataGridHeaderCellStyles.js.map +1 -1
  19. package/lib/components/TableCellLayout/TableCellLayout.types.js.map +1 -1
  20. package/lib/components/TableCellLayout/useTableCellLayout.js +1 -0
  21. package/lib/components/TableCellLayout/useTableCellLayout.js.map +1 -1
  22. package/lib/components/TableCellLayout/useTableCellLayoutStyles.js +18 -4
  23. package/lib/components/TableCellLayout/useTableCellLayoutStyles.js.map +1 -1
  24. package/lib/components/TableHeaderCell/TableHeaderCell.types.js.map +1 -1
  25. package/lib/components/TableHeaderCell/renderTableHeaderCell.js +3 -1
  26. package/lib/components/TableHeaderCell/renderTableHeaderCell.js.map +1 -1
  27. package/lib/components/TableHeaderCell/useTableHeaderCell.js +3 -1
  28. package/lib/components/TableHeaderCell/useTableHeaderCell.js.map +1 -1
  29. package/lib/components/TableHeaderCell/useTableHeaderCellStyles.js +10 -4
  30. package/lib/components/TableHeaderCell/useTableHeaderCellStyles.js.map +1 -1
  31. package/lib/components/TableResizeHandle/TableResizeHandle.js +14 -0
  32. package/lib/components/TableResizeHandle/TableResizeHandle.js.map +1 -0
  33. package/lib/components/TableResizeHandle/TableResizeHandle.types.js +2 -0
  34. package/lib/components/TableResizeHandle/TableResizeHandle.types.js.map +1 -0
  35. package/lib/components/TableResizeHandle/index.js +6 -0
  36. package/lib/components/TableResizeHandle/index.js.map +1 -0
  37. package/lib/components/TableResizeHandle/renderTableResizeHandle.js +15 -0
  38. package/lib/components/TableResizeHandle/renderTableResizeHandle.js.map +1 -0
  39. package/lib/components/TableResizeHandle/useTableResizeHandle.js +28 -0
  40. package/lib/components/TableResizeHandle/useTableResizeHandle.js.map +1 -0
  41. package/lib/components/TableResizeHandle/useTableResizeHandleStyles.js +49 -0
  42. package/lib/components/TableResizeHandle/useTableResizeHandleStyles.js.map +1 -0
  43. package/lib/components/TableSelectionCell/useTableSelectionCellStyles.js +1 -0
  44. package/lib/components/TableSelectionCell/useTableSelectionCellStyles.js.map +1 -1
  45. package/lib/hooks/index.js +1 -0
  46. package/lib/hooks/index.js.map +1 -1
  47. package/lib/hooks/types.js.map +1 -1
  48. package/lib/hooks/useMeasureElement.js +48 -0
  49. package/lib/hooks/useMeasureElement.js.map +1 -0
  50. package/lib/hooks/useTableColumnResizeMouseHandler.js +50 -0
  51. package/lib/hooks/useTableColumnResizeMouseHandler.js.map +1 -0
  52. package/lib/hooks/useTableColumnResizeState.js +112 -0
  53. package/lib/hooks/useTableColumnResizeState.js.map +1 -0
  54. package/lib/hooks/useTableColumnSizing.js +77 -0
  55. package/lib/hooks/useTableColumnSizing.js.map +1 -0
  56. package/lib/hooks/useTableFeatures.js +10 -2
  57. package/lib/hooks/useTableFeatures.js.map +1 -1
  58. package/lib/index.js +3 -2
  59. package/lib/index.js.map +1 -1
  60. package/lib/utils/columnResizeUtils.js +158 -0
  61. package/lib/utils/columnResizeUtils.js.map +1 -0
  62. package/lib-amd/DataGrid.js +6 -0
  63. package/lib-amd/DataGrid.js.map +1 -0
  64. package/lib-amd/DataGridBody.js +6 -0
  65. package/lib-amd/DataGridBody.js.map +1 -0
  66. package/lib-amd/DataGridCell.js +6 -0
  67. package/lib-amd/DataGridCell.js.map +1 -0
  68. package/lib-amd/DataGridHeader.js +6 -0
  69. package/lib-amd/DataGridHeader.js.map +1 -0
  70. package/lib-amd/DataGridHeaderCell.js +6 -0
  71. package/lib-amd/DataGridHeaderCell.js.map +1 -0
  72. package/lib-amd/DataGridRow.js +6 -0
  73. package/lib-amd/DataGridRow.js.map +1 -0
  74. package/lib-amd/DataGridSelectionCell.js +6 -0
  75. package/lib-amd/DataGridSelectionCell.js.map +1 -0
  76. package/lib-amd/Table.js +6 -0
  77. package/lib-amd/Table.js.map +1 -0
  78. package/lib-amd/TableBody.js +6 -0
  79. package/lib-amd/TableBody.js.map +1 -0
  80. package/lib-amd/TableCell.js +6 -0
  81. package/lib-amd/TableCell.js.map +1 -0
  82. package/lib-amd/TableCellActions.js +6 -0
  83. package/lib-amd/TableCellActions.js.map +1 -0
  84. package/lib-amd/TableCellLayout.js +6 -0
  85. package/lib-amd/TableCellLayout.js.map +1 -0
  86. package/lib-amd/TableHeader.js +6 -0
  87. package/lib-amd/TableHeader.js.map +1 -0
  88. package/lib-amd/TableHeaderCell.js +6 -0
  89. package/lib-amd/TableHeaderCell.js.map +1 -0
  90. package/lib-amd/TableResizeHandle.js +6 -0
  91. package/lib-amd/TableResizeHandle.js.map +1 -0
  92. package/lib-amd/TableRow.js +6 -0
  93. package/lib-amd/TableRow.js.map +1 -0
  94. package/lib-amd/TableSelectionCell.js +6 -0
  95. package/lib-amd/TableSelectionCell.js.map +1 -0
  96. package/lib-amd/components/DataGrid/DataGrid.js +15 -0
  97. package/lib-amd/components/DataGrid/DataGrid.js.map +1 -0
  98. package/lib-amd/components/DataGrid/DataGrid.types.js +5 -0
  99. package/lib-amd/components/DataGrid/DataGrid.types.js.map +1 -0
  100. package/lib-amd/components/DataGrid/index.js +11 -0
  101. package/lib-amd/components/DataGrid/index.js.map +1 -0
  102. package/lib-amd/components/DataGrid/renderDataGrid.js +13 -0
  103. package/lib-amd/components/DataGrid/renderDataGrid.js.map +1 -0
  104. package/lib-amd/components/DataGrid/useDataGrid.js +43 -0
  105. package/lib-amd/components/DataGrid/useDataGrid.js.map +1 -0
  106. package/lib-amd/components/DataGrid/useDataGridContextValues.js +11 -0
  107. package/lib-amd/components/DataGrid/useDataGridContextValues.js.map +1 -0
  108. package/lib-amd/components/DataGrid/useDataGridStyles.js +18 -0
  109. package/lib-amd/components/DataGrid/useDataGridStyles.js.map +1 -0
  110. package/lib-amd/components/DataGridBody/DataGridBody.js +15 -0
  111. package/lib-amd/components/DataGridBody/DataGridBody.js.map +1 -0
  112. package/lib-amd/components/DataGridBody/DataGridBody.types.js +5 -0
  113. package/lib-amd/components/DataGridBody/DataGridBody.types.js.map +1 -0
  114. package/lib-amd/components/DataGridBody/index.js +10 -0
  115. package/lib-amd/components/DataGridBody/index.js.map +1 -0
  116. package/lib-amd/components/DataGridBody/renderDataGridBody.js +14 -0
  117. package/lib-amd/components/DataGridBody/renderDataGridBody.js.map +1 -0
  118. package/lib-amd/components/DataGridBody/useDataGridBody.js +24 -0
  119. package/lib-amd/components/DataGridBody/useDataGridBody.js.map +1 -0
  120. package/lib-amd/components/DataGridBody/useDataGridBodyStyles.js +18 -0
  121. package/lib-amd/components/DataGridBody/useDataGridBodyStyles.js.map +1 -0
  122. package/lib-amd/components/DataGridCell/DataGridCell.js +15 -0
  123. package/lib-amd/components/DataGridCell/DataGridCell.js.map +1 -0
  124. package/lib-amd/components/DataGridCell/DataGridCell.types.js +5 -0
  125. package/lib-amd/components/DataGridCell/DataGridCell.types.js.map +1 -0
  126. package/lib-amd/components/DataGridCell/index.js +10 -0
  127. package/lib-amd/components/DataGridCell/index.js.map +1 -0
  128. package/lib-amd/components/DataGridCell/renderDataGridCell.js +13 -0
  129. package/lib-amd/components/DataGridCell/renderDataGridCell.js.map +1 -0
  130. package/lib-amd/components/DataGridCell/useDataGridCell.js +23 -0
  131. package/lib-amd/components/DataGridCell/useDataGridCell.js.map +1 -0
  132. package/lib-amd/components/DataGridCell/useDataGridCellStyles.js +18 -0
  133. package/lib-amd/components/DataGridCell/useDataGridCellStyles.js.map +1 -0
  134. package/lib-amd/components/DataGridHeader/DataGridHeader.js +15 -0
  135. package/lib-amd/components/DataGridHeader/DataGridHeader.js.map +1 -0
  136. package/lib-amd/components/DataGridHeader/DataGridHeader.types.js +5 -0
  137. package/lib-amd/components/DataGridHeader/DataGridHeader.types.js.map +1 -0
  138. package/lib-amd/components/DataGridHeader/index.js +10 -0
  139. package/lib-amd/components/DataGridHeader/index.js.map +1 -0
  140. package/lib-amd/components/DataGridHeader/renderDataGridHeader.js +13 -0
  141. package/lib-amd/components/DataGridHeader/renderDataGridHeader.js.map +1 -0
  142. package/lib-amd/components/DataGridHeader/useDataGridHeader.js +19 -0
  143. package/lib-amd/components/DataGridHeader/useDataGridHeader.js.map +1 -0
  144. package/lib-amd/components/DataGridHeader/useDataGridHeaderStyles.js +18 -0
  145. package/lib-amd/components/DataGridHeader/useDataGridHeaderStyles.js.map +1 -0
  146. package/lib-amd/components/DataGridHeaderCell/DataGridHeaderCell.js +15 -0
  147. package/lib-amd/components/DataGridHeaderCell/DataGridHeaderCell.js.map +1 -0
  148. package/lib-amd/components/DataGridHeaderCell/DataGridHeaderCell.types.js +5 -0
  149. package/lib-amd/components/DataGridHeaderCell/DataGridHeaderCell.types.js.map +1 -0
  150. package/lib-amd/components/DataGridHeaderCell/index.js +10 -0
  151. package/lib-amd/components/DataGridHeaderCell/index.js.map +1 -0
  152. package/lib-amd/components/DataGridHeaderCell/renderDataGridHeaderCell.js +13 -0
  153. package/lib-amd/components/DataGridHeaderCell/renderDataGridHeaderCell.js.map +1 -0
  154. package/lib-amd/components/DataGridHeaderCell/useDataGridHeaderCell.js +34 -0
  155. package/lib-amd/components/DataGridHeaderCell/useDataGridHeaderCell.js.map +1 -0
  156. package/lib-amd/components/DataGridHeaderCell/useDataGridHeaderCellStyles.js +30 -0
  157. package/lib-amd/components/DataGridHeaderCell/useDataGridHeaderCellStyles.js.map +1 -0
  158. package/lib-amd/components/DataGridRow/DataGridRow.js +15 -0
  159. package/lib-amd/components/DataGridRow/DataGridRow.js.map +1 -0
  160. package/lib-amd/components/DataGridRow/DataGridRow.types.js +5 -0
  161. package/lib-amd/components/DataGridRow/DataGridRow.types.js.map +1 -0
  162. package/lib-amd/components/DataGridRow/index.js +10 -0
  163. package/lib-amd/components/DataGridRow/index.js.map +1 -0
  164. package/lib-amd/components/DataGridRow/renderDataGridRow.js +16 -0
  165. package/lib-amd/components/DataGridRow/renderDataGridRow.js.map +1 -0
  166. package/lib-amd/components/DataGridRow/useDataGridRow.js +49 -0
  167. package/lib-amd/components/DataGridRow/useDataGridRow.js.map +1 -0
  168. package/lib-amd/components/DataGridRow/useDataGridRowStyles.js +22 -0
  169. package/lib-amd/components/DataGridRow/useDataGridRowStyles.js.map +1 -0
  170. package/lib-amd/components/DataGridSelectionCell/DataGridSelectionCell.js +15 -0
  171. package/lib-amd/components/DataGridSelectionCell/DataGridSelectionCell.js.map +1 -0
  172. package/lib-amd/components/DataGridSelectionCell/DataGridSelectionCell.types.js +5 -0
  173. package/lib-amd/components/DataGridSelectionCell/DataGridSelectionCell.types.js.map +1 -0
  174. package/lib-amd/components/DataGridSelectionCell/index.js +10 -0
  175. package/lib-amd/components/DataGridSelectionCell/index.js.map +1 -0
  176. package/lib-amd/components/DataGridSelectionCell/renderDataGridSelectionCell.js +13 -0
  177. package/lib-amd/components/DataGridSelectionCell/renderDataGridSelectionCell.js.map +1 -0
  178. package/lib-amd/components/DataGridSelectionCell/useDataGridSelectionCell.js +39 -0
  179. package/lib-amd/components/DataGridSelectionCell/useDataGridSelectionCell.js.map +1 -0
  180. package/lib-amd/components/DataGridSelectionCell/useDataGridSelectionCellStyles.js +26 -0
  181. package/lib-amd/components/DataGridSelectionCell/useDataGridSelectionCellStyles.js.map +1 -0
  182. package/lib-amd/components/Table/Table.js +15 -0
  183. package/lib-amd/components/Table/Table.js.map +1 -0
  184. package/lib-amd/components/Table/Table.types.js +5 -0
  185. package/lib-amd/components/Table/Table.types.js.map +1 -0
  186. package/lib-amd/components/Table/index.js +10 -0
  187. package/lib-amd/components/Table/index.js.map +1 -0
  188. package/lib-amd/components/Table/renderTable.js +15 -0
  189. package/lib-amd/components/Table/renderTable.js.map +1 -0
  190. package/lib-amd/components/Table/useTable.js +29 -0
  191. package/lib-amd/components/Table/useTable.js.map +1 -0
  192. package/lib-amd/components/Table/useTableContextValues.js +18 -0
  193. package/lib-amd/components/Table/useTableContextValues.js.map +1 -0
  194. package/lib-amd/components/Table/useTableStyles.js +45 -0
  195. package/lib-amd/components/Table/useTableStyles.js.map +1 -0
  196. package/lib-amd/components/TableBody/TableBody.js +15 -0
  197. package/lib-amd/components/TableBody/TableBody.js.map +1 -0
  198. package/lib-amd/components/TableBody/TableBody.types.js +5 -0
  199. package/lib-amd/components/TableBody/TableBody.types.js.map +1 -0
  200. package/lib-amd/components/TableBody/index.js +10 -0
  201. package/lib-amd/components/TableBody/index.js.map +1 -0
  202. package/lib-amd/components/TableBody/renderTableBody.js +14 -0
  203. package/lib-amd/components/TableBody/renderTableBody.js.map +1 -0
  204. package/lib-amd/components/TableBody/useTableBody.js +28 -0
  205. package/lib-amd/components/TableBody/useTableBody.js.map +1 -0
  206. package/lib-amd/components/TableBody/useTableBodyStyles.js +32 -0
  207. package/lib-amd/components/TableBody/useTableBodyStyles.js.map +1 -0
  208. package/lib-amd/components/TableCell/TableCell.js +15 -0
  209. package/lib-amd/components/TableCell/TableCell.js.map +1 -0
  210. package/lib-amd/components/TableCell/TableCell.types.js +5 -0
  211. package/lib-amd/components/TableCell/TableCell.types.js.map +1 -0
  212. package/lib-amd/components/TableCell/index.js +10 -0
  213. package/lib-amd/components/TableCell/index.js.map +1 -0
  214. package/lib-amd/components/TableCell/renderTableCell.js +14 -0
  215. package/lib-amd/components/TableCell/renderTableCell.js.map +1 -0
  216. package/lib-amd/components/TableCell/useTableCell.js +29 -0
  217. package/lib-amd/components/TableCell/useTableCell.js.map +1 -0
  218. package/lib-amd/components/TableCell/useTableCellStyles.js +56 -0
  219. package/lib-amd/components/TableCell/useTableCellStyles.js.map +1 -0
  220. package/lib-amd/components/TableCellActions/TableCellActions.js +15 -0
  221. package/lib-amd/components/TableCellActions/TableCellActions.js.map +1 -0
  222. package/lib-amd/components/TableCellActions/TableCellActions.types.js +5 -0
  223. package/lib-amd/components/TableCellActions/TableCellActions.types.js.map +1 -0
  224. package/lib-amd/components/TableCellActions/index.js +10 -0
  225. package/lib-amd/components/TableCellActions/index.js.map +1 -0
  226. package/lib-amd/components/TableCellActions/renderTableCellActions.js +14 -0
  227. package/lib-amd/components/TableCellActions/renderTableCellActions.js.map +1 -0
  228. package/lib-amd/components/TableCellActions/useTableCellActions.js +26 -0
  229. package/lib-amd/components/TableCellActions/useTableCellActions.js.map +1 -0
  230. package/lib-amd/components/TableCellActions/useTableCellActionsStyles.js +35 -0
  231. package/lib-amd/components/TableCellActions/useTableCellActionsStyles.js.map +1 -0
  232. package/lib-amd/components/TableCellLayout/TableCellLayout.js +15 -0
  233. package/lib-amd/components/TableCellLayout/TableCellLayout.js.map +1 -0
  234. package/lib-amd/components/TableCellLayout/TableCellLayout.types.js +5 -0
  235. package/lib-amd/components/TableCellLayout/TableCellLayout.types.js.map +1 -0
  236. package/lib-amd/components/TableCellLayout/index.js +10 -0
  237. package/lib-amd/components/TableCellLayout/index.js.map +1 -0
  238. package/lib-amd/components/TableCellLayout/renderTableCellLayout.js +19 -0
  239. package/lib-amd/components/TableCellLayout/renderTableCellLayout.js.map +1 -0
  240. package/lib-amd/components/TableCellLayout/useTableCellLayout.js +42 -0
  241. package/lib-amd/components/TableCellLayout/useTableCellLayout.js.map +1 -0
  242. package/lib-amd/components/TableCellLayout/useTableCellLayoutContextValues.js +16 -0
  243. package/lib-amd/components/TableCellLayout/useTableCellLayoutContextValues.js.map +1 -0
  244. package/lib-amd/components/TableCellLayout/useTableCellLayoutStyles.js +79 -0
  245. package/lib-amd/components/TableCellLayout/useTableCellLayoutStyles.js.map +1 -0
  246. package/lib-amd/components/TableHeader/TableHeader.js +15 -0
  247. package/lib-amd/components/TableHeader/TableHeader.js.map +1 -0
  248. package/lib-amd/components/TableHeader/TableHeader.types.js +5 -0
  249. package/lib-amd/components/TableHeader/TableHeader.types.js.map +1 -0
  250. package/lib-amd/components/TableHeader/index.js +10 -0
  251. package/lib-amd/components/TableHeader/index.js.map +1 -0
  252. package/lib-amd/components/TableHeader/renderTableHeader.js +15 -0
  253. package/lib-amd/components/TableHeader/renderTableHeader.js.map +1 -0
  254. package/lib-amd/components/TableHeader/useTableHeader.js +28 -0
  255. package/lib-amd/components/TableHeader/useTableHeader.js.map +1 -0
  256. package/lib-amd/components/TableHeader/useTableHeaderStyles.js +32 -0
  257. package/lib-amd/components/TableHeader/useTableHeaderStyles.js.map +1 -0
  258. package/lib-amd/components/TableHeaderCell/TableHeaderCell.js +15 -0
  259. package/lib-amd/components/TableHeaderCell/TableHeaderCell.js.map +1 -0
  260. package/lib-amd/components/TableHeaderCell/TableHeaderCell.types.js +5 -0
  261. package/lib-amd/components/TableHeaderCell/TableHeaderCell.types.js.map +1 -0
  262. package/lib-amd/components/TableHeaderCell/index.js +10 -0
  263. package/lib-amd/components/TableHeaderCell/index.js.map +1 -0
  264. package/lib-amd/components/TableHeaderCell/renderTableHeaderCell.js +18 -0
  265. package/lib-amd/components/TableHeaderCell/renderTableHeaderCell.js.map +1 -0
  266. package/lib-amd/components/TableHeaderCell/useTableHeaderCell.js +48 -0
  267. package/lib-amd/components/TableHeaderCell/useTableHeaderCell.js.map +1 -0
  268. package/lib-amd/components/TableHeaderCell/useTableHeaderCellStyles.js +67 -0
  269. package/lib-amd/components/TableHeaderCell/useTableHeaderCellStyles.js.map +1 -0
  270. package/lib-amd/components/TableResizeHandle/TableResizeHandle.js +15 -0
  271. package/lib-amd/components/TableResizeHandle/TableResizeHandle.js.map +1 -0
  272. package/lib-amd/components/TableResizeHandle/TableResizeHandle.types.js +5 -0
  273. package/lib-amd/components/TableResizeHandle/TableResizeHandle.types.js.map +1 -0
  274. package/lib-amd/components/TableResizeHandle/index.js +10 -0
  275. package/lib-amd/components/TableResizeHandle/index.js.map +1 -0
  276. package/lib-amd/components/TableResizeHandle/renderTableResizeHandle.js +14 -0
  277. package/lib-amd/components/TableResizeHandle/renderTableResizeHandle.js.map +1 -0
  278. package/lib-amd/components/TableResizeHandle/useTableResizeHandle.js +29 -0
  279. package/lib-amd/components/TableResizeHandle/useTableResizeHandle.js.map +1 -0
  280. package/lib-amd/components/TableResizeHandle/useTableResizeHandleStyles.js +37 -0
  281. package/lib-amd/components/TableResizeHandle/useTableResizeHandleStyles.js.map +1 -0
  282. package/lib-amd/components/TableRow/TableRow.js +15 -0
  283. package/lib-amd/components/TableRow/TableRow.js.map +1 -0
  284. package/lib-amd/components/TableRow/TableRow.types.js +5 -0
  285. package/lib-amd/components/TableRow/TableRow.types.js.map +1 -0
  286. package/lib-amd/components/TableRow/index.js +10 -0
  287. package/lib-amd/components/TableRow/index.js.map +1 -0
  288. package/lib-amd/components/TableRow/renderTableRow.js +14 -0
  289. package/lib-amd/components/TableRow/renderTableRow.js.map +1 -0
  290. package/lib-amd/components/TableRow/useTableRow.js +34 -0
  291. package/lib-amd/components/TableRow/useTableRow.js.map +1 -0
  292. package/lib-amd/components/TableRow/useTableRowStyles.js +98 -0
  293. package/lib-amd/components/TableRow/useTableRowStyles.js.map +1 -0
  294. package/lib-amd/components/TableSelectionCell/TableSelectionCell.js +15 -0
  295. package/lib-amd/components/TableSelectionCell/TableSelectionCell.js.map +1 -0
  296. package/lib-amd/components/TableSelectionCell/TableSelectionCell.types.js +5 -0
  297. package/lib-amd/components/TableSelectionCell/TableSelectionCell.types.js.map +1 -0
  298. package/lib-amd/components/TableSelectionCell/index.js +10 -0
  299. package/lib-amd/components/TableSelectionCell/index.js.map +1 -0
  300. package/lib-amd/components/TableSelectionCell/renderTableSelectionCell.js +16 -0
  301. package/lib-amd/components/TableSelectionCell/renderTableSelectionCell.js.map +1 -0
  302. package/lib-amd/components/TableSelectionCell/useTableSelectionCell.js +28 -0
  303. package/lib-amd/components/TableSelectionCell/useTableSelectionCell.js.map +1 -0
  304. package/lib-amd/components/TableSelectionCell/useTableSelectionCellStyles.js +58 -0
  305. package/lib-amd/components/TableSelectionCell/useTableSelectionCellStyles.js.map +1 -0
  306. package/lib-amd/contexts/columnIdContext.js +11 -0
  307. package/lib-amd/contexts/columnIdContext.js.map +1 -0
  308. package/lib-amd/contexts/dataGridContext.js +16 -0
  309. package/lib-amd/contexts/dataGridContext.js.map +1 -0
  310. package/lib-amd/contexts/rowIdContext.js +11 -0
  311. package/lib-amd/contexts/rowIdContext.js.map +1 -0
  312. package/lib-amd/contexts/tableContext.js +15 -0
  313. package/lib-amd/contexts/tableContext.js.map +1 -0
  314. package/lib-amd/contexts/tableHeaderContext.js +11 -0
  315. package/lib-amd/contexts/tableHeaderContext.js.map +1 -0
  316. package/lib-amd/hooks/createColumn.js +36 -0
  317. package/lib-amd/hooks/createColumn.js.map +1 -0
  318. package/lib-amd/hooks/index.js +11 -0
  319. package/lib-amd/hooks/index.js.map +1 -0
  320. package/lib-amd/hooks/selectionManager.js +82 -0
  321. package/lib-amd/hooks/selectionManager.js.map +1 -0
  322. package/lib-amd/hooks/types.js +5 -0
  323. package/lib-amd/hooks/types.js.map +1 -0
  324. package/lib-amd/hooks/useMeasureElement.js +46 -0
  325. package/lib-amd/hooks/useMeasureElement.js.map +1 -0
  326. package/lib-amd/hooks/useTableColumnResizeMouseHandler.js +50 -0
  327. package/lib-amd/hooks/useTableColumnResizeMouseHandler.js.map +1 -0
  328. package/lib-amd/hooks/useTableColumnResizeState.js +73 -0
  329. package/lib-amd/hooks/useTableColumnResizeState.js.map +1 -0
  330. package/lib-amd/hooks/useTableColumnSizing.js +56 -0
  331. package/lib-amd/hooks/useTableColumnSizing.js.map +1 -0
  332. package/lib-amd/hooks/useTableFeatures.js +39 -0
  333. package/lib-amd/hooks/useTableFeatures.js.map +1 -0
  334. package/lib-amd/hooks/useTableSelection.js +70 -0
  335. package/lib-amd/hooks/useTableSelection.js.map +1 -0
  336. package/lib-amd/hooks/useTableSort.js +74 -0
  337. package/lib-amd/hooks/useTableSort.js.map +1 -0
  338. package/lib-amd/index.js +107 -0
  339. package/lib-amd/index.js.map +1 -0
  340. package/lib-amd/utils/columnResizeUtils.js +158 -0
  341. package/lib-amd/utils/columnResizeUtils.js.map +1 -0
  342. package/lib-commonjs/TableResizeHandle.js +8 -0
  343. package/lib-commonjs/TableResizeHandle.js.map +1 -0
  344. package/lib-commonjs/components/DataGrid/index.js +1 -0
  345. package/lib-commonjs/components/DataGrid/index.js.map +1 -1
  346. package/lib-commonjs/components/DataGrid/useDataGrid.js +15 -3
  347. package/lib-commonjs/components/DataGrid/useDataGrid.js.map +1 -1
  348. package/lib-commonjs/components/DataGrid/useDataGridContextValues.js +2 -1
  349. package/lib-commonjs/components/DataGrid/useDataGridContextValues.js.map +1 -1
  350. package/lib-commonjs/components/DataGridCell/useDataGridCell.js +5 -0
  351. package/lib-commonjs/components/DataGridCell/useDataGridCell.js.map +1 -1
  352. package/lib-commonjs/components/DataGridHeaderCell/useDataGridHeaderCell.js +3 -0
  353. package/lib-commonjs/components/DataGridHeaderCell/useDataGridHeaderCell.js.map +1 -1
  354. package/lib-commonjs/components/DataGridHeaderCell/useDataGridHeaderCellStyles.js +5 -1
  355. package/lib-commonjs/components/DataGridHeaderCell/useDataGridHeaderCellStyles.js.map +1 -1
  356. package/lib-commonjs/components/TableCellLayout/useTableCellLayout.js +1 -0
  357. package/lib-commonjs/components/TableCellLayout/useTableCellLayout.js.map +1 -1
  358. package/lib-commonjs/components/TableCellLayout/useTableCellLayoutStyles.js +18 -4
  359. package/lib-commonjs/components/TableCellLayout/useTableCellLayoutStyles.js.map +1 -1
  360. package/lib-commonjs/components/TableHeaderCell/renderTableHeaderCell.js +3 -1
  361. package/lib-commonjs/components/TableHeaderCell/renderTableHeaderCell.js.map +1 -1
  362. package/lib-commonjs/components/TableHeaderCell/useTableHeaderCell.js +3 -1
  363. package/lib-commonjs/components/TableHeaderCell/useTableHeaderCell.js.map +1 -1
  364. package/lib-commonjs/components/TableHeaderCell/useTableHeaderCellStyles.js +10 -4
  365. package/lib-commonjs/components/TableHeaderCell/useTableHeaderCellStyles.js.map +1 -1
  366. package/lib-commonjs/components/TableResizeHandle/TableResizeHandle.js +20 -0
  367. package/lib-commonjs/components/TableResizeHandle/TableResizeHandle.js.map +1 -0
  368. package/lib-commonjs/components/TableResizeHandle/TableResizeHandle.types.js +6 -0
  369. package/lib-commonjs/components/TableResizeHandle/TableResizeHandle.types.js.map +1 -0
  370. package/lib-commonjs/components/TableResizeHandle/index.js +12 -0
  371. package/lib-commonjs/components/TableResizeHandle/index.js.map +1 -0
  372. package/lib-commonjs/components/TableResizeHandle/renderTableResizeHandle.js +22 -0
  373. package/lib-commonjs/components/TableResizeHandle/renderTableResizeHandle.js.map +1 -0
  374. package/lib-commonjs/components/TableResizeHandle/useTableResizeHandle.js +35 -0
  375. package/lib-commonjs/components/TableResizeHandle/useTableResizeHandle.js.map +1 -0
  376. package/lib-commonjs/components/TableResizeHandle/useTableResizeHandleStyles.js +56 -0
  377. package/lib-commonjs/components/TableResizeHandle/useTableResizeHandleStyles.js.map +1 -0
  378. package/lib-commonjs/components/TableSelectionCell/useTableSelectionCellStyles.js +2 -1
  379. package/lib-commonjs/components/TableSelectionCell/useTableSelectionCellStyles.js.map +1 -1
  380. package/lib-commonjs/hooks/index.js +1 -0
  381. package/lib-commonjs/hooks/index.js.map +1 -1
  382. package/lib-commonjs/hooks/useMeasureElement.js +55 -0
  383. package/lib-commonjs/hooks/useMeasureElement.js.map +1 -0
  384. package/lib-commonjs/hooks/useTableColumnResizeMouseHandler.js +57 -0
  385. package/lib-commonjs/hooks/useTableColumnResizeMouseHandler.js.map +1 -0
  386. package/lib-commonjs/hooks/useTableColumnResizeState.js +119 -0
  387. package/lib-commonjs/hooks/useTableColumnResizeState.js.map +1 -0
  388. package/lib-commonjs/hooks/useTableColumnSizing.js +84 -0
  389. package/lib-commonjs/hooks/useTableColumnSizing.js.map +1 -0
  390. package/lib-commonjs/hooks/useTableFeatures.js +10 -2
  391. package/lib-commonjs/hooks/useTableFeatures.js.map +1 -1
  392. package/lib-commonjs/index.js +46 -2
  393. package/lib-commonjs/index.js.map +1 -1
  394. package/lib-commonjs/utils/columnResizeUtils.js +172 -0
  395. package/lib-commonjs/utils/columnResizeUtils.js.map +1 -0
  396. package/package.json +10 -11
@@ -0,0 +1,158 @@
1
+ const DEFAULT_WIDTH = 150;
2
+ const DEFAULT_MIN_WIDTH = 100;
3
+ /**
4
+ * This function takes the column definitions and the curent ColumnWidthState and returns new state.
5
+ * - It uses existing state for existing columns.
6
+ * - It removes any state for columns no longer present.
7
+ * - It checks if any column has been replaced and returns updated state if so
8
+ * - It returns old state if no changes in the state have been made (so that react doesn't call effects)
9
+ * @param columns
10
+ * @param state
11
+ * @returns
12
+ */
13
+ export function columnDefinitionsToState(columns, state = [], columnSizingOptions = {}) {
14
+ let updated = false;
15
+ const stateMap = new Map(state.map(s => [s.columnId, s]));
16
+ const updatedState = columns.map(column => {
17
+ var _a, _b;
18
+ const existingColumnState = stateMap.get(column.columnId);
19
+ if (existingColumnState) {
20
+ const {
21
+ idealWidth = existingColumnState.idealWidth,
22
+ minWidth = existingColumnState.minWidth,
23
+ padding = existingColumnState.padding
24
+ } = (_a = columnSizingOptions[column.columnId]) !== null && _a !== void 0 ? _a : {};
25
+ if (idealWidth !== existingColumnState.idealWidth || minWidth !== existingColumnState.minWidth || padding !== existingColumnState.padding) {
26
+ updated = true;
27
+ return {
28
+ ...existingColumnState,
29
+ idealWidth,
30
+ width: idealWidth,
31
+ minWidth,
32
+ padding
33
+ };
34
+ }
35
+ return existingColumnState;
36
+ }
37
+ const {
38
+ defaultWidth,
39
+ idealWidth = DEFAULT_WIDTH,
40
+ minWidth = DEFAULT_MIN_WIDTH,
41
+ padding
42
+ } = (_b = columnSizingOptions[column.columnId]) !== null && _b !== void 0 ? _b : {};
43
+ updated = true;
44
+ return {
45
+ columnId: column.columnId,
46
+ width: Math.max(defaultWidth !== null && defaultWidth !== void 0 ? defaultWidth : idealWidth, minWidth),
47
+ minWidth,
48
+ idealWidth: Math.max(defaultWidth !== null && defaultWidth !== void 0 ? defaultWidth : idealWidth, minWidth),
49
+ padding: padding !== null && padding !== void 0 ? padding : 16
50
+ };
51
+ });
52
+ // If the length of the new state changed (column was added or removed) or any of
53
+ // the individual states has a new reference (column was replaced),
54
+ // we have to reset the column widths to their ideal width (because the column which was last may not be last now).
55
+ // Then the adjustColumnWidthsToFitContainer can do its job and properly stretch the last column.
56
+ if (updatedState.length !== state.length || updated) {
57
+ const column = updatedState.find(col => col.width > col.idealWidth);
58
+ if (column) {
59
+ column.width = column.idealWidth;
60
+ }
61
+ updated = true;
62
+ }
63
+ return updated ? updatedState : state;
64
+ }
65
+ export function getColumnById(state, columnId) {
66
+ return state.find(c => c.columnId === columnId);
67
+ }
68
+ export function getColumnByIndex(state, index) {
69
+ return state[index];
70
+ }
71
+ export function getTotalWidth(state) {
72
+ return state.reduce((sum, column) => sum + column.width + column.padding, 0);
73
+ }
74
+ export function getLength(state) {
75
+ return state.length;
76
+ }
77
+ export function getColumnWidth(state, columnId) {
78
+ var _a;
79
+ const column = getColumnById(state, columnId);
80
+ return (_a = column === null || column === void 0 ? void 0 : column.width) !== null && _a !== void 0 ? _a : 0;
81
+ }
82
+ /**
83
+ * This function takes the current state and returns an updated state, so that it can be set.
84
+ * The reason for this is that we can update the state multiple times before commiting to render.
85
+ * This is an optimization and also prevents flickering.
86
+ * It also returns new copy of the state only if the value is different than the one currently in
87
+ * the state, further preventing unnecessary updates.
88
+ * @param localState
89
+ * @param columnId
90
+ * @param property
91
+ * @param value
92
+ * @returns
93
+ */
94
+ export function setColumnProperty(localState, columnId, property, value) {
95
+ const currentColumn = getColumnById(localState, columnId);
96
+ if (!currentColumn || (currentColumn === null || currentColumn === void 0 ? void 0 : currentColumn[property]) === value) {
97
+ return localState;
98
+ }
99
+ const updatedColumn = {
100
+ ...currentColumn,
101
+ [property]: value
102
+ };
103
+ const newState = localState.reduce((acc, current) => {
104
+ if (current.columnId === updatedColumn.columnId) {
105
+ return [...acc, updatedColumn];
106
+ }
107
+ return [...acc, current];
108
+ }, []);
109
+ return newState;
110
+ }
111
+ /**
112
+ * This function takes the state and container width and makes sure the each column in the state
113
+ * is its optimal width, and that the columns
114
+ * a) fit to the container
115
+ * b) always fill the whole container
116
+ * @param state
117
+ * @param containerWidth
118
+ * @returns
119
+ */
120
+ export function adjustColumnWidthsToFitContainer(state, containerWidth) {
121
+ let newState = state;
122
+ const totalWidth = getTotalWidth(newState);
123
+ // The total width is smaller, we are expanding columns
124
+ if (totalWidth < containerWidth) {
125
+ let difference = containerWidth - totalWidth;
126
+ let i = 0;
127
+ // We start at the beginning and assign the columns their ideal width
128
+ while (i < newState.length && difference > 0) {
129
+ const currentCol = getColumnByIndex(newState, i);
130
+ const colAdjustment = Math.min(currentCol.idealWidth - currentCol.width, difference);
131
+ newState = setColumnProperty(newState, currentCol.columnId, 'width', currentCol.width + colAdjustment);
132
+ difference -= colAdjustment;
133
+ // if there is still empty space, after all columns are their ideal sizes, assign it to the last column
134
+ if (i === newState.length - 1 && difference !== 0) {
135
+ const lastCol = getColumnByIndex(newState, i);
136
+ newState = setColumnProperty(newState, lastCol.columnId, 'width', lastCol.width + difference);
137
+ }
138
+ i++;
139
+ }
140
+ }
141
+ // The total width is larger than container, we need to squash the columns
142
+ else if (totalWidth >= containerWidth) {
143
+ let difference = totalWidth - containerWidth;
144
+ // We start with the last column
145
+ let j = newState.length - 1;
146
+ while (j >= 0 && difference > 0) {
147
+ const currentCol = getColumnByIndex(newState, j);
148
+ if (currentCol.width > currentCol.minWidth) {
149
+ const colAdjustment = Math.min(currentCol.width - currentCol.minWidth, difference);
150
+ difference -= colAdjustment;
151
+ newState = setColumnProperty(newState, currentCol.columnId, 'width', currentCol.width - colAdjustment);
152
+ }
153
+ j--;
154
+ }
155
+ }
156
+ return newState;
157
+ }
158
+ //# sourceMappingURL=columnResizeUtils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"mappings":"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","names":["DEFAULT_WIDTH","DEFAULT_MIN_WIDTH","columnDefinitionsToState","columns","state","columnSizingOptions","updated","stateMap","Map","map","s","columnId","updatedState","column","existingColumnState","get","idealWidth","minWidth","padding","width","defaultWidth","Math","max","length","find","col","getColumnById","c","getColumnByIndex","index","getTotalWidth","reduce","sum","getLength","getColumnWidth","setColumnProperty","localState","property","value","currentColumn","updatedColumn","newState","acc","current","adjustColumnWidthsToFitContainer","containerWidth","totalWidth","difference","i","currentCol","colAdjustment","min","lastCol","j"],"sourceRoot":"../src/","sources":["packages/react-components/react-table/src/utils/columnResizeUtils.ts"],"sourcesContent":["import { TableColumnDefinition, ColumnWidthState, TableColumnId, TableColumnSizingOptions } from '../hooks';\n\nconst DEFAULT_WIDTH = 150;\nconst DEFAULT_MIN_WIDTH = 100;\n\n/**\n * This function takes the column definitions and the curent ColumnWidthState and returns new state.\n * - It uses existing state for existing columns.\n * - It removes any state for columns no longer present.\n * - It checks if any column has been replaced and returns updated state if so\n * - It returns old state if no changes in the state have been made (so that react doesn't call effects)\n * @param columns\n * @param state\n * @returns\n */\n\nexport function columnDefinitionsToState<T>(\n columns: TableColumnDefinition<T>[],\n state: ColumnWidthState[] = [],\n columnSizingOptions: TableColumnSizingOptions = {},\n): ColumnWidthState[] {\n let updated = false;\n const stateMap = new Map(state.map(s => [s.columnId, s]));\n\n const updatedState = columns.map(column => {\n const existingColumnState = stateMap.get(column.columnId);\n\n if (existingColumnState) {\n const {\n idealWidth = existingColumnState.idealWidth,\n minWidth = existingColumnState.minWidth,\n padding = existingColumnState.padding,\n } = columnSizingOptions[column.columnId] ?? {};\n\n if (\n idealWidth !== existingColumnState.idealWidth ||\n minWidth !== existingColumnState.minWidth ||\n padding !== existingColumnState.padding\n ) {\n updated = true;\n return {\n ...existingColumnState,\n idealWidth,\n width: idealWidth,\n minWidth,\n padding,\n };\n }\n return existingColumnState;\n }\n\n const { defaultWidth, idealWidth = DEFAULT_WIDTH, minWidth = DEFAULT_MIN_WIDTH, padding } =\n columnSizingOptions[column.columnId] ?? {};\n\n updated = true;\n return {\n columnId: column.columnId,\n width: Math.max(defaultWidth ?? idealWidth, minWidth),\n minWidth,\n idealWidth: Math.max(defaultWidth ?? idealWidth, minWidth),\n padding: padding ?? 16,\n };\n });\n\n // If the length of the new state changed (column was added or removed) or any of\n // the individual states has a new reference (column was replaced),\n // we have to reset the column widths to their ideal width (because the column which was last may not be last now).\n // Then the adjustColumnWidthsToFitContainer can do its job and properly stretch the last column.\n if (updatedState.length !== state.length || updated) {\n const column = updatedState.find(col => col.width > col.idealWidth);\n if (column) {\n column.width = column.idealWidth;\n }\n\n updated = true;\n }\n\n return updated ? updatedState : state;\n}\n\nexport function getColumnById(state: ColumnWidthState[], columnId: TableColumnId) {\n return state.find(c => c.columnId === columnId);\n}\n\nexport function getColumnByIndex(state: ColumnWidthState[], index: number) {\n return state[index];\n}\n\nexport function getTotalWidth(state: ColumnWidthState[]): number {\n return state.reduce((sum, column) => sum + column.width + column.padding, 0);\n}\n\nexport function getLength(state: ColumnWidthState[]) {\n return state.length;\n}\n\nexport function getColumnWidth(state: ColumnWidthState[], columnId: TableColumnId): number {\n const column = getColumnById(state, columnId);\n return column?.width ?? 0;\n}\n\n/**\n * This function takes the current state and returns an updated state, so that it can be set.\n * The reason for this is that we can update the state multiple times before commiting to render.\n * This is an optimization and also prevents flickering.\n * It also returns new copy of the state only if the value is different than the one currently in\n * the state, further preventing unnecessary updates.\n * @param localState\n * @param columnId\n * @param property\n * @param value\n * @returns\n */\nexport function setColumnProperty(\n localState: ColumnWidthState[],\n columnId: TableColumnId,\n property: keyof ColumnWidthState,\n value: number,\n) {\n const currentColumn = getColumnById(localState, columnId);\n\n if (!currentColumn || currentColumn?.[property] === value) {\n return localState;\n }\n\n const updatedColumn = { ...currentColumn, [property]: value };\n\n const newState = localState.reduce((acc, current) => {\n if (current.columnId === updatedColumn.columnId) {\n return [...acc, updatedColumn];\n }\n return [...acc, current];\n }, [] as ColumnWidthState[]);\n\n return newState;\n}\n\n/**\n * This function takes the state and container width and makes sure the each column in the state\n * is its optimal width, and that the columns\n * a) fit to the container\n * b) always fill the whole container\n * @param state\n * @param containerWidth\n * @returns\n */\nexport function adjustColumnWidthsToFitContainer(state: ColumnWidthState[], containerWidth: number) {\n let newState = state;\n const totalWidth = getTotalWidth(newState);\n\n // The total width is smaller, we are expanding columns\n if (totalWidth < containerWidth) {\n let difference = containerWidth - totalWidth;\n let i = 0;\n // We start at the beginning and assign the columns their ideal width\n while (i < newState.length && difference > 0) {\n const currentCol = getColumnByIndex(newState, i);\n const colAdjustment = Math.min(currentCol.idealWidth - currentCol.width, difference);\n newState = setColumnProperty(newState, currentCol.columnId, 'width', currentCol.width + colAdjustment);\n difference -= colAdjustment;\n\n // if there is still empty space, after all columns are their ideal sizes, assign it to the last column\n if (i === newState.length - 1 && difference !== 0) {\n const lastCol = getColumnByIndex(newState, i);\n newState = setColumnProperty(newState, lastCol.columnId, 'width', lastCol.width + difference);\n }\n\n i++;\n }\n }\n\n // The total width is larger than container, we need to squash the columns\n else if (totalWidth >= containerWidth) {\n let difference = totalWidth - containerWidth;\n // We start with the last column\n let j = newState.length - 1;\n while (j >= 0 && difference > 0) {\n const currentCol = getColumnByIndex(newState, j);\n if (currentCol.width > currentCol.minWidth) {\n const colAdjustment = Math.min(currentCol.width - currentCol.minWidth, difference);\n difference -= colAdjustment;\n newState = setColumnProperty(newState, currentCol.columnId, 'width', currentCol.width - colAdjustment);\n }\n j--;\n }\n }\n\n return newState;\n}\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/DataGrid/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=DataGrid.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DataGrid.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/DataGrid.ts"],"names":[],"mappings":";;;IAAA,uCAA4C","sourcesContent":["export * from './components/DataGrid/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/DataGridBody/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=DataGridBody.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DataGridBody.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/DataGridBody.ts"],"names":[],"mappings":";;;IAAA,uCAAgD","sourcesContent":["export * from './components/DataGridBody/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/DataGridCell/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=DataGridCell.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DataGridCell.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/DataGridCell.ts"],"names":[],"mappings":";;;IAAA,uCAAgD","sourcesContent":["export * from './components/DataGridCell/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/DataGridHeader/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=DataGridHeader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DataGridHeader.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/DataGridHeader.ts"],"names":[],"mappings":";;;IAAA,uCAAkD","sourcesContent":["export * from './components/DataGridHeader/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/DataGridHeaderCell/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=DataGridHeaderCell.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DataGridHeaderCell.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/DataGridHeaderCell.ts"],"names":[],"mappings":";;;IAAA,uCAAsD","sourcesContent":["export * from './components/DataGridHeaderCell/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/DataGridRow/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=DataGridRow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DataGridRow.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/DataGridRow.ts"],"names":[],"mappings":";;;IAAA,uCAA+C","sourcesContent":["export * from './components/DataGridRow/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/DataGridSelectionCell/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=DataGridSelectionCell.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DataGridSelectionCell.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/DataGridSelectionCell.ts"],"names":[],"mappings":";;;IAAA,uCAAyD","sourcesContent":["export * from './components/DataGridSelectionCell/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/Table/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=Table.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Table.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/Table.ts"],"names":[],"mappings":";;;IAAA,uCAAyC","sourcesContent":["export * from './components/Table/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/TableBody/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=TableBody.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableBody.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/TableBody.ts"],"names":[],"mappings":";;;IAAA,uCAA6C","sourcesContent":["export * from './components/TableBody/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/TableCell/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=TableCell.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableCell.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/TableCell.ts"],"names":[],"mappings":";;;IAAA,uCAA6C","sourcesContent":["export * from './components/TableCell/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/TableCellActions/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=TableCellActions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableCellActions.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/TableCellActions.ts"],"names":[],"mappings":";;;IAAA,uCAAoD","sourcesContent":["export * from './components/TableCellActions/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/TableCellLayout/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=TableCellLayout.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableCellLayout.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/TableCellLayout.ts"],"names":[],"mappings":";;;IAAA,uCAAmD","sourcesContent":["export * from './components/TableCellLayout/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/TableHeader/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=TableHeader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableHeader.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/TableHeader.ts"],"names":[],"mappings":";;;IAAA,uCAA+C","sourcesContent":["export * from './components/TableHeader/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/TableHeaderCell/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=TableHeaderCell.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableHeaderCell.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/TableHeaderCell.ts"],"names":[],"mappings":";;;IAAA,uCAAmD","sourcesContent":["export * from './components/TableHeaderCell/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/TableResizeHandle/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=TableResizeHandle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableResizeHandle.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/TableResizeHandle.ts"],"names":[],"mappings":";;;IAAA,uCAAqD","sourcesContent":["export * from './components/TableResizeHandle/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/TableRow/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=TableRow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableRow.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/TableRow.ts"],"names":[],"mappings":";;;IAAA,uCAA4C","sourcesContent":["export * from './components/TableRow/index';\n"]}
@@ -0,0 +1,6 @@
1
+ define(["require", "exports", "tslib", "./components/TableSelectionCell/index"], function (require, exports, tslib_1, index_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(index_1, exports);
5
+ });
6
+ //# sourceMappingURL=TableSelectionCell.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableSelectionCell.js","sourceRoot":"","sources":["../../../../../../../packages/react-components/react-table/src/TableSelectionCell.ts"],"names":[],"mappings":";;;IAAA,uCAAsD","sourcesContent":["export * from './components/TableSelectionCell/index';\n"]}
@@ -0,0 +1,15 @@
1
+ define(["require", "exports", "react", "./useDataGrid", "./renderDataGrid", "./useDataGridStyles", "./useDataGridContextValues"], function (require, exports, React, useDataGrid_1, renderDataGrid_1, useDataGridStyles_1, useDataGridContextValues_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.DataGrid = void 0;
5
+ /**
6
+ * DataGrid component
7
+ */
8
+ exports.DataGrid = React.forwardRef(function (props, ref) {
9
+ var state = useDataGrid_1.useDataGrid_unstable(props, ref);
10
+ useDataGridStyles_1.useDataGridStyles_unstable(state);
11
+ return renderDataGrid_1.renderDataGrid_unstable(state, useDataGridContextValues_1.useDataGridContextValues_unstable(state));
12
+ });
13
+ exports.DataGrid.displayName = 'DataGrid';
14
+ });
15
+ //# sourceMappingURL=DataGrid.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DataGrid.js","sourceRoot":"","sources":["../../../../../../../../../packages/react-components/react-table/src/components/DataGrid/DataGrid.tsx"],"names":[],"mappings":";;;;IAQA;;OAEG;IACU,QAAA,QAAQ,GAAuC,KAAK,CAAC,UAAU,CAAC,UAAC,KAAK,EAAE,GAAG;QACtF,IAAM,KAAK,GAAG,kCAAoB,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;QAE/C,8CAA0B,CAAC,KAAK,CAAC,CAAC;QAClC,OAAO,wCAAuB,CAAC,KAAK,EAAE,4DAAiC,CAAC,KAAK,CAAC,CAAC,CAAC;IAClF,CAAC,CAAC,CAAC;IAEH,gBAAQ,CAAC,WAAW,GAAG,UAAU,CAAC","sourcesContent":["import * as React from 'react';\nimport { useDataGrid_unstable } from './useDataGrid';\nimport { renderDataGrid_unstable } from './renderDataGrid';\nimport { useDataGridStyles_unstable } from './useDataGridStyles';\nimport type { DataGridProps } from './DataGrid.types';\nimport type { ForwardRefComponent } from '@fluentui/react-utilities';\nimport { useDataGridContextValues_unstable } from './useDataGridContextValues';\n\n/**\n * DataGrid component\n */\nexport const DataGrid: ForwardRefComponent<DataGridProps> = React.forwardRef((props, ref) => {\n const state = useDataGrid_unstable(props, ref);\n\n useDataGridStyles_unstable(state);\n return renderDataGrid_unstable(state, useDataGridContextValues_unstable(state));\n});\n\nDataGrid.displayName = 'DataGrid';\n"]}
@@ -0,0 +1,5 @@
1
+ define(["require", "exports"], function (require, exports) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ });
5
+ //# sourceMappingURL=DataGrid.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DataGrid.types.js","sourceRoot":"","sources":["../../../../../../../../../packages/react-components/react-table/src/components/DataGrid/DataGrid.types.ts"],"names":[],"mappings":"","sourcesContent":["import * as React from 'react';\nimport type { TableContextValues, TableProps, TableSlots, TableState } from '../Table/Table.types';\nimport type {\n SortState,\n TableFeaturesState,\n UseTableSortOptions,\n SelectionMode,\n UseTableSelectionOptions,\n OnSelectionChangeData,\n TableColumnSizingOptions,\n TableColumnId,\n} from '../../hooks';\nimport { TableRowProps } from '../TableRow/TableRow.types';\n\nexport type DataGridSlots = TableSlots;\n\nexport type DataGridFocusMode = 'none' | 'cell' | 'row_unstable';\n\nexport type DataGridContextValues = TableContextValues & {\n dataGrid: DataGridContextValue;\n};\n\n// Use any here since we can't know the user types\n// The user is responsible for narrowing the type downstream\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport type DataGridContextValue = TableFeaturesState<any> & {\n /**\n * How focus navigation will work in the datagrid\n * @default cell\n */\n focusMode: DataGridFocusMode;\n\n /**\n * Lets child components know if rows selection is enabled\n * @see selectionMode prop enables row selection on the component\n */\n selectableRows: boolean;\n\n /**\n * Enables subtle selection style\n * @default false\n */\n subtleSelection: boolean;\n\n /**\n * Row appearance when selected\n * @default brand\n */\n selectionAppearance: TableRowProps['appearance'];\n\n /**\n * Enables column resizing\n */\n resizableColumns?: boolean;\n};\n\n/**\n * DataGrid Props\n */\nexport type DataGridProps = TableProps &\n Pick<DataGridContextValue, 'items' | 'columns' | 'getRowId'> &\n Pick<Partial<DataGridContextValue>, 'focusMode' | 'subtleSelection' | 'selectionAppearance' | 'resizableColumns'> &\n Pick<UseTableSortOptions, 'sortState' | 'defaultSortState'> &\n Pick<UseTableSelectionOptions, 'defaultSelectedItems' | 'selectedItems'> & {\n onSortChange?: (e: React.MouseEvent, sortState: SortState) => void;\n onSelectionChange?: (e: React.MouseEvent | React.KeyboardEvent, data: OnSelectionChangeData) => void;\n /**\n * Enables row selection and sets the selection mode\n * @default false\n */\n selectionMode?: SelectionMode;\n /**\n * Options for column resizing\n */\n columnSizingOptions?: TableColumnSizingOptions;\n /**\n * A callback triggered when a column is resized.\n */\n onColumnResize?: (event: MouseEvent | undefined, data: { columnId: TableColumnId; width: number }) => void;\n };\n\n/**\n * State used in rendering DataGrid\n */\nexport type DataGridState = TableState & { tableState: TableFeaturesState<unknown> } & Pick<\n DataGridContextValue,\n 'focusMode' | 'selectableRows' | 'subtleSelection' | 'selectionAppearance' | 'getRowId' | 'resizableColumns'\n >;\n"]}
@@ -0,0 +1,11 @@
1
+ define(["require", "exports", "tslib", "./DataGrid", "./DataGrid.types", "./renderDataGrid", "./useDataGrid", "./useDataGridStyles", "./useDataGridContextValues"], function (require, exports, tslib_1, DataGrid_1, DataGrid_types_1, renderDataGrid_1, useDataGrid_1, useDataGridStyles_1, useDataGridContextValues_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ tslib_1.__exportStar(DataGrid_1, exports);
5
+ tslib_1.__exportStar(DataGrid_types_1, exports);
6
+ tslib_1.__exportStar(renderDataGrid_1, exports);
7
+ tslib_1.__exportStar(useDataGrid_1, exports);
8
+ tslib_1.__exportStar(useDataGridStyles_1, exports);
9
+ tslib_1.__exportStar(useDataGridContextValues_1, exports);
10
+ });
11
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/react-components/react-table/src/components/DataGrid/index.ts"],"names":[],"mappings":";;;IAAA,0CAA2B;IAC3B,gDAAiC;IACjC,gDAAiC;IACjC,6CAA8B;IAC9B,mDAAoC;IACpC,0DAA2C","sourcesContent":["export * from './DataGrid';\nexport * from './DataGrid.types';\nexport * from './renderDataGrid';\nexport * from './useDataGrid';\nexport * from './useDataGridStyles';\nexport * from './useDataGridContextValues';\n"]}
@@ -0,0 +1,13 @@
1
+ define(["require", "exports", "react", "../Table/renderTable", "../../contexts/dataGridContext"], function (require, exports, React, renderTable_1, dataGridContext_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.renderDataGrid_unstable = void 0;
5
+ /**
6
+ * Render the final JSX of DataGrid
7
+ */
8
+ var renderDataGrid_unstable = function (state, contextValues) {
9
+ return (React.createElement(dataGridContext_1.DataGridContextProvider, { value: contextValues.dataGrid }, renderTable_1.renderTable_unstable(state, contextValues)));
10
+ };
11
+ exports.renderDataGrid_unstable = renderDataGrid_unstable;
12
+ });
13
+ //# sourceMappingURL=renderDataGrid.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"renderDataGrid.js","sourceRoot":"","sources":["../../../../../../../../../packages/react-components/react-table/src/components/DataGrid/renderDataGrid.tsx"],"names":[],"mappings":";;;;IAKA;;OAEG;IACI,IAAM,uBAAuB,GAAG,UAAC,KAAoB,EAAE,aAAoC;QAChG,OAAO,CACL,oBAAC,yCAAuB,IAAC,KAAK,EAAE,aAAa,CAAC,QAAQ,IACnD,kCAAoB,CAAC,KAAK,EAAE,aAAa,CAAC,CACnB,CAC3B,CAAC;IACJ,CAAC,CAAC;IANW,QAAA,uBAAuB,2BAMlC","sourcesContent":["import * as React from 'react';\nimport type { DataGridContextValues, DataGridState } from './DataGrid.types';\nimport { renderTable_unstable } from '../Table/renderTable';\nimport { DataGridContextProvider } from '../../contexts/dataGridContext';\n\n/**\n * Render the final JSX of DataGrid\n */\nexport const renderDataGrid_unstable = (state: DataGridState, contextValues: DataGridContextValues) => {\n return (\n <DataGridContextProvider value={contextValues.dataGrid}>\n {renderTable_unstable(state, contextValues)}\n </DataGridContextProvider>\n );\n};\n"]}
@@ -0,0 +1,43 @@
1
+ define(["require", "exports", "tslib", "@fluentui/react-tabster", "../Table/useTable", "../../hooks", "../TableSelectionCell", "@fluentui/react-utilities"], function (require, exports, tslib_1, react_tabster_1, useTable_1, hooks_1, TableSelectionCell_1, react_utilities_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.useDataGrid_unstable = void 0;
5
+ /**
6
+ * Create the state required to render DataGrid.
7
+ *
8
+ * The returned state can be modified with hooks such as useDataGridStyles_unstable,
9
+ * before being passed to renderDataGrid_unstable.
10
+ *
11
+ * @param props - props from this instance of DataGrid
12
+ * @param ref - reference to root HTMLElement of DataGrid
13
+ */
14
+ var useDataGrid_unstable = function (props, ref) {
15
+ var items = props.items, columns = props.columns, _a = props.focusMode, focusMode = _a === void 0 ? 'cell' : _a, selectionMode = props.selectionMode, onSortChange = props.onSortChange, onSelectionChange = props.onSelectionChange, defaultSortState = props.defaultSortState, sortState = props.sortState, selectedItems = props.selectedItems, defaultSelectedItems = props.defaultSelectedItems, _b = props.subtleSelection, subtleSelection = _b === void 0 ? false : _b, _c = props.selectionAppearance, selectionAppearance = _c === void 0 ? 'brand' : _c, getRowId = props.getRowId, resizableColumns = props.resizableColumns, columnSizingOptions = props.columnSizingOptions, onColumnResize = props.onColumnResize;
16
+ var navigable = focusMode !== 'none';
17
+ var keyboardNavAttr = react_tabster_1.useArrowNavigationGroup({ axis: 'grid' });
18
+ var tableState = hooks_1.useTableFeatures({ items: items, columns: columns, getRowId: getRowId }, [
19
+ hooks_1.useTableSort({
20
+ defaultSortState: defaultSortState,
21
+ sortState: sortState,
22
+ onSortChange: onSortChange,
23
+ }),
24
+ hooks_1.useTableSelection({
25
+ defaultSelectedItems: defaultSelectedItems,
26
+ selectedItems: selectedItems,
27
+ onSelectionChange: onSelectionChange,
28
+ selectionMode: selectionMode !== null && selectionMode !== void 0 ? selectionMode : 'multiselect',
29
+ }),
30
+ hooks_1.useTableColumnSizing_unstable({
31
+ onColumnResize: onColumnResize,
32
+ columnSizingOptions: columnSizingOptions,
33
+ // The selection cell is not part of the columns, therefore its width needs to be subtracted
34
+ // from the container to make sure the columns don't overflow the table.
35
+ containerWidthOffset: selectionMode ? -TableSelectionCell_1.CELL_WIDTH : 0,
36
+ }),
37
+ ]);
38
+ var baseTableState = useTable_1.useTable_unstable(tslib_1.__assign(tslib_1.__assign({ role: 'grid', as: 'div', noNativeElements: true }, (navigable && keyboardNavAttr)), props), react_utilities_1.useMergedRefs(ref, tableState.tableRef));
39
+ return tslib_1.__assign(tslib_1.__assign({}, baseTableState), { focusMode: focusMode, tableState: tableState, selectableRows: !!selectionMode, subtleSelection: subtleSelection, selectionAppearance: selectionAppearance, resizableColumns: resizableColumns });
40
+ };
41
+ exports.useDataGrid_unstable = useDataGrid_unstable;
42
+ });
43
+ //# sourceMappingURL=useDataGrid.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDataGrid.js","sourceRoot":"","sources":["../../../../../../../../../packages/react-components/react-table/src/components/DataGrid/useDataGrid.ts"],"names":[],"mappings":";;;;IAQA;;;;;;;;OAQG;IACI,IAAM,oBAAoB,GAAG,UAAC,KAAoB,EAAE,GAA2B;QAElF,IAAA,KAAK,GAgBH,KAAK,MAhBF,EACL,OAAO,GAeL,KAAK,QAfA,EACP,KAcE,KAAK,UAdW,EAAlB,SAAS,mBAAG,MAAM,KAAA,EAClB,aAAa,GAaX,KAAK,cAbM,EACb,YAAY,GAYV,KAAK,aAZK,EACZ,iBAAiB,GAWf,KAAK,kBAXU,EACjB,gBAAgB,GAUd,KAAK,iBAVS,EAChB,SAAS,GASP,KAAK,UATE,EACT,aAAa,GAQX,KAAK,cARM,EACb,oBAAoB,GAOlB,KAAK,qBAPa,EACpB,KAME,KAAK,gBANgB,EAAvB,eAAe,mBAAG,KAAK,KAAA,EACvB,KAKE,KAAK,oBALsB,EAA7B,mBAAmB,mBAAG,OAAO,KAAA,EAC7B,QAAQ,GAIN,KAAK,SAJC,EACR,gBAAgB,GAGd,KAAK,iBAHS,EAChB,mBAAmB,GAEjB,KAAK,oBAFY,EACnB,cAAc,GACZ,KAAK,eADO,CACN;QAEV,IAAM,SAAS,GAAG,SAAS,KAAK,MAAM,CAAC;QACvC,IAAM,eAAe,GAAG,uCAAuB,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QAElE,IAAM,UAAU,GAAG,wBAAgB,CAAC,EAAE,KAAK,OAAA,EAAE,OAAO,SAAA,EAAE,QAAQ,UAAA,EAAE,EAAE;YAChE,oBAAY,CAAC;gBACX,gBAAgB,kBAAA;gBAChB,SAAS,WAAA;gBACT,YAAY,cAAA;aACb,CAAC;YACF,yBAAiB,CAAC;gBAChB,oBAAoB,sBAAA;gBACpB,aAAa,eAAA;gBACb,iBAAiB,mBAAA;gBACjB,aAAa,EAAE,aAAa,aAAb,aAAa,cAAb,aAAa,GAAI,aAAa;aAC9C,CAAC;YACF,qCAA6B,CAAC;gBAC5B,cAAc,gBAAA;gBACd,mBAAmB,qBAAA;gBACnB,4FAA4F;gBAC5F,wEAAwE;gBACxE,oBAAoB,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,+BAAU,CAAC,CAAC,CAAC,CAAC;aACtD,CAAC;SACH,CAAC,CAAC;QAEH,IAAM,cAAc,GAAG,4BAAiB,qCAEpC,IAAI,EAAE,MAAM,EACZ,EAAE,EAAE,KAAK,EACT,gBAAgB,EAAE,IAAI,IACnB,CAAC,SAAS,IAAI,eAAe,CAAC,GAC9B,KAAK,GAEV,+BAAa,CAAC,GAAG,EAAE,UAAU,CAAC,QAAQ,CAAC,CACxC,CAAC;QAEF,6CACK,cAAc,KACjB,SAAS,WAAA,EACT,UAAU,YAAA,EACV,cAAc,EAAE,CAAC,CAAC,aAAa,EAC/B,eAAe,iBAAA,EACf,mBAAmB,qBAAA,EACnB,gBAAgB,kBAAA,IAChB;IACJ,CAAC,CAAC;IAhEW,QAAA,oBAAoB,wBAgE/B","sourcesContent":["import * as React from 'react';\nimport { useArrowNavigationGroup } from '@fluentui/react-tabster';\nimport type { DataGridProps, DataGridState } from './DataGrid.types';\nimport { useTable_unstable } from '../Table/useTable';\nimport { useTableFeatures, useTableSort, useTableSelection, useTableColumnSizing_unstable } from '../../hooks';\nimport { CELL_WIDTH } from '../TableSelectionCell';\nimport { useMergedRefs } from '@fluentui/react-utilities';\n\n/**\n * Create the state required to render DataGrid.\n *\n * The returned state can be modified with hooks such as useDataGridStyles_unstable,\n * before being passed to renderDataGrid_unstable.\n *\n * @param props - props from this instance of DataGrid\n * @param ref - reference to root HTMLElement of DataGrid\n */\nexport const useDataGrid_unstable = (props: DataGridProps, ref: React.Ref<HTMLElement>): DataGridState => {\n const {\n items,\n columns,\n focusMode = 'cell',\n selectionMode,\n onSortChange,\n onSelectionChange,\n defaultSortState,\n sortState,\n selectedItems,\n defaultSelectedItems,\n subtleSelection = false,\n selectionAppearance = 'brand',\n getRowId,\n resizableColumns,\n columnSizingOptions,\n onColumnResize,\n } = props;\n\n const navigable = focusMode !== 'none';\n const keyboardNavAttr = useArrowNavigationGroup({ axis: 'grid' });\n\n const tableState = useTableFeatures({ items, columns, getRowId }, [\n useTableSort({\n defaultSortState,\n sortState,\n onSortChange,\n }),\n useTableSelection({\n defaultSelectedItems,\n selectedItems,\n onSelectionChange,\n selectionMode: selectionMode ?? 'multiselect',\n }),\n useTableColumnSizing_unstable({\n onColumnResize,\n columnSizingOptions,\n // The selection cell is not part of the columns, therefore its width needs to be subtracted\n // from the container to make sure the columns don't overflow the table.\n containerWidthOffset: selectionMode ? -CELL_WIDTH : 0,\n }),\n ]);\n\n const baseTableState = useTable_unstable(\n {\n role: 'grid',\n as: 'div',\n noNativeElements: true,\n ...(navigable && keyboardNavAttr),\n ...props,\n },\n useMergedRefs(ref, tableState.tableRef),\n );\n\n return {\n ...baseTableState,\n focusMode,\n tableState,\n selectableRows: !!selectionMode,\n subtleSelection,\n selectionAppearance,\n resizableColumns,\n };\n};\n"]}
@@ -0,0 +1,11 @@
1
+ define(["require", "exports", "tslib", "../Table/useTableContextValues"], function (require, exports, tslib_1, useTableContextValues_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.useDataGridContextValues_unstable = void 0;
5
+ function useDataGridContextValues_unstable(state) {
6
+ var tableContextValues = useTableContextValues_1.useTableContextValues_unstable(state);
7
+ return tslib_1.__assign(tslib_1.__assign({}, tableContextValues), { dataGrid: tslib_1.__assign(tslib_1.__assign({}, state.tableState), { focusMode: state.focusMode, selectableRows: state.selectableRows, subtleSelection: state.subtleSelection, selectionAppearance: state.selectionAppearance, resizableColumns: state.resizableColumns }) });
8
+ }
9
+ exports.useDataGridContextValues_unstable = useDataGridContextValues_unstable;
10
+ });
11
+ //# sourceMappingURL=useDataGridContextValues.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDataGridContextValues.js","sourceRoot":"","sources":["../../../../../../../../../packages/react-components/react-table/src/components/DataGrid/useDataGridContextValues.ts"],"names":[],"mappings":";;;;IAGA,SAAgB,iCAAiC,CAAC,KAAoB;QACpE,IAAM,kBAAkB,GAAG,sDAA8B,CAAC,KAAK,CAAC,CAAC;QACjE,6CACK,kBAAkB,KACrB,QAAQ,wCACH,KAAK,CAAC,UAAU,KACnB,SAAS,EAAE,KAAK,CAAC,SAAS,EAC1B,cAAc,EAAE,KAAK,CAAC,cAAc,EACpC,eAAe,EAAE,KAAK,CAAC,eAAe,EACtC,mBAAmB,EAAE,KAAK,CAAC,mBAAmB,EAC9C,gBAAgB,EAAE,KAAK,CAAC,gBAAgB,OAE1C;IACJ,CAAC;IAbD,8EAaC","sourcesContent":["import { useTableContextValues_unstable } from '../Table/useTableContextValues';\nimport { DataGridContextValues, DataGridState } from './DataGrid.types';\n\nexport function useDataGridContextValues_unstable(state: DataGridState): DataGridContextValues {\n const tableContextValues = useTableContextValues_unstable(state);\n return {\n ...tableContextValues,\n dataGrid: {\n ...state.tableState,\n focusMode: state.focusMode,\n selectableRows: state.selectableRows,\n subtleSelection: state.subtleSelection,\n selectionAppearance: state.selectionAppearance,\n resizableColumns: state.resizableColumns,\n },\n };\n}\n"]}
@@ -0,0 +1,18 @@
1
+ define(["require", "exports", "@griffel/react", "../Table/useTableStyles"], function (require, exports, react_1, useTableStyles_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.useDataGridStyles_unstable = exports.dataGridClassNames = void 0;
5
+ exports.dataGridClassNames = {
6
+ root: 'fui-DataGrid',
7
+ };
8
+ /**
9
+ * Apply styling to the DataGrid slots based on the state
10
+ */
11
+ var useDataGridStyles_unstable = function (state) {
12
+ useTableStyles_1.useTableStyles_unstable(state);
13
+ state.root.className = react_1.mergeClasses(exports.dataGridClassNames.root, state.root.className);
14
+ return state;
15
+ };
16
+ exports.useDataGridStyles_unstable = useDataGridStyles_unstable;
17
+ });
18
+ //# sourceMappingURL=useDataGridStyles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDataGridStyles.js","sourceRoot":"","sources":["../../../../../../../../../packages/react-components/react-table/src/components/DataGrid/useDataGridStyles.ts"],"names":[],"mappings":";;;;IAKa,QAAA,kBAAkB,GAAkC;QAC/D,IAAI,EAAE,cAAc;KACrB,CAAC;IAEF;;OAEG;IACI,IAAM,0BAA0B,GAAG,UAAC,KAAoB;QAC7D,wCAAuB,CAAC,KAAK,CAAC,CAAC;QAC/B,KAAK,CAAC,IAAI,CAAC,SAAS,GAAG,oBAAY,CAAC,0BAAkB,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAEnF,OAAO,KAAK,CAAC;IACf,CAAC,CAAC;IALW,QAAA,0BAA0B,8BAKrC","sourcesContent":["import { mergeClasses } from '@griffel/react';\nimport type { DataGridSlots, DataGridState } from './DataGrid.types';\nimport type { SlotClassNames } from '@fluentui/react-utilities';\nimport { useTableStyles_unstable } from '../Table/useTableStyles';\n\nexport const dataGridClassNames: SlotClassNames<DataGridSlots> = {\n root: 'fui-DataGrid',\n};\n\n/**\n * Apply styling to the DataGrid slots based on the state\n */\nexport const useDataGridStyles_unstable = (state: DataGridState): DataGridState => {\n useTableStyles_unstable(state);\n state.root.className = mergeClasses(dataGridClassNames.root, state.root.className);\n\n return state;\n};\n"]}
@@ -0,0 +1,15 @@
1
+ define(["require", "exports", "react", "./useDataGridBody", "./renderDataGridBody", "./useDataGridBodyStyles"], function (require, exports, React, useDataGridBody_1, renderDataGridBody_1, useDataGridBodyStyles_1) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.DataGridBody = void 0;
5
+ /**
6
+ * DataGridBody component
7
+ */
8
+ exports.DataGridBody = React.forwardRef(function (props, ref) {
9
+ var state = useDataGridBody_1.useDataGridBody_unstable(props, ref);
10
+ useDataGridBodyStyles_1.useDataGridBodyStyles_unstable(state);
11
+ return renderDataGridBody_1.renderDataGridBody_unstable(state);
12
+ });
13
+ exports.DataGridBody.displayName = 'DataGridBody';
14
+ });
15
+ //# sourceMappingURL=DataGridBody.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DataGridBody.js","sourceRoot":"","sources":["../../../../../../../../../packages/react-components/react-table/src/components/DataGridBody/DataGridBody.tsx"],"names":[],"mappings":";;;;IAOA;;OAEG;IACU,QAAA,YAAY,GACqC,KAAK,CAAC,UAAU,CAAC,UAAC,KAAK,EAAE,GAAG;QACxF,IAAM,KAAK,GAAG,0CAAwB,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;QAEnD,sDAA8B,CAAC,KAAK,CAAC,CAAC;QACtC,OAAO,gDAA2B,CAAC,KAAK,CAAC,CAAC;IAC5C,CAAC,CAAuG,CAAC;IAEzG,oBAAY,CAAC,WAAW,GAAG,cAAc,CAAC","sourcesContent":["import * as React from 'react';\nimport { useDataGridBody_unstable } from './useDataGridBody';\nimport { renderDataGridBody_unstable } from './renderDataGridBody';\nimport { useDataGridBodyStyles_unstable } from './useDataGridBodyStyles';\nimport type { DataGridBodyProps } from './DataGridBody.types';\nimport type { ForwardRefComponent } from '@fluentui/react-utilities';\n\n/**\n * DataGridBody component\n */\nexport const DataGridBody: ForwardRefComponent<DataGridBodyProps> &\n (<TItem>(props: DataGridBodyProps<TItem>) => JSX.Element) = React.forwardRef((props, ref) => {\n const state = useDataGridBody_unstable(props, ref);\n\n useDataGridBodyStyles_unstable(state);\n return renderDataGridBody_unstable(state);\n}) as ForwardRefComponent<DataGridBodyProps> & (<TItem>(props: DataGridBodyProps<TItem>) => JSX.Element);\n\nDataGridBody.displayName = 'DataGridBody';\n"]}
@@ -0,0 +1,5 @@
1
+ define(["require", "exports"], function (require, exports) {
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ });
5
+ //# sourceMappingURL=DataGridBody.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DataGridBody.types.js","sourceRoot":"","sources":["../../../../../../../../../packages/react-components/react-table/src/components/DataGridBody/DataGridBody.types.ts"],"names":[],"mappings":"","sourcesContent":["import * as React from 'react';\nimport type { TableRowData } from '../../hooks';\nimport type { TableBodySlots, TableBodyProps, TableBodyState } from '../TableBody/TableBody.types';\n\nexport type DataGridBodySlots = TableBodySlots;\n\nexport type RowRenderFunction<TItem = unknown> = (row: TableRowData<TItem>, ...rest: unknown[]) => React.ReactNode;\n\n/**\n * DataGridBody Props\n */\nexport type DataGridBodyProps<TItem = unknown> = Omit<TableBodyProps, 'children'> & {\n /**\n * Render function for rows\n */\n children: RowRenderFunction<TItem>;\n};\n\n/**\n * State used in rendering DataGridBody\n */\nexport type DataGridBodyState = TableBodyState & {\n rows: TableRowData<unknown>[];\n\n renderRow: RowRenderFunction;\n};\n"]}