@salt-ds/data-grid 1.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 (370) hide show
  1. package/dist-cjs/node_modules/style-inject/dist/style-inject.es.js +31 -0
  2. package/dist-cjs/node_modules/style-inject/dist/style-inject.es.js.map +1 -0
  3. package/dist-cjs/packages/grid/src/BaseCell.css.js +9 -0
  4. package/dist-cjs/packages/grid/src/BaseCell.css.js.map +1 -0
  5. package/dist-cjs/packages/grid/src/BaseCell.js +81 -0
  6. package/dist-cjs/packages/grid/src/BaseCell.js.map +1 -0
  7. package/dist-cjs/packages/grid/src/CellEditor.js +29 -0
  8. package/dist-cjs/packages/grid/src/CellEditor.js.map +1 -0
  9. package/dist-cjs/packages/grid/src/CheckboxCell.css.js +9 -0
  10. package/dist-cjs/packages/grid/src/CheckboxCell.css.js.map +1 -0
  11. package/dist-cjs/packages/grid/src/ColumnDataContext.js +18 -0
  12. package/dist-cjs/packages/grid/src/ColumnDataContext.js.map +1 -0
  13. package/dist-cjs/packages/grid/src/ColumnDragContext.js +20 -0
  14. package/dist-cjs/packages/grid/src/ColumnDragContext.js.map +1 -0
  15. package/dist-cjs/packages/grid/src/ColumnGroup.js +32 -0
  16. package/dist-cjs/packages/grid/src/ColumnGroup.js.map +1 -0
  17. package/dist-cjs/packages/grid/src/CornerTag.css.js +9 -0
  18. package/dist-cjs/packages/grid/src/CornerTag.css.js.map +1 -0
  19. package/dist-cjs/packages/grid/src/CornerTag.js +15 -0
  20. package/dist-cjs/packages/grid/src/CornerTag.js.map +1 -0
  21. package/dist-cjs/packages/grid/src/CursorContext.js +20 -0
  22. package/dist-cjs/packages/grid/src/CursorContext.js.map +1 -0
  23. package/dist-cjs/packages/grid/src/DropdownCellEditor.css.js +9 -0
  24. package/dist-cjs/packages/grid/src/DropdownCellEditor.css.js.map +1 -0
  25. package/dist-cjs/packages/grid/src/DropdownCellEditor.js +75 -0
  26. package/dist-cjs/packages/grid/src/DropdownCellEditor.js.map +1 -0
  27. package/dist-cjs/packages/grid/src/EditorContext.js +20 -0
  28. package/dist-cjs/packages/grid/src/EditorContext.js.map +1 -0
  29. package/dist-cjs/packages/grid/src/Grid.css.js +9 -0
  30. package/dist-cjs/packages/grid/src/Grid.css.js.map +1 -0
  31. package/dist-cjs/packages/grid/src/Grid.js +938 -0
  32. package/dist-cjs/packages/grid/src/Grid.js.map +1 -0
  33. package/dist-cjs/packages/grid/src/GridColumn.js +43 -0
  34. package/dist-cjs/packages/grid/src/GridColumn.js.map +1 -0
  35. package/dist-cjs/packages/grid/src/GridContext.js +20 -0
  36. package/dist-cjs/packages/grid/src/GridContext.js.map +1 -0
  37. package/dist-cjs/packages/grid/src/GroupHeaderCell.css.js +9 -0
  38. package/dist-cjs/packages/grid/src/GroupHeaderCell.css.js.map +1 -0
  39. package/dist-cjs/packages/grid/src/GroupHeaderCell.js +50 -0
  40. package/dist-cjs/packages/grid/src/GroupHeaderCell.js.map +1 -0
  41. package/dist-cjs/packages/grid/src/GroupHeaderCellValue.js +16 -0
  42. package/dist-cjs/packages/grid/src/GroupHeaderCellValue.js.map +1 -0
  43. package/dist-cjs/packages/grid/src/HeaderCell.css.js +9 -0
  44. package/dist-cjs/packages/grid/src/HeaderCell.css.js.map +1 -0
  45. package/dist-cjs/packages/grid/src/HeaderCell.js +120 -0
  46. package/dist-cjs/packages/grid/src/HeaderCell.js.map +1 -0
  47. package/dist-cjs/packages/grid/src/HeaderCellValue.js +19 -0
  48. package/dist-cjs/packages/grid/src/HeaderCellValue.js.map +1 -0
  49. package/dist-cjs/packages/grid/src/LayoutContext.js +12 -0
  50. package/dist-cjs/packages/grid/src/LayoutContext.js.map +1 -0
  51. package/dist-cjs/packages/grid/src/NumberRange.js +63 -0
  52. package/dist-cjs/packages/grid/src/NumberRange.js.map +1 -0
  53. package/dist-cjs/packages/grid/src/NumericColumn.css.js +9 -0
  54. package/dist-cjs/packages/grid/src/NumericColumn.css.js.map +1 -0
  55. package/dist-cjs/packages/grid/src/NumericColumn.js +108 -0
  56. package/dist-cjs/packages/grid/src/NumericColumn.js.map +1 -0
  57. package/dist-cjs/packages/grid/src/RowSelectionCheckboxCellValue.js +37 -0
  58. package/dist-cjs/packages/grid/src/RowSelectionCheckboxCellValue.js.map +1 -0
  59. package/dist-cjs/packages/grid/src/RowSelectionCheckboxColumn.js +32 -0
  60. package/dist-cjs/packages/grid/src/RowSelectionCheckboxColumn.js.map +1 -0
  61. package/dist-cjs/packages/grid/src/RowSelectionCheckboxHeaderCellValue.js +48 -0
  62. package/dist-cjs/packages/grid/src/RowSelectionCheckboxHeaderCellValue.js.map +1 -0
  63. package/dist-cjs/packages/grid/src/RowSelectionRadioCellValue.js +25 -0
  64. package/dist-cjs/packages/grid/src/RowSelectionRadioCellValue.js.map +1 -0
  65. package/dist-cjs/packages/grid/src/RowSelectionRadioColumn.js +30 -0
  66. package/dist-cjs/packages/grid/src/RowSelectionRadioColumn.js.map +1 -0
  67. package/dist-cjs/packages/grid/src/RowSelectionRadioHeaderCell.js +26 -0
  68. package/dist-cjs/packages/grid/src/RowSelectionRadioHeaderCell.js.map +1 -0
  69. package/dist-cjs/packages/grid/src/SelectionContext.js +20 -0
  70. package/dist-cjs/packages/grid/src/SelectionContext.js.map +1 -0
  71. package/dist-cjs/packages/grid/src/SizingContext.js +20 -0
  72. package/dist-cjs/packages/grid/src/SizingContext.js.map +1 -0
  73. package/dist-cjs/packages/grid/src/TextCellEditor.css.js +9 -0
  74. package/dist-cjs/packages/grid/src/TextCellEditor.css.js.map +1 -0
  75. package/dist-cjs/packages/grid/src/TextCellEditor.js +85 -0
  76. package/dist-cjs/packages/grid/src/TextCellEditor.js.map +1 -0
  77. package/dist-cjs/packages/grid/src/index.js +59 -0
  78. package/dist-cjs/packages/grid/src/index.js.map +1 -0
  79. package/dist-cjs/packages/grid/src/internal/Cell.css.js +9 -0
  80. package/dist-cjs/packages/grid/src/internal/Cell.css.js.map +1 -0
  81. package/dist-cjs/packages/grid/src/internal/Cell.js +59 -0
  82. package/dist-cjs/packages/grid/src/internal/Cell.js.map +1 -0
  83. package/dist-cjs/packages/grid/src/internal/CellMeasure.css.js +9 -0
  84. package/dist-cjs/packages/grid/src/internal/CellMeasure.css.js.map +1 -0
  85. package/dist-cjs/packages/grid/src/internal/CellMeasure.js +41 -0
  86. package/dist-cjs/packages/grid/src/internal/CellMeasure.js.map +1 -0
  87. package/dist-cjs/packages/grid/src/internal/ColumnDropTarget.css.js +9 -0
  88. package/dist-cjs/packages/grid/src/internal/ColumnDropTarget.css.js.map +1 -0
  89. package/dist-cjs/packages/grid/src/internal/ColumnDropTarget.js +28 -0
  90. package/dist-cjs/packages/grid/src/internal/ColumnDropTarget.js.map +1 -0
  91. package/dist-cjs/packages/grid/src/internal/ColumnGhost.css.js +9 -0
  92. package/dist-cjs/packages/grid/src/internal/ColumnGhost.css.js.map +1 -0
  93. package/dist-cjs/packages/grid/src/internal/ColumnGhost.js +51 -0
  94. package/dist-cjs/packages/grid/src/internal/ColumnGhost.js.map +1 -0
  95. package/dist-cjs/packages/grid/src/internal/Cursor.css.js +9 -0
  96. package/dist-cjs/packages/grid/src/internal/Cursor.css.js.map +1 -0
  97. package/dist-cjs/packages/grid/src/internal/Cursor.js +17 -0
  98. package/dist-cjs/packages/grid/src/internal/Cursor.js.map +1 -0
  99. package/dist-cjs/packages/grid/src/internal/DefaultCellValue.css.js +9 -0
  100. package/dist-cjs/packages/grid/src/internal/DefaultCellValue.css.js.map +1 -0
  101. package/dist-cjs/packages/grid/src/internal/DefaultCellValue.js +26 -0
  102. package/dist-cjs/packages/grid/src/internal/DefaultCellValue.js.map +1 -0
  103. package/dist-cjs/packages/grid/src/internal/FakeCell.css.js +9 -0
  104. package/dist-cjs/packages/grid/src/internal/FakeCell.css.js.map +1 -0
  105. package/dist-cjs/packages/grid/src/internal/FakeCell.js +19 -0
  106. package/dist-cjs/packages/grid/src/internal/FakeCell.js.map +1 -0
  107. package/dist-cjs/packages/grid/src/internal/FakeGroupCell.js +12 -0
  108. package/dist-cjs/packages/grid/src/internal/FakeGroupCell.js.map +1 -0
  109. package/dist-cjs/packages/grid/src/internal/FakeHeaderCell.js +14 -0
  110. package/dist-cjs/packages/grid/src/internal/FakeHeaderCell.js.map +1 -0
  111. package/dist-cjs/packages/grid/src/internal/GroupHeaderRow.css.js +9 -0
  112. package/dist-cjs/packages/grid/src/internal/GroupHeaderRow.css.js.map +1 -0
  113. package/dist-cjs/packages/grid/src/internal/GroupHeaderRow.js +38 -0
  114. package/dist-cjs/packages/grid/src/internal/GroupHeaderRow.js.map +1 -0
  115. package/dist-cjs/packages/grid/src/internal/HeaderRow.css.js +9 -0
  116. package/dist-cjs/packages/grid/src/internal/HeaderRow.css.js.map +1 -0
  117. package/dist-cjs/packages/grid/src/internal/HeaderRow.js +42 -0
  118. package/dist-cjs/packages/grid/src/internal/HeaderRow.js.map +1 -0
  119. package/dist-cjs/packages/grid/src/internal/LeftPart.css.js +9 -0
  120. package/dist-cjs/packages/grid/src/internal/LeftPart.css.js.map +1 -0
  121. package/dist-cjs/packages/grid/src/internal/LeftPart.js +62 -0
  122. package/dist-cjs/packages/grid/src/internal/LeftPart.js.map +1 -0
  123. package/dist-cjs/packages/grid/src/internal/MiddlePart.css.js +9 -0
  124. package/dist-cjs/packages/grid/src/internal/MiddlePart.css.js.map +1 -0
  125. package/dist-cjs/packages/grid/src/internal/MiddlePart.js +54 -0
  126. package/dist-cjs/packages/grid/src/internal/MiddlePart.js.map +1 -0
  127. package/dist-cjs/packages/grid/src/internal/RightPart.css.js +9 -0
  128. package/dist-cjs/packages/grid/src/internal/RightPart.css.js.map +1 -0
  129. package/dist-cjs/packages/grid/src/internal/RightPart.js +62 -0
  130. package/dist-cjs/packages/grid/src/internal/RightPart.js.map +1 -0
  131. package/dist-cjs/packages/grid/src/internal/Scrollable.css.js +9 -0
  132. package/dist-cjs/packages/grid/src/internal/Scrollable.css.js.map +1 -0
  133. package/dist-cjs/packages/grid/src/internal/Scrollable.js +89 -0
  134. package/dist-cjs/packages/grid/src/internal/Scrollable.js.map +1 -0
  135. package/dist-cjs/packages/grid/src/internal/TableBody.js +70 -0
  136. package/dist-cjs/packages/grid/src/internal/TableBody.js.map +1 -0
  137. package/dist-cjs/packages/grid/src/internal/TableColGroup.js +37 -0
  138. package/dist-cjs/packages/grid/src/internal/TableColGroup.js.map +1 -0
  139. package/dist-cjs/packages/grid/src/internal/TableRow.css.js +9 -0
  140. package/dist-cjs/packages/grid/src/internal/TableRow.css.js.map +1 -0
  141. package/dist-cjs/packages/grid/src/internal/TableRow.js +99 -0
  142. package/dist-cjs/packages/grid/src/internal/TableRow.js.map +1 -0
  143. package/dist-cjs/packages/grid/src/internal/TopLeftPart.css.js +9 -0
  144. package/dist-cjs/packages/grid/src/internal/TopLeftPart.css.js.map +1 -0
  145. package/dist-cjs/packages/grid/src/internal/TopLeftPart.js +54 -0
  146. package/dist-cjs/packages/grid/src/internal/TopLeftPart.js.map +1 -0
  147. package/dist-cjs/packages/grid/src/internal/TopPart.css.js +9 -0
  148. package/dist-cjs/packages/grid/src/internal/TopPart.css.js.map +1 -0
  149. package/dist-cjs/packages/grid/src/internal/TopPart.js +57 -0
  150. package/dist-cjs/packages/grid/src/internal/TopPart.js.map +1 -0
  151. package/dist-cjs/packages/grid/src/internal/TopRightPart.css.js +9 -0
  152. package/dist-cjs/packages/grid/src/internal/TopRightPart.css.js.map +1 -0
  153. package/dist-cjs/packages/grid/src/internal/TopRightPart.js +55 -0
  154. package/dist-cjs/packages/grid/src/internal/TopRightPart.js.map +1 -0
  155. package/dist-cjs/packages/grid/src/internal/gridHooks.js +916 -0
  156. package/dist-cjs/packages/grid/src/internal/gridHooks.js.map +1 -0
  157. package/dist-cjs/packages/grid/src/internal/utils.js +71 -0
  158. package/dist-cjs/packages/grid/src/internal/utils.js.map +1 -0
  159. package/dist-es/node_modules/style-inject/dist/style-inject.es.js +29 -0
  160. package/dist-es/node_modules/style-inject/dist/style-inject.es.js.map +1 -0
  161. package/dist-es/packages/grid/src/BaseCell.css.js +7 -0
  162. package/dist-es/packages/grid/src/BaseCell.css.js.map +1 -0
  163. package/dist-es/packages/grid/src/BaseCell.js +72 -0
  164. package/dist-es/packages/grid/src/BaseCell.js.map +1 -0
  165. package/dist-es/packages/grid/src/CellEditor.js +25 -0
  166. package/dist-es/packages/grid/src/CellEditor.js.map +1 -0
  167. package/dist-es/packages/grid/src/CheckboxCell.css.js +7 -0
  168. package/dist-es/packages/grid/src/CheckboxCell.css.js.map +1 -0
  169. package/dist-es/packages/grid/src/ColumnDataContext.js +13 -0
  170. package/dist-es/packages/grid/src/ColumnDataContext.js.map +1 -0
  171. package/dist-es/packages/grid/src/ColumnDragContext.js +15 -0
  172. package/dist-es/packages/grid/src/ColumnDragContext.js.map +1 -0
  173. package/dist-es/packages/grid/src/ColumnGroup.js +28 -0
  174. package/dist-es/packages/grid/src/ColumnGroup.js.map +1 -0
  175. package/dist-es/packages/grid/src/CornerTag.css.js +7 -0
  176. package/dist-es/packages/grid/src/CornerTag.css.js.map +1 -0
  177. package/dist-es/packages/grid/src/CornerTag.js +11 -0
  178. package/dist-es/packages/grid/src/CornerTag.js.map +1 -0
  179. package/dist-es/packages/grid/src/CursorContext.js +15 -0
  180. package/dist-es/packages/grid/src/CursorContext.js.map +1 -0
  181. package/dist-es/packages/grid/src/DropdownCellEditor.css.js +7 -0
  182. package/dist-es/packages/grid/src/DropdownCellEditor.css.js.map +1 -0
  183. package/dist-es/packages/grid/src/DropdownCellEditor.js +71 -0
  184. package/dist-es/packages/grid/src/DropdownCellEditor.js.map +1 -0
  185. package/dist-es/packages/grid/src/EditorContext.js +15 -0
  186. package/dist-es/packages/grid/src/EditorContext.js.map +1 -0
  187. package/dist-es/packages/grid/src/Grid.css.js +7 -0
  188. package/dist-es/packages/grid/src/Grid.css.js.map +1 -0
  189. package/dist-es/packages/grid/src/Grid.js +930 -0
  190. package/dist-es/packages/grid/src/Grid.js.map +1 -0
  191. package/dist-es/packages/grid/src/GridColumn.js +39 -0
  192. package/dist-es/packages/grid/src/GridColumn.js.map +1 -0
  193. package/dist-es/packages/grid/src/GridContext.js +15 -0
  194. package/dist-es/packages/grid/src/GridContext.js.map +1 -0
  195. package/dist-es/packages/grid/src/GroupHeaderCell.css.js +7 -0
  196. package/dist-es/packages/grid/src/GroupHeaderCell.css.js.map +1 -0
  197. package/dist-es/packages/grid/src/GroupHeaderCell.js +42 -0
  198. package/dist-es/packages/grid/src/GroupHeaderCell.js.map +1 -0
  199. package/dist-es/packages/grid/src/GroupHeaderCellValue.js +12 -0
  200. package/dist-es/packages/grid/src/GroupHeaderCellValue.js.map +1 -0
  201. package/dist-es/packages/grid/src/HeaderCell.css.js +7 -0
  202. package/dist-es/packages/grid/src/HeaderCell.css.js.map +1 -0
  203. package/dist-es/packages/grid/src/HeaderCell.js +110 -0
  204. package/dist-es/packages/grid/src/HeaderCell.js.map +1 -0
  205. package/dist-es/packages/grid/src/HeaderCellValue.js +15 -0
  206. package/dist-es/packages/grid/src/HeaderCellValue.js.map +1 -0
  207. package/dist-es/packages/grid/src/LayoutContext.js +8 -0
  208. package/dist-es/packages/grid/src/LayoutContext.js.map +1 -0
  209. package/dist-es/packages/grid/src/NumberRange.js +58 -0
  210. package/dist-es/packages/grid/src/NumberRange.js.map +1 -0
  211. package/dist-es/packages/grid/src/NumericColumn.css.js +7 -0
  212. package/dist-es/packages/grid/src/NumericColumn.css.js.map +1 -0
  213. package/dist-es/packages/grid/src/NumericColumn.js +102 -0
  214. package/dist-es/packages/grid/src/NumericColumn.js.map +1 -0
  215. package/dist-es/packages/grid/src/RowSelectionCheckboxCellValue.js +33 -0
  216. package/dist-es/packages/grid/src/RowSelectionCheckboxCellValue.js.map +1 -0
  217. package/dist-es/packages/grid/src/RowSelectionCheckboxColumn.js +28 -0
  218. package/dist-es/packages/grid/src/RowSelectionCheckboxColumn.js.map +1 -0
  219. package/dist-es/packages/grid/src/RowSelectionCheckboxHeaderCellValue.js +44 -0
  220. package/dist-es/packages/grid/src/RowSelectionCheckboxHeaderCellValue.js.map +1 -0
  221. package/dist-es/packages/grid/src/RowSelectionRadioCellValue.js +21 -0
  222. package/dist-es/packages/grid/src/RowSelectionRadioCellValue.js.map +1 -0
  223. package/dist-es/packages/grid/src/RowSelectionRadioColumn.js +26 -0
  224. package/dist-es/packages/grid/src/RowSelectionRadioColumn.js.map +1 -0
  225. package/dist-es/packages/grid/src/RowSelectionRadioHeaderCell.js +18 -0
  226. package/dist-es/packages/grid/src/RowSelectionRadioHeaderCell.js.map +1 -0
  227. package/dist-es/packages/grid/src/SelectionContext.js +15 -0
  228. package/dist-es/packages/grid/src/SelectionContext.js.map +1 -0
  229. package/dist-es/packages/grid/src/SizingContext.js +15 -0
  230. package/dist-es/packages/grid/src/SizingContext.js.map +1 -0
  231. package/dist-es/packages/grid/src/TextCellEditor.css.js +7 -0
  232. package/dist-es/packages/grid/src/TextCellEditor.css.js.map +1 -0
  233. package/dist-es/packages/grid/src/TextCellEditor.js +81 -0
  234. package/dist-es/packages/grid/src/TextCellEditor.js.map +1 -0
  235. package/dist-es/packages/grid/src/index.js +22 -0
  236. package/dist-es/packages/grid/src/index.js.map +1 -0
  237. package/dist-es/packages/grid/src/internal/Cell.css.js +7 -0
  238. package/dist-es/packages/grid/src/internal/Cell.css.js.map +1 -0
  239. package/dist-es/packages/grid/src/internal/Cell.js +51 -0
  240. package/dist-es/packages/grid/src/internal/Cell.js.map +1 -0
  241. package/dist-es/packages/grid/src/internal/CellMeasure.css.js +7 -0
  242. package/dist-es/packages/grid/src/internal/CellMeasure.css.js.map +1 -0
  243. package/dist-es/packages/grid/src/internal/CellMeasure.js +37 -0
  244. package/dist-es/packages/grid/src/internal/CellMeasure.js.map +1 -0
  245. package/dist-es/packages/grid/src/internal/ColumnDropTarget.css.js +7 -0
  246. package/dist-es/packages/grid/src/internal/ColumnDropTarget.css.js.map +1 -0
  247. package/dist-es/packages/grid/src/internal/ColumnDropTarget.js +24 -0
  248. package/dist-es/packages/grid/src/internal/ColumnDropTarget.js.map +1 -0
  249. package/dist-es/packages/grid/src/internal/ColumnGhost.css.js +7 -0
  250. package/dist-es/packages/grid/src/internal/ColumnGhost.css.js.map +1 -0
  251. package/dist-es/packages/grid/src/internal/ColumnGhost.js +47 -0
  252. package/dist-es/packages/grid/src/internal/ColumnGhost.js.map +1 -0
  253. package/dist-es/packages/grid/src/internal/Cursor.css.js +7 -0
  254. package/dist-es/packages/grid/src/internal/Cursor.css.js.map +1 -0
  255. package/dist-es/packages/grid/src/internal/Cursor.js +13 -0
  256. package/dist-es/packages/grid/src/internal/Cursor.js.map +1 -0
  257. package/dist-es/packages/grid/src/internal/DefaultCellValue.css.js +7 -0
  258. package/dist-es/packages/grid/src/internal/DefaultCellValue.css.js.map +1 -0
  259. package/dist-es/packages/grid/src/internal/DefaultCellValue.js +18 -0
  260. package/dist-es/packages/grid/src/internal/DefaultCellValue.js.map +1 -0
  261. package/dist-es/packages/grid/src/internal/FakeCell.css.js +7 -0
  262. package/dist-es/packages/grid/src/internal/FakeCell.css.js.map +1 -0
  263. package/dist-es/packages/grid/src/internal/FakeCell.js +15 -0
  264. package/dist-es/packages/grid/src/internal/FakeCell.js.map +1 -0
  265. package/dist-es/packages/grid/src/internal/FakeGroupCell.js +8 -0
  266. package/dist-es/packages/grid/src/internal/FakeGroupCell.js.map +1 -0
  267. package/dist-es/packages/grid/src/internal/FakeHeaderCell.js +10 -0
  268. package/dist-es/packages/grid/src/internal/FakeHeaderCell.js.map +1 -0
  269. package/dist-es/packages/grid/src/internal/GroupHeaderRow.css.js +7 -0
  270. package/dist-es/packages/grid/src/internal/GroupHeaderRow.css.js.map +1 -0
  271. package/dist-es/packages/grid/src/internal/GroupHeaderRow.js +34 -0
  272. package/dist-es/packages/grid/src/internal/GroupHeaderRow.js.map +1 -0
  273. package/dist-es/packages/grid/src/internal/HeaderRow.css.js +7 -0
  274. package/dist-es/packages/grid/src/internal/HeaderRow.css.js.map +1 -0
  275. package/dist-es/packages/grid/src/internal/HeaderRow.js +38 -0
  276. package/dist-es/packages/grid/src/internal/HeaderRow.js.map +1 -0
  277. package/dist-es/packages/grid/src/internal/LeftPart.css.js +7 -0
  278. package/dist-es/packages/grid/src/internal/LeftPart.css.js.map +1 -0
  279. package/dist-es/packages/grid/src/internal/LeftPart.js +54 -0
  280. package/dist-es/packages/grid/src/internal/LeftPart.js.map +1 -0
  281. package/dist-es/packages/grid/src/internal/MiddlePart.css.js +7 -0
  282. package/dist-es/packages/grid/src/internal/MiddlePart.css.js.map +1 -0
  283. package/dist-es/packages/grid/src/internal/MiddlePart.js +50 -0
  284. package/dist-es/packages/grid/src/internal/MiddlePart.js.map +1 -0
  285. package/dist-es/packages/grid/src/internal/RightPart.css.js +7 -0
  286. package/dist-es/packages/grid/src/internal/RightPart.css.js.map +1 -0
  287. package/dist-es/packages/grid/src/internal/RightPart.js +54 -0
  288. package/dist-es/packages/grid/src/internal/RightPart.js.map +1 -0
  289. package/dist-es/packages/grid/src/internal/Scrollable.css.js +7 -0
  290. package/dist-es/packages/grid/src/internal/Scrollable.css.js.map +1 -0
  291. package/dist-es/packages/grid/src/internal/Scrollable.js +85 -0
  292. package/dist-es/packages/grid/src/internal/Scrollable.js.map +1 -0
  293. package/dist-es/packages/grid/src/internal/TableBody.js +66 -0
  294. package/dist-es/packages/grid/src/internal/TableBody.js.map +1 -0
  295. package/dist-es/packages/grid/src/internal/TableColGroup.js +32 -0
  296. package/dist-es/packages/grid/src/internal/TableColGroup.js.map +1 -0
  297. package/dist-es/packages/grid/src/internal/TableRow.css.js +7 -0
  298. package/dist-es/packages/grid/src/internal/TableRow.css.js.map +1 -0
  299. package/dist-es/packages/grid/src/internal/TableRow.js +91 -0
  300. package/dist-es/packages/grid/src/internal/TableRow.js.map +1 -0
  301. package/dist-es/packages/grid/src/internal/TopLeftPart.css.js +7 -0
  302. package/dist-es/packages/grid/src/internal/TopLeftPart.css.js.map +1 -0
  303. package/dist-es/packages/grid/src/internal/TopLeftPart.js +46 -0
  304. package/dist-es/packages/grid/src/internal/TopLeftPart.js.map +1 -0
  305. package/dist-es/packages/grid/src/internal/TopPart.css.js +7 -0
  306. package/dist-es/packages/grid/src/internal/TopPart.css.js.map +1 -0
  307. package/dist-es/packages/grid/src/internal/TopPart.js +49 -0
  308. package/dist-es/packages/grid/src/internal/TopPart.js.map +1 -0
  309. package/dist-es/packages/grid/src/internal/TopRightPart.css.js +7 -0
  310. package/dist-es/packages/grid/src/internal/TopRightPart.css.js.map +1 -0
  311. package/dist-es/packages/grid/src/internal/TopRightPart.js +47 -0
  312. package/dist-es/packages/grid/src/internal/TopRightPart.js.map +1 -0
  313. package/dist-es/packages/grid/src/internal/gridHooks.js +886 -0
  314. package/dist-es/packages/grid/src/internal/gridHooks.js.map +1 -0
  315. package/dist-es/packages/grid/src/internal/utils.js +61 -0
  316. package/dist-es/packages/grid/src/internal/utils.js.map +1 -0
  317. package/dist-types/BaseCell.d.ts +6 -0
  318. package/dist-types/CellEditor.d.ts +10 -0
  319. package/dist-types/ColumnDataContext.d.ts +7 -0
  320. package/dist-types/ColumnDragContext.d.ts +7 -0
  321. package/dist-types/ColumnGroup.d.ts +18 -0
  322. package/dist-types/CornerTag.d.ts +6 -0
  323. package/dist-types/CursorContext.d.ts +12 -0
  324. package/dist-types/DropdownCellEditor.d.ts +9 -0
  325. package/dist-types/EditorContext.d.ts +10 -0
  326. package/dist-types/Grid.d.ts +99 -0
  327. package/dist-types/GridColumn.d.ts +113 -0
  328. package/dist-types/GridContext.d.ts +16 -0
  329. package/dist-types/GroupHeaderCell.d.ts +8 -0
  330. package/dist-types/GroupHeaderCellValue.d.ts +3 -0
  331. package/dist-types/HeaderCell.d.ts +10 -0
  332. package/dist-types/HeaderCellValue.d.ts +3 -0
  333. package/dist-types/LayoutContext.d.ts +9 -0
  334. package/dist-types/NumberRange.d.ts +15 -0
  335. package/dist-types/NumericColumn.d.ts +15 -0
  336. package/dist-types/RowSelectionCheckboxCellValue.d.ts +4 -0
  337. package/dist-types/RowSelectionCheckboxColumn.d.ts +4 -0
  338. package/dist-types/RowSelectionCheckboxHeaderCellValue.d.ts +4 -0
  339. package/dist-types/RowSelectionRadioCellValue.d.ts +4 -0
  340. package/dist-types/RowSelectionRadioColumn.d.ts +4 -0
  341. package/dist-types/RowSelectionRadioHeaderCell.d.ts +4 -0
  342. package/dist-types/SelectionContext.d.ts +13 -0
  343. package/dist-types/SizingContext.d.ts +8 -0
  344. package/dist-types/TextCellEditor.d.ts +8 -0
  345. package/dist-types/index.d.ts +21 -0
  346. package/dist-types/internal/Cell.d.ts +9 -0
  347. package/dist-types/internal/CellMeasure.d.ts +6 -0
  348. package/dist-types/internal/ColumnDropTarget.d.ts +6 -0
  349. package/dist-types/internal/ColumnGhost.d.ts +11 -0
  350. package/dist-types/internal/Cursor.d.ts +5 -0
  351. package/dist-types/internal/DefaultCellValue.d.ts +4 -0
  352. package/dist-types/internal/FakeCell.d.ts +5 -0
  353. package/dist-types/internal/FakeGroupCell.d.ts +2 -0
  354. package/dist-types/internal/FakeHeaderCell.d.ts +2 -0
  355. package/dist-types/internal/GroupHeaderRow.d.ts +8 -0
  356. package/dist-types/internal/HeaderRow.d.ts +8 -0
  357. package/dist-types/internal/LeftPart.d.ts +14 -0
  358. package/dist-types/internal/MiddlePart.d.ts +14 -0
  359. package/dist-types/internal/RightPart.d.ts +14 -0
  360. package/dist-types/internal/Scrollable.d.ts +16 -0
  361. package/dist-types/internal/TableBody.d.ts +11 -0
  362. package/dist-types/internal/TableColGroup.d.ts +11 -0
  363. package/dist-types/internal/TableRow.d.ts +19 -0
  364. package/dist-types/internal/TopLeftPart.d.ts +11 -0
  365. package/dist-types/internal/TopPart.d.ts +12 -0
  366. package/dist-types/internal/TopRightPart.d.ts +11 -0
  367. package/dist-types/internal/gridHooks.d.ts +91 -0
  368. package/dist-types/internal/index.d.ts +21 -0
  369. package/dist-types/internal/utils.d.ts +13 -0
  370. package/package.json +41 -0
@@ -0,0 +1,886 @@
1
+ import { useRef, useState, useMemo, useCallback, Children, isValidElement, useEffect } from 'react';
2
+ import { NumberRange } from '../NumberRange.js';
3
+ import { getAttribute, makeMapAdder, makeMapDeleter, getCellPosition } from './utils.js';
4
+ import { useControlled } from '@salt-ds/core';
5
+
6
+ function useActiveOnWheel(onWheel) {
7
+ const tableRef = useRef(null);
8
+ useEffect(() => {
9
+ const table = tableRef.current;
10
+ if (table && onWheel) {
11
+ table.addEventListener("wheel", onWheel, { passive: false });
12
+ return () => {
13
+ table.removeEventListener("wheel", onWheel);
14
+ };
15
+ }
16
+ }, [tableRef.current]);
17
+ return tableRef;
18
+ }
19
+ function sumWidth(columns) {
20
+ return columns.reduce((p, x) => p + x.info.width, 0);
21
+ }
22
+ function useSumWidth(columns) {
23
+ return useMemo(() => sumWidth(columns), [columns]);
24
+ }
25
+ function useSum(source) {
26
+ return useMemo(() => source.reduce((p, x) => p + x, 0), source);
27
+ }
28
+ function sumRangeWidth(columns, range) {
29
+ let w = 0;
30
+ range.forEach((i) => {
31
+ w += columns[i].info.width;
32
+ });
33
+ return w;
34
+ }
35
+ function useSumRangeWidth(columns, range) {
36
+ return useMemo(() => sumRangeWidth(columns, range), [columns, range]);
37
+ }
38
+ function useMemoRng(fn, deps) {
39
+ const prevRef = useRef(NumberRange.empty);
40
+ const range = useMemo(fn, deps);
41
+ if (!NumberRange.equals(prevRef.current, range)) {
42
+ prevRef.current = range;
43
+ }
44
+ return prevRef.current;
45
+ }
46
+ function useBodyVisibleColumnRange(midColumns, scrollLeft, clientMidWidth) {
47
+ return useMemoRng(() => {
48
+ if (clientMidWidth === 0 || midColumns.length === 0) {
49
+ return NumberRange.empty;
50
+ }
51
+ let width = scrollLeft;
52
+ let start = 0;
53
+ for (let i = 0; i < midColumns.length; ++i) {
54
+ const colWidth = midColumns[i].info.width;
55
+ if (width > colWidth) {
56
+ width -= colWidth;
57
+ } else {
58
+ start = i;
59
+ width += clientMidWidth;
60
+ break;
61
+ }
62
+ }
63
+ let end = start + 1;
64
+ for (let i = start; i < midColumns.length; ++i) {
65
+ const colWidth = midColumns[i].info.width;
66
+ width -= colWidth;
67
+ end = i + 1;
68
+ if (width <= 0) {
69
+ break;
70
+ }
71
+ }
72
+ if (end > midColumns.length) {
73
+ end = midColumns.length;
74
+ }
75
+ return new NumberRange(start, end);
76
+ }, [midColumns, scrollLeft, clientMidWidth]);
77
+ }
78
+ function useClientMidWidth(clientWidth, leftWidth, rightWidth) {
79
+ return useMemo(
80
+ () => clientWidth - leftWidth - rightWidth,
81
+ [clientWidth, leftWidth, rightWidth]
82
+ );
83
+ }
84
+ function useClientMidHeight(clientHeight, topHeight, botHeight) {
85
+ return useMemo(
86
+ () => clientHeight - topHeight - botHeight,
87
+ [clientHeight, topHeight, botHeight]
88
+ );
89
+ }
90
+ function useBodyVisibleAreaTop(rowHeight, visibleRowRange, topHeight) {
91
+ return useMemo(() => {
92
+ let top = topHeight + visibleRowRange.start * rowHeight;
93
+ if (visibleRowRange.start > 0) {
94
+ top += 1;
95
+ }
96
+ return top;
97
+ }, [rowHeight, visibleRowRange, topHeight]);
98
+ }
99
+ function useVisibleRowRange(scrollTop, clientMidHeight, rowHeight, rowCount) {
100
+ return useMemoRng(() => {
101
+ if (rowHeight < 1) {
102
+ return NumberRange.empty;
103
+ }
104
+ const firstRowHeight = rowHeight + 1;
105
+ const start = scrollTop > firstRowHeight ? 1 + Math.floor((scrollTop - firstRowHeight) / rowHeight) : 0;
106
+ let endPos = scrollTop + clientMidHeight;
107
+ if (start === 0) {
108
+ endPos -= 1;
109
+ }
110
+ const end = Math.min(
111
+ rowCount,
112
+ Math.max(start, Math.ceil(endPos / rowHeight))
113
+ );
114
+ return new NumberRange(start, end);
115
+ }, [scrollTop, clientMidHeight, rowHeight, rowCount]);
116
+ }
117
+ function useColumnRange(columns, range) {
118
+ return useMemo(() => columns.slice(range.start, range.end), [columns, range]);
119
+ }
120
+ function useLeftScrolledOutWidth(midColumns, bodyVisibleColumnRange) {
121
+ return useMemo(() => {
122
+ let w = 0;
123
+ for (let i = 0; i < bodyVisibleColumnRange.start; ++i) {
124
+ w += midColumns[i].info.width;
125
+ }
126
+ return w;
127
+ }, [midColumns, bodyVisibleColumnRange]);
128
+ }
129
+ function useRowModels(getKey, rowData, visibleRowRange) {
130
+ return useMemo(() => {
131
+ const rows = [];
132
+ visibleRowRange.forEach((i) => {
133
+ const key = getKey(rowData[i], i);
134
+ rows.push({ data: rowData[i], key, index: i });
135
+ });
136
+ return rows;
137
+ }, [getKey, rowData, visibleRowRange]);
138
+ }
139
+ const useColumnGroups = (grpPs, startIdx) => useMemo(
140
+ () => grpPs.map((data, i) => {
141
+ const childrenIds = Children.toArray(data.children).map((child) => {
142
+ if (!isValidElement(child)) {
143
+ return void 0;
144
+ }
145
+ return child.props.id;
146
+ }).filter((x) => x !== void 0);
147
+ const colSpan = childrenIds.length;
148
+ return {
149
+ data,
150
+ index: i + startIdx,
151
+ childrenIds,
152
+ colSpan,
153
+ columnSeparator: "regular",
154
+ rowSeparator: "regular"
155
+ };
156
+ }),
157
+ [grpPs, startIdx]
158
+ );
159
+ function useVisibleColumnGroupRange(bodyVisColRng, midCols, midGrpByColId, leftGrpCount) {
160
+ return useMemoRng(() => {
161
+ if (bodyVisColRng.length === 0) {
162
+ return NumberRange.empty;
163
+ }
164
+ const firstVisibleCol = midCols[bodyVisColRng.start];
165
+ const lastVisibleCol = midCols[bodyVisColRng.end - 1];
166
+ const firstVisibleGroup = midGrpByColId.get(firstVisibleCol.info.props.id);
167
+ const lastVisibleGroup = midGrpByColId.get(lastVisibleCol.info.props.id);
168
+ if (!firstVisibleGroup || !lastVisibleGroup) {
169
+ return NumberRange.empty;
170
+ }
171
+ return new NumberRange(
172
+ firstVisibleGroup.index - leftGrpCount,
173
+ lastVisibleGroup.index + 1 - leftGrpCount
174
+ );
175
+ }, [bodyVisColRng, midCols, midGrpByColId, leftGrpCount]);
176
+ }
177
+ function last(source) {
178
+ return source[source.length - 1];
179
+ }
180
+ function useHeadVisibleColumnRange(bodyVisColRng, visColGrps, midColsById, leftColCount) {
181
+ return useMemoRng(() => {
182
+ var _a, _b;
183
+ if (visColGrps.length === 0) {
184
+ return bodyVisColRng;
185
+ }
186
+ const firstVisibleGroup = visColGrps[0];
187
+ const lastVisibleGroup = last(visColGrps);
188
+ const firstColId = firstVisibleGroup.childrenIds[0];
189
+ const lastColId = last(lastVisibleGroup.childrenIds);
190
+ const firstColIdx = (_a = midColsById.get(firstColId)) == null ? void 0 : _a.index;
191
+ const lastColIdx = (_b = midColsById.get(lastColId)) == null ? void 0 : _b.index;
192
+ if (firstColIdx === void 0 || lastColIdx === void 0) {
193
+ return NumberRange.empty;
194
+ }
195
+ return new NumberRange(
196
+ firstColIdx - leftColCount,
197
+ lastColIdx + 1 - leftColCount
198
+ );
199
+ }, [bodyVisColRng, visColGrps, midColsById, leftColCount]);
200
+ }
201
+ function useCols(colInfos, startIdx, groups) {
202
+ return useMemo(() => {
203
+ const edgeColIds = /* @__PURE__ */ new Set();
204
+ groups.forEach((g) => {
205
+ edgeColIds.add(last(g.childrenIds));
206
+ });
207
+ const columnModels = colInfos.map((info, i) => ({
208
+ info,
209
+ index: i + startIdx,
210
+ separator: edgeColIds.has(info.props.id) ? "groupEdge" : "regular"
211
+ }));
212
+ return columnModels;
213
+ }, [colInfos, startIdx, groups]);
214
+ }
215
+ function useScrollToCell(visRowRng, rowHeight, clientMidHeight, midCols, bodyVisColRng, clientMidWidth, scroll) {
216
+ return useCallback(
217
+ (part, rowIdx, colIdx) => {
218
+ if (part !== "body") {
219
+ return;
220
+ }
221
+ let x = void 0;
222
+ let y = void 0;
223
+ if (rowIdx <= visRowRng.start) {
224
+ y = rowIdx === 0 ? 0 : 1 + rowHeight * rowIdx;
225
+ } else if (rowIdx >= visRowRng.end - 1) {
226
+ const extraBorder = rowIdx > 0 ? 1 : 0;
227
+ y = Math.max(
228
+ 0,
229
+ rowHeight * rowIdx + extraBorder - clientMidHeight + rowHeight
230
+ );
231
+ }
232
+ const isMidCol = midCols.length > 0 && colIdx >= midCols[0].index && colIdx <= last(midCols).index;
233
+ if (isMidCol) {
234
+ const midColIdx = colIdx - midCols[0].index;
235
+ if (midColIdx <= bodyVisColRng.start) {
236
+ let w = 0;
237
+ for (let i = 0; i < midColIdx; ++i) {
238
+ w += midCols[i].info.width;
239
+ }
240
+ x = w;
241
+ } else if (midColIdx >= bodyVisColRng.end - 1) {
242
+ let w = 0;
243
+ for (let i = 0; i <= midColIdx; ++i) {
244
+ w += midCols[i].info.width;
245
+ }
246
+ x = Math.max(0, w - clientMidWidth);
247
+ }
248
+ }
249
+ if (x !== void 0 || y !== void 0) {
250
+ scroll(x, y, "table");
251
+ }
252
+ },
253
+ [
254
+ visRowRng,
255
+ rowHeight,
256
+ clientMidHeight,
257
+ midCols,
258
+ bodyVisColRng,
259
+ clientMidWidth,
260
+ scroll
261
+ ]
262
+ );
263
+ }
264
+ const MIN_COLUMN_WIDTH = 10;
265
+ function useColumnResize(cols, resizeColumn) {
266
+ const columnResizeDataRef = useRef();
267
+ const onMouseUp = useCallback(() => {
268
+ var _a;
269
+ (_a = columnResizeDataRef.current) == null ? void 0 : _a.eventsUnsubscription();
270
+ columnResizeDataRef.current = void 0;
271
+ }, []);
272
+ const onMouseMove = useCallback((event) => {
273
+ const x = event.screenX;
274
+ const { startX, columnIndex, initialColumnWidth, minWidth } = columnResizeDataRef.current;
275
+ const shift = x - startX;
276
+ let width = Math.max(minWidth, initialColumnWidth + shift);
277
+ columnResizeDataRef.current.resizeColumn(columnIndex, Math.round(width));
278
+ }, []);
279
+ return useCallback(
280
+ (event) => {
281
+ const targetElement = event.target;
282
+ const [columnIndexAttribute, thElement] = getAttribute(
283
+ targetElement,
284
+ "data-column-index"
285
+ );
286
+ const columnIndex = parseInt(columnIndexAttribute, 10);
287
+ document.addEventListener("mouseup", onMouseUp);
288
+ document.addEventListener("mousemove", onMouseMove);
289
+ const initialColumnWidth = thElement.getBoundingClientRect().width;
290
+ columnResizeDataRef.current = {
291
+ startX: event.screenX,
292
+ startY: event.screenY,
293
+ eventsUnsubscription: () => {
294
+ document.removeEventListener("mouseup", onMouseUp);
295
+ document.removeEventListener("mousemove", onMouseMove);
296
+ },
297
+ columnIndex,
298
+ initialColumnWidth,
299
+ resizeColumn,
300
+ minWidth: cols[columnIndex].info.props.minWidth || MIN_COLUMN_WIDTH
301
+ };
302
+ event.preventDefault();
303
+ },
304
+ [resizeColumn]
305
+ );
306
+ }
307
+ function useFlatten(map) {
308
+ return useMemo(() => {
309
+ const entries = [...map.entries()].filter(([index, value]) => !!value);
310
+ entries.sort((a, b) => a[0] - b[0]);
311
+ return entries.map((x) => x[1]);
312
+ }, [map]);
313
+ }
314
+ function useColMap() {
315
+ return useState(/* @__PURE__ */ new Map());
316
+ }
317
+ function useGrpMap() {
318
+ return useState(/* @__PURE__ */ new Map());
319
+ }
320
+ function useColumnRegistry(children) {
321
+ const [leftColMap, setLeftColMap] = useColMap();
322
+ const [rightColMap, setRightColMap] = useColMap();
323
+ const [midColMap, setMidColMap] = useColMap();
324
+ const [leftGrpMap, setLeftGrpMap] = useGrpMap();
325
+ const [rightGrpMap, setRightGrpMap] = useGrpMap();
326
+ const [midGrpMap, setMidGrpMap] = useGrpMap();
327
+ const [editorMap, setEditorMap] = useState(
328
+ /* @__PURE__ */ new Map()
329
+ );
330
+ const leftColInfos = useFlatten(leftColMap);
331
+ const rightColInfos = useFlatten(rightColMap);
332
+ const midColInfos = useFlatten(midColMap);
333
+ const leftGrpPs = useFlatten(leftGrpMap);
334
+ const rightGrpPs = useFlatten(rightGrpMap);
335
+ const midGrpPs = useFlatten(midGrpMap);
336
+ const leftGroups = useColumnGroups(leftGrpPs, 0);
337
+ const midGroups = useColumnGroups(midGrpPs, leftGroups.length);
338
+ const rightGroups = useColumnGroups(
339
+ rightGrpPs,
340
+ leftGroups.length + midGroups.length
341
+ );
342
+ if (leftGroups.length > 0) {
343
+ last(leftGroups).columnSeparator = "pinned";
344
+ }
345
+ if (rightGroups.length > 0 && midGroups.length > 0) {
346
+ last(midGroups).columnSeparator = "pinned";
347
+ }
348
+ const leftCols = useCols(leftColInfos, 0, leftGroups);
349
+ const midCols = useCols(
350
+ midColInfos,
351
+ leftCols.length,
352
+ midGroups
353
+ );
354
+ const rightCols = useCols(
355
+ rightColInfos,
356
+ leftCols.length + midCols.length,
357
+ rightGroups
358
+ );
359
+ if (leftCols.length > 0) {
360
+ last(leftCols).separator = "pinned";
361
+ }
362
+ if (rightCols.length > 0 && midCols.length > 0) {
363
+ last(midCols).separator = "pinned";
364
+ }
365
+ const chPosById = useRef(/* @__PURE__ */ new Map());
366
+ const indexChildren = () => {
367
+ const m = /* @__PURE__ */ new Map();
368
+ let i = 0;
369
+ const indexChildrenRec = (c) => {
370
+ if (!c) {
371
+ return;
372
+ }
373
+ Children.forEach(c, (x) => {
374
+ if (isValidElement(x) && x.props.id !== void 0) {
375
+ m.set(x.props.id, i);
376
+ i++;
377
+ indexChildrenRec(x.props.children);
378
+ }
379
+ });
380
+ };
381
+ indexChildrenRec(children);
382
+ return m;
383
+ };
384
+ chPosById.current = indexChildren();
385
+ const getChildIndex = useCallback((id) => {
386
+ const idx = chPosById.current.get(id);
387
+ if (idx === void 0) {
388
+ console.log(`Unknown child id "${id}"`);
389
+ console.log(
390
+ `Known ids: ${Array.from(chPosById.current.keys()).map((x) => `"${x}"`).join(", ")}`
391
+ );
392
+ throw new Error(`Unknown child id: "${id}"`);
393
+ }
394
+ return idx;
395
+ }, []);
396
+ const getColMapSet = (pinned) => pinned === "left" ? setLeftColMap : pinned === "right" ? setRightColMap : setMidColMap;
397
+ const onColumnAdded = useCallback((columnInfo) => {
398
+ const { id, pinned } = columnInfo.props;
399
+ const index = getChildIndex(id);
400
+ getColMapSet(pinned)(makeMapAdder(index, columnInfo));
401
+ }, []);
402
+ const onColumnRemoved = useCallback(
403
+ (index, columnInfo) => {
404
+ const { id, pinned } = columnInfo.props;
405
+ getColMapSet(pinned)(makeMapDeleter(index));
406
+ },
407
+ []
408
+ );
409
+ const getGrpMapSet = (pinned) => pinned === "left" ? setLeftGrpMap : pinned === "right" ? setRightGrpMap : setMidGrpMap;
410
+ const onColumnGroupAdded = useCallback((colGroupProps) => {
411
+ const { id, pinned } = colGroupProps;
412
+ getGrpMapSet(pinned)(makeMapAdder(getChildIndex(id), colGroupProps));
413
+ }, []);
414
+ const onColumnGroupRemoved = useCallback(
415
+ (index, colGroupProps) => {
416
+ const { id, pinned } = colGroupProps;
417
+ getGrpMapSet(pinned)(makeMapDeleter(index));
418
+ },
419
+ []
420
+ );
421
+ const onEditorAdded = useCallback((info) => {
422
+ const { columnId } = info;
423
+ setEditorMap(makeMapAdder(columnId, info));
424
+ }, []);
425
+ const onEditorRemoved = useCallback((info) => {
426
+ const { columnId } = info;
427
+ setEditorMap(makeMapDeleter(columnId));
428
+ }, []);
429
+ const getEditor = useCallback(
430
+ (columnId) => editorMap.get(columnId),
431
+ [editorMap]
432
+ );
433
+ const contextValue = useMemo(
434
+ () => ({
435
+ getChildIndex,
436
+ onColumnAdded,
437
+ onColumnRemoved,
438
+ onColumnGroupAdded,
439
+ onColumnGroupRemoved,
440
+ onEditorAdded,
441
+ onEditorRemoved,
442
+ getEditor
443
+ }),
444
+ [
445
+ getChildIndex,
446
+ onColumnAdded,
447
+ onColumnRemoved,
448
+ onColumnGroupAdded,
449
+ onColumnGroupRemoved,
450
+ onEditorAdded,
451
+ onEditorRemoved,
452
+ getEditor
453
+ ]
454
+ );
455
+ return {
456
+ leftCols,
457
+ midCols,
458
+ rightCols,
459
+ leftGroups,
460
+ midGroups,
461
+ rightGroups,
462
+ contextValue
463
+ };
464
+ }
465
+ function useRowSelection(rowKeyGetter, rowData, defaultSelectedRowIdxs, selectedRowIdxs, rowSelectionMode, onRowSelected) {
466
+ const selectedRowIdxsProp = useMemo(() => {
467
+ if (selectedRowIdxs == void 0) {
468
+ return void 0;
469
+ }
470
+ return new Set(selectedRowIdxs);
471
+ }, [selectedRowIdxs]);
472
+ const defaultSelectedRowIdxsProp = useMemo(() => {
473
+ if (defaultSelectedRowIdxs == void 0) {
474
+ return /* @__PURE__ */ new Set([]);
475
+ }
476
+ return new Set(defaultSelectedRowIdxs);
477
+ }, [defaultSelectedRowIdxs]);
478
+ const [selRowIdxs, setSelRowIdxs] = useControlled({
479
+ controlled: selectedRowIdxsProp,
480
+ default: defaultSelectedRowIdxsProp,
481
+ name: "useRowSelection",
482
+ state: "selRowIdxs"
483
+ });
484
+ const [lastSelRowIdx, setLastSelRowIdx] = useState(
485
+ void 0
486
+ );
487
+ useEffect(() => {
488
+ if (rowSelectionMode === "none" && selRowIdxs.size > 0 || rowSelectionMode === "single" && selRowIdxs.size > 1) {
489
+ setSelRowIdxs(/* @__PURE__ */ new Set());
490
+ }
491
+ }, [rowSelectionMode, selRowIdxs, setSelRowIdxs]);
492
+ const selectRows = useCallback(
493
+ ({
494
+ rowIndex,
495
+ isRange = false,
496
+ incremental = false,
497
+ unselectOtherRows = false
498
+ }) => {
499
+ const idxFrom = rowSelectionMode === "multi" && lastSelRowIdx !== void 0 && isRange ? lastSelRowIdx : void 0;
500
+ let nextSelRowIdxs = void 0;
501
+ let nextLastSelRowIdx = void 0;
502
+ if (idxFrom === void 0) {
503
+ if (unselectOtherRows) {
504
+ if (incremental && selRowIdxs.has(rowIndex)) {
505
+ nextSelRowIdxs = /* @__PURE__ */ new Set([]);
506
+ nextLastSelRowIdx = void 0;
507
+ } else {
508
+ nextSelRowIdxs = /* @__PURE__ */ new Set([rowIndex]);
509
+ nextLastSelRowIdx = rowIndex;
510
+ }
511
+ } else {
512
+ if (incremental && rowSelectionMode === "multi") {
513
+ nextSelRowIdxs = new Set(selRowIdxs);
514
+ if (nextSelRowIdxs.has(rowIndex)) {
515
+ nextSelRowIdxs.delete(rowIndex);
516
+ nextLastSelRowIdx = void 0;
517
+ } else {
518
+ nextSelRowIdxs.add(rowIndex);
519
+ nextLastSelRowIdx = rowIndex;
520
+ }
521
+ } else {
522
+ nextSelRowIdxs = /* @__PURE__ */ new Set([rowIndex]);
523
+ nextLastSelRowIdx = rowIndex;
524
+ }
525
+ }
526
+ } else {
527
+ const s = incremental ? new Set(selRowIdxs) : /* @__PURE__ */ new Set();
528
+ const idxs = [rowIndex, idxFrom];
529
+ idxs.sort((a, b) => a - b);
530
+ const rowIdxs = [];
531
+ for (let i = idxs[0]; i <= idxs[1]; ++i) {
532
+ rowIdxs.push(i);
533
+ }
534
+ if (selRowIdxs.has(rowIndex)) {
535
+ rowIdxs.forEach((k) => s.delete(k));
536
+ } else {
537
+ rowIdxs.forEach((k) => s.add(k));
538
+ }
539
+ nextSelRowIdxs = s;
540
+ nextLastSelRowIdx = rowIndex;
541
+ }
542
+ setSelRowIdxs(nextSelRowIdxs);
543
+ setLastSelRowIdx(nextLastSelRowIdx);
544
+ if (onRowSelected) {
545
+ onRowSelected(Array.from(nextSelRowIdxs.keys()));
546
+ }
547
+ },
548
+ [
549
+ selRowIdxs,
550
+ lastSelRowIdx,
551
+ setSelRowIdxs,
552
+ setLastSelRowIdx,
553
+ rowData,
554
+ rowKeyGetter,
555
+ onRowSelected
556
+ ]
557
+ );
558
+ const isAllSelected = selRowIdxs.size === rowData.length;
559
+ const isAnySelected = selRowIdxs.size > 0;
560
+ const selectAll = useCallback(() => {
561
+ const allRowIdxs = [...new Array(rowData.length).keys()].map((_, i) => i);
562
+ setSelRowIdxs(new Set(allRowIdxs));
563
+ if (onRowSelected) {
564
+ onRowSelected(allRowIdxs);
565
+ }
566
+ }, [rowData, setSelRowIdxs]);
567
+ const unselectAll = useCallback(() => {
568
+ setSelRowIdxs(/* @__PURE__ */ new Set());
569
+ if (onRowSelected) {
570
+ onRowSelected([]);
571
+ }
572
+ }, [setSelRowIdxs]);
573
+ const onMouseDown = useCallback(
574
+ (event) => {
575
+ if (rowSelectionMode === "none") {
576
+ return;
577
+ }
578
+ const target = event.target;
579
+ try {
580
+ const [rowIndex] = getCellPosition(target);
581
+ selectRows({
582
+ rowIndex,
583
+ isRange: event.shiftKey,
584
+ incremental: event.metaKey || event.ctrlKey
585
+ });
586
+ } catch (e) {
587
+ }
588
+ },
589
+ [selectRows, rowSelectionMode]
590
+ );
591
+ return {
592
+ onMouseDown,
593
+ selRowIdxs,
594
+ isAllSelected,
595
+ isAnySelected,
596
+ selectRows,
597
+ selectAll,
598
+ unselectAll
599
+ };
600
+ }
601
+ const COLUMN_DRAG_TOLERANCE = 10;
602
+ function useColumnMove(columnMove, rootRef, leftCols, midCols, rightCols, cols, scrollLeft, clientMidWidth, onColumnMove) {
603
+ const moveRef = useRef();
604
+ const activeTargetRef = useRef(void 0);
605
+ const [dragState, setDragState] = useState(
606
+ void 0
607
+ );
608
+ const columnDragStart = useCallback(
609
+ (columnIndex, x, y) => {
610
+ setDragState({ columnIndex, x, y });
611
+ },
612
+ [setDragState]
613
+ );
614
+ const columnDrag = useCallback(
615
+ (x, y) => {
616
+ setDragState((old) => {
617
+ return { ...old, x, y };
618
+ });
619
+ },
620
+ [setDragState]
621
+ );
622
+ const columnDrop = useCallback(() => {
623
+ var _a, _b, _c, _d;
624
+ const toIndex = (_a = activeTargetRef.current) == null ? void 0 : _a.columnIndex;
625
+ const fromIndex = (_b = moveRef.current) == null ? void 0 : _b.columnIndex;
626
+ const columnId = (_c = moveRef.current) == null ? void 0 : _c.columnId;
627
+ const handler = (_d = moveRef.current) == null ? void 0 : _d.onColumnMove;
628
+ if (toIndex !== void 0 && fromIndex !== void 0 && handler !== void 0 && columnId !== void 0) {
629
+ handler(columnId, fromIndex, toIndex);
630
+ }
631
+ setDragState(void 0);
632
+ }, [setDragState]);
633
+ const onMouseUp = useCallback(() => {
634
+ var _a, _b;
635
+ if ((_a = moveRef.current) == null ? void 0 : _a.dragTriggered) {
636
+ columnDrop();
637
+ }
638
+ (_b = moveRef.current) == null ? void 0 : _b.unsubscribe();
639
+ moveRef.current = void 0;
640
+ }, [columnDrop]);
641
+ const onMouseMove = useCallback(
642
+ (event) => {
643
+ const {
644
+ columnIndex,
645
+ startHeaderX,
646
+ startHeaderY,
647
+ startScreenX,
648
+ startScreenY,
649
+ dragTriggered
650
+ } = moveRef.current;
651
+ const shiftX = event.screenX - startScreenX;
652
+ const shiftY = event.screenY - startScreenY;
653
+ const x = startHeaderX + shiftX;
654
+ const y = startHeaderY + shiftY;
655
+ if (!dragTriggered) {
656
+ if (Math.sqrt(shiftX * shiftX + shiftY * shiftY) > COLUMN_DRAG_TOLERANCE) {
657
+ moveRef.current.dragTriggered = true;
658
+ columnDragStart(columnIndex, x, y);
659
+ }
660
+ } else {
661
+ columnDrag(x, y);
662
+ }
663
+ },
664
+ [columnDrag]
665
+ );
666
+ const onColumnMoveHandleMouseDown = useCallback(
667
+ (event) => {
668
+ const [columnIndexAttribute, thElement] = getAttribute(
669
+ event.target,
670
+ "data-column-index"
671
+ );
672
+ const rootElement = rootRef.current;
673
+ document.addEventListener("mouseup", onMouseUp);
674
+ document.addEventListener("mousemove", onMouseMove);
675
+ const columnIndex = parseInt(columnIndexAttribute, 10);
676
+ const columnId = cols[columnIndex].info.props.id;
677
+ const thRect = thElement.getBoundingClientRect();
678
+ const rootRect = rootElement.getBoundingClientRect();
679
+ const x = thRect.x - rootRect.x;
680
+ const y = thRect.y - rootRect.y;
681
+ moveRef.current = {
682
+ unsubscribe: () => {
683
+ document.removeEventListener("mouseup", onMouseUp);
684
+ document.removeEventListener("mousemove", onMouseMove);
685
+ },
686
+ startScreenX: event.screenX,
687
+ startScreenY: event.screenY,
688
+ startHeaderX: x,
689
+ startHeaderY: y,
690
+ columnIndex,
691
+ columnId,
692
+ dragTriggered: false,
693
+ onColumnMove
694
+ };
695
+ event.preventDefault();
696
+ },
697
+ [columnDragStart, cols]
698
+ );
699
+ const onColumnMoveCancel = useCallback(() => {
700
+ var _a;
701
+ setDragState(void 0);
702
+ (_a = moveRef.current) == null ? void 0 : _a.unsubscribe();
703
+ moveRef.current = void 0;
704
+ }, [setDragState]);
705
+ const targets = useMemo(() => {
706
+ if (!dragState) {
707
+ return void 0;
708
+ }
709
+ let ts = [];
710
+ let x = 0;
711
+ leftCols.forEach((c, i2) => {
712
+ ts.push({ columnIndex: c.index, x });
713
+ x += c.info.width;
714
+ });
715
+ let w = scrollLeft;
716
+ let i = 0;
717
+ while (w > 0 && i < midCols.length) {
718
+ w -= midCols[i].info.width;
719
+ i++;
720
+ }
721
+ x -= w;
722
+ w += clientMidWidth;
723
+ while (w > 0 && i < midCols.length) {
724
+ const c = midCols[i];
725
+ ts.push({ columnIndex: c.index, x });
726
+ x += c.info.width;
727
+ w -= c.info.width;
728
+ i++;
729
+ }
730
+ if (rightCols.length > 0) {
731
+ x += w;
732
+ rightCols.forEach((c, i2) => {
733
+ ts.push({ columnIndex: c.index, x });
734
+ x += c.info.width;
735
+ });
736
+ ts.push({ columnIndex: last(rightCols).index + 1, x });
737
+ } else {
738
+ ts.push({ columnIndex: last(midCols).index + 1, x });
739
+ }
740
+ return ts;
741
+ }, [dragState, leftCols, midCols, rightCols, scrollLeft, clientMidWidth]);
742
+ const activeTargetIdx = useMemo(() => {
743
+ const x = dragState == null ? void 0 : dragState.x;
744
+ if (x === void 0 || targets === void 0 || targets.length < 1) {
745
+ return void 0;
746
+ }
747
+ let i = 0;
748
+ while (i < targets.length && targets[i].x < x) {
749
+ i++;
750
+ }
751
+ if (i === 0) {
752
+ return 0;
753
+ }
754
+ if (i >= targets.length) {
755
+ return targets.length - 1;
756
+ }
757
+ return targets[i].x - x < x - targets[i - 1].x ? i : i - 1;
758
+ }, [targets, dragState == null ? void 0 : dragState.x]);
759
+ const activeTarget = activeTargetIdx === void 0 ? void 0 : targets[activeTargetIdx];
760
+ activeTargetRef.current = activeTarget;
761
+ return {
762
+ onColumnMoveHandleMouseDown,
763
+ dragState,
764
+ activeTarget,
765
+ onColumnMoveCancel
766
+ };
767
+ }
768
+ function cellPositionEquals(a, b) {
769
+ return a.rowIdx === b.rowIdx && a.colIdx === b.colIdx;
770
+ }
771
+ function cellRangeEquals(a, b) {
772
+ if (!a) {
773
+ return !b;
774
+ }
775
+ return !!b && cellPositionEquals(a.start, b.start) && cellPositionEquals(a.end, b.end);
776
+ }
777
+ function useRangeSelection(cellSelectionMode) {
778
+ const mouseSelectionRef = useRef();
779
+ const keyboardSelectionRef = useRef();
780
+ if (cellSelectionMode !== "range") {
781
+ if (mouseSelectionRef.current) {
782
+ mouseSelectionRef.current.unsubscribe();
783
+ mouseSelectionRef.current = void 0;
784
+ }
785
+ if (keyboardSelectionRef.current) {
786
+ keyboardSelectionRef.current = void 0;
787
+ }
788
+ }
789
+ const [selectedCellRange, setSelectedCellRange] = useState(void 0);
790
+ const onMouseMove = useCallback((event) => {
791
+ const { clientX, clientY } = event;
792
+ const element = document.elementFromPoint(clientX, clientY);
793
+ try {
794
+ const [rowIdx, colIdx] = getCellPosition(element);
795
+ setSelectedCellRange((old) => {
796
+ const { start } = mouseSelectionRef.current;
797
+ const p = { start, end: { rowIdx, colIdx } };
798
+ return cellRangeEquals(old, p) ? old : p;
799
+ });
800
+ } catch (exc) {
801
+ }
802
+ }, []);
803
+ const onMouseUp = useCallback((event) => {
804
+ if (!mouseSelectionRef.current) {
805
+ throw new Error(`useRangeSelection state is not initialized`);
806
+ }
807
+ mouseSelectionRef.current.unsubscribe();
808
+ mouseSelectionRef.current = void 0;
809
+ }, []);
810
+ const onCellMouseDown = useCallback(
811
+ (event) => {
812
+ if (cellSelectionMode !== "range") {
813
+ return;
814
+ }
815
+ const target = event.target;
816
+ try {
817
+ const [rowIdx, colIdx] = getCellPosition(target);
818
+ document.addEventListener("mouseup", onMouseUp);
819
+ document.addEventListener("mousemove", onMouseMove);
820
+ const pos = { rowIdx, colIdx };
821
+ mouseSelectionRef.current = {
822
+ start: pos,
823
+ unsubscribe: () => {
824
+ document.removeEventListener("mouseup", onMouseUp);
825
+ document.removeEventListener("mousemove", onMouseMove);
826
+ }
827
+ };
828
+ setSelectedCellRange({ start: pos, end: pos });
829
+ } catch (exc) {
830
+ }
831
+ },
832
+ [cellSelectionMode]
833
+ );
834
+ const onKeyboardRangeSelectionStart = useCallback((pos) => {
835
+ keyboardSelectionRef.current = {
836
+ start: pos
837
+ };
838
+ }, []);
839
+ const onKeyboardRangeSelectionEnd = useCallback(() => {
840
+ keyboardSelectionRef.current = void 0;
841
+ }, []);
842
+ const onCursorMove = useCallback((pos) => {
843
+ if (!keyboardSelectionRef.current) {
844
+ return;
845
+ }
846
+ setSelectedCellRange((old) => {
847
+ if (!keyboardSelectionRef.current) {
848
+ return old;
849
+ }
850
+ const { start } = keyboardSelectionRef.current;
851
+ const p = { start, end: pos };
852
+ return cellRangeEquals(old, p) ? old : p;
853
+ });
854
+ }, []);
855
+ const selectRange = useCallback((range) => {
856
+ if (cellSelectionMode !== "range") {
857
+ return;
858
+ }
859
+ setSelectedCellRange(range);
860
+ }, []);
861
+ return {
862
+ selectedCellRange,
863
+ onCellMouseDown,
864
+ onKeyboardRangeSelectionStart,
865
+ onKeyboardRangeSelectionEnd,
866
+ onCursorMove,
867
+ selectRange
868
+ };
869
+ }
870
+ function useFocusableContent() {
871
+ const ref = useRef(null);
872
+ const [isFocusableContent, setFocusableContent] = useState(false);
873
+ const onFocus = (event) => {
874
+ if (event.target === ref.current) {
875
+ const nestedInteractive = ref.current.querySelector(`[tabindex="0"]`);
876
+ if (nestedInteractive) {
877
+ nestedInteractive.focus();
878
+ setFocusableContent(true);
879
+ }
880
+ }
881
+ };
882
+ return { ref, isFocusableContent, onFocus };
883
+ }
884
+
885
+ export { cellPositionEquals, cellRangeEquals, last, useActiveOnWheel, useBodyVisibleAreaTop, useBodyVisibleColumnRange, useClientMidHeight, useClientMidWidth, useCols, useColumnGroups, useColumnMove, useColumnRange, useColumnRegistry, useColumnResize, useFlatten, useFocusableContent, useHeadVisibleColumnRange, useLeftScrolledOutWidth, useRangeSelection, useRowModels, useRowSelection, useScrollToCell, useSum, useSumRangeWidth, useSumWidth, useVisibleColumnGroupRange, useVisibleRowRange };
886
+ //# sourceMappingURL=gridHooks.js.map