@salt-ds/data-grid 0.0.0-snapshot-20230620094559

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 (381) hide show
  1. package/dist-cjs/BaseCell.css.js +6 -0
  2. package/dist-cjs/BaseCell.css.js.map +1 -0
  3. package/dist-cjs/BaseCell.js +116 -0
  4. package/dist-cjs/BaseCell.js.map +1 -0
  5. package/dist-cjs/CellEditor.js +29 -0
  6. package/dist-cjs/CellEditor.js.map +1 -0
  7. package/dist-cjs/CheckboxCell.css.js +6 -0
  8. package/dist-cjs/CheckboxCell.css.js.map +1 -0
  9. package/dist-cjs/ColumnDataContext.js +18 -0
  10. package/dist-cjs/ColumnDataContext.js.map +1 -0
  11. package/dist-cjs/ColumnDragContext.js +20 -0
  12. package/dist-cjs/ColumnDragContext.js.map +1 -0
  13. package/dist-cjs/ColumnGroup.js +32 -0
  14. package/dist-cjs/ColumnGroup.js.map +1 -0
  15. package/dist-cjs/ColumnSortContext.js +20 -0
  16. package/dist-cjs/ColumnSortContext.js.map +1 -0
  17. package/dist-cjs/CornerTag.css.js +6 -0
  18. package/dist-cjs/CornerTag.css.js.map +1 -0
  19. package/dist-cjs/CornerTag.js +23 -0
  20. package/dist-cjs/CornerTag.js.map +1 -0
  21. package/dist-cjs/CursorContext.js +20 -0
  22. package/dist-cjs/CursorContext.js.map +1 -0
  23. package/dist-cjs/DropdownCellEditor.css.js +6 -0
  24. package/dist-cjs/DropdownCellEditor.css.js.map +1 -0
  25. package/dist-cjs/DropdownCellEditor.js +82 -0
  26. package/dist-cjs/DropdownCellEditor.js.map +1 -0
  27. package/dist-cjs/EditorContext.js +20 -0
  28. package/dist-cjs/EditorContext.js.map +1 -0
  29. package/dist-cjs/Grid.css.js +6 -0
  30. package/dist-cjs/Grid.css.js.map +1 -0
  31. package/dist-cjs/Grid.js +1026 -0
  32. package/dist-cjs/Grid.js.map +1 -0
  33. package/dist-cjs/GridColumn.js +43 -0
  34. package/dist-cjs/GridColumn.js.map +1 -0
  35. package/dist-cjs/GridContext.js +20 -0
  36. package/dist-cjs/GridContext.js.map +1 -0
  37. package/dist-cjs/GroupHeaderCell.css.js +6 -0
  38. package/dist-cjs/GroupHeaderCell.css.js.map +1 -0
  39. package/dist-cjs/GroupHeaderCell.js +54 -0
  40. package/dist-cjs/GroupHeaderCell.js.map +1 -0
  41. package/dist-cjs/GroupHeaderCellValue.js +16 -0
  42. package/dist-cjs/GroupHeaderCellValue.js.map +1 -0
  43. package/dist-cjs/HeaderCell.css.js +6 -0
  44. package/dist-cjs/HeaderCell.css.js.map +1 -0
  45. package/dist-cjs/HeaderCell.js +187 -0
  46. package/dist-cjs/HeaderCell.js.map +1 -0
  47. package/dist-cjs/HeaderCellValue.js +19 -0
  48. package/dist-cjs/HeaderCellValue.js.map +1 -0
  49. package/dist-cjs/LayoutContext.js +12 -0
  50. package/dist-cjs/LayoutContext.js.map +1 -0
  51. package/dist-cjs/NumberRange.js +63 -0
  52. package/dist-cjs/NumberRange.js.map +1 -0
  53. package/dist-cjs/NumericColumn.css.js +6 -0
  54. package/dist-cjs/NumericColumn.css.js.map +1 -0
  55. package/dist-cjs/NumericColumn.js +127 -0
  56. package/dist-cjs/NumericColumn.js.map +1 -0
  57. package/dist-cjs/RowSelectionCheckboxCellValue.js +45 -0
  58. package/dist-cjs/RowSelectionCheckboxCellValue.js.map +1 -0
  59. package/dist-cjs/RowSelectionCheckboxColumn.js +39 -0
  60. package/dist-cjs/RowSelectionCheckboxColumn.js.map +1 -0
  61. package/dist-cjs/RowSelectionCheckboxHeaderCellValue.js +56 -0
  62. package/dist-cjs/RowSelectionCheckboxHeaderCellValue.js.map +1 -0
  63. package/dist-cjs/RowSelectionRadioCellValue.js +33 -0
  64. package/dist-cjs/RowSelectionRadioCellValue.js.map +1 -0
  65. package/dist-cjs/RowSelectionRadioColumn.js +34 -0
  66. package/dist-cjs/RowSelectionRadioColumn.js.map +1 -0
  67. package/dist-cjs/RowSelectionRadioHeaderCell.js +30 -0
  68. package/dist-cjs/RowSelectionRadioHeaderCell.js.map +1 -0
  69. package/dist-cjs/RowValidationStatus.js +13 -0
  70. package/dist-cjs/RowValidationStatus.js.map +1 -0
  71. package/dist-cjs/SelectionContext.js +20 -0
  72. package/dist-cjs/SelectionContext.js.map +1 -0
  73. package/dist-cjs/SizingContext.js +20 -0
  74. package/dist-cjs/SizingContext.js.map +1 -0
  75. package/dist-cjs/TextCellEditor.css.js +6 -0
  76. package/dist-cjs/TextCellEditor.css.js.map +1 -0
  77. package/dist-cjs/TextCellEditor.js +104 -0
  78. package/dist-cjs/TextCellEditor.js.map +1 -0
  79. package/dist-cjs/index.js +60 -0
  80. package/dist-cjs/index.js.map +1 -0
  81. package/dist-cjs/internal/Cell.css.js +6 -0
  82. package/dist-cjs/internal/Cell.css.js.map +1 -0
  83. package/dist-cjs/internal/Cell.js +63 -0
  84. package/dist-cjs/internal/Cell.js.map +1 -0
  85. package/dist-cjs/internal/CellMeasure.css.js +6 -0
  86. package/dist-cjs/internal/CellMeasure.css.js.map +1 -0
  87. package/dist-cjs/internal/CellMeasure.js +49 -0
  88. package/dist-cjs/internal/CellMeasure.js.map +1 -0
  89. package/dist-cjs/internal/CellStatusIcons.js +46 -0
  90. package/dist-cjs/internal/CellStatusIcons.js.map +1 -0
  91. package/dist-cjs/internal/ColumnDropTarget.css.js +6 -0
  92. package/dist-cjs/internal/ColumnDropTarget.css.js.map +1 -0
  93. package/dist-cjs/internal/ColumnDropTarget.js +36 -0
  94. package/dist-cjs/internal/ColumnDropTarget.js.map +1 -0
  95. package/dist-cjs/internal/ColumnGhost.css.js +6 -0
  96. package/dist-cjs/internal/ColumnGhost.css.js.map +1 -0
  97. package/dist-cjs/internal/ColumnGhost.js +59 -0
  98. package/dist-cjs/internal/ColumnGhost.js.map +1 -0
  99. package/dist-cjs/internal/Cursor.css.js +6 -0
  100. package/dist-cjs/internal/Cursor.css.js.map +1 -0
  101. package/dist-cjs/internal/Cursor.js +25 -0
  102. package/dist-cjs/internal/Cursor.js.map +1 -0
  103. package/dist-cjs/internal/DefaultCellValue.css.js +6 -0
  104. package/dist-cjs/internal/DefaultCellValue.css.js.map +1 -0
  105. package/dist-cjs/internal/DefaultCellValue.js +30 -0
  106. package/dist-cjs/internal/DefaultCellValue.js.map +1 -0
  107. package/dist-cjs/internal/FakeCell.css.js +6 -0
  108. package/dist-cjs/internal/FakeCell.css.js.map +1 -0
  109. package/dist-cjs/internal/FakeCell.js +27 -0
  110. package/dist-cjs/internal/FakeCell.js.map +1 -0
  111. package/dist-cjs/internal/FakeGroupCell.js +12 -0
  112. package/dist-cjs/internal/FakeGroupCell.js.map +1 -0
  113. package/dist-cjs/internal/FakeHeaderCell.js +14 -0
  114. package/dist-cjs/internal/FakeHeaderCell.js.map +1 -0
  115. package/dist-cjs/internal/GroupHeaderRow.css.js +6 -0
  116. package/dist-cjs/internal/GroupHeaderRow.css.js.map +1 -0
  117. package/dist-cjs/internal/GroupHeaderRow.js +46 -0
  118. package/dist-cjs/internal/GroupHeaderRow.js.map +1 -0
  119. package/dist-cjs/internal/HeaderRow.css.js +6 -0
  120. package/dist-cjs/internal/HeaderRow.css.js.map +1 -0
  121. package/dist-cjs/internal/HeaderRow.js +50 -0
  122. package/dist-cjs/internal/HeaderRow.js.map +1 -0
  123. package/dist-cjs/internal/LeftPart.css.js +6 -0
  124. package/dist-cjs/internal/LeftPart.css.js.map +1 -0
  125. package/dist-cjs/internal/LeftPart.js +68 -0
  126. package/dist-cjs/internal/LeftPart.js.map +1 -0
  127. package/dist-cjs/internal/MiddlePart.css.js +6 -0
  128. package/dist-cjs/internal/MiddlePart.css.js.map +1 -0
  129. package/dist-cjs/internal/MiddlePart.js +64 -0
  130. package/dist-cjs/internal/MiddlePart.js.map +1 -0
  131. package/dist-cjs/internal/RightPart.css.js +6 -0
  132. package/dist-cjs/internal/RightPart.css.js.map +1 -0
  133. package/dist-cjs/internal/RightPart.js +68 -0
  134. package/dist-cjs/internal/RightPart.js.map +1 -0
  135. package/dist-cjs/internal/Scrollable.css.js +6 -0
  136. package/dist-cjs/internal/Scrollable.css.js.map +1 -0
  137. package/dist-cjs/internal/Scrollable.js +103 -0
  138. package/dist-cjs/internal/Scrollable.js.map +1 -0
  139. package/dist-cjs/internal/TableBody.js +77 -0
  140. package/dist-cjs/internal/TableBody.js.map +1 -0
  141. package/dist-cjs/internal/TableColGroup.js +37 -0
  142. package/dist-cjs/internal/TableColGroup.js.map +1 -0
  143. package/dist-cjs/internal/TableRow.css.js +6 -0
  144. package/dist-cjs/internal/TableRow.css.js.map +1 -0
  145. package/dist-cjs/internal/TableRow.js +125 -0
  146. package/dist-cjs/internal/TableRow.js.map +1 -0
  147. package/dist-cjs/internal/TopLeftPart.css.js +6 -0
  148. package/dist-cjs/internal/TopLeftPart.css.js.map +1 -0
  149. package/dist-cjs/internal/TopLeftPart.js +58 -0
  150. package/dist-cjs/internal/TopLeftPart.js.map +1 -0
  151. package/dist-cjs/internal/TopPart.css.js +6 -0
  152. package/dist-cjs/internal/TopPart.css.js.map +1 -0
  153. package/dist-cjs/internal/TopPart.js +61 -0
  154. package/dist-cjs/internal/TopPart.js.map +1 -0
  155. package/dist-cjs/internal/TopRightPart.css.js +6 -0
  156. package/dist-cjs/internal/TopRightPart.css.js.map +1 -0
  157. package/dist-cjs/internal/TopRightPart.js +59 -0
  158. package/dist-cjs/internal/TopRightPart.js.map +1 -0
  159. package/dist-cjs/internal/gridHooks.js +916 -0
  160. package/dist-cjs/internal/gridHooks.js.map +1 -0
  161. package/dist-cjs/internal/utils.js +71 -0
  162. package/dist-cjs/internal/utils.js.map +1 -0
  163. package/dist-es/BaseCell.css.js +4 -0
  164. package/dist-es/BaseCell.css.js.map +1 -0
  165. package/dist-es/BaseCell.js +111 -0
  166. package/dist-es/BaseCell.js.map +1 -0
  167. package/dist-es/CellEditor.js +25 -0
  168. package/dist-es/CellEditor.js.map +1 -0
  169. package/dist-es/CheckboxCell.css.js +4 -0
  170. package/dist-es/CheckboxCell.css.js.map +1 -0
  171. package/dist-es/ColumnDataContext.js +13 -0
  172. package/dist-es/ColumnDataContext.js.map +1 -0
  173. package/dist-es/ColumnDragContext.js +15 -0
  174. package/dist-es/ColumnDragContext.js.map +1 -0
  175. package/dist-es/ColumnGroup.js +28 -0
  176. package/dist-es/ColumnGroup.js.map +1 -0
  177. package/dist-es/ColumnSortContext.js +15 -0
  178. package/dist-es/ColumnSortContext.js.map +1 -0
  179. package/dist-es/CornerTag.css.js +4 -0
  180. package/dist-es/CornerTag.css.js.map +1 -0
  181. package/dist-es/CornerTag.js +19 -0
  182. package/dist-es/CornerTag.js.map +1 -0
  183. package/dist-es/CursorContext.js +15 -0
  184. package/dist-es/CursorContext.js.map +1 -0
  185. package/dist-es/DropdownCellEditor.css.js +4 -0
  186. package/dist-es/DropdownCellEditor.css.js.map +1 -0
  187. package/dist-es/DropdownCellEditor.js +78 -0
  188. package/dist-es/DropdownCellEditor.js.map +1 -0
  189. package/dist-es/EditorContext.js +15 -0
  190. package/dist-es/EditorContext.js.map +1 -0
  191. package/dist-es/Grid.css.js +4 -0
  192. package/dist-es/Grid.css.js.map +1 -0
  193. package/dist-es/Grid.js +1021 -0
  194. package/dist-es/Grid.js.map +1 -0
  195. package/dist-es/GridColumn.js +39 -0
  196. package/dist-es/GridColumn.js.map +1 -0
  197. package/dist-es/GridContext.js +15 -0
  198. package/dist-es/GridContext.js.map +1 -0
  199. package/dist-es/GroupHeaderCell.css.js +4 -0
  200. package/dist-es/GroupHeaderCell.css.js.map +1 -0
  201. package/dist-es/GroupHeaderCell.js +50 -0
  202. package/dist-es/GroupHeaderCell.js.map +1 -0
  203. package/dist-es/GroupHeaderCellValue.js +12 -0
  204. package/dist-es/GroupHeaderCellValue.js.map +1 -0
  205. package/dist-es/HeaderCell.css.js +4 -0
  206. package/dist-es/HeaderCell.css.js.map +1 -0
  207. package/dist-es/HeaderCell.js +181 -0
  208. package/dist-es/HeaderCell.js.map +1 -0
  209. package/dist-es/HeaderCellValue.js +15 -0
  210. package/dist-es/HeaderCellValue.js.map +1 -0
  211. package/dist-es/LayoutContext.js +8 -0
  212. package/dist-es/LayoutContext.js.map +1 -0
  213. package/dist-es/NumberRange.js +58 -0
  214. package/dist-es/NumberRange.js.map +1 -0
  215. package/dist-es/NumericColumn.css.js +4 -0
  216. package/dist-es/NumericColumn.css.js.map +1 -0
  217. package/dist-es/NumericColumn.js +121 -0
  218. package/dist-es/NumericColumn.js.map +1 -0
  219. package/dist-es/RowSelectionCheckboxCellValue.js +41 -0
  220. package/dist-es/RowSelectionCheckboxCellValue.js.map +1 -0
  221. package/dist-es/RowSelectionCheckboxColumn.js +35 -0
  222. package/dist-es/RowSelectionCheckboxColumn.js.map +1 -0
  223. package/dist-es/RowSelectionCheckboxHeaderCellValue.js +52 -0
  224. package/dist-es/RowSelectionCheckboxHeaderCellValue.js.map +1 -0
  225. package/dist-es/RowSelectionRadioCellValue.js +29 -0
  226. package/dist-es/RowSelectionRadioCellValue.js.map +1 -0
  227. package/dist-es/RowSelectionRadioColumn.js +30 -0
  228. package/dist-es/RowSelectionRadioColumn.js.map +1 -0
  229. package/dist-es/RowSelectionRadioHeaderCell.js +26 -0
  230. package/dist-es/RowSelectionRadioHeaderCell.js.map +1 -0
  231. package/dist-es/RowValidationStatus.js +9 -0
  232. package/dist-es/RowValidationStatus.js.map +1 -0
  233. package/dist-es/SelectionContext.js +15 -0
  234. package/dist-es/SelectionContext.js.map +1 -0
  235. package/dist-es/SizingContext.js +15 -0
  236. package/dist-es/SizingContext.js.map +1 -0
  237. package/dist-es/TextCellEditor.css.js +4 -0
  238. package/dist-es/TextCellEditor.css.js.map +1 -0
  239. package/dist-es/TextCellEditor.js +100 -0
  240. package/dist-es/TextCellEditor.js.map +1 -0
  241. package/dist-es/index.js +22 -0
  242. package/dist-es/index.js.map +1 -0
  243. package/dist-es/internal/Cell.css.js +4 -0
  244. package/dist-es/internal/Cell.css.js.map +1 -0
  245. package/dist-es/internal/Cell.js +59 -0
  246. package/dist-es/internal/Cell.js.map +1 -0
  247. package/dist-es/internal/CellMeasure.css.js +4 -0
  248. package/dist-es/internal/CellMeasure.css.js.map +1 -0
  249. package/dist-es/internal/CellMeasure.js +45 -0
  250. package/dist-es/internal/CellMeasure.js.map +1 -0
  251. package/dist-es/internal/CellStatusIcons.js +40 -0
  252. package/dist-es/internal/CellStatusIcons.js.map +1 -0
  253. package/dist-es/internal/ColumnDropTarget.css.js +4 -0
  254. package/dist-es/internal/ColumnDropTarget.css.js.map +1 -0
  255. package/dist-es/internal/ColumnDropTarget.js +32 -0
  256. package/dist-es/internal/ColumnDropTarget.js.map +1 -0
  257. package/dist-es/internal/ColumnGhost.css.js +4 -0
  258. package/dist-es/internal/ColumnGhost.css.js.map +1 -0
  259. package/dist-es/internal/ColumnGhost.js +55 -0
  260. package/dist-es/internal/ColumnGhost.js.map +1 -0
  261. package/dist-es/internal/Cursor.css.js +4 -0
  262. package/dist-es/internal/Cursor.css.js.map +1 -0
  263. package/dist-es/internal/Cursor.js +21 -0
  264. package/dist-es/internal/Cursor.js.map +1 -0
  265. package/dist-es/internal/DefaultCellValue.css.js +4 -0
  266. package/dist-es/internal/DefaultCellValue.css.js.map +1 -0
  267. package/dist-es/internal/DefaultCellValue.js +26 -0
  268. package/dist-es/internal/DefaultCellValue.js.map +1 -0
  269. package/dist-es/internal/FakeCell.css.js +4 -0
  270. package/dist-es/internal/FakeCell.css.js.map +1 -0
  271. package/dist-es/internal/FakeCell.js +23 -0
  272. package/dist-es/internal/FakeCell.js.map +1 -0
  273. package/dist-es/internal/FakeGroupCell.js +8 -0
  274. package/dist-es/internal/FakeGroupCell.js.map +1 -0
  275. package/dist-es/internal/FakeHeaderCell.js +10 -0
  276. package/dist-es/internal/FakeHeaderCell.js.map +1 -0
  277. package/dist-es/internal/GroupHeaderRow.css.js +4 -0
  278. package/dist-es/internal/GroupHeaderRow.css.js.map +1 -0
  279. package/dist-es/internal/GroupHeaderRow.js +42 -0
  280. package/dist-es/internal/GroupHeaderRow.js.map +1 -0
  281. package/dist-es/internal/HeaderRow.css.js +4 -0
  282. package/dist-es/internal/HeaderRow.css.js.map +1 -0
  283. package/dist-es/internal/HeaderRow.js +46 -0
  284. package/dist-es/internal/HeaderRow.js.map +1 -0
  285. package/dist-es/internal/LeftPart.css.js +4 -0
  286. package/dist-es/internal/LeftPart.css.js.map +1 -0
  287. package/dist-es/internal/LeftPart.js +64 -0
  288. package/dist-es/internal/LeftPart.js.map +1 -0
  289. package/dist-es/internal/MiddlePart.css.js +4 -0
  290. package/dist-es/internal/MiddlePart.css.js.map +1 -0
  291. package/dist-es/internal/MiddlePart.js +60 -0
  292. package/dist-es/internal/MiddlePart.js.map +1 -0
  293. package/dist-es/internal/RightPart.css.js +4 -0
  294. package/dist-es/internal/RightPart.css.js.map +1 -0
  295. package/dist-es/internal/RightPart.js +64 -0
  296. package/dist-es/internal/RightPart.js.map +1 -0
  297. package/dist-es/internal/Scrollable.css.js +4 -0
  298. package/dist-es/internal/Scrollable.css.js.map +1 -0
  299. package/dist-es/internal/Scrollable.js +99 -0
  300. package/dist-es/internal/Scrollable.js.map +1 -0
  301. package/dist-es/internal/TableBody.js +73 -0
  302. package/dist-es/internal/TableBody.js.map +1 -0
  303. package/dist-es/internal/TableColGroup.js +32 -0
  304. package/dist-es/internal/TableColGroup.js.map +1 -0
  305. package/dist-es/internal/TableRow.css.js +4 -0
  306. package/dist-es/internal/TableRow.css.js.map +1 -0
  307. package/dist-es/internal/TableRow.js +121 -0
  308. package/dist-es/internal/TableRow.js.map +1 -0
  309. package/dist-es/internal/TopLeftPart.css.js +4 -0
  310. package/dist-es/internal/TopLeftPart.css.js.map +1 -0
  311. package/dist-es/internal/TopLeftPart.js +54 -0
  312. package/dist-es/internal/TopLeftPart.js.map +1 -0
  313. package/dist-es/internal/TopPart.css.js +4 -0
  314. package/dist-es/internal/TopPart.css.js.map +1 -0
  315. package/dist-es/internal/TopPart.js +57 -0
  316. package/dist-es/internal/TopPart.js.map +1 -0
  317. package/dist-es/internal/TopRightPart.css.js +4 -0
  318. package/dist-es/internal/TopRightPart.css.js.map +1 -0
  319. package/dist-es/internal/TopRightPart.js +55 -0
  320. package/dist-es/internal/TopRightPart.js.map +1 -0
  321. package/dist-es/internal/gridHooks.js +886 -0
  322. package/dist-es/internal/gridHooks.js.map +1 -0
  323. package/dist-es/internal/utils.js +61 -0
  324. package/dist-es/internal/utils.js.map +1 -0
  325. package/dist-types/BaseCell.d.ts +5 -0
  326. package/dist-types/CellEditor.d.ts +10 -0
  327. package/dist-types/ColumnDataContext.d.ts +7 -0
  328. package/dist-types/ColumnDragContext.d.ts +7 -0
  329. package/dist-types/ColumnGroup.d.ts +18 -0
  330. package/dist-types/ColumnSortContext.d.ts +12 -0
  331. package/dist-types/CornerTag.d.ts +5 -0
  332. package/dist-types/CursorContext.d.ts +12 -0
  333. package/dist-types/DropdownCellEditor.d.ts +8 -0
  334. package/dist-types/EditorContext.d.ts +10 -0
  335. package/dist-types/Grid.d.ts +104 -0
  336. package/dist-types/GridColumn.d.ts +165 -0
  337. package/dist-types/GridContext.d.ts +16 -0
  338. package/dist-types/GroupHeaderCell.d.ts +7 -0
  339. package/dist-types/GroupHeaderCellValue.d.ts +3 -0
  340. package/dist-types/HeaderCell.d.ts +9 -0
  341. package/dist-types/HeaderCellValue.d.ts +3 -0
  342. package/dist-types/LayoutContext.d.ts +9 -0
  343. package/dist-types/NumberRange.d.ts +15 -0
  344. package/dist-types/NumericColumn.d.ts +14 -0
  345. package/dist-types/RowSelectionCheckboxCellValue.d.ts +3 -0
  346. package/dist-types/RowSelectionCheckboxColumn.d.ts +4 -0
  347. package/dist-types/RowSelectionCheckboxHeaderCellValue.d.ts +3 -0
  348. package/dist-types/RowSelectionRadioCellValue.d.ts +3 -0
  349. package/dist-types/RowSelectionRadioColumn.d.ts +4 -0
  350. package/dist-types/RowSelectionRadioHeaderCell.d.ts +3 -0
  351. package/dist-types/RowValidationStatus.d.ts +7 -0
  352. package/dist-types/SelectionContext.d.ts +13 -0
  353. package/dist-types/SizingContext.d.ts +8 -0
  354. package/dist-types/TextCellEditor.d.ts +7 -0
  355. package/dist-types/index.d.ts +21 -0
  356. package/dist-types/internal/Cell.d.ts +8 -0
  357. package/dist-types/internal/CellMeasure.d.ts +5 -0
  358. package/dist-types/internal/CellStatusIcons.d.ts +4 -0
  359. package/dist-types/internal/ColumnDropTarget.d.ts +5 -0
  360. package/dist-types/internal/ColumnGhost.d.ts +10 -0
  361. package/dist-types/internal/Cursor.d.ts +4 -0
  362. package/dist-types/internal/DefaultCellValue.d.ts +3 -0
  363. package/dist-types/internal/FakeCell.d.ts +4 -0
  364. package/dist-types/internal/FakeGroupCell.d.ts +2 -0
  365. package/dist-types/internal/FakeHeaderCell.d.ts +2 -0
  366. package/dist-types/internal/GroupHeaderRow.d.ts +7 -0
  367. package/dist-types/internal/HeaderRow.d.ts +7 -0
  368. package/dist-types/internal/LeftPart.d.ts +15 -0
  369. package/dist-types/internal/MiddlePart.d.ts +15 -0
  370. package/dist-types/internal/RightPart.d.ts +15 -0
  371. package/dist-types/internal/Scrollable.d.ts +20 -0
  372. package/dist-types/internal/TableBody.d.ts +13 -0
  373. package/dist-types/internal/TableColGroup.d.ts +11 -0
  374. package/dist-types/internal/TableRow.d.ts +19 -0
  375. package/dist-types/internal/TopLeftPart.d.ts +10 -0
  376. package/dist-types/internal/TopPart.d.ts +11 -0
  377. package/dist-types/internal/TopRightPart.d.ts +10 -0
  378. package/dist-types/internal/gridHooks.d.ts +91 -0
  379. package/dist-types/internal/index.d.ts +21 -0
  380. package/dist-types/internal/utils.d.ts +13 -0
  381. package/package.json +42 -0
@@ -0,0 +1,12 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var react = require('react');
6
+
7
+ const LayoutContext = react.createContext(
8
+ void 0
9
+ );
10
+
11
+ exports.LayoutContext = LayoutContext;
12
+ //# sourceMappingURL=LayoutContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LayoutContext.js","sources":["../src/LayoutContext.ts"],"sourcesContent":["import { createContext, useContext } from \"react\";\n\nexport interface LayoutContext {\n totalWidth: number;\n totalHeight: number;\n clientWidth: number;\n clientHeight: number;\n}\n\nexport const LayoutContext = createContext<LayoutContext | undefined>(\n undefined\n);\n\nexport const useLayoutContext = () => {\n const c = useContext(LayoutContext);\n if (!c) {\n throw new Error(`useLayoutContext invoked outside of a Grid`);\n }\n return c;\n};\n"],"names":["createContext"],"mappings":";;;;;;AASO,MAAM,aAAgB,GAAAA,mBAAA;AAAA,EAC3B,KAAA,CAAA;AACF;;;;"}
@@ -0,0 +1,63 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ function range(...args) {
6
+ let start = 0;
7
+ let end = 0;
8
+ let step = 1;
9
+ if (args.length < 2) {
10
+ end = args[0];
11
+ } else {
12
+ start = args[0];
13
+ end = args[1];
14
+ if (args.length > 2) {
15
+ step = args[2];
16
+ }
17
+ }
18
+ return [...Array(end - start).keys()].map((i) => start + i * step);
19
+ }
20
+ const _NumberRange = class {
21
+ constructor(start, end) {
22
+ if (end < start) {
23
+ throw new Error(`Invalid start and end: [${start}, ${end}]`);
24
+ }
25
+ this.start = start;
26
+ this.end = end;
27
+ }
28
+ get length() {
29
+ return this.end - this.start;
30
+ }
31
+ map(fn) {
32
+ return range(this.start, this.end).map(fn);
33
+ }
34
+ forEach(fn) {
35
+ range(this.start, this.end).forEach(fn);
36
+ }
37
+ *[Symbol.iterator]() {
38
+ for (let i = this.start; i < this.end; ++i) {
39
+ yield i;
40
+ }
41
+ }
42
+ static equals(a, b) {
43
+ if (!a) {
44
+ return !b;
45
+ }
46
+ return !b ? false : a.start === b.start && a.end === b.end;
47
+ }
48
+ update(start, end) {
49
+ return this.end !== end || this.start !== start ? new _NumberRange(start, end) : this;
50
+ }
51
+ toString() {
52
+ return `[${this.start}, ${this.end}]`;
53
+ }
54
+ contains(n) {
55
+ return this.start <= n && n < this.end;
56
+ }
57
+ };
58
+ let NumberRange = _NumberRange;
59
+ NumberRange.empty = new _NumberRange(0, 0);
60
+
61
+ exports.NumberRange = NumberRange;
62
+ exports.range = range;
63
+ //# sourceMappingURL=NumberRange.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NumberRange.js","sources":["../src/NumberRange.ts"],"sourcesContent":["export function range(\n ...args: [number] | [number, number] | [number, number, number]\n): number[] {\n let start = 0;\n let end = 0;\n let step = 1;\n if (args.length < 2) {\n end = args[0];\n } else {\n start = args[0];\n end = args[1]!;\n if (args.length > 2) {\n step = args[2]!;\n }\n }\n return [...Array(end - start).keys()].map((i) => start + i * step);\n}\n\nexport class NumberRange {\n public readonly start: number;\n public readonly end: number;\n\n public constructor(start: number, end: number) {\n if (end < start) {\n throw new Error(`Invalid start and end: [${start}, ${end}]`);\n }\n this.start = start;\n this.end = end;\n }\n\n public get length(): number {\n return this.end - this.start;\n }\n\n public map<T>(fn: (i: number) => T): T[] {\n return range(this.start, this.end).map(fn);\n }\n\n public forEach(fn: (i: number) => void): void {\n range(this.start, this.end).forEach(fn);\n }\n\n public *[Symbol.iterator]() {\n for (let i = this.start; i < this.end; ++i) {\n yield i;\n }\n }\n\n public static equals(a: NumberRange | undefined, b: NumberRange | undefined) {\n if (!a) {\n return !b;\n }\n return !b ? false : a.start === b.start && a.end === b.end;\n }\n\n public update(start: number, end: number) {\n return this.end !== end || this.start !== start\n ? new NumberRange(start, end)\n : this;\n }\n\n public static empty: NumberRange = new NumberRange(0, 0);\n\n public toString() {\n return `[${this.start}, ${this.end}]`;\n }\n\n public contains(n: number) {\n return this.start <= n && n < this.end;\n }\n}\n"],"names":[],"mappings":";;;;AAAO,SAAS,SACX,IACO,EAAA;AACV,EAAA,IAAI,KAAQ,GAAA,CAAA,CAAA;AACZ,EAAA,IAAI,GAAM,GAAA,CAAA,CAAA;AACV,EAAA,IAAI,IAAO,GAAA,CAAA,CAAA;AACX,EAAI,IAAA,IAAA,CAAK,SAAS,CAAG,EAAA;AACnB,IAAA,GAAA,GAAM,IAAK,CAAA,CAAA,CAAA,CAAA;AAAA,GACN,MAAA;AACL,IAAA,KAAA,GAAQ,IAAK,CAAA,CAAA,CAAA,CAAA;AACb,IAAA,GAAA,GAAM,IAAK,CAAA,CAAA,CAAA,CAAA;AACX,IAAI,IAAA,IAAA,CAAK,SAAS,CAAG,EAAA;AACnB,MAAA,IAAA,GAAO,IAAK,CAAA,CAAA,CAAA,CAAA;AAAA,KACd;AAAA,GACF;AACA,EAAA,OAAO,CAAC,GAAG,KAAM,CAAA,GAAA,GAAM,KAAK,CAAE,CAAA,IAAA,EAAM,CAAA,CAAE,GAAI,CAAA,CAAC,CAAM,KAAA,KAAA,GAAQ,IAAI,IAAI,CAAA,CAAA;AACnE,CAAA;AAEO,MAAM,eAAN,MAAkB;AAAA,EAIhB,WAAA,CAAY,OAAe,GAAa,EAAA;AAC7C,IAAA,IAAI,MAAM,KAAO,EAAA;AACf,MAAA,MAAM,IAAI,KAAA,CAAM,CAA2B,wBAAA,EAAA,KAAA,CAAA,EAAA,EAAU,GAAM,CAAA,CAAA,CAAA,CAAA,CAAA;AAAA,KAC7D;AACA,IAAA,IAAA,CAAK,KAAQ,GAAA,KAAA,CAAA;AACb,IAAA,IAAA,CAAK,GAAM,GAAA,GAAA,CAAA;AAAA,GACb;AAAA,EAEA,IAAW,MAAiB,GAAA;AAC1B,IAAO,OAAA,IAAA,CAAK,MAAM,IAAK,CAAA,KAAA,CAAA;AAAA,GACzB;AAAA,EAEO,IAAO,EAA2B,EAAA;AACvC,IAAA,OAAO,MAAM,IAAK,CAAA,KAAA,EAAO,KAAK,GAAG,CAAA,CAAE,IAAI,EAAE,CAAA,CAAA;AAAA,GAC3C;AAAA,EAEO,QAAQ,EAA+B,EAAA;AAC5C,IAAA,KAAA,CAAM,KAAK,KAAO,EAAA,IAAA,CAAK,GAAG,CAAA,CAAE,QAAQ,EAAE,CAAA,CAAA;AAAA,GACxC;AAAA,EAEA,EAAS,OAAO,QAAY,CAAA,GAAA;AAC1B,IAAA,KAAA,IAAS,IAAI,IAAK,CAAA,KAAA,EAAO,IAAI,IAAK,CAAA,GAAA,EAAK,EAAE,CAAG,EAAA;AAC1C,MAAM,MAAA,CAAA,CAAA;AAAA,KACR;AAAA,GACF;AAAA,EAEA,OAAc,MAAO,CAAA,CAAA,EAA4B,CAA4B,EAAA;AAC3E,IAAA,IAAI,CAAC,CAAG,EAAA;AACN,MAAA,OAAO,CAAC,CAAA,CAAA;AAAA,KACV;AACA,IAAO,OAAA,CAAC,IAAI,KAAQ,GAAA,CAAA,CAAE,UAAU,CAAE,CAAA,KAAA,IAAS,CAAE,CAAA,GAAA,KAAQ,CAAE,CAAA,GAAA,CAAA;AAAA,GACzD;AAAA,EAEO,MAAA,CAAO,OAAe,GAAa,EAAA;AACxC,IAAO,OAAA,IAAA,CAAK,GAAQ,KAAA,GAAA,IAAO,IAAK,CAAA,KAAA,KAAU,QACtC,IAAI,YAAA,CAAY,KAAO,EAAA,GAAG,CAC1B,GAAA,IAAA,CAAA;AAAA,GACN;AAAA,EAIO,QAAW,GAAA;AAChB,IAAO,OAAA,CAAA,CAAA,EAAI,IAAK,CAAA,KAAA,CAAA,EAAA,EAAU,IAAK,CAAA,GAAA,CAAA,CAAA,CAAA,CAAA;AAAA,GACjC;AAAA,EAEO,SAAS,CAAW,EAAA;AACzB,IAAA,OAAO,IAAK,CAAA,KAAA,IAAS,CAAK,IAAA,CAAA,GAAI,IAAK,CAAA,GAAA,CAAA;AAAA,GACrC;AACF,CAAA,CAAA;AApDO,IAAM,WAAN,GAAA,aAAA;AAAM,WAAA,CA2CG,KAAqB,GAAA,IAAI,YAAY,CAAA,CAAA,EAAG,CAAC,CAAA;;;;;"}
@@ -0,0 +1,6 @@
1
+ 'use strict';
2
+
3
+ var css_248z = ".saltGridNumericCellValue {\n overflow: hidden;\n text-overflow: ellipsis;\n padding: var(--grid-cell-padding);\n text-align: right;\n}\n\n.saltGridNumericCellEditor {\n}\n\n.saltGridNumericCellEditor-inputContainer {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n background: var(--grid-background);\n box-sizing: border-box;\n border-style: dotted;\n border-width: 2px;\n border-color: var(--grid-cursor-borderColor);\n padding: 0;\n}\n\n.saltGridNumericCellEditor input {\n position: absolute;\n top: 0;\n left: 0;\n bottom: 0;\n right: 0;\n outline: none;\n border: none;\n padding: 0 calc(var(--grid-padding) - 2px);\n font-size: var(--grid-fontSize);\n font-family: inherit;\n background: var(--grid-editableCell-background-active);\n color: var(--grid-editableCell-color-active);\n}\n";
4
+
5
+ module.exports = css_248z;
6
+ //# sourceMappingURL=NumericColumn.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NumericColumn.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -0,0 +1,127 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var react = require('react');
7
+ var window = require('@salt-ds/window');
8
+ var styles = require('@salt-ds/styles');
9
+ var GridColumn = require('./GridColumn.js');
10
+ var EditorContext = require('./EditorContext.js');
11
+ var CornerTag = require('./CornerTag.js');
12
+ var Cell = require('./internal/Cell.js');
13
+ require('./internal/CellMeasure.js');
14
+ require('./internal/Cursor.js');
15
+ require('./internal/GroupHeaderRow.js');
16
+ require('./internal/HeaderRow.js');
17
+ require('./internal/LeftPart.js');
18
+ require('./internal/MiddlePart.js');
19
+ require('./internal/RightPart.js');
20
+ require('./internal/Scrollable.js');
21
+ require('./internal/TableRow.js');
22
+ require('./SelectionContext.js');
23
+ require('./CursorContext.js');
24
+ require('./NumberRange.js');
25
+ require('@salt-ds/core');
26
+ require('./internal/TopLeftPart.js');
27
+ require('./internal/TopPart.js');
28
+ require('./internal/TopRightPart.js');
29
+ require('./internal/DefaultCellValue.js');
30
+ var NumericColumn$1 = require('./NumericColumn.css.js');
31
+
32
+ function isNumber(value) {
33
+ return typeof value === "number" && Number.isFinite(value);
34
+ }
35
+ function NumericCellValue(props) {
36
+ const { column, value } = props;
37
+ const targetWindow = window.useWindow();
38
+ styles.useComponentCssInjection({
39
+ testId: "salt-numeric-column",
40
+ css: NumericColumn$1,
41
+ window: targetWindow
42
+ });
43
+ const columnProps = column.info.props;
44
+ const { precision } = columnProps;
45
+ const text = isNumber(value) ? value.toFixed(precision) : "";
46
+ return /* @__PURE__ */ jsxRuntime.jsx("div", {
47
+ className: "saltGridNumericCellValue",
48
+ children: text
49
+ });
50
+ }
51
+ function NumericCellEditor(props) {
52
+ const { column, row } = props;
53
+ const inputRef = react.useRef(null);
54
+ const { endEditMode, cancelEditMode, initialText } = EditorContext.useEditorContext();
55
+ const [editorText, setEditorText] = react.useState(
56
+ initialText != null ? initialText : column.info.props.getValue(row.data)
57
+ );
58
+ const initialSelectionRef = react.useRef(!!initialText);
59
+ const onChange = (e) => {
60
+ setEditorText(e.target.value);
61
+ };
62
+ const onKeyDown = (event) => {
63
+ if (event.key === "Enter") {
64
+ endEditMode(editorText);
65
+ return;
66
+ }
67
+ if (event.key === "Escape") {
68
+ cancelEditMode();
69
+ return;
70
+ }
71
+ if (event.key === "Tab") {
72
+ endEditMode(editorText);
73
+ event.preventDefault();
74
+ return;
75
+ }
76
+ event.stopPropagation();
77
+ };
78
+ react.useEffect(() => {
79
+ if (inputRef.current && !initialSelectionRef.current) {
80
+ inputRef.current.select();
81
+ initialSelectionRef.current = true;
82
+ }
83
+ }, [inputRef.current]);
84
+ react.useEffect(() => {
85
+ const input = inputRef.current;
86
+ const focusOut = (event) => {
87
+ if (!(input == null ? void 0 : input.contains(event.target))) {
88
+ endEditMode(editorText);
89
+ }
90
+ };
91
+ document == null ? void 0 : document.addEventListener("mousedown", focusOut, true);
92
+ return () => {
93
+ document == null ? void 0 : document.removeEventListener("mousedown", focusOut, true);
94
+ };
95
+ }, [endEditMode, editorText]);
96
+ return /* @__PURE__ */ jsxRuntime.jsxs(Cell.Cell, {
97
+ separator: column == null ? void 0 : column.separator,
98
+ className: "saltGridNumericCellEditor",
99
+ children: [
100
+ /* @__PURE__ */ jsxRuntime.jsx("div", {
101
+ className: "saltGridNumericCellEditor-inputContainer",
102
+ children: /* @__PURE__ */ jsxRuntime.jsx("input", {
103
+ ref: inputRef,
104
+ "data-testid": "grid-cell-editor-input",
105
+ autoFocus: true,
106
+ value: editorText,
107
+ onChange,
108
+ onKeyDown
109
+ })
110
+ }),
111
+ /* @__PURE__ */ jsxRuntime.jsx(CornerTag.CornerTag, {})
112
+ ]
113
+ });
114
+ }
115
+ function NumericColumn(props) {
116
+ return /* @__PURE__ */ jsxRuntime.jsx(GridColumn.GridColumn, {
117
+ ...props,
118
+ align: "right",
119
+ cellValueComponent: NumericCellValue,
120
+ children: props.children
121
+ });
122
+ }
123
+
124
+ exports.NumericCellEditor = NumericCellEditor;
125
+ exports.NumericCellValue = NumericCellValue;
126
+ exports.NumericColumn = NumericColumn;
127
+ //# sourceMappingURL=NumericColumn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NumericColumn.js","sources":["../src/NumericColumn.tsx"],"sourcesContent":["import {\n ChangeEventHandler,\n KeyboardEventHandler,\n ReactNode,\n useEffect,\n useRef,\n useState,\n} from \"react\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { GridCellValueProps, GridColumn, GridColumnProps } from \"./GridColumn\";\nimport { GridColumnModel, GridRowModel } from \"./Grid\";\nimport { useEditorContext } from \"./EditorContext\";\nimport { CornerTag } from \"./CornerTag\";\nimport { Cell } from \"./internal\";\n\nimport numericColumnCss from \"./NumericColumn.css\";\n\nexport interface NumericColumnProps<T> extends GridColumnProps<T> {\n precision: number;\n}\n\nfunction isNumber(value: any): value is number {\n return typeof value === \"number\" && Number.isFinite(value);\n}\n\nexport function NumericCellValue<T>(props: GridCellValueProps<T>) {\n const { column, value } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-numeric-column\",\n css: numericColumnCss,\n window: targetWindow,\n });\n\n const columnProps = column.info.props as NumericColumnProps<T>;\n const { precision } = columnProps;\n const text = isNumber(value) ? value.toFixed(precision) : \"\";\n return <div className=\"saltGridNumericCellValue\">{text}</div>;\n}\n\nexport interface NumericEditorProps<T> {\n row?: GridRowModel<T>;\n column?: GridColumnModel<T>;\n children?: ReactNode;\n}\n\nexport function NumericCellEditor<T>(props: NumericEditorProps<T>) {\n const { column, row } = props;\n const inputRef = useRef<HTMLInputElement>(null);\n\n const { endEditMode, cancelEditMode, initialText } = useEditorContext();\n\n const [editorText, setEditorText] = useState<string>(\n initialText != null ? initialText : column!.info.props.getValue!(row!.data)\n );\n\n const initialSelectionRef = useRef(!!initialText);\n\n const onChange: ChangeEventHandler<HTMLInputElement> = (e) => {\n setEditorText(e.target.value);\n };\n\n const onKeyDown: KeyboardEventHandler<HTMLInputElement> = (event) => {\n if (event.key === \"Enter\") {\n endEditMode(editorText);\n return;\n }\n if (event.key === \"Escape\") {\n cancelEditMode();\n return;\n }\n if (event.key === \"Tab\") {\n endEditMode(editorText);\n event.preventDefault();\n return;\n }\n event.stopPropagation();\n };\n\n useEffect(() => {\n if (inputRef.current && !initialSelectionRef.current) {\n inputRef.current.select();\n initialSelectionRef.current = true;\n }\n }, [inputRef.current]);\n\n useEffect(() => {\n const input = inputRef.current;\n const focusOut = (event: FocusEvent) => {\n if (!input?.contains(event.target as Node)) {\n endEditMode(editorText);\n }\n };\n\n // This uses the capture phase to detect clicks outside the input to avoid a race condition where the component gets unmounted when edit mode ends.\n document?.addEventListener(\"mousedown\", focusOut, true);\n\n return () => {\n document?.removeEventListener(\"mousedown\", focusOut, true);\n };\n }, [endEditMode, editorText]);\n\n return (\n <Cell separator={column?.separator} className=\"saltGridNumericCellEditor\">\n <div className=\"saltGridNumericCellEditor-inputContainer\">\n <input\n ref={inputRef}\n data-testid=\"grid-cell-editor-input\"\n autoFocus={true}\n value={editorText}\n onChange={onChange}\n onKeyDown={onKeyDown}\n />\n </div>\n <CornerTag />\n </Cell>\n );\n}\n\nexport function NumericColumn<T>(props: NumericColumnProps<T>) {\n return (\n <GridColumn\n {...props}\n align={\"right\"}\n cellValueComponent={NumericCellValue}\n >\n {props.children}\n </GridColumn>\n );\n}\n"],"names":["useWindow","useComponentCssInjection","numericColumnCss","jsx","useRef","useEditorContext","useState","useEffect","jsxs","Cell","CornerTag","GridColumn"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuBA,SAAS,SAAS,KAA6B,EAAA;AAC7C,EAAA,OAAO,OAAO,KAAA,KAAU,QAAY,IAAA,MAAA,CAAO,SAAS,KAAK,CAAA,CAAA;AAC3D,CAAA;AAEO,SAAS,iBAAoB,KAA8B,EAAA;AAChE,EAAM,MAAA,EAAE,MAAQ,EAAA,KAAA,EAAU,GAAA,KAAA,CAAA;AAE1B,EAAA,MAAM,eAAeA,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,qBAAA;AAAA,IACR,GAAK,EAAAC,eAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAM,MAAA,WAAA,GAAc,OAAO,IAAK,CAAA,KAAA,CAAA;AAChC,EAAM,MAAA,EAAE,WAAc,GAAA,WAAA,CAAA;AACtB,EAAA,MAAM,OAAO,QAAS,CAAA,KAAK,IAAI,KAAM,CAAA,OAAA,CAAQ,SAAS,CAAI,GAAA,EAAA,CAAA;AAC1D,EAAA,uBAAQC,cAAA,CAAA,KAAA,EAAA;AAAA,IAAI,SAAU,EAAA,0BAAA;AAAA,IAA4B,QAAA,EAAA,IAAA;AAAA,GAAK,CAAA,CAAA;AACzD,CAAA;AAQO,SAAS,kBAAqB,KAA8B,EAAA;AACjE,EAAM,MAAA,EAAE,MAAQ,EAAA,GAAA,EAAQ,GAAA,KAAA,CAAA;AACxB,EAAM,MAAA,QAAA,GAAWC,aAAyB,IAAI,CAAA,CAAA;AAE9C,EAAA,MAAM,EAAE,WAAA,EAAa,cAAgB,EAAA,WAAA,KAAgBC,8BAAiB,EAAA,CAAA;AAEtE,EAAM,MAAA,CAAC,UAAY,EAAA,aAAa,CAAI,GAAAC,cAAA;AAAA,IAClC,WAAA,IAAe,OAAO,WAAc,GAAA,MAAA,CAAQ,KAAK,KAAM,CAAA,QAAA,CAAU,IAAK,IAAI,CAAA;AAAA,GAC5E,CAAA;AAEA,EAAA,MAAM,mBAAsB,GAAAF,YAAA,CAAO,CAAC,CAAC,WAAW,CAAA,CAAA;AAEhD,EAAM,MAAA,QAAA,GAAiD,CAAC,CAAM,KAAA;AAC5D,IAAc,aAAA,CAAA,CAAA,CAAE,OAAO,KAAK,CAAA,CAAA;AAAA,GAC9B,CAAA;AAEA,EAAM,MAAA,SAAA,GAAoD,CAAC,KAAU,KAAA;AACnE,IAAI,IAAA,KAAA,CAAM,QAAQ,OAAS,EAAA;AACzB,MAAA,WAAA,CAAY,UAAU,CAAA,CAAA;AACtB,MAAA,OAAA;AAAA,KACF;AACA,IAAI,IAAA,KAAA,CAAM,QAAQ,QAAU,EAAA;AAC1B,MAAe,cAAA,EAAA,CAAA;AACf,MAAA,OAAA;AAAA,KACF;AACA,IAAI,IAAA,KAAA,CAAM,QAAQ,KAAO,EAAA;AACvB,MAAA,WAAA,CAAY,UAAU,CAAA,CAAA;AACtB,MAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,MAAA,OAAA;AAAA,KACF;AACA,IAAA,KAAA,CAAM,eAAgB,EAAA,CAAA;AAAA,GACxB,CAAA;AAEA,EAAAG,eAAA,CAAU,MAAM;AACd,IAAA,IAAI,QAAS,CAAA,OAAA,IAAW,CAAC,mBAAA,CAAoB,OAAS,EAAA;AACpD,MAAA,QAAA,CAAS,QAAQ,MAAO,EAAA,CAAA;AACxB,MAAA,mBAAA,CAAoB,OAAU,GAAA,IAAA,CAAA;AAAA,KAChC;AAAA,GACC,EAAA,CAAC,QAAS,CAAA,OAAO,CAAC,CAAA,CAAA;AAErB,EAAAA,eAAA,CAAU,MAAM;AACd,IAAA,MAAM,QAAQ,QAAS,CAAA,OAAA,CAAA;AACvB,IAAM,MAAA,QAAA,GAAW,CAAC,KAAsB,KAAA;AACtC,MAAA,IAAI,EAAC,KAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,KAAA,CAAO,QAAS,CAAA,KAAA,CAAM,MAAiB,CAAA,CAAA,EAAA;AAC1C,QAAA,WAAA,CAAY,UAAU,CAAA,CAAA;AAAA,OACxB;AAAA,KACF,CAAA;AAGA,IAAU,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,gBAAA,CAAiB,aAAa,QAAU,EAAA,IAAA,CAAA,CAAA;AAElD,IAAA,OAAO,MAAM;AACX,MAAU,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,mBAAA,CAAoB,aAAa,QAAU,EAAA,IAAA,CAAA,CAAA;AAAA,KACvD,CAAA;AAAA,GACC,EAAA,CAAC,WAAa,EAAA,UAAU,CAAC,CAAA,CAAA;AAE5B,EAAA,uBACGC,eAAA,CAAAC,SAAA,EAAA;AAAA,IAAK,WAAW,MAAQ,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,MAAA,CAAA,SAAA;AAAA,IAAW,SAAU,EAAA,2BAAA;AAAA,IAC5C,QAAA,EAAA;AAAA,sBAACN,cAAA,CAAA,KAAA,EAAA;AAAA,QAAI,SAAU,EAAA,0CAAA;AAAA,QACb,QAAC,kBAAAA,cAAA,CAAA,OAAA,EAAA;AAAA,UACC,GAAK,EAAA,QAAA;AAAA,UACL,aAAY,EAAA,wBAAA;AAAA,UACZ,SAAW,EAAA,IAAA;AAAA,UACX,KAAO,EAAA,UAAA;AAAA,UACP,QAAA;AAAA,UACA,SAAA;AAAA,SACF,CAAA;AAAA,OACF,CAAA;AAAA,qCACCO,mBAAU,EAAA,EAAA,CAAA;AAAA,KAAA;AAAA,GACb,CAAA,CAAA;AAEJ,CAAA;AAEO,SAAS,cAAiB,KAA8B,EAAA;AAC7D,EAAA,uBACGP,cAAA,CAAAQ,qBAAA,EAAA;AAAA,IACE,GAAG,KAAA;AAAA,IACJ,KAAO,EAAA,OAAA;AAAA,IACP,kBAAoB,EAAA,gBAAA;AAAA,IAEnB,QAAM,EAAA,KAAA,CAAA,QAAA;AAAA,GACT,CAAA,CAAA;AAEJ;;;;;;"}
@@ -0,0 +1,45 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var core = require('@salt-ds/core');
7
+ var window = require('@salt-ds/window');
8
+ var styles = require('@salt-ds/styles');
9
+ var SelectionContext = require('./SelectionContext.js');
10
+ var CursorContext = require('./CursorContext.js');
11
+ var CheckboxCell = require('./CheckboxCell.css.js');
12
+
13
+ function RowSelectionCheckboxCellValue(props) {
14
+ const { row, column, isFocused } = props;
15
+ const targetWindow = window.useWindow();
16
+ styles.useComponentCssInjection({
17
+ testId: "salt-checkbox-cell",
18
+ css: CheckboxCell,
19
+ window: targetWindow
20
+ });
21
+ const { selRowIdxs, selectRows } = SelectionContext.useSelectionContext();
22
+ const { moveCursor } = CursorContext.useCursorContext();
23
+ const isSelected = selRowIdxs.has(row.index);
24
+ const onMouseDown = (event) => {
25
+ selectRows({ rowIndex: row.index, incremental: true });
26
+ moveCursor("body", row.index, column.index);
27
+ event.preventDefault();
28
+ event.stopPropagation();
29
+ };
30
+ return /* @__PURE__ */ jsxRuntime.jsx("div", {
31
+ className: "saltGridCheckboxContainer",
32
+ onMouseDown,
33
+ children: /* @__PURE__ */ jsxRuntime.jsx(core.Checkbox, {
34
+ "data-testid": "grid-row-selection-checkbox",
35
+ inputProps: {
36
+ "aria-label": "Select Row",
37
+ tabIndex: isFocused ? 0 : -1
38
+ },
39
+ checked: isSelected
40
+ })
41
+ });
42
+ }
43
+
44
+ exports.RowSelectionCheckboxCellValue = RowSelectionCheckboxCellValue;
45
+ //# sourceMappingURL=RowSelectionCheckboxCellValue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RowSelectionCheckboxCellValue.js","sources":["../src/RowSelectionCheckboxCellValue.tsx"],"sourcesContent":["import { Checkbox } from \"@salt-ds/core\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { GridCellValueProps } from \"./GridColumn\";\nimport { useSelectionContext } from \"./SelectionContext\";\nimport { MouseEventHandler } from \"react\";\nimport { useCursorContext } from \"./CursorContext\";\n\nimport checkboxCellCss from \"./CheckboxCell.css\";\n\nexport function RowSelectionCheckboxCellValue<T>(props: GridCellValueProps<T>) {\n const { row, column, isFocused } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-checkbox-cell\",\n css: checkboxCellCss,\n window: targetWindow,\n });\n\n const { selRowIdxs, selectRows } = useSelectionContext();\n const { moveCursor } = useCursorContext();\n\n const isSelected = selRowIdxs.has(row.index);\n\n const onMouseDown: MouseEventHandler<HTMLDivElement> = (event) => {\n selectRows({ rowIndex: row.index, incremental: true });\n moveCursor(\"body\", row.index, column.index);\n event.preventDefault();\n event.stopPropagation();\n };\n\n return (\n <div className=\"saltGridCheckboxContainer\" onMouseDown={onMouseDown}>\n <Checkbox\n data-testid=\"grid-row-selection-checkbox\"\n inputProps={{\n \"aria-label\": \"Select Row\",\n tabIndex: isFocused ? 0 : -1,\n }}\n checked={isSelected}\n />\n </div>\n );\n}\n"],"names":["useWindow","useComponentCssInjection","checkboxCellCss","useSelectionContext","useCursorContext","jsx","Checkbox"],"mappings":";;;;;;;;;;;;AAWO,SAAS,8BAAiC,KAA8B,EAAA;AAC7E,EAAA,MAAM,EAAE,GAAA,EAAK,MAAQ,EAAA,SAAA,EAAc,GAAA,KAAA,CAAA;AAEnC,EAAA,MAAM,eAAeA,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,oBAAA;AAAA,IACR,GAAK,EAAAC,YAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,MAAM,EAAE,UAAA,EAAY,UAAW,EAAA,GAAIC,oCAAoB,EAAA,CAAA;AACvD,EAAM,MAAA,EAAE,UAAW,EAAA,GAAIC,8BAAiB,EAAA,CAAA;AAExC,EAAA,MAAM,UAAa,GAAA,UAAA,CAAW,GAAI,CAAA,GAAA,CAAI,KAAK,CAAA,CAAA;AAE3C,EAAM,MAAA,WAAA,GAAiD,CAAC,KAAU,KAAA;AAChE,IAAA,UAAA,CAAW,EAAE,QAAU,EAAA,GAAA,CAAI,KAAO,EAAA,WAAA,EAAa,MAAM,CAAA,CAAA;AACrD,IAAA,UAAA,CAAW,MAAQ,EAAA,GAAA,CAAI,KAAO,EAAA,MAAA,CAAO,KAAK,CAAA,CAAA;AAC1C,IAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,IAAA,KAAA,CAAM,eAAgB,EAAA,CAAA;AAAA,GACxB,CAAA;AAEA,EAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,IAAI,SAAU,EAAA,2BAAA;AAAA,IAA4B,WAAA;AAAA,IACzC,QAAC,kBAAAA,cAAA,CAAAC,aAAA,EAAA;AAAA,MACC,aAAY,EAAA,6BAAA;AAAA,MACZ,UAAY,EAAA;AAAA,QACV,YAAc,EAAA,YAAA;AAAA,QACd,QAAA,EAAU,YAAY,CAAI,GAAA,CAAA,CAAA;AAAA,OAC5B;AAAA,MACA,OAAS,EAAA,UAAA;AAAA,KACX,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,39 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var react = require('react');
7
+ var RowSelectionCheckboxHeaderCellValue = require('./RowSelectionCheckboxHeaderCellValue.js');
8
+ var RowSelectionCheckboxCellValue = require('./RowSelectionCheckboxCellValue.js');
9
+ var GridColumn = require('./GridColumn.js');
10
+ var SelectionContext = require('./SelectionContext.js');
11
+ var HeaderCell = require('./HeaderCell.js');
12
+
13
+ function RowSelectionCheckboxColumn(props) {
14
+ const { selectRows } = SelectionContext.useSelectionContext();
15
+ const onKeyDown = react.useCallback(
16
+ (event, rowIndex) => {
17
+ if (event.key === " ") {
18
+ selectRows({
19
+ rowIndex,
20
+ incremental: true
21
+ });
22
+ event.preventDefault();
23
+ event.stopPropagation();
24
+ }
25
+ },
26
+ [selectRows]
27
+ );
28
+ return /* @__PURE__ */ jsxRuntime.jsx(GridColumn.GridColumn, {
29
+ ...props,
30
+ defaultWidth: 100,
31
+ headerComponent: HeaderCell.AutoSizeHeaderCell,
32
+ headerValueComponent: RowSelectionCheckboxHeaderCellValue.RowSelectionCheckboxHeaderCellValue,
33
+ cellValueComponent: RowSelectionCheckboxCellValue.RowSelectionCheckboxCellValue,
34
+ onKeyDown
35
+ });
36
+ }
37
+
38
+ exports.RowSelectionCheckboxColumn = RowSelectionCheckboxColumn;
39
+ //# sourceMappingURL=RowSelectionCheckboxColumn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RowSelectionCheckboxColumn.js","sources":["../src/RowSelectionCheckboxColumn.tsx"],"sourcesContent":["import { KeyboardEvent, useCallback } from \"react\";\nimport { RowSelectionCheckboxHeaderCellValue } from \"./RowSelectionCheckboxHeaderCellValue\";\nimport { RowSelectionCheckboxCellValue } from \"./RowSelectionCheckboxCellValue\";\nimport { GridColumn, GridColumnProps } from \"./GridColumn\";\nimport { useSelectionContext } from \"./SelectionContext\";\nimport { AutoSizeHeaderCell } from \"./HeaderCell\";\n\nexport type RowSelectionCheckboxColumnProps<T> = Omit<\n GridColumnProps<T>,\n \"width\" | \"name\"\n>;\n\nexport function RowSelectionCheckboxColumn<T>(\n props: RowSelectionCheckboxColumnProps<T>\n) {\n const { selectRows } = useSelectionContext();\n\n const onKeyDown = useCallback(\n (event: KeyboardEvent<HTMLDivElement>, rowIndex: number) => {\n if (event.key === \" \") {\n selectRows({\n rowIndex,\n incremental: true,\n });\n event.preventDefault();\n event.stopPropagation();\n }\n },\n [selectRows]\n );\n\n return (\n <GridColumn\n {...props}\n defaultWidth={100}\n headerComponent={AutoSizeHeaderCell}\n headerValueComponent={RowSelectionCheckboxHeaderCellValue}\n cellValueComponent={RowSelectionCheckboxCellValue}\n onKeyDown={onKeyDown}\n />\n );\n}\n"],"names":["useSelectionContext","useCallback","jsx","GridColumn","AutoSizeHeaderCell","RowSelectionCheckboxHeaderCellValue","RowSelectionCheckboxCellValue"],"mappings":";;;;;;;;;;;;AAYO,SAAS,2BACd,KACA,EAAA;AACA,EAAM,MAAA,EAAE,UAAW,EAAA,GAAIA,oCAAoB,EAAA,CAAA;AAE3C,EAAA,MAAM,SAAY,GAAAC,iBAAA;AAAA,IAChB,CAAC,OAAsC,QAAqB,KAAA;AAC1D,MAAI,IAAA,KAAA,CAAM,QAAQ,GAAK,EAAA;AACrB,QAAW,UAAA,CAAA;AAAA,UACT,QAAA;AAAA,UACA,WAAa,EAAA,IAAA;AAAA,SACd,CAAA,CAAA;AACD,QAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,QAAA,KAAA,CAAM,eAAgB,EAAA,CAAA;AAAA,OACxB;AAAA,KACF;AAAA,IACA,CAAC,UAAU,CAAA;AAAA,GACb,CAAA;AAEA,EAAA,uBACGC,cAAA,CAAAC,qBAAA,EAAA;AAAA,IACE,GAAG,KAAA;AAAA,IACJ,YAAc,EAAA,GAAA;AAAA,IACd,eAAiB,EAAAC,6BAAA;AAAA,IACjB,oBAAsB,EAAAC,uEAAA;AAAA,IACtB,kBAAoB,EAAAC,2DAAA;AAAA,IACpB,SAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,56 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var window = require('@salt-ds/window');
7
+ var styles = require('@salt-ds/styles');
8
+ var core = require('@salt-ds/core');
9
+ var SelectionContext = require('./SelectionContext.js');
10
+ var CheckboxCell = require('./CheckboxCell.css.js');
11
+
12
+ function RowSelectionCheckboxHeaderCellValue(props) {
13
+ const { isFocused } = props;
14
+ const targetWindow = window.useWindow();
15
+ styles.useComponentCssInjection({
16
+ testId: "salt-checkbox-cell",
17
+ css: CheckboxCell,
18
+ window: targetWindow
19
+ });
20
+ const { selectAll, unselectAll, isAllSelected, isAnySelected } = SelectionContext.useSelectionContext();
21
+ const onMousedown = (event) => {
22
+ if (isAllSelected) {
23
+ unselectAll();
24
+ } else {
25
+ selectAll();
26
+ }
27
+ };
28
+ const onKeyDown = (event) => {
29
+ if (event.key === " ") {
30
+ if (isAllSelected) {
31
+ unselectAll();
32
+ } else {
33
+ selectAll();
34
+ }
35
+ event.preventDefault();
36
+ event.stopPropagation();
37
+ }
38
+ };
39
+ return /* @__PURE__ */ jsxRuntime.jsx("div", {
40
+ onMouseDown: onMousedown,
41
+ className: "saltGridCheckboxContainer",
42
+ onKeyDown,
43
+ children: /* @__PURE__ */ jsxRuntime.jsx(core.Checkbox, {
44
+ "data-testid": "grid-row-select-all-checkbox",
45
+ inputProps: {
46
+ "aria-label": "Select All",
47
+ tabIndex: isFocused ? 0 : -1
48
+ },
49
+ checked: isAllSelected,
50
+ indeterminate: !isAllSelected && isAnySelected
51
+ })
52
+ });
53
+ }
54
+
55
+ exports.RowSelectionCheckboxHeaderCellValue = RowSelectionCheckboxHeaderCellValue;
56
+ //# sourceMappingURL=RowSelectionCheckboxHeaderCellValue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RowSelectionCheckboxHeaderCellValue.js","sources":["../src/RowSelectionCheckboxHeaderCellValue.tsx"],"sourcesContent":["import { KeyboardEventHandler, MouseEventHandler } from \"react\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { Checkbox } from \"@salt-ds/core\";\n\nimport { useSelectionContext } from \"./SelectionContext\";\nimport { GridHeaderValueProps } from \"./GridColumn\";\n\nimport checkboxCellCss from \"./CheckboxCell.css\";\n\nexport function RowSelectionCheckboxHeaderCellValue<T>(\n props: GridHeaderValueProps<T>\n) {\n const { isFocused } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-checkbox-cell\",\n css: checkboxCellCss,\n window: targetWindow,\n });\n\n const { selectAll, unselectAll, isAllSelected, isAnySelected } =\n useSelectionContext();\n\n const onMousedown: MouseEventHandler<HTMLDivElement> = (event) => {\n if (isAllSelected) {\n unselectAll();\n } else {\n selectAll();\n }\n };\n\n const onKeyDown: KeyboardEventHandler<HTMLDivElement> = (event) => {\n if (event.key === \" \") {\n if (isAllSelected) {\n unselectAll();\n } else {\n selectAll();\n }\n event.preventDefault();\n event.stopPropagation();\n }\n };\n\n return (\n <div\n onMouseDown={onMousedown}\n className=\"saltGridCheckboxContainer\"\n onKeyDown={onKeyDown}\n >\n <Checkbox\n data-testid=\"grid-row-select-all-checkbox\"\n inputProps={{\n \"aria-label\": \"Select All\",\n tabIndex: isFocused ? 0 : -1,\n }}\n checked={isAllSelected}\n indeterminate={!isAllSelected && isAnySelected}\n />\n </div>\n );\n}\n"],"names":["useWindow","useComponentCssInjection","checkboxCellCss","useSelectionContext","jsx","Checkbox"],"mappings":";;;;;;;;;;;AAUO,SAAS,oCACd,KACA,EAAA;AACA,EAAM,MAAA,EAAE,WAAc,GAAA,KAAA,CAAA;AAEtB,EAAA,MAAM,eAAeA,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,oBAAA;AAAA,IACR,GAAK,EAAAC,YAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,MAAM,EAAE,SAAW,EAAA,WAAA,EAAa,aAAe,EAAA,aAAA,KAC7CC,oCAAoB,EAAA,CAAA;AAEtB,EAAM,MAAA,WAAA,GAAiD,CAAC,KAAU,KAAA;AAChE,IAAA,IAAI,aAAe,EAAA;AACjB,MAAY,WAAA,EAAA,CAAA;AAAA,KACP,MAAA;AACL,MAAU,SAAA,EAAA,CAAA;AAAA,KACZ;AAAA,GACF,CAAA;AAEA,EAAM,MAAA,SAAA,GAAkD,CAAC,KAAU,KAAA;AACjE,IAAI,IAAA,KAAA,CAAM,QAAQ,GAAK,EAAA;AACrB,MAAA,IAAI,aAAe,EAAA;AACjB,QAAY,WAAA,EAAA,CAAA;AAAA,OACP,MAAA;AACL,QAAU,SAAA,EAAA,CAAA;AAAA,OACZ;AACA,MAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,MAAA,KAAA,CAAM,eAAgB,EAAA,CAAA;AAAA,KACxB;AAAA,GACF,CAAA;AAEA,EAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,IACC,WAAa,EAAA,WAAA;AAAA,IACb,SAAU,EAAA,2BAAA;AAAA,IACV,SAAA;AAAA,IAEA,QAAC,kBAAAA,cAAA,CAAAC,aAAA,EAAA;AAAA,MACC,aAAY,EAAA,8BAAA;AAAA,MACZ,UAAY,EAAA;AAAA,QACV,YAAc,EAAA,YAAA;AAAA,QACd,QAAA,EAAU,YAAY,CAAI,GAAA,CAAA,CAAA;AAAA,OAC5B;AAAA,MACA,OAAS,EAAA,aAAA;AAAA,MACT,aAAA,EAAe,CAAC,aAAiB,IAAA,aAAA;AAAA,KACnC,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,33 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var core = require('@salt-ds/core');
7
+ var window = require('@salt-ds/window');
8
+ var styles = require('@salt-ds/styles');
9
+ var SelectionContext = require('./SelectionContext.js');
10
+ var CheckboxCell = require('./CheckboxCell.css.js');
11
+
12
+ function RowSelectionRadioCellValue(props) {
13
+ const { row, isFocused } = props;
14
+ const targetWindow = window.useWindow();
15
+ styles.useComponentCssInjection({
16
+ testId: "salt-checkbox-cell",
17
+ css: CheckboxCell,
18
+ window: targetWindow
19
+ });
20
+ const { selRowIdxs } = SelectionContext.useSelectionContext();
21
+ const isSelected = selRowIdxs.has(row.index);
22
+ return /* @__PURE__ */ jsxRuntime.jsx("div", {
23
+ className: "saltGridCheckboxContainer",
24
+ children: /* @__PURE__ */ jsxRuntime.jsx(core.RadioButton, {
25
+ checked: isSelected,
26
+ "data-testid": "grid-row-selection-radiobox",
27
+ tabIndex: isFocused ? 0 : -1
28
+ })
29
+ });
30
+ }
31
+
32
+ exports.RowSelectionRadioCellValue = RowSelectionRadioCellValue;
33
+ //# sourceMappingURL=RowSelectionRadioCellValue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RowSelectionRadioCellValue.js","sources":["../src/RowSelectionRadioCellValue.tsx"],"sourcesContent":["import { RadioButton } from \"@salt-ds/core\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { GridCellValueProps } from \"./GridColumn\";\nimport { useSelectionContext } from \"./SelectionContext\";\n\nimport checkboxCellCss from \"./CheckboxCell.css\";\n\nexport function RowSelectionRadioCellValue<T>(props: GridCellValueProps<T>) {\n const { row, isFocused } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-checkbox-cell\",\n css: checkboxCellCss,\n window: targetWindow,\n });\n\n const { selRowIdxs } = useSelectionContext();\n\n const isSelected = selRowIdxs.has(row.index);\n\n return (\n <div className=\"saltGridCheckboxContainer\">\n <RadioButton\n checked={isSelected}\n data-testid=\"grid-row-selection-radiobox\"\n tabIndex={isFocused ? 0 : -1}\n />\n </div>\n );\n}\n"],"names":["useWindow","useComponentCssInjection","checkboxCellCss","useSelectionContext","jsx","RadioButton"],"mappings":";;;;;;;;;;;AASO,SAAS,2BAA8B,KAA8B,EAAA;AAC1E,EAAM,MAAA,EAAE,GAAK,EAAA,SAAA,EAAc,GAAA,KAAA,CAAA;AAE3B,EAAA,MAAM,eAAeA,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,oBAAA;AAAA,IACR,GAAK,EAAAC,YAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAM,MAAA,EAAE,UAAW,EAAA,GAAIC,oCAAoB,EAAA,CAAA;AAE3C,EAAA,MAAM,UAAa,GAAA,UAAA,CAAW,GAAI,CAAA,GAAA,CAAI,KAAK,CAAA,CAAA;AAE3C,EAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,IAAI,SAAU,EAAA,2BAAA;AAAA,IACb,QAAC,kBAAAA,cAAA,CAAAC,gBAAA,EAAA;AAAA,MACC,OAAS,EAAA,UAAA;AAAA,MACT,aAAY,EAAA,6BAAA;AAAA,MACZ,QAAA,EAAU,YAAY,CAAI,GAAA,CAAA,CAAA;AAAA,KAC5B,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,34 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var RowSelectionRadioCellValue = require('./RowSelectionRadioCellValue.js');
7
+ var GridColumn = require('./GridColumn.js');
8
+ var RowSelectionRadioHeaderCell = require('./RowSelectionRadioHeaderCell.js');
9
+ var SelectionContext = require('./SelectionContext.js');
10
+ var react = require('react');
11
+
12
+ function RowSelectionRadioColumn(props) {
13
+ const { selectRows } = SelectionContext.useSelectionContext();
14
+ const onKeyDown = react.useCallback(
15
+ (event, rowIndex) => {
16
+ if (event.key === " ") {
17
+ selectRows({ rowIndex });
18
+ event.preventDefault();
19
+ event.stopPropagation();
20
+ }
21
+ },
22
+ [selectRows]
23
+ );
24
+ return /* @__PURE__ */ jsxRuntime.jsx(GridColumn.GridColumn, {
25
+ ...props,
26
+ defaultWidth: 100,
27
+ headerComponent: RowSelectionRadioHeaderCell.RowSelectionRadioHeaderCell,
28
+ cellValueComponent: RowSelectionRadioCellValue.RowSelectionRadioCellValue,
29
+ onKeyDown
30
+ });
31
+ }
32
+
33
+ exports.RowSelectionRadioColumn = RowSelectionRadioColumn;
34
+ //# sourceMappingURL=RowSelectionRadioColumn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RowSelectionRadioColumn.js","sources":["../src/RowSelectionRadioColumn.tsx"],"sourcesContent":["import { RowSelectionRadioCellValue } from \"./RowSelectionRadioCellValue\";\nimport { GridColumn, GridColumnProps } from \"./GridColumn\";\nimport { RowSelectionRadioHeaderCell } from \"./RowSelectionRadioHeaderCell\";\nimport { useSelectionContext } from \"./SelectionContext\";\nimport { KeyboardEvent, useCallback } from \"react\";\n\nexport type RowSelectionRadioColumnProps<T> = Omit<\n GridColumnProps<T>,\n \"width\" | \"name\"\n>;\n\nexport function RowSelectionRadioColumn<T>(\n props: RowSelectionRadioColumnProps<T>\n) {\n const { selectRows } = useSelectionContext();\n\n const onKeyDown = useCallback(\n (event: KeyboardEvent<HTMLDivElement>, rowIndex: number) => {\n if (event.key === \" \") {\n selectRows({ rowIndex });\n event.preventDefault();\n event.stopPropagation();\n }\n },\n [selectRows]\n );\n\n return (\n <GridColumn\n {...props}\n defaultWidth={100}\n headerComponent={RowSelectionRadioHeaderCell}\n cellValueComponent={RowSelectionRadioCellValue}\n onKeyDown={onKeyDown}\n />\n );\n}\n"],"names":["useSelectionContext","useCallback","jsx","GridColumn","RowSelectionRadioHeaderCell","RowSelectionRadioCellValue"],"mappings":";;;;;;;;;;;AAWO,SAAS,wBACd,KACA,EAAA;AACA,EAAM,MAAA,EAAE,UAAW,EAAA,GAAIA,oCAAoB,EAAA,CAAA;AAE3C,EAAA,MAAM,SAAY,GAAAC,iBAAA;AAAA,IAChB,CAAC,OAAsC,QAAqB,KAAA;AAC1D,MAAI,IAAA,KAAA,CAAM,QAAQ,GAAK,EAAA;AACrB,QAAW,UAAA,CAAA,EAAE,UAAU,CAAA,CAAA;AACvB,QAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,QAAA,KAAA,CAAM,eAAgB,EAAA,CAAA;AAAA,OACxB;AAAA,KACF;AAAA,IACA,CAAC,UAAU,CAAA;AAAA,GACb,CAAA;AAEA,EAAA,uBACGC,cAAA,CAAAC,qBAAA,EAAA;AAAA,IACE,GAAG,KAAA;AAAA,IACJ,YAAc,EAAA,GAAA;AAAA,IACd,eAAiB,EAAAC,uDAAA;AAAA,IACjB,kBAAoB,EAAAC,qDAAA;AAAA,IACpB,SAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,30 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var clsx = require('clsx');
7
+ var core = require('@salt-ds/core');
8
+ var window = require('@salt-ds/window');
9
+ var styles = require('@salt-ds/styles');
10
+ var HeaderCell = require('./HeaderCell.js');
11
+ var CheckboxCell = require('./CheckboxCell.css.js');
12
+
13
+ function RowSelectionRadioHeaderCell(props) {
14
+ const targetWindow = window.useWindow();
15
+ styles.useComponentCssInjection({
16
+ testId: "salt-checkbox-cell",
17
+ css: CheckboxCell,
18
+ window: targetWindow
19
+ });
20
+ return /* @__PURE__ */ jsxRuntime.jsx(HeaderCell.AutoSizeHeaderCell, {
21
+ ...props,
22
+ children: /* @__PURE__ */ jsxRuntime.jsx("div", {
23
+ className: clsx.clsx("saltGridCheckboxContainer", "saltGrid-hidden"),
24
+ children: /* @__PURE__ */ jsxRuntime.jsx(core.RadioButtonIcon, {})
25
+ })
26
+ });
27
+ }
28
+
29
+ exports.RowSelectionRadioHeaderCell = RowSelectionRadioHeaderCell;
30
+ //# sourceMappingURL=RowSelectionRadioHeaderCell.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RowSelectionRadioHeaderCell.js","sources":["../src/RowSelectionRadioHeaderCell.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\n\nimport { RadioButtonIcon } from \"@salt-ds/core\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { AutoSizeHeaderCell } from \"./HeaderCell\";\nimport { HeaderCellProps } from \"./GridColumn\";\n\nimport checkboxCellCss from \"./CheckboxCell.css\";\n\nexport function RowSelectionRadioHeaderCell<T>(props: HeaderCellProps<T>) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-checkbox-cell\",\n css: checkboxCellCss,\n window: targetWindow,\n });\n\n return (\n <AutoSizeHeaderCell {...props}>\n <div className={clsx(\"saltGridCheckboxContainer\", \"saltGrid-hidden\")}>\n <RadioButtonIcon />\n </div>\n </AutoSizeHeaderCell>\n );\n}\n"],"names":["useWindow","useComponentCssInjection","checkboxCellCss","jsx","AutoSizeHeaderCell","clsx","RadioButtonIcon"],"mappings":";;;;;;;;;;;;AAWO,SAAS,4BAA+B,KAA2B,EAAA;AACxE,EAAA,MAAM,eAAeA,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,oBAAA;AAAA,IACR,GAAK,EAAAC,YAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACGC,cAAA,CAAAC,6BAAA,EAAA;AAAA,IAAoB,GAAG,KAAA;AAAA,IACtB,QAAC,kBAAAD,cAAA,CAAA,KAAA,EAAA;AAAA,MAAI,SAAA,EAAWE,SAAK,CAAA,2BAAA,EAA6B,iBAAiB,CAAA;AAAA,MACjE,yCAACC,oBAAgB,EAAA,EAAA,CAAA;AAAA,KACnB,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,13 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ require('react/jsx-runtime');
6
+ require('@salt-ds/core');
7
+ var react = require('react');
8
+ require('./GridContext.js');
9
+
10
+ const RowValidationStatusContext = react.createContext({});
11
+
12
+ exports.RowValidationStatusContext = RowValidationStatusContext;
13
+ //# sourceMappingURL=RowValidationStatus.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RowValidationStatus.js","sources":["../src/RowValidationStatus.tsx"],"sourcesContent":["import { StatusIndicator } from \"@salt-ds/core\";\nimport { createContext, useContext } from \"react\";\nimport { CellValidationState, GridColumn, GridColumnProps } from \"./GridColumn\";\n\nexport const RowValidationStatusContext = createContext<{\n status?: CellValidationState;\n}>({});\n\nexport type RowValidationStatusColumnProps<T> = Omit<\n GridColumnProps<T>,\n \"width\" | \"name\"\n>;\n\nexport function RowValidationStatusColumn<T>(\n props: RowValidationStatusColumnProps<T>\n) {\n return (\n <GridColumn\n aria-label=\"Row status\"\n defaultWidth={30}\n cellValueComponent={RowValidationCell}\n {...props}\n />\n );\n}\n\nconst knownStatus = new Set([\"error\", \"warning\", \"success\"]);\n\nfunction RowValidationCell() {\n const rowValidationContext = useContext(RowValidationStatusContext);\n if (\n !rowValidationContext?.status ||\n !knownStatus.has(rowValidationContext.status)\n )\n return null;\n\n const validationStatus = rowValidationContext.status;\n\n return (\n <div\n style={{\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n height: \"100%\",\n width: \"100%\",\n }}\n >\n <StatusIndicator\n aria-label={`Row ${validationStatus}`}\n status={validationStatus}\n />\n </div>\n );\n}\n"],"names":["createContext"],"mappings":";;;;;;;;;AAIa,MAAA,0BAAA,GAA6BA,mBAEvC,CAAA,EAAE;;;;"}
@@ -0,0 +1,20 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var react = require('react');
6
+
7
+ const SelectionContext = react.createContext(
8
+ void 0
9
+ );
10
+ const useSelectionContext = () => {
11
+ const c = react.useContext(SelectionContext);
12
+ if (!c) {
13
+ throw new Error(`useSelectionContext invoked outside of a Grid`);
14
+ }
15
+ return c;
16
+ };
17
+
18
+ exports.SelectionContext = SelectionContext;
19
+ exports.useSelectionContext = useSelectionContext;
20
+ //# sourceMappingURL=SelectionContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectionContext.js","sources":["../src/SelectionContext.ts"],"sourcesContent":["import { createContext, useContext } from \"react\";\nimport { CellRange, SelectRowsOptions } from \"./internal\";\n\nexport interface SelectionContext {\n selectedCellRange: CellRange | undefined;\n selRowIdxs: Set<number>;\n isAnySelected: boolean;\n isAllSelected: boolean;\n selectRows: (args: SelectRowsOptions) => void;\n selectAll: () => void;\n unselectAll: () => void;\n}\n\nexport const SelectionContext = createContext<SelectionContext | undefined>(\n undefined\n);\n\nexport const useSelectionContext = () => {\n const c = useContext(SelectionContext);\n if (!c) {\n throw new Error(`useSelectionContext invoked outside of a Grid`);\n }\n return c;\n};\n"],"names":["createContext","useContext"],"mappings":";;;;;;AAaO,MAAM,gBAAmB,GAAAA,mBAAA;AAAA,EAC9B,KAAA,CAAA;AACF,EAAA;AAEO,MAAM,sBAAsB,MAAM;AACvC,EAAM,MAAA,CAAA,GAAIC,iBAAW,gBAAgB,CAAA,CAAA;AACrC,EAAA,IAAI,CAAC,CAAG,EAAA;AACN,IAAM,MAAA,IAAI,MAAM,CAA+C,6CAAA,CAAA,CAAA,CAAA;AAAA,GACjE;AACA,EAAO,OAAA,CAAA,CAAA;AACT;;;;;"}
@@ -0,0 +1,20 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var react = require('react');
6
+
7
+ const SizingContext = react.createContext(
8
+ void 0
9
+ );
10
+ const useSizingContext = () => {
11
+ const c = react.useContext(SizingContext);
12
+ if (!c) {
13
+ throw new Error(`useSizingContext invoked outside of a Grid`);
14
+ }
15
+ return c;
16
+ };
17
+
18
+ exports.SizingContext = SizingContext;
19
+ exports.useSizingContext = useSizingContext;
20
+ //# sourceMappingURL=SizingContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SizingContext.js","sources":["../src/SizingContext.ts"],"sourcesContent":["import React, { createContext, useContext } from \"react\";\n\nexport interface SizingContext {\n rowHeight: number;\n resizeColumn: (colIdx: number, width: number) => void;\n onResizeHandleMouseDown: (event: React.MouseEvent<HTMLDivElement>) => void;\n}\n\nexport const SizingContext = createContext<SizingContext | undefined>(\n undefined\n);\nexport const useSizingContext = () => {\n const c = useContext(SizingContext);\n if (!c) {\n throw new Error(`useSizingContext invoked outside of a Grid`);\n }\n return c;\n};\n"],"names":["createContext","useContext"],"mappings":";;;;;;AAQO,MAAM,aAAgB,GAAAA,mBAAA;AAAA,EAC3B,KAAA,CAAA;AACF,EAAA;AACO,MAAM,mBAAmB,MAAM;AACpC,EAAM,MAAA,CAAA,GAAIC,iBAAW,aAAa,CAAA,CAAA;AAClC,EAAA,IAAI,CAAC,CAAG,EAAA;AACN,IAAM,MAAA,IAAI,MAAM,CAA4C,0CAAA,CAAA,CAAA,CAAA;AAAA,GAC9D;AACA,EAAO,OAAA,CAAA,CAAA;AACT;;;;;"}
@@ -0,0 +1,6 @@
1
+ 'use strict';
2
+
3
+ var css_248z = ".saltGridTextCellEditor {\n}\n\n.saltGridTextCellEditor-inputContainer {\n background: var(--grid-background);\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n box-sizing: border-box;\n border-style: var(--grid-cursor-border-style);\n border-width: var(--grid-cursor-border-width);\n border-color: var(--grid-cursor-borderColor);\n padding: 0;\n}\n\n.saltGridTextCellEditor input {\n position: absolute;\n top: 0;\n left: 0;\n bottom: 0;\n right: 0;\n outline: none;\n border: none;\n padding: 0 calc(var(--grid-padding) - 2px);\n font-size: var(--grid-fontSize);\n font-family: inherit;\n background: var(--grid-editableCell-background-active);\n color: var(--grid-editableCell-color-active);\n}\n";
4
+
5
+ module.exports = css_248z;
6
+ //# sourceMappingURL=TextCellEditor.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TextCellEditor.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}