@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,6 @@
1
+ 'use strict';
2
+
3
+ var css_248z = ".saltGridBaseCell-valueContainer {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n box-sizing: border-box;\n overflow: hidden;\n text-overflow: ellipsis;\n line-height: calc(var(--grid-row-height) - 2px);\n border-style: solid;\n border-width: 1px;\n border-color: transparent;\n --grid-cell-padding: 0 calc(var(--grid-padding) - 1px);\n}\n\n.saltGridCell-editable .saltGridBaseCell-valueContainer {\n border-style: solid;\n border-width: 1px;\n border-color: var(--grid-editableCell-borderColor);\n}\n\n.saltGridCell-editable:hover .saltGridBaseCell-valueContainer {\n border-color: var(--grid-editableCell-borderColor-hover);\n}\n\n.saltGridCell-editable:focus .saltGridBaseCell-valueContainer {\n border-color: transparent;\n}\n\n.saltGridBaseCell-status-error {\n --status-border-color: var(--salt-status-error-borderColor);\n --status-background-color: var(--salt-status-error-background-emphasize);\n}\n\n.saltGridBaseCell-status-warning {\n --status-border-color: var(--salt-status-warning-borderColor);\n --status-background-color: var(--salt-status-warning-background-emphasize);\n}\n\n.saltGridBaseCell-status-success {\n --status-border-color: var(--salt-status-success-borderColor);\n --status-background-color: var(--salt-status-success-background-emphasize);\n}\n\n.saltGridCell-editable .saltGridBaseCell-valueContainer {\n border-color: var(--status-border-color);\n}\n\n.saltGridBaseCell-hasValidation:focus .saltGridCursor {\n border-color: var(--status-border-color);\n}\n\n.saltGridBaseCell-hasValidation:focus .saltGridCornerTag-focusOnly {\n border-left-color: var(--status-border-color);\n}\n\n.saltGridBaseCell-valueContainer {\n background-color: var(--status-background-color);\n}\n\n.salt-density-high {\n --grid-statusIndicator-size: 5px;\n}\n\n.salt-density-medium {\n --grid-statusIndicator-size: 6px;\n}\n\n.salt-density-low {\n --grid-statusIndicator-size: 7px;\n}\n\n.salt-density-touch {\n --grid-statusIndicator-size: 9px;\n}\n\n.saltGridBaseCell-statusContainer {\n font-size: var(--saltGrid-statusIndicator-size, var(--grid-statusIndicator-size));\n position: absolute;\n bottom: 3px;\n right: 3px;\n}\n\n.saltGridBaseCell-statusContainer svg {\n display: block;\n fill: var(--status-border-color);\n}\n\n.saltGridBaseCell-statusContainer.saltGridBaseCell-statusContainer-align-right {\n right: auto;\n left: 3px;\n}\n";
4
+
5
+ module.exports = css_248z;
6
+ //# sourceMappingURL=BaseCell.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BaseCell.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -0,0 +1,116 @@
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 Cell = require('./internal/Cell.js');
11
+ require('./internal/CellMeasure.js');
12
+ var Cursor = require('./internal/Cursor.js');
13
+ require('./internal/GroupHeaderRow.js');
14
+ require('./internal/HeaderRow.js');
15
+ require('./internal/LeftPart.js');
16
+ require('./internal/MiddlePart.js');
17
+ require('./internal/RightPart.js');
18
+ require('./internal/Scrollable.js');
19
+ require('react');
20
+ require('./internal/TableRow.js');
21
+ require('./SelectionContext.js');
22
+ require('./EditorContext.js');
23
+ require('./CursorContext.js');
24
+ var gridHooks = require('./internal/gridHooks.js');
25
+ require('./internal/TopLeftPart.js');
26
+ require('./internal/TopPart.js');
27
+ require('./internal/TopRightPart.js');
28
+ require('./internal/DefaultCellValue.js');
29
+ var CornerTag = require('./CornerTag.js');
30
+ var CellStatusIcons = require('./internal/CellStatusIcons.js');
31
+ var BaseCell$1 = require('./BaseCell.css.js');
32
+
33
+ const withBaseName = core.makePrefixer("saltGridBaseCell");
34
+ function getCellId(rowKey, column) {
35
+ return `R${rowKey}C${column.info.props.id}`;
36
+ }
37
+ const icons = {
38
+ warning: CellStatusIcons.CellWarningIcon,
39
+ error: CellStatusIcons.CellErrorIcon,
40
+ success: CellStatusIcons.CellSuccessIcon
41
+ };
42
+ function BaseCell(props) {
43
+ const {
44
+ column,
45
+ className,
46
+ row,
47
+ style,
48
+ isFocused,
49
+ isSelected,
50
+ isEditable,
51
+ children,
52
+ validationStatus,
53
+ validationMessage,
54
+ validationType = "light",
55
+ align
56
+ } = props;
57
+ const targetWindow = window.useWindow();
58
+ styles.useComponentCssInjection({
59
+ testId: "salt-base-cell",
60
+ css: BaseCell$1,
61
+ window: targetWindow
62
+ });
63
+ const { ref, isFocusableContent, onFocus } = gridHooks.useFocusableContent();
64
+ const cellId = getCellId(row.key, column);
65
+ const hasValidation = !!validationStatus;
66
+ const hasValidationMessage = !!validationMessage || hasValidation;
67
+ const validationMessageId = `${cellId}-statusMessage`;
68
+ return /* @__PURE__ */ jsxRuntime.jsxs(Cell.Cell, {
69
+ ref,
70
+ id: cellId,
71
+ "data-row-index": row.index,
72
+ "data-column-index": column.index,
73
+ "data-testid": isFocused ? "grid-cell-focused" : void 0,
74
+ "aria-colindex": column.index + 1,
75
+ role: "gridcell",
76
+ separator: column.separator,
77
+ isSelected,
78
+ isEditable,
79
+ className: clsx.clsx(className, {
80
+ [withBaseName("hasValidation")]: hasValidation,
81
+ [withBaseName(`status-${validationStatus}`)]: validationStatus
82
+ }),
83
+ style,
84
+ tabIndex: isFocused && !isFocusableContent ? 0 : -1,
85
+ onFocus,
86
+ "aria-invalid": validationStatus === "error" || void 0,
87
+ "aria-describedby": hasValidationMessage ? validationMessageId : void 0,
88
+ children: [
89
+ hasValidationMessage ? /* @__PURE__ */ jsxRuntime.jsx("div", {
90
+ id: validationMessageId,
91
+ className: "salt-visuallyHidden",
92
+ "aria-hidden": true,
93
+ role: "status",
94
+ children: validationMessage ? validationMessage : `Cell validation state is ${validationStatus}`
95
+ }) : null,
96
+ /* @__PURE__ */ jsxRuntime.jsx("div", {
97
+ className: clsx.clsx(withBaseName("valueContainer")),
98
+ children
99
+ }),
100
+ hasValidation && validationType === "strong" ? /* @__PURE__ */ jsxRuntime.jsx("div", {
101
+ className: clsx.clsx(withBaseName("statusContainer"), {
102
+ [withBaseName(`statusContainer-align-${align}`)]: align
103
+ }),
104
+ children: icons[validationStatus]
105
+ }) : null,
106
+ isFocused && isEditable && /* @__PURE__ */ jsxRuntime.jsx(CornerTag.CornerTag, {
107
+ focusOnly: true
108
+ }),
109
+ isFocused && !isFocusableContent && /* @__PURE__ */ jsxRuntime.jsx(Cursor.Cursor, {})
110
+ ]
111
+ });
112
+ }
113
+
114
+ exports.BaseCell = BaseCell;
115
+ exports.getCellId = getCellId;
116
+ //# sourceMappingURL=BaseCell.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BaseCell.js","sources":["../src/BaseCell.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport { makePrefixer } from \"@salt-ds/core\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { GridCellProps } from \"./GridColumn\";\nimport { GridColumnModel } from \"./Grid\";\nimport { Cell, Cursor, useFocusableContent } from \"./internal\";\nimport { CornerTag } from \"./CornerTag\";\nimport {\n CellErrorIcon,\n CellSuccessIcon,\n CellWarningIcon,\n} from \"./internal/CellStatusIcons\";\n\nimport baseCellCss from \"./BaseCell.css\";\n\nconst withBaseName = makePrefixer(\"saltGridBaseCell\");\n\nexport function getCellId<T>(rowKey: string, column: GridColumnModel<T>) {\n return `R${rowKey}C${column.info.props.id}`;\n}\n\nconst icons = {\n warning: CellWarningIcon,\n error: CellErrorIcon,\n success: CellSuccessIcon,\n};\n\n// Default component for grid cells. Provides selection, on-hover highlighting,\n// cursor etc.\nexport function BaseCell<T>(props: GridCellProps<T>) {\n const {\n column,\n className,\n row,\n style,\n isFocused,\n isSelected,\n isEditable,\n children,\n validationStatus,\n validationMessage,\n validationType = \"light\",\n align,\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-base-cell\",\n css: baseCellCss,\n window: targetWindow,\n });\n\n const { ref, isFocusableContent, onFocus } =\n useFocusableContent<HTMLTableCellElement>();\n const cellId = getCellId(row.key, column);\n const hasValidation = !!validationStatus;\n const hasValidationMessage = !!validationMessage || hasValidation;\n const validationMessageId = `${cellId}-statusMessage`;\n return (\n <Cell\n ref={ref}\n id={cellId}\n data-row-index={row.index}\n data-column-index={column.index}\n data-testid={isFocused ? \"grid-cell-focused\" : undefined}\n // aria-colindex uses one-based array indexing\n aria-colindex={column.index + 1}\n role=\"gridcell\"\n separator={column.separator}\n isSelected={isSelected}\n isEditable={isEditable}\n className={clsx(className, {\n [withBaseName(\"hasValidation\")]: hasValidation,\n [withBaseName(`status-${validationStatus as string}`)]:\n validationStatus,\n })}\n style={style}\n tabIndex={isFocused && !isFocusableContent ? 0 : -1}\n onFocus={onFocus}\n aria-invalid={validationStatus === \"error\" || undefined}\n aria-describedby={hasValidationMessage ? validationMessageId : undefined}\n >\n {hasValidationMessage ? (\n <div\n id={validationMessageId}\n className=\"salt-visuallyHidden\"\n aria-hidden\n role=\"status\"\n >\n {validationMessage\n ? validationMessage\n : `Cell validation state is ${validationStatus as string}`}\n </div>\n ) : null}\n <div className={clsx(withBaseName(\"valueContainer\"))}>{children}</div>\n {hasValidation && validationType === \"strong\" ? (\n <div\n className={clsx(withBaseName(\"statusContainer\"), {\n [withBaseName(`statusContainer-align-${align as string}`)]: align,\n })}\n >\n {icons[validationStatus]}\n </div>\n ) : null}\n {isFocused && isEditable && <CornerTag focusOnly={true} />}\n {isFocused && !isFocusableContent && <Cursor />}\n </Cell>\n );\n}\n"],"names":["makePrefixer","CellWarningIcon","CellErrorIcon","CellSuccessIcon","useWindow","useComponentCssInjection","baseCellCss","useFocusableContent","jsxs","Cell","clsx","jsx","CornerTag","Cursor"],"mappings":"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"}
@@ -0,0 +1,29 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var react = require('react');
6
+ var GridContext = require('./GridContext.js');
7
+
8
+ function CellEditor(props) {
9
+ const { children } = props;
10
+ const columnId = props.columnId;
11
+ const grid = GridContext.useGridContext();
12
+ const info = react.useMemo(
13
+ () => ({
14
+ columnId,
15
+ children
16
+ }),
17
+ [columnId, children]
18
+ );
19
+ react.useEffect(() => {
20
+ grid.onEditorAdded(info);
21
+ return () => {
22
+ grid.onEditorRemoved(info);
23
+ };
24
+ }, [info]);
25
+ return null;
26
+ }
27
+
28
+ exports.CellEditor = CellEditor;
29
+ //# sourceMappingURL=CellEditor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CellEditor.js","sources":["../src/CellEditor.tsx"],"sourcesContent":["import { ReactNode, useEffect, useMemo } from \"react\";\nimport { useGridContext } from \"./GridContext\";\n\nexport interface CellEditorInfo<T> {\n columnId: string;\n children: ReactNode;\n}\n\nexport interface CellEditorProps<T> {\n columnId?: string;\n children: ReactNode;\n}\n\n// Non-rendered component. Used as a child of GridColumn. Children prop is\n// expected to be a specific implementation of cell editor (text, dropdown etc)\n// Registers the editor in the grid. The grid then renders the editor when\n// edit mode is activated.\n// TODO This feature is experimental.\nexport function CellEditor<T>(props: CellEditorProps<T>) {\n const { children } = props;\n const columnId = props.columnId!;\n const grid = useGridContext();\n\n const info = useMemo(\n () => ({\n columnId,\n children,\n }),\n [columnId, children]\n );\n\n useEffect(() => {\n grid.onEditorAdded(info);\n return () => {\n grid.onEditorRemoved(info);\n };\n }, [info]);\n\n return null;\n}\n"],"names":["useGridContext","useMemo","useEffect"],"mappings":";;;;;;;AAkBO,SAAS,WAAc,KAA2B,EAAA;AACvD,EAAM,MAAA,EAAE,UAAa,GAAA,KAAA,CAAA;AACrB,EAAA,MAAM,WAAW,KAAM,CAAA,QAAA,CAAA;AACvB,EAAA,MAAM,OAAOA,0BAAe,EAAA,CAAA;AAE5B,EAAA,MAAM,IAAO,GAAAC,aAAA;AAAA,IACX,OAAO;AAAA,MACL,QAAA;AAAA,MACA,QAAA;AAAA,KACF,CAAA;AAAA,IACA,CAAC,UAAU,QAAQ,CAAA;AAAA,GACrB,CAAA;AAEA,EAAAC,eAAA,CAAU,MAAM;AACd,IAAA,IAAA,CAAK,cAAc,IAAI,CAAA,CAAA;AACvB,IAAA,OAAO,MAAM;AACX,MAAA,IAAA,CAAK,gBAAgB,IAAI,CAAA,CAAA;AAAA,KAC3B,CAAA;AAAA,GACF,EAAG,CAAC,IAAI,CAAC,CAAA,CAAA;AAET,EAAO,OAAA,IAAA,CAAA;AACT;;;;"}
@@ -0,0 +1,6 @@
1
+ 'use strict';
2
+
3
+ var css_248z = ".saltGridCheckboxContainer {\n height: 100%;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n}\n";
4
+
5
+ module.exports = css_248z;
6
+ //# sourceMappingURL=CheckboxCell.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CheckboxCell.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -0,0 +1,18 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var react = require('react');
6
+
7
+ const ColumnDataContext = react.createContext(void 0);
8
+ const useColumnDataContext = () => {
9
+ const c = react.useContext(ColumnDataContext);
10
+ if (!c) {
11
+ throw new Error(`useColumnDataContext invoked outside of a Grid`);
12
+ }
13
+ return c;
14
+ };
15
+
16
+ exports.ColumnDataContext = ColumnDataContext;
17
+ exports.useColumnDataContext = useColumnDataContext;
18
+ //# sourceMappingURL=ColumnDataContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ColumnDataContext.js","sources":["../src/ColumnDataContext.ts"],"sourcesContent":["import { createContext, useContext } from \"react\";\nimport type { GridColumnModel } from \"./Grid\";\n\nexport interface ColumnDataContext<T> {\n getColById: (id: string) => GridColumnModel<T> | undefined;\n}\n\nexport const ColumnDataContext = createContext<\n ColumnDataContext<any> | undefined\n>(undefined);\n\nexport const useColumnDataContext = () => {\n const c = useContext(ColumnDataContext);\n if (!c) {\n throw new Error(`useColumnDataContext invoked outside of a Grid`);\n }\n return c;\n};\n"],"names":["createContext","useContext"],"mappings":";;;;;;AAOa,MAAA,iBAAA,GAAoBA,oBAE/B,KAAS,CAAA,EAAA;AAEJ,MAAM,uBAAuB,MAAM;AACxC,EAAM,MAAA,CAAA,GAAIC,iBAAW,iBAAiB,CAAA,CAAA;AACtC,EAAA,IAAI,CAAC,CAAG,EAAA;AACN,IAAM,MAAA,IAAI,MAAM,CAAgD,8CAAA,CAAA,CAAA,CAAA;AAAA,GAClE;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 ColumnDragContext = react.createContext(
8
+ void 0
9
+ );
10
+ const useColumnDragContext = () => {
11
+ const c = react.useContext(ColumnDragContext);
12
+ if (!c) {
13
+ throw new Error(`useColumnDragContext invoked outside of a Grid`);
14
+ }
15
+ return c;
16
+ };
17
+
18
+ exports.ColumnDragContext = ColumnDragContext;
19
+ exports.useColumnDragContext = useColumnDragContext;
20
+ //# sourceMappingURL=ColumnDragContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ColumnDragContext.js","sources":["../src/ColumnDragContext.ts"],"sourcesContent":["import { createContext, MouseEventHandler, useContext } from \"react\";\n\nexport interface ColumnDragContext {\n columnMove?: boolean;\n onColumnMoveHandleMouseDown: MouseEventHandler<HTMLDivElement>;\n}\n\nexport const ColumnDragContext = createContext<ColumnDragContext | undefined>(\n undefined\n);\n\nexport const useColumnDragContext = () => {\n const c = useContext(ColumnDragContext);\n if (!c) {\n throw new Error(`useColumnDragContext invoked outside of a Grid`);\n }\n return c;\n};\n"],"names":["createContext","useContext"],"mappings":";;;;;;AAOO,MAAM,iBAAoB,GAAAA,mBAAA;AAAA,EAC/B,KAAA,CAAA;AACF,EAAA;AAEO,MAAM,uBAAuB,MAAM;AACxC,EAAM,MAAA,CAAA,GAAIC,iBAAW,iBAAiB,CAAA,CAAA;AACtC,EAAA,IAAI,CAAC,CAAG,EAAA;AACN,IAAM,MAAA,IAAI,MAAM,CAAgD,8CAAA,CAAA,CAAA,CAAA;AAAA,GAClE;AACA,EAAO,OAAA,CAAA,CAAA;AACT;;;;;"}
@@ -0,0 +1,32 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var GridContext = require('./GridContext.js');
7
+ var react = require('react');
8
+
9
+ function ColumnGroup(props) {
10
+ const pinned = props.pinned || null;
11
+ const indexRef = react.useRef();
12
+ const grid = GridContext.useGridContext();
13
+ react.useEffect(() => {
14
+ indexRef.current = grid.getChildIndex(props.id);
15
+ grid.onColumnGroupAdded(props);
16
+ return () => {
17
+ grid.onColumnGroupRemoved(indexRef.current, props);
18
+ };
19
+ });
20
+ const childrenWithPinnedOverridden = react.Children.map(props.children, (child) => {
21
+ if (react.isValidElement(child)) {
22
+ return react.cloneElement(child, { pinned });
23
+ }
24
+ return child;
25
+ });
26
+ return /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, {
27
+ children: childrenWithPinnedOverridden
28
+ });
29
+ }
30
+
31
+ exports.ColumnGroup = ColumnGroup;
32
+ //# sourceMappingURL=ColumnGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ColumnGroup.js","sources":["../src/ColumnGroup.tsx"],"sourcesContent":["import { useGridContext } from \"./GridContext\";\nimport {\n Children,\n cloneElement,\n ComponentType,\n isValidElement,\n ReactNode,\n useEffect,\n useRef,\n} from \"react\";\nimport { GridColumnPin } from \"./GridColumn\";\nimport { GridColumnGroupModel } from \"./Grid\";\n\nexport interface ColumnGroupCellProps {\n group: GridColumnGroupModel;\n}\n\nexport interface ColumnGroupCellValueProps {\n group: GridColumnGroupModel;\n}\n\nexport interface ColumnGroupProps {\n children: ReactNode;\n name: string;\n id: string;\n pinned?: GridColumnPin;\n headerComponent?: ComponentType<ColumnGroupCellProps>;\n headerValueComponent?: ComponentType<ColumnGroupCellValueProps>;\n}\n\nexport function ColumnGroup(props: ColumnGroupProps) {\n const pinned = props.pinned || null;\n const indexRef = useRef<number>();\n const grid = useGridContext();\n useEffect(() => {\n indexRef.current = grid.getChildIndex(props.id);\n grid.onColumnGroupAdded(props);\n return () => {\n grid.onColumnGroupRemoved(indexRef.current!, props);\n };\n });\n const childrenWithPinnedOverridden = Children.map(props.children, (child) => {\n if (isValidElement(child)) {\n return cloneElement(child, { pinned });\n }\n return child;\n });\n return <>{childrenWithPinnedOverridden}</>;\n}\n"],"names":["useRef","useGridContext","useEffect","Children","isValidElement","cloneElement","jsx","Fragment"],"mappings":";;;;;;;;AA8BO,SAAS,YAAY,KAAyB,EAAA;AACnD,EAAM,MAAA,MAAA,GAAS,MAAM,MAAU,IAAA,IAAA,CAAA;AAC/B,EAAA,MAAM,WAAWA,YAAe,EAAA,CAAA;AAChC,EAAA,MAAM,OAAOC,0BAAe,EAAA,CAAA;AAC5B,EAAAC,eAAA,CAAU,MAAM;AACd,IAAA,QAAA,CAAS,OAAU,GAAA,IAAA,CAAK,aAAc,CAAA,KAAA,CAAM,EAAE,CAAA,CAAA;AAC9C,IAAA,IAAA,CAAK,mBAAmB,KAAK,CAAA,CAAA;AAC7B,IAAA,OAAO,MAAM;AACX,MAAK,IAAA,CAAA,oBAAA,CAAqB,QAAS,CAAA,OAAA,EAAU,KAAK,CAAA,CAAA;AAAA,KACpD,CAAA;AAAA,GACD,CAAA,CAAA;AACD,EAAA,MAAM,+BAA+BC,cAAS,CAAA,GAAA,CAAI,KAAM,CAAA,QAAA,EAAU,CAAC,KAAU,KAAA;AAC3E,IAAI,IAAAC,oBAAA,CAAe,KAAK,CAAG,EAAA;AACzB,MAAA,OAAOC,kBAAa,CAAA,KAAA,EAAO,EAAE,MAAA,EAAQ,CAAA,CAAA;AAAA,KACvC;AACA,IAAO,OAAA,KAAA,CAAA;AAAA,GACR,CAAA,CAAA;AACD,EAAO,uBAAAC,cAAA,CAAAC,mBAAA,EAAA;AAAA,IAAG,QAAA,EAAA,4BAAA;AAAA,GAA6B,CAAA,CAAA;AACzC;;;;"}
@@ -0,0 +1,20 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var react = require('react');
6
+
7
+ const ColumnSortContext = react.createContext(
8
+ void 0
9
+ );
10
+ const useColumnSortContext = () => {
11
+ const c = react.useContext(ColumnSortContext);
12
+ if (!c) {
13
+ throw new Error(`useColumnSortContext invoked outside of a Grid`);
14
+ }
15
+ return c;
16
+ };
17
+
18
+ exports.ColumnSortContext = ColumnSortContext;
19
+ exports.useColumnSortContext = useColumnSortContext;
20
+ //# sourceMappingURL=ColumnSortContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ColumnSortContext.js","sources":["../src/ColumnSortContext.ts"],"sourcesContent":["import React, { createContext, useContext } from \"react\";\nimport { SortOrder } from \"./Grid\";\nimport { GridColumnProps } from \"./GridColumn\";\n\nexport interface ColumnSortContext {\n sortByColumnId?: GridColumnProps[\"id\"];\n setSortByColumnId: (c: React.SetStateAction<GridColumnProps[\"id\"]>) => void;\n sortOrder: SortOrder;\n setSortOrder: (o: SortOrder) => void;\n onClickSortColumn: (colHeaderId: GridColumnProps[\"id\"]) => void;\n}\n\nexport const ColumnSortContext = createContext<ColumnSortContext | undefined>(\n undefined\n);\n\nexport const useColumnSortContext = () => {\n const c = useContext(ColumnSortContext);\n if (!c) {\n throw new Error(`useColumnSortContext invoked outside of a Grid`);\n }\n return c;\n};\n"],"names":["createContext","useContext"],"mappings":";;;;;;AAYO,MAAM,iBAAoB,GAAAA,mBAAA;AAAA,EAC/B,KAAA,CAAA;AACF,EAAA;AAEO,MAAM,uBAAuB,MAAM;AACxC,EAAM,MAAA,CAAA,GAAIC,iBAAW,iBAAiB,CAAA,CAAA;AACtC,EAAA,IAAI,CAAC,CAAG,EAAA;AACN,IAAM,MAAA,IAAI,MAAM,CAAgD,8CAAA,CAAA,CAAA,CAAA;AAAA,GAClE;AACA,EAAO,OAAA,CAAA,CAAA;AACT;;;;;"}
@@ -0,0 +1,6 @@
1
+ 'use strict';
2
+
3
+ var css_248z = ".saltGridCornerTag,\n:focus .saltGridCornerTag-focusOnly {\n position: absolute;\n top: 0;\n left: 0;\n width: 0;\n height: 0;\n border-top: 0 solid transparent;\n border-left: var(--grid-editableCell-cornerTag-size) solid var(--grid-cursor-borderColor);\n border-bottom: var(--grid-editableCell-cornerTag-size) solid transparent;\n}\n";
4
+
5
+ module.exports = css_248z;
6
+ //# sourceMappingURL=CornerTag.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CornerTag.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -0,0 +1,23 @@
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 CornerTag$1 = require('./CornerTag.css.js');
9
+
10
+ function CornerTag(props) {
11
+ const targetWindow = window.useWindow();
12
+ styles.useComponentCssInjection({
13
+ testId: "salt-corner-tag",
14
+ css: CornerTag$1,
15
+ window: targetWindow
16
+ });
17
+ return /* @__PURE__ */ jsxRuntime.jsx("div", {
18
+ className: props.focusOnly ? "saltGridCornerTag-focusOnly" : "saltGridCornerTag"
19
+ });
20
+ }
21
+
22
+ exports.CornerTag = CornerTag;
23
+ //# sourceMappingURL=CornerTag.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CornerTag.js","sources":["../src/CornerTag.tsx"],"sourcesContent":["import { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport cornerTagCss from \"./CornerTag.css\";\n\nexport interface CornerTagProps {\n focusOnly?: boolean; // Show when the parent is focused, hide when not\n}\n\nexport function CornerTag(props: CornerTagProps) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-corner-tag\",\n css: cornerTagCss,\n window: targetWindow,\n });\n\n return (\n <div\n className={\n props.focusOnly ? \"saltGridCornerTag-focusOnly\" : \"saltGridCornerTag\"\n }\n />\n );\n}\n"],"names":["useWindow","useComponentCssInjection","cornerTagCss","jsx"],"mappings":";;;;;;;;;AASO,SAAS,UAAU,KAAuB,EAAA;AAC/C,EAAA,MAAM,eAAeA,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,iBAAA;AAAA,IACR,GAAK,EAAAC,WAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,IACC,SAAA,EACE,KAAM,CAAA,SAAA,GAAY,6BAAgC,GAAA,mBAAA;AAAA,GAEtD,CAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,20 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var react = require('react');
6
+
7
+ const CursorContext = react.createContext(
8
+ void 0
9
+ );
10
+ const useCursorContext = () => {
11
+ const c = react.useContext(CursorContext);
12
+ if (!c) {
13
+ throw new Error(`useCursorContext invoked outside of a Grid`);
14
+ }
15
+ return c;
16
+ };
17
+
18
+ exports.CursorContext = CursorContext;
19
+ exports.useCursorContext = useCursorContext;
20
+ //# sourceMappingURL=CursorContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CursorContext.js","sources":["../src/CursorContext.ts"],"sourcesContent":["import { createContext, useContext } from \"react\";\n\nexport type FocusedPart = \"header\" | \"body\";\n\nexport interface CursorContext {\n isFocused: boolean;\n cursorRowIdx: number | undefined;\n cursorColIdx: number | undefined;\n moveCursor: (part: FocusedPart, rowIdx: number, colIdx: number) => void;\n focusedPart: FocusedPart;\n headerIsFocusable: boolean;\n}\n\nexport const CursorContext = createContext<CursorContext | undefined>(\n undefined\n);\nexport const useCursorContext = () => {\n const c = useContext(CursorContext);\n if (!c) {\n throw new Error(`useCursorContext invoked outside of a Grid`);\n }\n return c;\n};\n"],"names":["createContext","useContext"],"mappings":";;;;;;AAaO,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 = ".saltGridDropdownCellEditor {\n font-size: var(--grid-fontSize);\n}\n\n.saltGridDropdownCellEditor-dropdownContainer {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n box-sizing: border-box;\n background: var(--grid-background);\n border-style: dotted;\n border-width: 2px;\n border-color: var(--grid-cursor-borderColor);\n padding: 0;\n}\n\n/* TODO this is currently the same as saltGridBaseCell-valueContainer. Update when UX is available. */\n.saltGridDropdownCellEditor-currentValue {\n height: calc(var(--grid-row-height) - 4px);\n box-sizing: border-box;\n overflow: hidden;\n text-overflow: ellipsis;\n line-height: calc(var(--grid-row-height) - 4px);\n\n outline: none;\n\n padding: 0 calc(var(--grid-padding) - 2px);\n}\n";
4
+
5
+ module.exports = css_248z;
6
+ //# sourceMappingURL=DropdownCellEditor.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DropdownCellEditor.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -0,0 +1,82 @@
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 core = require('@salt-ds/core');
8
+ var lab = require('@salt-ds/lab');
9
+ var window = require('@salt-ds/window');
10
+ var styles = require('@salt-ds/styles');
11
+ var EditorContext = require('./EditorContext.js');
12
+ var CornerTag = require('./CornerTag.js');
13
+ var Cell = require('./internal/Cell.js');
14
+ require('./internal/CellMeasure.js');
15
+ require('./internal/Cursor.js');
16
+ require('./internal/GroupHeaderRow.js');
17
+ require('./internal/HeaderRow.js');
18
+ require('./internal/LeftPart.js');
19
+ require('./internal/MiddlePart.js');
20
+ require('./internal/RightPart.js');
21
+ require('./internal/Scrollable.js');
22
+ require('./internal/TableRow.js');
23
+ require('./SelectionContext.js');
24
+ require('./CursorContext.js');
25
+ require('./NumberRange.js');
26
+ require('./internal/TopLeftPart.js');
27
+ require('./internal/TopPart.js');
28
+ require('./internal/TopRightPart.js');
29
+ require('./internal/DefaultCellValue.js');
30
+ var DropdownCellEditor$1 = require('./DropdownCellEditor.css.js');
31
+
32
+ const withBaseName = core.makePrefixer("saltGridDropdownCellEditor");
33
+ function DropdownCellEditor(props) {
34
+ const { options, column, row } = props;
35
+ const targetWindow = window.useWindow();
36
+ styles.useComponentCssInjection({
37
+ testId: "salt-dropdown-cell-editor",
38
+ css: DropdownCellEditor$1,
39
+ window: targetWindow
40
+ });
41
+ const triggerRef = react.useRef(null);
42
+ const value = column.info.props.getValue(row.data);
43
+ const { endEditMode } = EditorContext.useEditorContext();
44
+ const onSelectionChange = (event, item) => {
45
+ if (item) {
46
+ endEditMode(item);
47
+ }
48
+ };
49
+ react.useEffect(() => {
50
+ if (triggerRef.current) {
51
+ triggerRef.current.focus();
52
+ }
53
+ }, [triggerRef.current]);
54
+ const triggerComponent = /* @__PURE__ */ jsxRuntime.jsx("div", {
55
+ tabIndex: 0,
56
+ ref: triggerRef,
57
+ className: withBaseName("currentValue"),
58
+ "data-testid": "grid-cell-editor-trigger",
59
+ children: value
60
+ });
61
+ return /* @__PURE__ */ jsxRuntime.jsxs(Cell.Cell, {
62
+ separator: column == null ? void 0 : column.separator,
63
+ className: withBaseName(),
64
+ children: [
65
+ /* @__PURE__ */ jsxRuntime.jsx("div", {
66
+ className: withBaseName("dropdownContainer"),
67
+ children: /* @__PURE__ */ jsxRuntime.jsx(lab.Dropdown, {
68
+ isOpen: true,
69
+ source: options,
70
+ defaultSelected: value,
71
+ onSelectionChange,
72
+ triggerComponent,
73
+ width: column.info.width - 5
74
+ })
75
+ }),
76
+ /* @__PURE__ */ jsxRuntime.jsx(CornerTag.CornerTag, {})
77
+ ]
78
+ });
79
+ }
80
+
81
+ exports.DropdownCellEditor = DropdownCellEditor;
82
+ //# sourceMappingURL=DropdownCellEditor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DropdownCellEditor.js","sources":["../src/DropdownCellEditor.tsx"],"sourcesContent":["import { useEffect, useRef } from \"react\";\nimport { makePrefixer } from \"@salt-ds/core\";\nimport { Dropdown, SelectionChangeHandler } from \"@salt-ds/lab\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { useEditorContext } from \"./EditorContext\";\nimport { GridColumnModel, GridRowModel } from \"./Grid\";\nimport { CornerTag } from \"./CornerTag\";\nimport { Cell } from \"./internal\";\n\nimport dropdownCellEditorCss from \"./DropdownCellEditor.css\";\n\nconst withBaseName = makePrefixer(\"saltGridDropdownCellEditor\");\n\nexport interface DropdownCellEditorProps<T> {\n options: ReadonlyArray<string>;\n // Row and column are provided by the grid. See TableRow.tsx\n row?: GridRowModel<T>;\n column?: GridColumnModel<T>;\n}\n\nexport function DropdownCellEditor<T>(props: DropdownCellEditorProps<T>) {\n const { options, column, row } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-dropdown-cell-editor\",\n css: dropdownCellEditorCss,\n window: targetWindow,\n });\n\n const triggerRef = useRef<HTMLDivElement>(null);\n\n const value = column!.info.props.getValue!(row!.data);\n\n const { endEditMode } = useEditorContext();\n\n const onSelectionChange: SelectionChangeHandler = (event, item) => {\n if (item) {\n endEditMode(item);\n }\n };\n\n useEffect(() => {\n if (triggerRef.current) {\n triggerRef.current.focus();\n }\n }, [triggerRef.current]);\n\n const triggerComponent = (\n <div\n tabIndex={0}\n ref={triggerRef}\n className={withBaseName(\"currentValue\")}\n data-testid=\"grid-cell-editor-trigger\"\n >\n {value}\n </div>\n );\n\n return (\n <Cell separator={column?.separator} className={withBaseName()}>\n <div className={withBaseName(\"dropdownContainer\")}>\n <Dropdown\n isOpen={true}\n source={options}\n defaultSelected={value}\n onSelectionChange={onSelectionChange}\n triggerComponent={triggerComponent}\n width={column!.info.width! - 5}\n />\n </div>\n <CornerTag />\n </Cell>\n );\n}\n"],"names":["makePrefixer","useWindow","useComponentCssInjection","dropdownCellEditorCss","useRef","useEditorContext","useEffect","jsx","jsxs","Cell","Dropdown","CornerTag"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAaA,MAAM,YAAA,GAAeA,kBAAa,4BAA4B,CAAA,CAAA;AASvD,SAAS,mBAAsB,KAAmC,EAAA;AACvE,EAAA,MAAM,EAAE,OAAA,EAAS,MAAQ,EAAA,GAAA,EAAQ,GAAA,KAAA,CAAA;AAEjC,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,2BAAA;AAAA,IACR,GAAK,EAAAC,oBAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAM,MAAA,UAAA,GAAaC,aAAuB,IAAI,CAAA,CAAA;AAE9C,EAAA,MAAM,QAAQ,MAAQ,CAAA,IAAA,CAAK,KAAM,CAAA,QAAA,CAAU,IAAK,IAAI,CAAA,CAAA;AAEpD,EAAM,MAAA,EAAE,WAAY,EAAA,GAAIC,8BAAiB,EAAA,CAAA;AAEzC,EAAM,MAAA,iBAAA,GAA4C,CAAC,KAAA,EAAO,IAAS,KAAA;AACjE,IAAA,IAAI,IAAM,EAAA;AACR,MAAA,WAAA,CAAY,IAAI,CAAA,CAAA;AAAA,KAClB;AAAA,GACF,CAAA;AAEA,EAAAC,eAAA,CAAU,MAAM;AACd,IAAA,IAAI,WAAW,OAAS,EAAA;AACtB,MAAA,UAAA,CAAW,QAAQ,KAAM,EAAA,CAAA;AAAA,KAC3B;AAAA,GACC,EAAA,CAAC,UAAW,CAAA,OAAO,CAAC,CAAA,CAAA;AAEvB,EAAA,MAAM,mCACHC,cAAA,CAAA,KAAA,EAAA;AAAA,IACC,QAAU,EAAA,CAAA;AAAA,IACV,GAAK,EAAA,UAAA;AAAA,IACL,SAAA,EAAW,aAAa,cAAc,CAAA;AAAA,IACtC,aAAY,EAAA,0BAAA;AAAA,IAEX,QAAA,EAAA,KAAA;AAAA,GACH,CAAA,CAAA;AAGF,EAAA,uBACGC,eAAA,CAAAC,SAAA,EAAA;AAAA,IAAK,WAAW,MAAQ,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,MAAA,CAAA,SAAA;AAAA,IAAW,WAAW,YAAa,EAAA;AAAA,IAC1D,QAAA,EAAA;AAAA,sBAACF,cAAA,CAAA,KAAA,EAAA;AAAA,QAAI,SAAA,EAAW,aAAa,mBAAmB,CAAA;AAAA,QAC9C,QAAC,kBAAAA,cAAA,CAAAG,YAAA,EAAA;AAAA,UACC,MAAQ,EAAA,IAAA;AAAA,UACR,MAAQ,EAAA,OAAA;AAAA,UACR,eAAiB,EAAA,KAAA;AAAA,UACjB,iBAAA;AAAA,UACA,gBAAA;AAAA,UACA,KAAA,EAAO,MAAQ,CAAA,IAAA,CAAK,KAAS,GAAA,CAAA;AAAA,SAC/B,CAAA;AAAA,OACF,CAAA;AAAA,qCACCC,mBAAU,EAAA,EAAA,CAAA;AAAA,KAAA;AAAA,GACb,CAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,20 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var react = require('react');
6
+
7
+ const EditorContext = react.createContext(
8
+ void 0
9
+ );
10
+ const useEditorContext = () => {
11
+ const c = react.useContext(EditorContext);
12
+ if (!c) {
13
+ throw new Error(`useEditorContext invoked outside of a Grid`);
14
+ }
15
+ return c;
16
+ };
17
+
18
+ exports.EditorContext = EditorContext;
19
+ exports.useEditorContext = useEditorContext;
20
+ //# sourceMappingURL=EditorContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"EditorContext.js","sources":["../src/EditorContext.ts"],"sourcesContent":["import { createContext, useContext } from \"react\";\n\nexport interface EditorContext {\n initialText?: string;\n editMode?: boolean;\n startEditMode: () => void;\n endEditMode: (value: string) => void;\n cancelEditMode: () => void;\n}\n\nexport const EditorContext = createContext<EditorContext | undefined>(\n undefined\n);\nexport const useEditorContext = () => {\n const c = useContext(EditorContext);\n if (!c) {\n throw new Error(`useEditorContext invoked outside of a Grid`);\n }\n return c;\n};\n"],"names":["createContext","useContext"],"mappings":";;;;;;AAUO,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 = ".salt-density-touch {\n --grid-row-height-default: 61px;\n --grid-padding-default: 16px;\n --grid-fontSize-default: 16px;\n --grid-header-fontSize-default: 14px;\n --grid-separatorGap-default: 20px;\n --grid-cornerTag-size-default: 14px;\n}\n\n.salt-density-low {\n --grid-row-height-default: 49px;\n --grid-padding-default: 12px;\n --grid-fontSize-default: 14px;\n --grid-header-fontSize-default: 12px;\n --grid-separatorGap-default: 16px;\n --grid-cornerTag-size-default: 12px;\n}\n\n.salt-density-medium {\n --grid-row-height-default: 37px;\n --grid-padding-default: 8px;\n --grid-fontSize-default: 12px;\n --grid-header-fontSize-default: 11px;\n --grid-separatorGap-default: 12px;\n --grid-cornerTag-size-default: 10px;\n}\n\n.salt-density-high {\n --grid-row-height-default: 25px;\n --grid-padding-default: 8px;\n --grid-fontSize-default: 11px;\n --grid-header-fontSize-default: 10px;\n --grid-separatorGap-default: 8px;\n --grid-cornerTag-size-default: 8px;\n}\n\n/* Styles applied to the root element */\n.saltGrid {\n --grid-row-height: var(--saltGrid-row-height, var(--grid-row-height-default));\n --grid-padding: var(--saltGrid-padding, var(--grid-padding-default));\n --grid-fontSize: var(--saltGrid-fontSize, var(--grid-fontSize-default));\n --grid-separatorGap: var(--saltGrid-separatorGap, var(--grid-separatorGap-default));\n --grid-header-fontSize: var(--saltGrid-header-fontSize, var(--grid-header-fontSize-default));\n --grid-groupHeader-fontSize: var(--saltGrid-groupHeader-fontSize, var(--grid-header-fontSize));\n --grid-groupHeader-fontWeight: var(--saltGrid-groupHeader-fontWeight, var(--salt-text-label-fontWeight-strong));\n\n --grid-cell-padding: 0 var(--grid-padding);\n\n --grid-background-primary: var(--saltGrid-background-primary, var(--salt-container-primary-background));\n --grid-background-secondary: var(--saltGrid-background-secondary, var(--salt-container-secondary-background));\n --grid-zebraColor: var(--saltGrid-zebraColor, var(--salt-container-secondary-background));\n\n --grid-row-background-hover: var(--saltGrid-row-background-hover, var(--salt-selectable-background-hover));\n --grid-row-background-selected: var(--saltGrid-row-background-selected, var(--salt-selectable-background-selected));\n\n --grid-row-borderColor-selected: var(--saltGrid-row-borderColor-selected, var(--salt-selectable-borderColor-selected));\n --grid-cell-background-selected: var(--saltGrid-cell-background-selected, var(--salt-selectable-background-selected));\n --grid-editableCell-borderColor: var(--saltGrid-editableCell-borderColor, var(--salt-editable-borderColor));\n --grid-editableCell-borderColor-hover: var(--saltGrid-editableCell-borderColor-hover, var(--salt-editable-borderColor-hover));\n --grid-editableCell-background-active: var(--saltGrid-editableCell-background-active, var(--salt-editable-primary-background-active));\n --grid-editableCell-color-active: var(--saltGrid-editableCell-color-active, var(--salt-text-primary-foreground));\n --grid-editableCell-cornerTag-size: var(--saltGrid-editableCell-cornerTag-size, var(--grid-cornerTag-size-default));\n\n --grid-header-color: var(--saltGrid-header-color, var(--salt-text-secondary-foreground));\n\n --grid-headerColumnSeparator-color: var(--saltGrid-headerColumnSeparator-color, var(--salt-separable-tertiary-borderColor));\n --grid-headerRowSeparator-color: var(--saltGrid-headerRowSeparator-color, var(--salt-separable-primary-borderColor));\n --grid-headerRowSeparator-gap: var(--saltGrid-headerRowSeparator-gap, var(--salt-size-unit));\n --grid-headerRowSeparator-height: var(--saltGrid-headerRowSeparator-height, 1px);\n --grid-groupHeaderRowSeparator-color: var(--saltGrid-groupHeaderRowSeparator-color, var(--salt-separable-tertiary-borderColor));\n\n --grid-groupHeader-color: var(--saltGrid-groupHeader-color, var(--salt-text-secondary-foreground));\n --grid-shadow-color: var(--saltGrid-shadow-color, var(--salt-shadow-1-color));\n --grid-columnDropTarget-color: var(--saltGrid-columnDropTarget-color, var(--salt-target-borderColor-hover));\n --grid-cursor-border-style: var(--saltGrid-cursor-borderStyle, var(--salt-focused-outlineStyle));\n --grid-cursor-border-width: var(--saltGrid-cursor-borderWidth, var(--salt-focused-outlineWidth));\n --grid-cursor-borderColor: var(--saltGrid-cursor-borderColor, var(--salt-focused-outlineColor));\n --grid-borderColor: var(--saltGrid-borderColor, var(--salt-container-secondary-borderColor));\n\n --grid-rowSeparator-width: 1px;\n --grid-rowSeparator-color: var(--saltGrid-rowSeparator-color, var(--salt-separable-tertiary-borderColor));\n --grid-columnSeparator-color: var(--saltGrid-columnSeparator-color, var(--salt-separable-tertiary-borderColor));\n --grid-rowSeparator-color-divided: var(--saltGrid-rowSeparator-color-divided, var(--salt-separable-secondary-borderColor));\n\n --grid-pinnedSeparator-color: var(--saltGrid-pinnedSeparator-color, var(--salt-separable-primary-borderColor));\n\n --grid-columnGhost-borderColor: var(--saltGrid-columnGhost-borderColor, var(--salt-palette-interact-border-hover));\n --grid-columnGhost-borderWidth: var(--saltGrid-columnGhost-borderWidth, 1px);\n --grid-columnGhost-boxShadow: var(--saltGrid-columnGhost-boxShadow, var(--salt-overlayable-shadow-drag));\n\n --grid-mid-body-zIndex: 0;\n --grid-left-body-zIndex: 1;\n --grid-right-body-zIndex: 1;\n --grid-middle-header-zIndex: 2;\n --grid-left-header-zIndex: 3;\n --grid-right-header-zIndex: 3;\n}\n\n.saltGrid-columnSeparators {\n}\n\n.saltGrid table {\n border-collapse: separate;\n border-spacing: 0;\n}\n\n.saltGrid-framed {\n border: solid 1px var(--grid-borderColor);\n}\n\n/* Styles applied to the root element if variant=\"primary\" */\n.saltGrid-primaryBackground {\n --grid-background: var(--grid-background-primary);\n}\n\n/* Styles applied to the root element if variant=\"secondary\" */\n.saltGrid-secondaryBackground {\n --grid-background: var(--grid-background-secondary);\n}\n\n.saltGrid {\n position: relative;\n outline: none;\n user-select: none;\n background: var(--grid-background);\n}\n\n/* Styles applied to the root element if zebra is enabled */\n.saltGrid.saltGrid-zebra {\n --grid-rowSeparator-color: transparent;\n}\n\n.saltGrid-hidden {\n visibility: hidden;\n}\n";
4
+
5
+ module.exports = css_248z;
6
+ //# sourceMappingURL=Grid.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Grid.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}