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