@salt-ds/data-grid 1.0.4-alpha.0 → 1.0.4-alpha.2

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 (365) hide show
  1. package/dist-cjs/packages/data-grid/src/BaseCell.css.js +9 -0
  2. package/dist-cjs/packages/{grid → data-grid}/src/BaseCell.js +35 -3
  3. package/dist-cjs/packages/data-grid/src/BaseCell.js.map +1 -0
  4. package/dist-cjs/packages/data-grid/src/ColumnSortContext.js +20 -0
  5. package/dist-cjs/packages/data-grid/src/ColumnSortContext.js.map +1 -0
  6. package/dist-cjs/packages/{grid → data-grid}/src/Grid.js +208 -126
  7. package/dist-cjs/packages/data-grid/src/Grid.js.map +1 -0
  8. package/dist-cjs/packages/data-grid/src/GridColumn.js.map +1 -0
  9. package/dist-cjs/packages/data-grid/src/HeaderCell.css.js +9 -0
  10. package/dist-cjs/packages/{grid → data-grid}/src/HeaderCell.js +66 -2
  11. package/dist-cjs/packages/data-grid/src/HeaderCell.js.map +1 -0
  12. package/dist-cjs/packages/{grid → data-grid}/src/RowSelectionCheckboxColumn.js +14 -7
  13. package/dist-cjs/packages/data-grid/src/RowSelectionCheckboxColumn.js.map +1 -0
  14. package/dist-cjs/packages/{grid → data-grid}/src/RowSelectionRadioColumn.js +11 -7
  15. package/dist-cjs/packages/data-grid/src/RowSelectionRadioColumn.js.map +1 -0
  16. package/dist-cjs/packages/data-grid/src/RowValidationStatus.js +13 -0
  17. package/dist-cjs/packages/data-grid/src/RowValidationStatus.js.map +1 -0
  18. package/dist-cjs/packages/{grid → data-grid}/src/index.js +1 -0
  19. package/dist-cjs/packages/{grid → data-grid}/src/index.js.map +1 -1
  20. package/dist-cjs/packages/data-grid/src/internal/Cell.css.js +9 -0
  21. package/dist-cjs/packages/data-grid/src/internal/CellStatusIcons.js +46 -0
  22. package/dist-cjs/packages/data-grid/src/internal/CellStatusIcons.js.map +1 -0
  23. package/dist-cjs/packages/{grid → data-grid}/src/internal/LeftPart.js +4 -2
  24. package/dist-cjs/packages/data-grid/src/internal/LeftPart.js.map +1 -0
  25. package/dist-cjs/packages/{grid → data-grid}/src/internal/MiddlePart.js +4 -2
  26. package/dist-cjs/packages/data-grid/src/internal/MiddlePart.js.map +1 -0
  27. package/dist-cjs/packages/{grid → data-grid}/src/internal/RightPart.js +4 -2
  28. package/dist-cjs/packages/data-grid/src/internal/RightPart.js.map +1 -0
  29. package/dist-cjs/packages/{grid → data-grid}/src/internal/TableBody.js +11 -4
  30. package/dist-cjs/packages/data-grid/src/internal/TableBody.js.map +1 -0
  31. package/dist-cjs/packages/data-grid/src/internal/TableRow.css.js +9 -0
  32. package/dist-cjs/packages/{grid → data-grid}/src/internal/TableRow.js +33 -12
  33. package/dist-cjs/packages/data-grid/src/internal/TableRow.js.map +1 -0
  34. package/dist-es/packages/data-grid/src/BaseCell.css.js +7 -0
  35. package/dist-es/packages/{grid → data-grid}/src/BaseCell.js +35 -3
  36. package/dist-es/packages/data-grid/src/BaseCell.js.map +1 -0
  37. package/dist-es/packages/data-grid/src/ColumnSortContext.js +15 -0
  38. package/dist-es/packages/data-grid/src/ColumnSortContext.js.map +1 -0
  39. package/dist-es/packages/{grid → data-grid}/src/Grid.js +208 -127
  40. package/dist-es/packages/data-grid/src/Grid.js.map +1 -0
  41. package/dist-es/packages/data-grid/src/GridColumn.js.map +1 -0
  42. package/dist-es/packages/data-grid/src/HeaderCell.css.js +7 -0
  43. package/dist-es/packages/{grid → data-grid}/src/HeaderCell.js +66 -2
  44. package/dist-es/packages/data-grid/src/HeaderCell.js.map +1 -0
  45. package/dist-es/packages/{grid → data-grid}/src/RowSelectionCheckboxColumn.js +14 -7
  46. package/dist-es/packages/data-grid/src/RowSelectionCheckboxColumn.js.map +1 -0
  47. package/dist-es/packages/{grid → data-grid}/src/RowSelectionRadioColumn.js +11 -7
  48. package/dist-es/packages/data-grid/src/RowSelectionRadioColumn.js.map +1 -0
  49. package/dist-es/packages/data-grid/src/RowValidationStatus.js +9 -0
  50. package/dist-es/packages/data-grid/src/RowValidationStatus.js.map +1 -0
  51. package/dist-es/packages/{grid → data-grid}/src/index.js +1 -1
  52. package/dist-es/packages/data-grid/src/internal/Cell.css.js +7 -0
  53. package/dist-es/packages/data-grid/src/internal/CellStatusIcons.js +40 -0
  54. package/dist-es/packages/data-grid/src/internal/CellStatusIcons.js.map +1 -0
  55. package/dist-es/packages/{grid → data-grid}/src/internal/LeftPart.js +4 -2
  56. package/dist-es/packages/data-grid/src/internal/LeftPart.js.map +1 -0
  57. package/dist-es/packages/{grid → data-grid}/src/internal/MiddlePart.js +4 -2
  58. package/dist-es/packages/data-grid/src/internal/MiddlePart.js.map +1 -0
  59. package/dist-es/packages/{grid → data-grid}/src/internal/RightPart.js +4 -2
  60. package/dist-es/packages/data-grid/src/internal/RightPart.js.map +1 -0
  61. package/dist-es/packages/{grid → data-grid}/src/internal/TableBody.js +11 -4
  62. package/dist-es/packages/data-grid/src/internal/TableBody.js.map +1 -0
  63. package/dist-es/packages/data-grid/src/internal/TableRow.css.js +7 -0
  64. package/dist-es/packages/{grid → data-grid}/src/internal/TableRow.js +33 -12
  65. package/dist-es/packages/data-grid/src/internal/TableRow.js.map +1 -0
  66. package/dist-es/packages/{grid → data-grid}/src/internal/gridHooks.js +1 -1
  67. package/dist-types/ColumnSortContext.d.ts +12 -0
  68. package/dist-types/Grid.d.ts +7 -1
  69. package/dist-types/GridColumn.d.ts +54 -2
  70. package/dist-types/RowValidationStatus.d.ts +7 -0
  71. package/dist-types/internal/CellStatusIcons.d.ts +4 -0
  72. package/dist-types/internal/LeftPart.d.ts +2 -0
  73. package/dist-types/internal/MiddlePart.d.ts +2 -0
  74. package/dist-types/internal/RightPart.d.ts +2 -0
  75. package/dist-types/internal/TableBody.d.ts +2 -0
  76. package/dist-types/internal/TableRow.d.ts +2 -1
  77. package/package.json +7 -6
  78. package/dist-cjs/packages/grid/src/BaseCell.css.js +0 -9
  79. package/dist-cjs/packages/grid/src/BaseCell.js.map +0 -1
  80. package/dist-cjs/packages/grid/src/Grid.js.map +0 -1
  81. package/dist-cjs/packages/grid/src/GridColumn.js.map +0 -1
  82. package/dist-cjs/packages/grid/src/HeaderCell.css.js +0 -9
  83. package/dist-cjs/packages/grid/src/HeaderCell.js.map +0 -1
  84. package/dist-cjs/packages/grid/src/RowSelectionCheckboxColumn.js.map +0 -1
  85. package/dist-cjs/packages/grid/src/RowSelectionRadioColumn.js.map +0 -1
  86. package/dist-cjs/packages/grid/src/internal/Cell.css.js +0 -9
  87. package/dist-cjs/packages/grid/src/internal/LeftPart.js.map +0 -1
  88. package/dist-cjs/packages/grid/src/internal/MiddlePart.js.map +0 -1
  89. package/dist-cjs/packages/grid/src/internal/RightPart.js.map +0 -1
  90. package/dist-cjs/packages/grid/src/internal/TableBody.js.map +0 -1
  91. package/dist-cjs/packages/grid/src/internal/TableRow.css.js +0 -9
  92. package/dist-cjs/packages/grid/src/internal/TableRow.js.map +0 -1
  93. package/dist-es/packages/grid/src/BaseCell.css.js +0 -7
  94. package/dist-es/packages/grid/src/BaseCell.js.map +0 -1
  95. package/dist-es/packages/grid/src/Grid.js.map +0 -1
  96. package/dist-es/packages/grid/src/GridColumn.js.map +0 -1
  97. package/dist-es/packages/grid/src/HeaderCell.css.js +0 -7
  98. package/dist-es/packages/grid/src/HeaderCell.js.map +0 -1
  99. package/dist-es/packages/grid/src/RowSelectionCheckboxColumn.js.map +0 -1
  100. package/dist-es/packages/grid/src/RowSelectionRadioColumn.js.map +0 -1
  101. package/dist-es/packages/grid/src/internal/Cell.css.js +0 -7
  102. package/dist-es/packages/grid/src/internal/LeftPart.js.map +0 -1
  103. package/dist-es/packages/grid/src/internal/MiddlePart.js.map +0 -1
  104. package/dist-es/packages/grid/src/internal/RightPart.js.map +0 -1
  105. package/dist-es/packages/grid/src/internal/TableBody.js.map +0 -1
  106. package/dist-es/packages/grid/src/internal/TableRow.css.js +0 -7
  107. package/dist-es/packages/grid/src/internal/TableRow.js.map +0 -1
  108. package/dist-cjs/packages/{grid → data-grid}/src/BaseCell.css.js.map +0 -0
  109. package/dist-cjs/packages/{grid → data-grid}/src/CellEditor.js +0 -0
  110. package/dist-cjs/packages/{grid → data-grid}/src/CellEditor.js.map +0 -0
  111. package/dist-cjs/packages/{grid → data-grid}/src/CheckboxCell.css.js +0 -0
  112. package/dist-cjs/packages/{grid → data-grid}/src/CheckboxCell.css.js.map +0 -0
  113. package/dist-cjs/packages/{grid → data-grid}/src/ColumnDataContext.js +0 -0
  114. package/dist-cjs/packages/{grid → data-grid}/src/ColumnDataContext.js.map +0 -0
  115. package/dist-cjs/packages/{grid → data-grid}/src/ColumnDragContext.js +0 -0
  116. package/dist-cjs/packages/{grid → data-grid}/src/ColumnDragContext.js.map +0 -0
  117. package/dist-cjs/packages/{grid → data-grid}/src/ColumnGroup.js +0 -0
  118. package/dist-cjs/packages/{grid → data-grid}/src/ColumnGroup.js.map +0 -0
  119. package/dist-cjs/packages/{grid → data-grid}/src/CornerTag.css.js +0 -0
  120. package/dist-cjs/packages/{grid → data-grid}/src/CornerTag.css.js.map +0 -0
  121. package/dist-cjs/packages/{grid → data-grid}/src/CornerTag.js +0 -0
  122. package/dist-cjs/packages/{grid → data-grid}/src/CornerTag.js.map +0 -0
  123. package/dist-cjs/packages/{grid → data-grid}/src/CursorContext.js +0 -0
  124. package/dist-cjs/packages/{grid → data-grid}/src/CursorContext.js.map +0 -0
  125. package/dist-cjs/packages/{grid → data-grid}/src/DropdownCellEditor.css.js +0 -0
  126. package/dist-cjs/packages/{grid → data-grid}/src/DropdownCellEditor.css.js.map +0 -0
  127. package/dist-cjs/packages/{grid → data-grid}/src/DropdownCellEditor.js +0 -0
  128. package/dist-cjs/packages/{grid → data-grid}/src/DropdownCellEditor.js.map +0 -0
  129. package/dist-cjs/packages/{grid → data-grid}/src/EditorContext.js +0 -0
  130. package/dist-cjs/packages/{grid → data-grid}/src/EditorContext.js.map +0 -0
  131. package/dist-cjs/packages/{grid → data-grid}/src/Grid.css.js +0 -0
  132. package/dist-cjs/packages/{grid → data-grid}/src/Grid.css.js.map +0 -0
  133. package/dist-cjs/packages/{grid → data-grid}/src/GridColumn.js +1 -1
  134. package/dist-cjs/packages/{grid → data-grid}/src/GridContext.js +0 -0
  135. package/dist-cjs/packages/{grid → data-grid}/src/GridContext.js.map +0 -0
  136. package/dist-cjs/packages/{grid → data-grid}/src/GroupHeaderCell.css.js +0 -0
  137. package/dist-cjs/packages/{grid → data-grid}/src/GroupHeaderCell.css.js.map +0 -0
  138. package/dist-cjs/packages/{grid → data-grid}/src/GroupHeaderCell.js +0 -0
  139. package/dist-cjs/packages/{grid → data-grid}/src/GroupHeaderCell.js.map +0 -0
  140. package/dist-cjs/packages/{grid → data-grid}/src/GroupHeaderCellValue.js +0 -0
  141. package/dist-cjs/packages/{grid → data-grid}/src/GroupHeaderCellValue.js.map +0 -0
  142. package/dist-cjs/packages/{grid → data-grid}/src/HeaderCell.css.js.map +0 -0
  143. package/dist-cjs/packages/{grid → data-grid}/src/HeaderCellValue.js +0 -0
  144. package/dist-cjs/packages/{grid → data-grid}/src/HeaderCellValue.js.map +0 -0
  145. package/dist-cjs/packages/{grid → data-grid}/src/LayoutContext.js +0 -0
  146. package/dist-cjs/packages/{grid → data-grid}/src/LayoutContext.js.map +0 -0
  147. package/dist-cjs/packages/{grid → data-grid}/src/NumberRange.js +0 -0
  148. package/dist-cjs/packages/{grid → data-grid}/src/NumberRange.js.map +0 -0
  149. package/dist-cjs/packages/{grid → data-grid}/src/NumericColumn.css.js +0 -0
  150. package/dist-cjs/packages/{grid → data-grid}/src/NumericColumn.css.js.map +0 -0
  151. package/dist-cjs/packages/{grid → data-grid}/src/NumericColumn.js +0 -0
  152. package/dist-cjs/packages/{grid → data-grid}/src/NumericColumn.js.map +0 -0
  153. package/dist-cjs/packages/{grid → data-grid}/src/RowSelectionCheckboxCellValue.js +0 -0
  154. package/dist-cjs/packages/{grid → data-grid}/src/RowSelectionCheckboxCellValue.js.map +0 -0
  155. package/dist-cjs/packages/{grid → data-grid}/src/RowSelectionCheckboxHeaderCellValue.js +0 -0
  156. package/dist-cjs/packages/{grid → data-grid}/src/RowSelectionCheckboxHeaderCellValue.js.map +0 -0
  157. package/dist-cjs/packages/{grid → data-grid}/src/RowSelectionRadioCellValue.js +0 -0
  158. package/dist-cjs/packages/{grid → data-grid}/src/RowSelectionRadioCellValue.js.map +0 -0
  159. package/dist-cjs/packages/{grid → data-grid}/src/RowSelectionRadioHeaderCell.js +0 -0
  160. package/dist-cjs/packages/{grid → data-grid}/src/RowSelectionRadioHeaderCell.js.map +0 -0
  161. package/dist-cjs/packages/{grid → data-grid}/src/SelectionContext.js +0 -0
  162. package/dist-cjs/packages/{grid → data-grid}/src/SelectionContext.js.map +0 -0
  163. package/dist-cjs/packages/{grid → data-grid}/src/SizingContext.js +0 -0
  164. package/dist-cjs/packages/{grid → data-grid}/src/SizingContext.js.map +0 -0
  165. package/dist-cjs/packages/{grid → data-grid}/src/TextCellEditor.css.js +0 -0
  166. package/dist-cjs/packages/{grid → data-grid}/src/TextCellEditor.css.js.map +0 -0
  167. package/dist-cjs/packages/{grid → data-grid}/src/TextCellEditor.js +0 -0
  168. package/dist-cjs/packages/{grid → data-grid}/src/TextCellEditor.js.map +0 -0
  169. package/dist-cjs/packages/{grid → data-grid}/src/internal/Cell.css.js.map +0 -0
  170. package/dist-cjs/packages/{grid → data-grid}/src/internal/Cell.js +0 -0
  171. package/dist-cjs/packages/{grid → data-grid}/src/internal/Cell.js.map +0 -0
  172. package/dist-cjs/packages/{grid → data-grid}/src/internal/CellMeasure.css.js +0 -0
  173. package/dist-cjs/packages/{grid → data-grid}/src/internal/CellMeasure.css.js.map +0 -0
  174. package/dist-cjs/packages/{grid → data-grid}/src/internal/CellMeasure.js +0 -0
  175. package/dist-cjs/packages/{grid → data-grid}/src/internal/CellMeasure.js.map +0 -0
  176. package/dist-cjs/packages/{grid → data-grid}/src/internal/ColumnDropTarget.css.js +0 -0
  177. package/dist-cjs/packages/{grid → data-grid}/src/internal/ColumnDropTarget.css.js.map +0 -0
  178. package/dist-cjs/packages/{grid → data-grid}/src/internal/ColumnDropTarget.js +0 -0
  179. package/dist-cjs/packages/{grid → data-grid}/src/internal/ColumnDropTarget.js.map +0 -0
  180. package/dist-cjs/packages/{grid → data-grid}/src/internal/ColumnGhost.css.js +0 -0
  181. package/dist-cjs/packages/{grid → data-grid}/src/internal/ColumnGhost.css.js.map +0 -0
  182. package/dist-cjs/packages/{grid → data-grid}/src/internal/ColumnGhost.js +0 -0
  183. package/dist-cjs/packages/{grid → data-grid}/src/internal/ColumnGhost.js.map +0 -0
  184. package/dist-cjs/packages/{grid → data-grid}/src/internal/Cursor.css.js +0 -0
  185. package/dist-cjs/packages/{grid → data-grid}/src/internal/Cursor.css.js.map +0 -0
  186. package/dist-cjs/packages/{grid → data-grid}/src/internal/Cursor.js +0 -0
  187. package/dist-cjs/packages/{grid → data-grid}/src/internal/Cursor.js.map +0 -0
  188. package/dist-cjs/packages/{grid → data-grid}/src/internal/DefaultCellValue.css.js +0 -0
  189. package/dist-cjs/packages/{grid → data-grid}/src/internal/DefaultCellValue.css.js.map +0 -0
  190. package/dist-cjs/packages/{grid → data-grid}/src/internal/DefaultCellValue.js +0 -0
  191. package/dist-cjs/packages/{grid → data-grid}/src/internal/DefaultCellValue.js.map +0 -0
  192. package/dist-cjs/packages/{grid → data-grid}/src/internal/FakeCell.css.js +0 -0
  193. package/dist-cjs/packages/{grid → data-grid}/src/internal/FakeCell.css.js.map +0 -0
  194. package/dist-cjs/packages/{grid → data-grid}/src/internal/FakeCell.js +0 -0
  195. package/dist-cjs/packages/{grid → data-grid}/src/internal/FakeCell.js.map +0 -0
  196. package/dist-cjs/packages/{grid → data-grid}/src/internal/FakeGroupCell.js +0 -0
  197. package/dist-cjs/packages/{grid → data-grid}/src/internal/FakeGroupCell.js.map +0 -0
  198. package/dist-cjs/packages/{grid → data-grid}/src/internal/FakeHeaderCell.js +0 -0
  199. package/dist-cjs/packages/{grid → data-grid}/src/internal/FakeHeaderCell.js.map +0 -0
  200. package/dist-cjs/packages/{grid → data-grid}/src/internal/GroupHeaderRow.css.js +0 -0
  201. package/dist-cjs/packages/{grid → data-grid}/src/internal/GroupHeaderRow.css.js.map +0 -0
  202. package/dist-cjs/packages/{grid → data-grid}/src/internal/GroupHeaderRow.js +0 -0
  203. package/dist-cjs/packages/{grid → data-grid}/src/internal/GroupHeaderRow.js.map +0 -0
  204. package/dist-cjs/packages/{grid → data-grid}/src/internal/HeaderRow.css.js +0 -0
  205. package/dist-cjs/packages/{grid → data-grid}/src/internal/HeaderRow.css.js.map +0 -0
  206. package/dist-cjs/packages/{grid → data-grid}/src/internal/HeaderRow.js +0 -0
  207. package/dist-cjs/packages/{grid → data-grid}/src/internal/HeaderRow.js.map +0 -0
  208. package/dist-cjs/packages/{grid → data-grid}/src/internal/LeftPart.css.js +0 -0
  209. package/dist-cjs/packages/{grid → data-grid}/src/internal/LeftPart.css.js.map +0 -0
  210. package/dist-cjs/packages/{grid → data-grid}/src/internal/MiddlePart.css.js +0 -0
  211. package/dist-cjs/packages/{grid → data-grid}/src/internal/MiddlePart.css.js.map +0 -0
  212. package/dist-cjs/packages/{grid → data-grid}/src/internal/RightPart.css.js +0 -0
  213. package/dist-cjs/packages/{grid → data-grid}/src/internal/RightPart.css.js.map +0 -0
  214. package/dist-cjs/packages/{grid → data-grid}/src/internal/Scrollable.css.js +0 -0
  215. package/dist-cjs/packages/{grid → data-grid}/src/internal/Scrollable.css.js.map +0 -0
  216. package/dist-cjs/packages/{grid → data-grid}/src/internal/Scrollable.js +0 -0
  217. package/dist-cjs/packages/{grid → data-grid}/src/internal/Scrollable.js.map +0 -0
  218. package/dist-cjs/packages/{grid → data-grid}/src/internal/TableColGroup.js +0 -0
  219. package/dist-cjs/packages/{grid → data-grid}/src/internal/TableColGroup.js.map +0 -0
  220. package/dist-cjs/packages/{grid → data-grid}/src/internal/TableRow.css.js.map +0 -0
  221. package/dist-cjs/packages/{grid → data-grid}/src/internal/TopLeftPart.css.js +0 -0
  222. package/dist-cjs/packages/{grid → data-grid}/src/internal/TopLeftPart.css.js.map +0 -0
  223. package/dist-cjs/packages/{grid → data-grid}/src/internal/TopLeftPart.js +0 -0
  224. package/dist-cjs/packages/{grid → data-grid}/src/internal/TopLeftPart.js.map +0 -0
  225. package/dist-cjs/packages/{grid → data-grid}/src/internal/TopPart.css.js +0 -0
  226. package/dist-cjs/packages/{grid → data-grid}/src/internal/TopPart.css.js.map +0 -0
  227. package/dist-cjs/packages/{grid → data-grid}/src/internal/TopPart.js +0 -0
  228. package/dist-cjs/packages/{grid → data-grid}/src/internal/TopPart.js.map +0 -0
  229. package/dist-cjs/packages/{grid → data-grid}/src/internal/TopRightPart.css.js +0 -0
  230. package/dist-cjs/packages/{grid → data-grid}/src/internal/TopRightPart.css.js.map +0 -0
  231. package/dist-cjs/packages/{grid → data-grid}/src/internal/TopRightPart.js +0 -0
  232. package/dist-cjs/packages/{grid → data-grid}/src/internal/TopRightPart.js.map +0 -0
  233. package/dist-cjs/packages/{grid → data-grid}/src/internal/gridHooks.js +0 -0
  234. package/dist-cjs/packages/{grid → data-grid}/src/internal/gridHooks.js.map +0 -0
  235. package/dist-cjs/packages/{grid → data-grid}/src/internal/utils.js +0 -0
  236. package/dist-cjs/packages/{grid → data-grid}/src/internal/utils.js.map +0 -0
  237. package/dist-es/packages/{grid → data-grid}/src/BaseCell.css.js.map +0 -0
  238. package/dist-es/packages/{grid → data-grid}/src/CellEditor.js +0 -0
  239. package/dist-es/packages/{grid → data-grid}/src/CellEditor.js.map +0 -0
  240. package/dist-es/packages/{grid → data-grid}/src/CheckboxCell.css.js +0 -0
  241. package/dist-es/packages/{grid → data-grid}/src/CheckboxCell.css.js.map +0 -0
  242. package/dist-es/packages/{grid → data-grid}/src/ColumnDataContext.js +0 -0
  243. package/dist-es/packages/{grid → data-grid}/src/ColumnDataContext.js.map +0 -0
  244. package/dist-es/packages/{grid → data-grid}/src/ColumnDragContext.js +0 -0
  245. package/dist-es/packages/{grid → data-grid}/src/ColumnDragContext.js.map +0 -0
  246. package/dist-es/packages/{grid → data-grid}/src/ColumnGroup.js +0 -0
  247. package/dist-es/packages/{grid → data-grid}/src/ColumnGroup.js.map +0 -0
  248. package/dist-es/packages/{grid → data-grid}/src/CornerTag.css.js +0 -0
  249. package/dist-es/packages/{grid → data-grid}/src/CornerTag.css.js.map +0 -0
  250. package/dist-es/packages/{grid → data-grid}/src/CornerTag.js +0 -0
  251. package/dist-es/packages/{grid → data-grid}/src/CornerTag.js.map +0 -0
  252. package/dist-es/packages/{grid → data-grid}/src/CursorContext.js +0 -0
  253. package/dist-es/packages/{grid → data-grid}/src/CursorContext.js.map +0 -0
  254. package/dist-es/packages/{grid → data-grid}/src/DropdownCellEditor.css.js +0 -0
  255. package/dist-es/packages/{grid → data-grid}/src/DropdownCellEditor.css.js.map +0 -0
  256. package/dist-es/packages/{grid → data-grid}/src/DropdownCellEditor.js +0 -0
  257. package/dist-es/packages/{grid → data-grid}/src/DropdownCellEditor.js.map +0 -0
  258. package/dist-es/packages/{grid → data-grid}/src/EditorContext.js +0 -0
  259. package/dist-es/packages/{grid → data-grid}/src/EditorContext.js.map +0 -0
  260. package/dist-es/packages/{grid → data-grid}/src/Grid.css.js +0 -0
  261. package/dist-es/packages/{grid → data-grid}/src/Grid.css.js.map +0 -0
  262. package/dist-es/packages/{grid → data-grid}/src/GridColumn.js +1 -1
  263. /package/dist-es/packages/{grid → data-grid}/src/GridContext.js +0 -0
  264. /package/dist-es/packages/{grid → data-grid}/src/GridContext.js.map +0 -0
  265. /package/dist-es/packages/{grid → data-grid}/src/GroupHeaderCell.css.js +0 -0
  266. /package/dist-es/packages/{grid → data-grid}/src/GroupHeaderCell.css.js.map +0 -0
  267. /package/dist-es/packages/{grid → data-grid}/src/GroupHeaderCell.js +0 -0
  268. /package/dist-es/packages/{grid → data-grid}/src/GroupHeaderCell.js.map +0 -0
  269. /package/dist-es/packages/{grid → data-grid}/src/GroupHeaderCellValue.js +0 -0
  270. /package/dist-es/packages/{grid → data-grid}/src/GroupHeaderCellValue.js.map +0 -0
  271. /package/dist-es/packages/{grid → data-grid}/src/HeaderCell.css.js.map +0 -0
  272. /package/dist-es/packages/{grid → data-grid}/src/HeaderCellValue.js +0 -0
  273. /package/dist-es/packages/{grid → data-grid}/src/HeaderCellValue.js.map +0 -0
  274. /package/dist-es/packages/{grid → data-grid}/src/LayoutContext.js +0 -0
  275. /package/dist-es/packages/{grid → data-grid}/src/LayoutContext.js.map +0 -0
  276. /package/dist-es/packages/{grid → data-grid}/src/NumberRange.js +0 -0
  277. /package/dist-es/packages/{grid → data-grid}/src/NumberRange.js.map +0 -0
  278. /package/dist-es/packages/{grid → data-grid}/src/NumericColumn.css.js +0 -0
  279. /package/dist-es/packages/{grid → data-grid}/src/NumericColumn.css.js.map +0 -0
  280. /package/dist-es/packages/{grid → data-grid}/src/NumericColumn.js +0 -0
  281. /package/dist-es/packages/{grid → data-grid}/src/NumericColumn.js.map +0 -0
  282. /package/dist-es/packages/{grid → data-grid}/src/RowSelectionCheckboxCellValue.js +0 -0
  283. /package/dist-es/packages/{grid → data-grid}/src/RowSelectionCheckboxCellValue.js.map +0 -0
  284. /package/dist-es/packages/{grid → data-grid}/src/RowSelectionCheckboxHeaderCellValue.js +0 -0
  285. /package/dist-es/packages/{grid → data-grid}/src/RowSelectionCheckboxHeaderCellValue.js.map +0 -0
  286. /package/dist-es/packages/{grid → data-grid}/src/RowSelectionRadioCellValue.js +0 -0
  287. /package/dist-es/packages/{grid → data-grid}/src/RowSelectionRadioCellValue.js.map +0 -0
  288. /package/dist-es/packages/{grid → data-grid}/src/RowSelectionRadioHeaderCell.js +0 -0
  289. /package/dist-es/packages/{grid → data-grid}/src/RowSelectionRadioHeaderCell.js.map +0 -0
  290. /package/dist-es/packages/{grid → data-grid}/src/SelectionContext.js +0 -0
  291. /package/dist-es/packages/{grid → data-grid}/src/SelectionContext.js.map +0 -0
  292. /package/dist-es/packages/{grid → data-grid}/src/SizingContext.js +0 -0
  293. /package/dist-es/packages/{grid → data-grid}/src/SizingContext.js.map +0 -0
  294. /package/dist-es/packages/{grid → data-grid}/src/TextCellEditor.css.js +0 -0
  295. /package/dist-es/packages/{grid → data-grid}/src/TextCellEditor.css.js.map +0 -0
  296. /package/dist-es/packages/{grid → data-grid}/src/TextCellEditor.js +0 -0
  297. /package/dist-es/packages/{grid → data-grid}/src/TextCellEditor.js.map +0 -0
  298. /package/dist-es/packages/{grid → data-grid}/src/index.js.map +0 -0
  299. /package/dist-es/packages/{grid → data-grid}/src/internal/Cell.css.js.map +0 -0
  300. /package/dist-es/packages/{grid → data-grid}/src/internal/Cell.js +0 -0
  301. /package/dist-es/packages/{grid → data-grid}/src/internal/Cell.js.map +0 -0
  302. /package/dist-es/packages/{grid → data-grid}/src/internal/CellMeasure.css.js +0 -0
  303. /package/dist-es/packages/{grid → data-grid}/src/internal/CellMeasure.css.js.map +0 -0
  304. /package/dist-es/packages/{grid → data-grid}/src/internal/CellMeasure.js +0 -0
  305. /package/dist-es/packages/{grid → data-grid}/src/internal/CellMeasure.js.map +0 -0
  306. /package/dist-es/packages/{grid → data-grid}/src/internal/ColumnDropTarget.css.js +0 -0
  307. /package/dist-es/packages/{grid → data-grid}/src/internal/ColumnDropTarget.css.js.map +0 -0
  308. /package/dist-es/packages/{grid → data-grid}/src/internal/ColumnDropTarget.js +0 -0
  309. /package/dist-es/packages/{grid → data-grid}/src/internal/ColumnDropTarget.js.map +0 -0
  310. /package/dist-es/packages/{grid → data-grid}/src/internal/ColumnGhost.css.js +0 -0
  311. /package/dist-es/packages/{grid → data-grid}/src/internal/ColumnGhost.css.js.map +0 -0
  312. /package/dist-es/packages/{grid → data-grid}/src/internal/ColumnGhost.js +0 -0
  313. /package/dist-es/packages/{grid → data-grid}/src/internal/ColumnGhost.js.map +0 -0
  314. /package/dist-es/packages/{grid → data-grid}/src/internal/Cursor.css.js +0 -0
  315. /package/dist-es/packages/{grid → data-grid}/src/internal/Cursor.css.js.map +0 -0
  316. /package/dist-es/packages/{grid → data-grid}/src/internal/Cursor.js +0 -0
  317. /package/dist-es/packages/{grid → data-grid}/src/internal/Cursor.js.map +0 -0
  318. /package/dist-es/packages/{grid → data-grid}/src/internal/DefaultCellValue.css.js +0 -0
  319. /package/dist-es/packages/{grid → data-grid}/src/internal/DefaultCellValue.css.js.map +0 -0
  320. /package/dist-es/packages/{grid → data-grid}/src/internal/DefaultCellValue.js +0 -0
  321. /package/dist-es/packages/{grid → data-grid}/src/internal/DefaultCellValue.js.map +0 -0
  322. /package/dist-es/packages/{grid → data-grid}/src/internal/FakeCell.css.js +0 -0
  323. /package/dist-es/packages/{grid → data-grid}/src/internal/FakeCell.css.js.map +0 -0
  324. /package/dist-es/packages/{grid → data-grid}/src/internal/FakeCell.js +0 -0
  325. /package/dist-es/packages/{grid → data-grid}/src/internal/FakeCell.js.map +0 -0
  326. /package/dist-es/packages/{grid → data-grid}/src/internal/FakeGroupCell.js +0 -0
  327. /package/dist-es/packages/{grid → data-grid}/src/internal/FakeGroupCell.js.map +0 -0
  328. /package/dist-es/packages/{grid → data-grid}/src/internal/FakeHeaderCell.js +0 -0
  329. /package/dist-es/packages/{grid → data-grid}/src/internal/FakeHeaderCell.js.map +0 -0
  330. /package/dist-es/packages/{grid → data-grid}/src/internal/GroupHeaderRow.css.js +0 -0
  331. /package/dist-es/packages/{grid → data-grid}/src/internal/GroupHeaderRow.css.js.map +0 -0
  332. /package/dist-es/packages/{grid → data-grid}/src/internal/GroupHeaderRow.js +0 -0
  333. /package/dist-es/packages/{grid → data-grid}/src/internal/GroupHeaderRow.js.map +0 -0
  334. /package/dist-es/packages/{grid → data-grid}/src/internal/HeaderRow.css.js +0 -0
  335. /package/dist-es/packages/{grid → data-grid}/src/internal/HeaderRow.css.js.map +0 -0
  336. /package/dist-es/packages/{grid → data-grid}/src/internal/HeaderRow.js +0 -0
  337. /package/dist-es/packages/{grid → data-grid}/src/internal/HeaderRow.js.map +0 -0
  338. /package/dist-es/packages/{grid → data-grid}/src/internal/LeftPart.css.js +0 -0
  339. /package/dist-es/packages/{grid → data-grid}/src/internal/LeftPart.css.js.map +0 -0
  340. /package/dist-es/packages/{grid → data-grid}/src/internal/MiddlePart.css.js +0 -0
  341. /package/dist-es/packages/{grid → data-grid}/src/internal/MiddlePart.css.js.map +0 -0
  342. /package/dist-es/packages/{grid → data-grid}/src/internal/RightPart.css.js +0 -0
  343. /package/dist-es/packages/{grid → data-grid}/src/internal/RightPart.css.js.map +0 -0
  344. /package/dist-es/packages/{grid → data-grid}/src/internal/Scrollable.css.js +0 -0
  345. /package/dist-es/packages/{grid → data-grid}/src/internal/Scrollable.css.js.map +0 -0
  346. /package/dist-es/packages/{grid → data-grid}/src/internal/Scrollable.js +0 -0
  347. /package/dist-es/packages/{grid → data-grid}/src/internal/Scrollable.js.map +0 -0
  348. /package/dist-es/packages/{grid → data-grid}/src/internal/TableColGroup.js +0 -0
  349. /package/dist-es/packages/{grid → data-grid}/src/internal/TableColGroup.js.map +0 -0
  350. /package/dist-es/packages/{grid → data-grid}/src/internal/TableRow.css.js.map +0 -0
  351. /package/dist-es/packages/{grid → data-grid}/src/internal/TopLeftPart.css.js +0 -0
  352. /package/dist-es/packages/{grid → data-grid}/src/internal/TopLeftPart.css.js.map +0 -0
  353. /package/dist-es/packages/{grid → data-grid}/src/internal/TopLeftPart.js +0 -0
  354. /package/dist-es/packages/{grid → data-grid}/src/internal/TopLeftPart.js.map +0 -0
  355. /package/dist-es/packages/{grid → data-grid}/src/internal/TopPart.css.js +0 -0
  356. /package/dist-es/packages/{grid → data-grid}/src/internal/TopPart.css.js.map +0 -0
  357. /package/dist-es/packages/{grid → data-grid}/src/internal/TopPart.js +0 -0
  358. /package/dist-es/packages/{grid → data-grid}/src/internal/TopPart.js.map +0 -0
  359. /package/dist-es/packages/{grid → data-grid}/src/internal/TopRightPart.css.js +0 -0
  360. /package/dist-es/packages/{grid → data-grid}/src/internal/TopRightPart.css.js.map +0 -0
  361. /package/dist-es/packages/{grid → data-grid}/src/internal/TopRightPart.js +0 -0
  362. /package/dist-es/packages/{grid → data-grid}/src/internal/TopRightPart.js.map +0 -0
  363. /package/dist-es/packages/{grid → data-grid}/src/internal/gridHooks.js.map +0 -0
  364. /package/dist-es/packages/{grid → data-grid}/src/internal/utils.js +0 -0
  365. /package/dist-es/packages/{grid → data-grid}/src/internal/utils.js.map +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GridColumn.js","sources":["../src/GridColumn.tsx"],"sourcesContent":["import {\n Children,\n cloneElement,\n ComponentType,\n CSSProperties,\n isValidElement,\n KeyboardEvent,\n ReactNode,\n useEffect,\n useRef,\n useState,\n} from \"react\";\nimport { useGridContext } from \"./GridContext\";\nimport { GridColumnModel, GridRowModel, SortOrder } from \"./Grid\";\n\nexport type GridColumnPin = \"left\" | \"right\" | null;\n\nexport type CellValidationState = \"error\" | \"warning\" | \"success\";\ntype CellValidationType = \"strong\" | \"light\";\n\nexport interface GridCellProps<T, U = any> {\n row: GridRowModel<T>;\n column: GridColumnModel<T>;\n className?: string;\n style?: CSSProperties;\n isFocused?: boolean;\n isSelected?: boolean;\n isEditable?: boolean;\n children?: ReactNode;\n align?: GridColumnProps[\"align\"];\n value?: U;\n validationStatus?: CellValidationState;\n validationMessage?: string;\n validationType?: CellValidationType;\n}\n\nexport interface GridCellValueProps<T, U = any> {\n row: GridRowModel<T>;\n column: GridColumnModel<T>;\n isFocused?: boolean;\n value?: U;\n validationStatus?: CellValidationState;\n validationMessage?: string;\n validationType?: CellValidationType;\n}\n\nexport interface HeaderCellProps<T> {\n column: GridColumnModel<T>;\n children: ReactNode;\n isFocused?: boolean;\n}\n\nexport interface GridHeaderValueProps<T> {\n column: GridColumnModel<T>;\n isFocused?: boolean;\n}\n\nexport interface GridEditorProps<T> {\n row: GridRowModel<T>;\n column: GridColumnModel<T>;\n}\n\nexport interface GridColumnProps<T = any> {\n /**\n * Unique identifier of the column.\n * */\n id: string; // TODO make optional\n /**\n * Enables sorting (by sort order: `asc | desc | none`) for the column.\n * To enable column header's keyboard navigation on sort,\n * users need to set `headerIsFocusable` prop to `true` in Grid component.\n * To customise how GridColumn data sorts, use also `customSort` or `onSortOrderChanged`.\n * */\n sortable?: boolean;\n /**\n * Custom sorting function. Use for client side sorting.\n * */\n customSort?: (args: { rowData: T[]; sortOrder: SortOrder }) => T[];\n /**\n * Exposes GridColumn sort order. Use for server side sorting.\n * */\n onSortOrderChange?: (args: { sortOrder: SortOrder }) => void;\n /**\n * Name is displayed on the column header by default.\n * */\n name?: string;\n /**\n * Default width of the column in `px`.\n * */\n defaultWidth?: number;\n /**\n * Min width of the column.\n * */\n minWidth?: number;\n /**\n * Callback invoked when the user resizes the column.\n * */\n onWidthChanged?: (width: number) => void;\n /**\n * Whether the column should be pinned `left` or `right`. By default columns\n * are unpinned. Accepts `\"left\" | \"right\" | null`.\n * */\n pinned?: GridColumnPin;\n /**\n * Text align for the header and cells.\n * */\n align?: \"left\" | \"right\";\n /**\n * Component to render for every cell in the column. Useful when major\n * customization is needed. Use this only if `cellValueComponent` is not\n * sufficient. Default implementation of cell component takes care of\n * selection, hover, focus and other basic grid features.\n * */\n cellComponent?: ComponentType<GridCellProps<T>>;\n /**\n * Component to render inside every cell. This is the preferred way of\n * customizing grid cells.\n * */\n cellValueComponent?: ComponentType<GridCellValueProps<T>>;\n /**\n * Cell value getter. Should return the value to be displayed in the cell\n * for the given row data item.\n * */\n getValue?: (rowData: T) => any;\n /**\n * Cell validation status getter. Should return one of the known validation status names: \"none\" | \"error\" | \"warning\"\n * If you require a custom validation status, you can achieve that by providing a custom cell component.\n * */\n getValidationStatus?: (\n value: GridCellValueProps<T>\n ) => CellValidationState | undefined;\n /**\n * Cell validation status message getter. Should return a string description of the validation state that can be used for the screen reader.\n * This prop is optional but if you don't provide a function a default message will be used.\n * */\n getValidationMessage?: (value: GridCellValueProps<T>) => string | undefined;\n /**\n * Cell validation type. Determines the visual style of the validation. The available values are \"strong\" and \"light\". Strong will display the icon\n * along side the background and border. Light will only affect border and background. Use light if you are validation the whole row, and optionally\n * strong on one of the columns, and strong if you are validating user input on a particular cell.\n * The default value is \"light\".\n * */\n validationType?: GridCellProps<T>[\"validationType\"];\n /**\n * CSS class to be applied to the column header.\n * Useful for minor customizations\n * */\n headerClassName?: string;\n /**\n * Custom header component. Use this when `headerValueComponent` doesn't\n * provide enough flexibility.\n * */\n headerComponent?: ComponentType<HeaderCellProps<T>>;\n /**\n * Renders the content of the column header. This is the preferred way of\n * customizing column headers.\n * */\n headerValueComponent?: ComponentType<GridHeaderValueProps<T>>;\n /**\n * A callback to be invoked when the user modifies a cell value.\n * */\n onChange?: (row: T, rowIndex: number, value: string) => void;\n /**\n * A callback to be invoked on key down when the focus is in this column.\n */\n onKeyDown?: (event: KeyboardEvent<HTMLDivElement>, rowIndex: number) => void;\n /**\n * Children is optional, and accepts non-rendered elements i.e. `CellEditor`\n */\n children?: ReactNode;\n /**\n * aria-label is optional, and accepts any string value\n */\n \"aria-label\"?: string;\n}\n\nexport interface GridColumnInfo<T> {\n width: number;\n onWidthChanged: (width: number) => void;\n props: GridColumnProps<T>;\n}\n\nexport const GridColumn = function GridColumn<T = any>(\n props: GridColumnProps<T>\n) {\n const { defaultWidth } = props;\n const indexRef = useRef<number>();\n const [width, setWidth] = useState<number>(\n defaultWidth !== undefined ? defaultWidth : 100\n );\n\n const grid = useGridContext();\n\n const onWidthChanged = (w: number) => {\n setWidth(w);\n if (props.onWidthChanged) {\n props.onWidthChanged(w);\n }\n };\n\n const info: GridColumnInfo<T> = {\n width,\n onWidthChanged,\n props,\n };\n\n useEffect(() => {\n indexRef.current = grid.getChildIndex(props.id);\n grid.onColumnAdded(info);\n return () => {\n grid.onColumnRemoved(indexRef.current!, info);\n };\n });\n\n return (\n <>\n {Children.map(props.children, (ch) =>\n isValidElement(ch)\n ? cloneElement(ch, { columnId: props.id } as any)\n : ch\n )}\n </>\n );\n};\n"],"names":["GridColumn"],"mappings":";;;;AAsLa,MAAA,UAAA,GAAa,SAASA,WAAAA,CACjC,KACA,EAAA;AACA,EAAM,MAAA,EAAE,cAAiB,GAAA,KAAA,CAAA;AACzB,EAAA,MAAM,WAAW,MAAe,EAAA,CAAA;AAChC,EAAM,MAAA,CAAC,KAAO,EAAA,QAAQ,CAAI,GAAA,QAAA;AAAA,IACxB,YAAA,KAAiB,SAAY,YAAe,GAAA,GAAA;AAAA,GAC9C,CAAA;AAEA,EAAA,MAAM,OAAO,cAAe,EAAA,CAAA;AAE5B,EAAM,MAAA,cAAA,GAAiB,CAAC,CAAc,KAAA;AACpC,IAAA,QAAA,CAAS,CAAC,CAAA,CAAA;AACV,IAAA,IAAI,MAAM,cAAgB,EAAA;AACxB,MAAA,KAAA,CAAM,eAAe,CAAC,CAAA,CAAA;AAAA,KACxB;AAAA,GACF,CAAA;AAEA,EAAA,MAAM,IAA0B,GAAA;AAAA,IAC9B,KAAA;AAAA,IACA,cAAA;AAAA,IACA,KAAA;AAAA,GACF,CAAA;AAEA,EAAA,SAAA,CAAU,MAAM;AACd,IAAA,QAAA,CAAS,OAAU,GAAA,IAAA,CAAK,aAAc,CAAA,KAAA,CAAM,EAAE,CAAA,CAAA;AAC9C,IAAA,IAAA,CAAK,cAAc,IAAI,CAAA,CAAA;AACvB,IAAA,OAAO,MAAM;AACX,MAAK,IAAA,CAAA,eAAA,CAAgB,QAAS,CAAA,OAAA,EAAU,IAAI,CAAA,CAAA;AAAA,KAC9C,CAAA;AAAA,GACD,CAAA,CAAA;AAED,EACE,uBAAA,GAAA,CAAA,QAAA,EAAA;AAAA,IACG,QAAS,EAAA,QAAA,CAAA,GAAA;AAAA,MAAI,KAAM,CAAA,QAAA;AAAA,MAAU,CAAC,EAAA,KAC7B,cAAe,CAAA,EAAE,CACb,GAAA,YAAA,CAAa,EAAI,EAAA,EAAE,QAAU,EAAA,KAAA,CAAM,EAAG,EAAQ,CAC9C,GAAA,EAAA;AAAA,KACN;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,7 @@
1
+ import styleInject from '../../../node_modules/style-inject/dist/style-inject.es.js';
2
+
3
+ var css_248z = ".saltGridHeaderCell {\n text-align: left;\n font-size: var(--grid-header-fontSize);\n font-weight: var(--salt-text-label-fontWeight-strong);\n line-height: var(--grid-row-height);\n position: relative;\n box-sizing: border-box;\n color: var(--grid-header-color);\n white-space: nowrap;\n outline: 0;\n}\n\n.saltGridHeaderCell-valueContainer {\n line-height: var(--grid-row-height);\n padding: var(--grid-cell-padding);\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.saltGridHeaderCell-alignRight {\n text-align: right;\n}\n\n.saltGridHeaderCell-alignRightWithSortOrder {\n margin-left: calc(var(--salt-size-unit) * 2);\n}\n\n.saltGridHeaderCell-alignLeftWithSortOrder {\n margin-right: calc(var(--salt-size-unit) * 2);\n}\n\n.saltGridHeaderCell-autosizeContainer {\n line-height: var(--grid-row-height);\n padding: 0;\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n overflow: hidden;\n}\n\n.saltGridHeaderCell-measuredContent {\n height: 100%;\n display: inline-block;\n padding: var(--grid-cell-padding);\n}\n\n.saltGridHeaderCell-text {\n color: var(--grid-header-color);\n overflow: hidden;\n}\n\n.saltGridHeaderCell-regularSeparator {\n background: var(--grid-headerColumnSeparator-color);\n width: 1px;\n height: auto;\n position: absolute;\n right: 0;\n top: var(--grid-separatorGap);\n bottom: var(--grid-separatorGap);\n}\n\n.saltGridHeaderCell-groupEdgeSeparator,\n.saltGridHeaderCell-pinnedSeparator {\n background: var(--grid-headerColumnSeparator-color);\n width: 1px;\n height: auto;\n position: absolute;\n right: 0;\n top: 0;\n bottom: var(--grid-separatorGap);\n}\n\n.saltGrid-pinnedSeparators .saltGridHeaderCell-pinnedSeparator {\n background: var(--grid-pinnedSeparator-color);\n width: 1px;\n position: absolute;\n right: 0;\n top: 0;\n bottom: 0;\n}\n\n.saltGridHeaderCell-resizeHandle {\n position: absolute;\n right: -8px;\n top: 0;\n bottom: 0;\n width: 16px;\n background: transparent;\n cursor: col-resize;\n z-index: 2;\n}\n\n.saltGridHeaderCell-sortable {\n cursor: pointer;\n}\n\n.saltGridHeaderCell-sortingIcon {\n display: flex;\n margin: 0 var(--salt-size-unit);\n}\n\n.saltGridHeaderCell-sortingIconStart {\n justify-content: start;\n}\n\n.saltGridHeaderCell-sortingIconEnd {\n justify-content: end;\n}\n";
4
+ styleInject(css_248z);
5
+
6
+ export { css_248z as default };
7
+ //# sourceMappingURL=HeaderCell.css.js.map
@@ -3,6 +3,7 @@ import './HeaderCell.css.js';
3
3
  import { useRef } from 'react';
4
4
  import { makePrefixer, useIsomorphicLayoutEffect } from '@salt-ds/core';
5
5
  import { clsx } from 'clsx';
6
+ import { SortOrder } from './Grid.js';
6
7
  import { useSizingContext } from './SizingContext.js';
7
8
  import { useColumnDragContext } from './ColumnDragContext.js';
8
9
  import './internal/Cell.js';
@@ -24,6 +25,8 @@ import './internal/TopPart.js';
24
25
  import './internal/TopRightPart.js';
25
26
  import './internal/FakeCell.css.js';
26
27
  import './internal/DefaultCellValue.js';
28
+ import { useColumnSortContext } from './ColumnSortContext.js';
29
+ import { ArrowUpIcon, ArrowDownIcon } from '@salt-ds/icons';
27
30
 
28
31
  const withBaseName = makePrefixer("saltGridHeaderCell");
29
32
  function HeaderCellSeparator(props) {
@@ -35,27 +38,88 @@ function HeaderCellSeparator(props) {
35
38
  function HeaderCell(props) {
36
39
  const { column, children, isFocused } = props;
37
40
  const { separator } = column;
41
+ const { align, id, headerClassName, sortable, onSortOrderChange } = column.info.props;
38
42
  const { onResizeHandleMouseDown } = useSizingContext();
39
43
  const { columnMove, onColumnMoveHandleMouseDown } = useColumnDragContext();
40
44
  const onMouseDown = columnMove ? onColumnMoveHandleMouseDown : void 0;
41
45
  const { ref, isFocusableContent, onFocus } = useFocusableContent();
46
+ const {
47
+ onClickSortColumn,
48
+ setSortByColumnId,
49
+ sortOrder,
50
+ sortByColumnId,
51
+ setSortOrder
52
+ } = useColumnSortContext();
53
+ const valueAlignRight = align === "right";
54
+ const HeaderCellSortingIcon = ({ justify }) => {
55
+ const className = withBaseName("sortingIcon");
56
+ const icon = /* @__PURE__ */ jsxs("div", {
57
+ className: clsx(className, {
58
+ [withBaseName("sortingIconStart")]: justify === "start",
59
+ [withBaseName("sortingIconEnd")]: justify === "end"
60
+ }),
61
+ "aria-hidden": true,
62
+ children: [
63
+ sortOrder === SortOrder.ASC && /* @__PURE__ */ jsx(ArrowUpIcon, {}),
64
+ sortOrder === SortOrder.DESC && /* @__PURE__ */ jsx(ArrowDownIcon, {})
65
+ ]
66
+ });
67
+ return icon;
68
+ };
69
+ const ariaSortMap = {
70
+ asc: "ascending",
71
+ desc: "descending",
72
+ none: "none"
73
+ };
74
+ const ariaSort = ariaSortMap[sortOrder];
75
+ const order = sortOrder === SortOrder.ASC ? SortOrder.DESC : sortOrder === SortOrder.DESC ? SortOrder.NONE : SortOrder.ASC;
76
+ const withSortOrder = sortOrder !== SortOrder.NONE && sortByColumnId === id;
77
+ const onClick = () => {
78
+ if (onSortOrderChange) {
79
+ setSortByColumnId(id);
80
+ setSortOrder(order);
81
+ onSortOrderChange({ sortOrder: order });
82
+ return;
83
+ }
84
+ setSortByColumnId(id);
85
+ onClickSortColumn(id);
86
+ };
87
+ const onKeyDown = (event) => {
88
+ if (event.key === "Enter" || event.key === " ") {
89
+ onClick();
90
+ }
91
+ };
42
92
  return /* @__PURE__ */ jsxs("th", {
43
93
  ref,
44
94
  "aria-colindex": column.index + 1,
45
95
  "data-column-index": column.index,
46
- className: clsx(withBaseName(), column.info.props.headerClassName),
96
+ className: clsx(withBaseName(), headerClassName, {
97
+ [withBaseName("sortable")]: sortable
98
+ }),
47
99
  role: "columnheader",
48
100
  "data-testid": "column-header",
49
101
  tabIndex: isFocused && !isFocusableContent ? 0 : -1,
50
102
  onFocus,
103
+ onClick: sortable ? onClick : void 0,
104
+ onKeyDown: sortable ? onKeyDown : void 0,
105
+ "aria-sort": sortByColumnId === id && sortable ? ariaSort : void 0,
106
+ "aria-label": column.info.props["aria-label"],
51
107
  children: [
108
+ sortByColumnId === id && sortable && valueAlignRight && /* @__PURE__ */ jsx(HeaderCellSortingIcon, {
109
+ justify: "start"
110
+ }),
52
111
  /* @__PURE__ */ jsx("div", {
53
112
  className: clsx(withBaseName("valueContainer"), {
54
- [withBaseName("alignRight")]: column.info.props.align === "right"
113
+ [withBaseName("alignRight")]: valueAlignRight,
114
+ [withBaseName("alignRightWithSortOrder")]: valueAlignRight && withSortOrder,
115
+ [withBaseName("alignLeftWithSortOrder")]: !valueAlignRight && withSortOrder
55
116
  }),
56
117
  onMouseDown,
57
118
  children
58
119
  }),
120
+ sortByColumnId === id && sortable && !valueAlignRight && /* @__PURE__ */ jsx(HeaderCellSortingIcon, {
121
+ justify: "end"
122
+ }),
59
123
  /* @__PURE__ */ jsx(HeaderCellSeparator, {
60
124
  separatorType: separator
61
125
  }),
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HeaderCell.js","sources":["../src/HeaderCell.tsx"],"sourcesContent":["import \"./HeaderCell.css\";\nimport { KeyboardEventHandler, useRef } from \"react\";\nimport {\n FlexContentAlignment,\n makePrefixer,\n useIsomorphicLayoutEffect,\n} from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { ColumnSeparatorType, SortOrder } from \"./Grid\";\nimport { useSizingContext } from \"./SizingContext\";\nimport { useColumnDragContext } from \"./ColumnDragContext\";\nimport { Cursor, useFocusableContent } from \"./internal\";\nimport { HeaderCellProps } from \"./GridColumn\";\nimport { useColumnSortContext } from \"./ColumnSortContext\";\nimport { ArrowDownIcon, ArrowUpIcon } from \"@salt-ds/icons\";\n\nconst withBaseName = makePrefixer(\"saltGridHeaderCell\");\n\nexport interface HeaderCellSeparatorProps {\n separatorType: ColumnSeparatorType;\n}\n\nexport function HeaderCellSeparator(props: HeaderCellSeparatorProps) {\n const className = withBaseName([props.separatorType, \"Separator\"].join(\"\"));\n return <div className={className} />;\n}\n\ntype AriaSortProps = \"none\" | \"ascending\" | \"descending\";\n\nexport function HeaderCell<T>(props: HeaderCellProps<T>) {\n const { column, children, isFocused } = props;\n const { separator } = column;\n const { align, id, headerClassName, sortable, onSortOrderChange } =\n column.info.props;\n const { onResizeHandleMouseDown } = useSizingContext();\n\n const { columnMove, onColumnMoveHandleMouseDown } = useColumnDragContext();\n const onMouseDown = columnMove ? onColumnMoveHandleMouseDown : undefined;\n\n const { ref, isFocusableContent, onFocus } =\n useFocusableContent<HTMLTableHeaderCellElement>();\n\n const {\n onClickSortColumn,\n setSortByColumnId,\n sortOrder,\n sortByColumnId,\n setSortOrder,\n } = useColumnSortContext();\n\n const valueAlignRight = align === \"right\";\n\n interface HeaderCellSortingIconProps {\n justify: FlexContentAlignment;\n }\n\n const HeaderCellSortingIcon = ({ justify }: HeaderCellSortingIconProps) => {\n const className = withBaseName(\"sortingIcon\");\n const icon = (\n <div\n className={clsx(className, {\n [withBaseName(\"sortingIconStart\")]: justify === \"start\",\n [withBaseName(\"sortingIconEnd\")]: justify === \"end\",\n })}\n aria-hidden\n >\n {sortOrder === SortOrder.ASC && <ArrowUpIcon />}\n {sortOrder === SortOrder.DESC && <ArrowDownIcon />}\n </div>\n );\n\n return icon;\n };\n\n const ariaSortMap = {\n asc: \"ascending\",\n desc: \"descending\",\n none: \"none\",\n };\n\n const ariaSort = ariaSortMap[sortOrder] as AriaSortProps;\n\n const order =\n sortOrder === SortOrder.ASC\n ? SortOrder.DESC\n : sortOrder === SortOrder.DESC\n ? SortOrder.NONE\n : SortOrder.ASC;\n\n const withSortOrder = sortOrder !== SortOrder.NONE && sortByColumnId === id;\n\n const onClick = () => {\n if (onSortOrderChange) {\n setSortByColumnId(id);\n setSortOrder(order);\n onSortOrderChange({ sortOrder: order });\n return;\n }\n setSortByColumnId(id);\n onClickSortColumn(id);\n };\n\n const onKeyDown: KeyboardEventHandler<HTMLTableHeaderCellElement> = (\n event\n ) => {\n if (event.key === \"Enter\" || event.key === \" \") {\n onClick();\n }\n };\n\n return (\n <th\n ref={ref}\n aria-colindex={column.index + 1}\n data-column-index={column.index}\n className={clsx(withBaseName(), headerClassName, {\n [withBaseName(\"sortable\")]: sortable,\n })}\n role=\"columnheader\"\n data-testid=\"column-header\"\n tabIndex={isFocused && !isFocusableContent ? 0 : -1}\n onFocus={onFocus}\n onClick={sortable ? onClick : undefined}\n onKeyDown={sortable ? onKeyDown : undefined}\n aria-sort={sortByColumnId === id && sortable ? ariaSort : undefined}\n aria-label={column.info.props[\"aria-label\"]}\n >\n {sortByColumnId === id && sortable && valueAlignRight && (\n <HeaderCellSortingIcon justify=\"start\" />\n )}\n <div\n className={clsx(withBaseName(\"valueContainer\"), {\n [withBaseName(\"alignRight\")]: valueAlignRight,\n // both classNames below needed to ensure header cell title & sort icon do not overlap when column resized to be smaller\n [withBaseName(\"alignRightWithSortOrder\")]:\n valueAlignRight && withSortOrder,\n [withBaseName(\"alignLeftWithSortOrder\")]:\n !valueAlignRight && withSortOrder,\n })}\n onMouseDown={onMouseDown}\n >\n {children}\n </div>\n {sortByColumnId === id && sortable && !valueAlignRight && (\n <HeaderCellSortingIcon justify=\"end\" />\n )}\n <HeaderCellSeparator separatorType={separator} />\n <div\n data-testid={`column-${column.index}-resize-handle`}\n className={withBaseName(\"resizeHandle\")}\n onMouseDown={onResizeHandleMouseDown}\n />\n {isFocused && !isFocusableContent && <Cursor />}\n </th>\n );\n}\n\nexport function AutoSizeHeaderCell<T>(props: HeaderCellProps<T>) {\n const { column, children, isFocused } = props;\n const { separator } = column;\n const valueContainerRef = useRef<HTMLDivElement>(null);\n const { resizeColumn } = useSizingContext();\n\n const { ref, isFocusableContent, onFocus } =\n useFocusableContent<HTMLTableHeaderCellElement>();\n\n useIsomorphicLayoutEffect(() => {\n const width = valueContainerRef.current\n ? valueContainerRef.current.offsetWidth\n : undefined;\n if (width != undefined && width !== column.info.width) {\n resizeColumn(column.index, width);\n }\n });\n\n return (\n <th\n ref={ref}\n aria-colindex={column.index + 1}\n data-column-index={column.index}\n className={withBaseName()}\n role=\"columnheader\"\n data-testid=\"column-header\"\n tabIndex={isFocused && !isFocusableContent ? 0 : -1}\n onFocus={onFocus}\n >\n <div className={withBaseName(\"autosizeContainer\")}>\n <div\n ref={valueContainerRef}\n className={withBaseName(\"measuredContent\")}\n >\n {children}\n </div>\n </div>\n <HeaderCellSeparator separatorType={separator} />\n {isFocused && !isFocusableContent && <Cursor />}\n </th>\n );\n}\n"],"names":[],"mappings":"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"}
@@ -1,4 +1,5 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
+ import { useCallback } from 'react';
2
3
  import { RowSelectionCheckboxHeaderCellValue } from './RowSelectionCheckboxHeaderCellValue.js';
3
4
  import { RowSelectionCheckboxCellValue } from './RowSelectionCheckboxCellValue.js';
4
5
  import { GridColumn } from './GridColumn.js';
@@ -7,13 +8,19 @@ import { AutoSizeHeaderCell } from './HeaderCell.js';
7
8
 
8
9
  function RowSelectionCheckboxColumn(props) {
9
10
  const { selectRows } = useSelectionContext();
10
- const onKeyDown = (event, rowIndex) => {
11
- if (event.key === " ") {
12
- selectRows({ rowIndex, incremental: true });
13
- event.preventDefault();
14
- event.stopPropagation();
15
- }
16
- };
11
+ const onKeyDown = useCallback(
12
+ (event, rowIndex) => {
13
+ if (event.key === " ") {
14
+ selectRows({
15
+ rowIndex,
16
+ incremental: true
17
+ });
18
+ event.preventDefault();
19
+ event.stopPropagation();
20
+ }
21
+ },
22
+ [selectRows]
23
+ );
17
24
  return /* @__PURE__ */ jsx(GridColumn, {
18
25
  ...props,
19
26
  defaultWidth: 100,
@@ -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":[],"mappings":";;;;;;;;AAYO,SAAS,2BACd,KACA,EAAA;AACA,EAAM,MAAA,EAAE,UAAW,EAAA,GAAI,mBAAoB,EAAA,CAAA;AAE3C,EAAA,MAAM,SAAY,GAAA,WAAA;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,uBACG,GAAA,CAAA,UAAA,EAAA;AAAA,IACE,GAAG,KAAA;AAAA,IACJ,YAAc,EAAA,GAAA;AAAA,IACd,eAAiB,EAAA,kBAAA;AAAA,IACjB,oBAAsB,EAAA,mCAAA;AAAA,IACtB,kBAAoB,EAAA,6BAAA;AAAA,IACpB,SAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
@@ -3,16 +3,20 @@ import { RowSelectionRadioCellValue } from './RowSelectionRadioCellValue.js';
3
3
  import { GridColumn } from './GridColumn.js';
4
4
  import { RowSelectionRadioHeaderCell } from './RowSelectionRadioHeaderCell.js';
5
5
  import { useSelectionContext } from './SelectionContext.js';
6
+ import { useCallback } from 'react';
6
7
 
7
8
  function RowSelectionRadioColumn(props) {
8
9
  const { selectRows } = useSelectionContext();
9
- const onKeyDown = (event, rowIndex) => {
10
- if (event.key === " ") {
11
- selectRows({ rowIndex });
12
- event.preventDefault();
13
- event.stopPropagation();
14
- }
15
- };
10
+ const onKeyDown = useCallback(
11
+ (event, rowIndex) => {
12
+ if (event.key === " ") {
13
+ selectRows({ rowIndex });
14
+ event.preventDefault();
15
+ event.stopPropagation();
16
+ }
17
+ },
18
+ [selectRows]
19
+ );
16
20
  return /* @__PURE__ */ jsx(GridColumn, {
17
21
  ...props,
18
22
  defaultWidth: 100,
@@ -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":[],"mappings":";;;;;;;AAWO,SAAS,wBACd,KACA,EAAA;AACA,EAAM,MAAA,EAAE,UAAW,EAAA,GAAI,mBAAoB,EAAA,CAAA;AAE3C,EAAA,MAAM,SAAY,GAAA,WAAA;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,uBACG,GAAA,CAAA,UAAA,EAAA;AAAA,IACE,GAAG,KAAA;AAAA,IACJ,YAAc,EAAA,GAAA;AAAA,IACd,eAAiB,EAAA,2BAAA;AAAA,IACjB,kBAAoB,EAAA,0BAAA;AAAA,IACpB,SAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,9 @@
1
+ import 'react/jsx-runtime';
2
+ import '@salt-ds/core';
3
+ import { createContext } from 'react';
4
+ import './GridContext.js';
5
+
6
+ const RowValidationStatusContext = createContext({});
7
+
8
+ export { RowValidationStatusContext };
9
+ //# 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":[],"mappings":";;;;;AAIa,MAAA,0BAAA,GAA6B,aAEvC,CAAA,EAAE;;;;"}
@@ -12,7 +12,7 @@ export { RowSelectionCheckboxCellValue } from './RowSelectionCheckboxCellValue.j
12
12
  export { RowSelectionRadioColumn } from './RowSelectionRadioColumn.js';
13
13
  export { SelectionContext, useSelectionContext } from './SelectionContext.js';
14
14
  export { SizingContext, useSizingContext } from './SizingContext.js';
15
- export { Grid } from './Grid.js';
15
+ export { Grid, SortOrder } from './Grid.js';
16
16
  export { GridColumn } from './GridColumn.js';
17
17
  export { GridContext, useGridContext } from './GridContext.js';
18
18
  export { RowSelectionCheckboxColumn } from './RowSelectionCheckboxColumn.js';
@@ -0,0 +1,7 @@
1
+ import styleInject from '../../../../node_modules/style-inject/dist/style-inject.es.js';
2
+
3
+ var css_248z = ".saltGridCell {\n box-sizing: border-box;\n margin: 0;\n padding: 0;\n\n white-space: nowrap;\n position: relative;\n font-size: var(--grid-fontSize);\n font-weight: normal;\n\n outline: 0;\n}\n\n.saltGridCell-selected {\n background: var(--grid-cell-background-selected);\n}\n\n.saltGridCell-rowSeparator {\n position: absolute;\n right: 0;\n bottom: 0;\n left: 0;\n height: 1px;\n background-color: var(--grid-row-borderColor);\n}\n\n.saltGridCell-topSeparator {\n position: absolute;\n top: 0;\n right: 0;\n left: 0;\n height: 1px;\n background-color: transparent;\n display: none;\n}\n\n.saltGridTableRow-first .saltGridCell-topSeparator {\n display: unset;\n}\n\n.saltGridCell-columnSeparator {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n width: 1px;\n background-color: var(--grid-row-background);\n}\n\n.saltGrid-columnSeparators .saltGridCell-regularSeparator .saltGridCell-columnSeparator {\n background-color: var(--grid-columnSeparator-color);\n}\n\n.saltGrid-columnSeparators .saltGridCell-pinnedSeparator .saltGridCell-columnSeparator {\n background-color: var(--grid-columnSeparator-color);\n}\n\n.saltGrid-pinnedSeparators .saltGridCell-pinnedSeparator .saltGridCell-columnSeparator {\n background-color: var(--grid-pinnedSeparator-color);\n}\n\n.saltGridTableRow-selected.saltGridTableRow-first .saltGridCell-topSeparator {\n background-color: var(--grid-row-borderColor);\n}\n\n.saltGridCell-body {\n box-sizing: border-box;\n position: absolute;\n top: 0;\n right: 0;\n bottom: 1px;\n left: 0;\n background: var(--grid-row-background);\n border-right: solid 1px transparent;\n}\n\n.saltGridTableRow-first .saltGridCell-body {\n top: 1px;\n}\n";
4
+ styleInject(css_248z);
5
+
6
+ export { css_248z as default };
7
+ //# sourceMappingURL=Cell.css.js.map
@@ -0,0 +1,40 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+
3
+ const CellWarningIcon = /* @__PURE__ */ jsx("svg", {
4
+ "aria-hidden": true,
5
+ height: "1em",
6
+ viewBox: "0 0 10 8",
7
+ fill: "none",
8
+ xmlns: "http://www.w3.org/2000/svg",
9
+ children: /* @__PURE__ */ jsx("path", {
10
+ d: "M4.6188 0L9.2376 8H0L4.6188 0Z"
11
+ })
12
+ });
13
+ const CellErrorIcon = /* @__PURE__ */ jsx("svg", {
14
+ "aria-hidden": true,
15
+ width: "1em",
16
+ height: "1em",
17
+ viewBox: "0 0 8 8",
18
+ fill: "none",
19
+ xmlns: "http://www.w3.org/2000/svg",
20
+ children: /* @__PURE__ */ jsx("circle", {
21
+ cx: "4",
22
+ cy: "4",
23
+ r: "4"
24
+ })
25
+ });
26
+ const CellSuccessIcon = /* @__PURE__ */ jsx("svg", {
27
+ xmlns: "http://www.w3.org/2000/svg",
28
+ width: "1em",
29
+ viewBox: "0 0 14 14",
30
+ fill: "none",
31
+ children: /* @__PURE__ */ jsx("path", {
32
+ fillRule: "evenodd",
33
+ clipRule: "evenodd",
34
+ d: "M13.7668 2.63645L5.06034 12.0309L0.277532 7.56074L1.47248 6.28223L4.97136 9.55242L12.4832 1.4469L13.7668 2.63645Z",
35
+ fill: "#24874B"
36
+ })
37
+ });
38
+
39
+ export { CellErrorIcon, CellSuccessIcon, CellWarningIcon };
40
+ //# sourceMappingURL=CellStatusIcons.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CellStatusIcons.js","sources":["../src/internal/CellStatusIcons.tsx"],"sourcesContent":["export const CellWarningIcon = (\n <svg\n aria-hidden\n height=\"1em\"\n viewBox=\"0 0 10 8\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path d=\"M4.6188 0L9.2376 8H0L4.6188 0Z\" />\n </svg>\n);\n\nexport const CellErrorIcon = (\n <svg\n aria-hidden\n width=\"1em\"\n height=\"1em\"\n viewBox=\"0 0 8 8\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <circle cx=\"4\" cy=\"4\" r=\"4\" />\n </svg>\n);\n\nexport const CellSuccessIcon = (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"1em\"\n viewBox=\"0 0 14 14\"\n fill=\"none\"\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M13.7668 2.63645L5.06034 12.0309L0.277532 7.56074L1.47248 6.28223L4.97136 9.55242L12.4832 1.4469L13.7668 2.63645Z\"\n fill=\"#24874B\"\n />\n </svg>\n);\n"],"names":[],"mappings":";;AAAO,MAAM,kCACV,GAAA,CAAA,KAAA,EAAA;AAAA,EACC,aAAW,EAAA,IAAA;AAAA,EACX,MAAO,EAAA,KAAA;AAAA,EACP,OAAQ,EAAA,UAAA;AAAA,EACR,IAAK,EAAA,MAAA;AAAA,EACL,KAAM,EAAA,4BAAA;AAAA,EAEN,QAAC,kBAAA,GAAA,CAAA,MAAA,EAAA;AAAA,IAAK,CAAE,EAAA,gCAAA;AAAA,GAAiC,CAAA;AAAA,CAC3C,EAAA;AAGK,MAAM,gCACV,GAAA,CAAA,KAAA,EAAA;AAAA,EACC,aAAW,EAAA,IAAA;AAAA,EACX,KAAM,EAAA,KAAA;AAAA,EACN,MAAO,EAAA,KAAA;AAAA,EACP,OAAQ,EAAA,SAAA;AAAA,EACR,IAAK,EAAA,MAAA;AAAA,EACL,KAAM,EAAA,4BAAA;AAAA,EAEN,QAAC,kBAAA,GAAA,CAAA,QAAA,EAAA;AAAA,IAAO,EAAG,EAAA,GAAA;AAAA,IAAI,EAAG,EAAA,GAAA;AAAA,IAAI,CAAE,EAAA,GAAA;AAAA,GAAI,CAAA;AAAA,CAC9B,EAAA;AAGK,MAAM,kCACV,GAAA,CAAA,KAAA,EAAA;AAAA,EACC,KAAM,EAAA,4BAAA;AAAA,EACN,KAAM,EAAA,KAAA;AAAA,EACN,OAAQ,EAAA,WAAA;AAAA,EACR,IAAK,EAAA,MAAA;AAAA,EAEL,QAAC,kBAAA,GAAA,CAAA,MAAA,EAAA;AAAA,IACC,QAAS,EAAA,SAAA;AAAA,IACT,QAAS,EAAA,SAAA;AAAA,IACT,CAAE,EAAA,mHAAA;AAAA,IACF,IAAK,EAAA,SAAA;AAAA,GACP,CAAA;AAAA,CACF;;;;"}
@@ -16,7 +16,8 @@ function LeftPart(props) {
16
16
  rows,
17
17
  hoverOverRowKey,
18
18
  setHoverOverRowKey,
19
- zebra
19
+ zebra,
20
+ getRowValidationStatus
20
21
  } = props;
21
22
  const tableRef = useActiveOnWheel(onWheel);
22
23
  if (columns.length === 0) {
@@ -42,7 +43,8 @@ function LeftPart(props) {
42
43
  rows,
43
44
  hoverRowKey: hoverOverRowKey,
44
45
  setHoverRowKey: setHoverOverRowKey,
45
- zebra
46
+ zebra,
47
+ getRowValidationStatus
46
48
  })
47
49
  ]
48
50
  })
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LeftPart.js","sources":["../src/internal/LeftPart.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport { TableColGroup } from \"./TableColGroup\";\nimport { TableBody } from \"./TableBody\";\nimport { RefObject } from \"react\";\nimport \"./LeftPart.css\";\nimport { makePrefixer } from \"@salt-ds/core\";\nimport { GridColumnModel, GridRowModel } from \"../Grid\";\nimport { useActiveOnWheel } from \"./gridHooks\";\nimport { CellValidationState } from \"../GridColumn\";\n\nconst withBaseName = makePrefixer(\"saltGridLeftPart\");\n\nexport interface LeftPartProps<T> {\n leftRef: RefObject<HTMLDivElement>;\n onWheel: EventListener;\n rightShadow?: boolean;\n columns: GridColumnModel<T>[];\n rows: GridRowModel<T>[];\n hoverOverRowKey?: string;\n setHoverOverRowKey: (key: string | undefined) => void;\n zebra?: boolean;\n getRowValidationStatus?: (\n row: GridRowModel<T>\n ) => CellValidationState | undefined;\n}\n\nexport function LeftPart<T>(props: LeftPartProps<T>) {\n const {\n leftRef,\n onWheel,\n rightShadow,\n columns,\n rows,\n hoverOverRowKey,\n setHoverOverRowKey,\n zebra,\n getRowValidationStatus,\n } = props;\n\n const tableRef = useActiveOnWheel(onWheel);\n\n if (columns.length === 0) {\n return null;\n }\n\n return (\n <div\n ref={leftRef}\n className={clsx(withBaseName(), {\n [withBaseName(\"rightShadow\")]: rightShadow,\n })}\n >\n <div className={withBaseName(\"space\")} data-testid=\"grid-left-part\">\n <table ref={tableRef} role=\"presentation\">\n <TableColGroup columns={columns} />\n <TableBody\n columns={columns}\n rows={rows}\n hoverRowKey={hoverOverRowKey}\n setHoverRowKey={setHoverOverRowKey}\n zebra={zebra}\n getRowValidationStatus={getRowValidationStatus}\n />\n </table>\n </div>\n </div>\n );\n}\n"],"names":[],"mappings":";;;;;;;;AAUA,MAAM,YAAA,GAAe,aAAa,kBAAkB,CAAA,CAAA;AAgB7C,SAAS,SAAY,KAAyB,EAAA;AACnD,EAAM,MAAA;AAAA,IACJ,OAAA;AAAA,IACA,OAAA;AAAA,IACA,WAAA;AAAA,IACA,OAAA;AAAA,IACA,IAAA;AAAA,IACA,eAAA;AAAA,IACA,kBAAA;AAAA,IACA,KAAA;AAAA,IACA,sBAAA;AAAA,GACE,GAAA,KAAA,CAAA;AAEJ,EAAM,MAAA,QAAA,GAAW,iBAAiB,OAAO,CAAA,CAAA;AAEzC,EAAI,IAAA,OAAA,CAAQ,WAAW,CAAG,EAAA;AACxB,IAAO,OAAA,IAAA,CAAA;AAAA,GACT;AAEA,EAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,IACC,GAAK,EAAA,OAAA;AAAA,IACL,SAAA,EAAW,IAAK,CAAA,YAAA,EAAgB,EAAA;AAAA,MAC9B,CAAC,YAAa,CAAA,aAAa,CAAI,GAAA,WAAA;AAAA,KAChC,CAAA;AAAA,IAED,QAAC,kBAAA,GAAA,CAAA,KAAA,EAAA;AAAA,MAAI,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,MAAG,aAAY,EAAA,gBAAA;AAAA,MACjD,QAAC,kBAAA,IAAA,CAAA,OAAA,EAAA;AAAA,QAAM,GAAK,EAAA,QAAA;AAAA,QAAU,IAAK,EAAA,cAAA;AAAA,QACzB,QAAA,EAAA;AAAA,0BAAC,GAAA,CAAA,aAAA,EAAA;AAAA,YAAc,OAAA;AAAA,WAAkB,CAAA;AAAA,0BAChC,GAAA,CAAA,SAAA,EAAA;AAAA,YACC,OAAA;AAAA,YACA,IAAA;AAAA,YACA,WAAa,EAAA,eAAA;AAAA,YACb,cAAgB,EAAA,kBAAA;AAAA,YAChB,KAAA;AAAA,YACA,sBAAA;AAAA,WACF,CAAA;AAAA,SAAA;AAAA,OACF,CAAA;AAAA,KACF,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
@@ -15,7 +15,8 @@ function MiddlePart(props) {
15
15
  hoverOverRowKey,
16
16
  setHoverOverRowKey,
17
17
  midGap,
18
- zebra
18
+ zebra,
19
+ getRowValidationStatus
19
20
  } = props;
20
21
  const tableRef = useActiveOnWheel(onWheel);
21
22
  return /* @__PURE__ */ jsx("div", {
@@ -38,7 +39,8 @@ function MiddlePart(props) {
38
39
  hoverRowKey: hoverOverRowKey,
39
40
  setHoverRowKey: setHoverOverRowKey,
40
41
  gap: midGap,
41
- zebra
42
+ zebra,
43
+ getRowValidationStatus
42
44
  })
43
45
  ]
44
46
  })
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MiddlePart.js","sources":["../src/internal/MiddlePart.tsx"],"sourcesContent":["import { RefObject } from \"react\";\nimport { TableColGroup } from \"./TableColGroup\";\nimport { TableBody } from \"./TableBody\";\nimport \"./MiddlePart.css\";\nimport { makePrefixer } from \"@salt-ds/core\";\nimport { GridColumnModel, GridRowModel } from \"../Grid\";\nimport { useActiveOnWheel } from \"./gridHooks\";\nimport { CellValidationState } from \"../GridColumn\";\n\nconst withBaseName = makePrefixer(\"saltGridMiddlePart\");\n\nexport interface MiddlePartProps<T> {\n middleRef: RefObject<HTMLDivElement>;\n onWheel: EventListener;\n columns: GridColumnModel<T>[];\n rows: GridRowModel<T>[];\n hoverOverRowKey?: string;\n setHoverOverRowKey: (key: string | undefined) => void;\n midGap: number;\n zebra?: boolean;\n getRowValidationStatus?: (\n row: GridRowModel<T>\n ) => CellValidationState | undefined;\n}\n\nexport function MiddlePart<T>(props: MiddlePartProps<T>) {\n const {\n middleRef,\n onWheel,\n columns,\n rows,\n hoverOverRowKey,\n setHoverOverRowKey,\n midGap,\n zebra,\n getRowValidationStatus,\n } = props;\n\n const tableRef = useActiveOnWheel(onWheel);\n\n return (\n <div\n ref={middleRef}\n className={withBaseName()}\n data-testid=\"grid-middle-part\"\n >\n <div className={withBaseName(\"space\")}>\n <table ref={tableRef} role=\"presentation\">\n <TableColGroup columns={columns} gap={midGap} />\n <TableBody\n columns={columns}\n rows={rows}\n hoverRowKey={hoverOverRowKey}\n setHoverRowKey={setHoverOverRowKey}\n gap={midGap}\n zebra={zebra}\n getRowValidationStatus={getRowValidationStatus}\n />\n </table>\n </div>\n </div>\n );\n}\n"],"names":[],"mappings":";;;;;;;AASA,MAAM,YAAA,GAAe,aAAa,oBAAoB,CAAA,CAAA;AAgB/C,SAAS,WAAc,KAA2B,EAAA;AACvD,EAAM,MAAA;AAAA,IACJ,SAAA;AAAA,IACA,OAAA;AAAA,IACA,OAAA;AAAA,IACA,IAAA;AAAA,IACA,eAAA;AAAA,IACA,kBAAA;AAAA,IACA,MAAA;AAAA,IACA,KAAA;AAAA,IACA,sBAAA;AAAA,GACE,GAAA,KAAA,CAAA;AAEJ,EAAM,MAAA,QAAA,GAAW,iBAAiB,OAAO,CAAA,CAAA;AAEzC,EAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,IACC,GAAK,EAAA,SAAA;AAAA,IACL,WAAW,YAAa,EAAA;AAAA,IACxB,aAAY,EAAA,kBAAA;AAAA,IAEZ,QAAC,kBAAA,GAAA,CAAA,KAAA,EAAA;AAAA,MAAI,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,MAClC,QAAC,kBAAA,IAAA,CAAA,OAAA,EAAA;AAAA,QAAM,GAAK,EAAA,QAAA;AAAA,QAAU,IAAK,EAAA,cAAA;AAAA,QACzB,QAAA,EAAA;AAAA,0BAAC,GAAA,CAAA,aAAA,EAAA;AAAA,YAAc,OAAA;AAAA,YAAkB,GAAK,EAAA,MAAA;AAAA,WAAQ,CAAA;AAAA,0BAC7C,GAAA,CAAA,SAAA,EAAA;AAAA,YACC,OAAA;AAAA,YACA,IAAA;AAAA,YACA,WAAa,EAAA,eAAA;AAAA,YACb,cAAgB,EAAA,kBAAA;AAAA,YAChB,GAAK,EAAA,MAAA;AAAA,YACL,KAAA;AAAA,YACA,sBAAA;AAAA,WACF,CAAA;AAAA,SAAA;AAAA,OACF,CAAA;AAAA,KACF,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
@@ -16,7 +16,8 @@ function RightPart(props) {
16
16
  rows,
17
17
  hoverOverRowKey,
18
18
  setHoverOverRowKey,
19
- zebra
19
+ zebra,
20
+ getRowValidationStatus
20
21
  } = props;
21
22
  const tableRef = useActiveOnWheel(onWheel);
22
23
  if (columns.length === 0) {
@@ -42,7 +43,8 @@ function RightPart(props) {
42
43
  rows,
43
44
  hoverRowKey: hoverOverRowKey,
44
45
  setHoverRowKey: setHoverOverRowKey,
45
- zebra
46
+ zebra,
47
+ getRowValidationStatus
46
48
  })
47
49
  ]
48
50
  })
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RightPart.js","sources":["../src/internal/RightPart.tsx"],"sourcesContent":["import { RefObject } from \"react\";\nimport { clsx } from \"clsx\";\nimport { TableColGroup } from \"./TableColGroup\";\nimport { TableBody } from \"./TableBody\";\nimport \"./RightPart.css\";\nimport { makePrefixer } from \"@salt-ds/core\";\nimport { GridColumnModel, GridRowModel } from \"../Grid\";\nimport { useActiveOnWheel } from \"./gridHooks\";\nimport { CellValidationState } from \"../GridColumn\";\n\nconst withBaseName = makePrefixer(\"saltGridRightPart\");\n\nexport interface RightPartProps<T> {\n rightRef: RefObject<HTMLDivElement>;\n onWheel: EventListener;\n leftShadow?: boolean;\n columns: GridColumnModel<T>[];\n rows: GridRowModel<T>[];\n hoverOverRowKey?: string;\n setHoverOverRowKey: (key: string | undefined) => void;\n zebra?: boolean;\n getRowValidationStatus?: (\n row: GridRowModel<T>\n ) => CellValidationState | undefined;\n}\n\nexport function RightPart<T>(props: RightPartProps<T>) {\n const {\n rightRef,\n onWheel,\n columns,\n leftShadow,\n rows,\n hoverOverRowKey,\n setHoverOverRowKey,\n zebra,\n getRowValidationStatus,\n } = props;\n\n const tableRef = useActiveOnWheel(onWheel);\n\n if (columns.length === 0) {\n return null;\n }\n\n return (\n <div\n ref={rightRef}\n className={clsx(withBaseName(), {\n [withBaseName(\"leftShadow\")]: leftShadow,\n })}\n data-testid=\"grid-right-part\"\n >\n <div className={withBaseName(\"space\")}>\n <table ref={tableRef} role=\"presentation\">\n <TableColGroup columns={columns} />\n <TableBody\n columns={columns}\n rows={rows}\n hoverRowKey={hoverOverRowKey}\n setHoverRowKey={setHoverOverRowKey}\n zebra={zebra}\n getRowValidationStatus={getRowValidationStatus}\n />\n </table>\n </div>\n </div>\n );\n}\n"],"names":[],"mappings":";;;;;;;;AAUA,MAAM,YAAA,GAAe,aAAa,mBAAmB,CAAA,CAAA;AAgB9C,SAAS,UAAa,KAA0B,EAAA;AACrD,EAAM,MAAA;AAAA,IACJ,QAAA;AAAA,IACA,OAAA;AAAA,IACA,OAAA;AAAA,IACA,UAAA;AAAA,IACA,IAAA;AAAA,IACA,eAAA;AAAA,IACA,kBAAA;AAAA,IACA,KAAA;AAAA,IACA,sBAAA;AAAA,GACE,GAAA,KAAA,CAAA;AAEJ,EAAM,MAAA,QAAA,GAAW,iBAAiB,OAAO,CAAA,CAAA;AAEzC,EAAI,IAAA,OAAA,CAAQ,WAAW,CAAG,EAAA;AACxB,IAAO,OAAA,IAAA,CAAA;AAAA,GACT;AAEA,EAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,IACC,GAAK,EAAA,QAAA;AAAA,IACL,SAAA,EAAW,IAAK,CAAA,YAAA,EAAgB,EAAA;AAAA,MAC9B,CAAC,YAAa,CAAA,YAAY,CAAI,GAAA,UAAA;AAAA,KAC/B,CAAA;AAAA,IACD,aAAY,EAAA,iBAAA;AAAA,IAEZ,QAAC,kBAAA,GAAA,CAAA,KAAA,EAAA;AAAA,MAAI,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,MAClC,QAAC,kBAAA,IAAA,CAAA,OAAA,EAAA;AAAA,QAAM,GAAK,EAAA,QAAA;AAAA,QAAU,IAAK,EAAA,cAAA;AAAA,QACzB,QAAA,EAAA;AAAA,0BAAC,GAAA,CAAA,aAAA,EAAA;AAAA,YAAc,OAAA;AAAA,WAAkB,CAAA;AAAA,0BAChC,GAAA,CAAA,SAAA,EAAA;AAAA,YACC,OAAA;AAAA,YACA,IAAA;AAAA,YACA,WAAa,EAAA,eAAA;AAAA,YACb,cAAgB,EAAA,kBAAA;AAAA,YAChB,KAAA;AAAA,YACA,sBAAA;AAAA,WACF,CAAA;AAAA,SAAA;AAAA,OACF,CAAA;AAAA,KACF,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
@@ -7,7 +7,15 @@ import { useEditorContext } from '../EditorContext.js';
7
7
  import { useCursorContext } from '../CursorContext.js';
8
8
 
9
9
  function TableBody(props) {
10
- const { columns, rows, hoverRowKey, setHoverRowKey, gap, zebra } = props;
10
+ const {
11
+ columns,
12
+ rows,
13
+ hoverRowKey,
14
+ setHoverRowKey,
15
+ gap,
16
+ zebra,
17
+ getRowValidationStatus
18
+ } = props;
11
19
  const { selRowIdxs, selectedCellRange } = useSelectionContext();
12
20
  const isCellInSelectedRange = useCallback(
13
21
  (rowIdx, colIdx) => {
@@ -41,7 +49,6 @@ function TableBody(props) {
41
49
  onDoubleClick,
42
50
  children: rows.map((row) => {
43
51
  const isSelected = selRowIdxs.has(row.index);
44
- const isFollowedBySelected = selRowIdxs.has(row.index + 1);
45
52
  const cursorIdx = focusedPart === "body" && cursorRowIdx === row.index ? cursorColIdx : void 0;
46
53
  const editorColIdx = editMode ? cursorIdx : void 0;
47
54
  return /* @__PURE__ */ jsx(TableRow, {
@@ -50,13 +57,13 @@ function TableBody(props) {
50
57
  columns,
51
58
  isHoverOver: row.key === hoverRowKey,
52
59
  isSelected,
53
- isFollowedBySelected,
54
60
  cursorColIdx: cursorIdx,
55
61
  gap,
56
62
  zebra: zebra && row.index % 2 == 0,
57
63
  editorColIdx,
58
64
  isCellSelected: isCellInSelectedRange,
59
- headerIsFocusable
65
+ headerIsFocusable,
66
+ validationStatus: getRowValidationStatus ? getRowValidationStatus(row) : void 0
60
67
  }, row.key);
61
68
  })
62
69
  });
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableBody.js","sources":["../src/internal/TableBody.tsx"],"sourcesContent":["import { MouseEventHandler, useCallback, useMemo } from \"react\";\nimport { TableRow } from \"./TableRow\";\nimport { GridColumnModel, GridRowModel } from \"../Grid\";\nimport { getRowKeyAttribute } from \"./utils\";\nimport { useSelectionContext } from \"../SelectionContext\";\nimport { useEditorContext } from \"../EditorContext\";\nimport { useCursorContext } from \"../CursorContext\";\nimport { CellValidationState } from \"../GridColumn\";\n\nexport interface TableBodyProps<T> {\n columns: GridColumnModel<T>[];\n rows: GridRowModel<T>[];\n hoverRowKey?: string;\n setHoverRowKey: (key: string | undefined) => void;\n gap?: number;\n zebra?: boolean;\n getRowValidationStatus?: (\n row: GridRowModel<T>\n ) => CellValidationState | undefined;\n}\n\nexport function TableBody<T>(props: TableBodyProps<T>) {\n const {\n columns,\n rows,\n hoverRowKey,\n setHoverRowKey,\n gap,\n zebra,\n getRowValidationStatus,\n } = props;\n const { selRowIdxs, selectedCellRange } = useSelectionContext();\n\n const isCellInSelectedRange = useCallback(\n (rowIdx: number, colIdx: number) => {\n if (!selectedCellRange) {\n return false;\n }\n const { start, end } = selectedCellRange;\n const minRowIdx = Math.min(start.rowIdx, end.rowIdx);\n const maxRowIdx = Math.max(start.rowIdx, end.rowIdx);\n const minColIdx = Math.min(start.colIdx, end.colIdx);\n const maxColIdx = Math.max(start.colIdx, end.colIdx);\n return (\n rowIdx >= minRowIdx &&\n rowIdx <= maxRowIdx &&\n colIdx >= minColIdx &&\n colIdx <= maxColIdx\n );\n },\n [selectedCellRange]\n );\n\n const { cursorRowIdx, cursorColIdx, focusedPart, headerIsFocusable } =\n useCursorContext();\n\n const { editMode, startEditMode } = useEditorContext();\n\n const onRowMouseEnter: MouseEventHandler<HTMLTableRowElement> = (event) => {\n const target = event.target as HTMLElement;\n const rowKey = getRowKeyAttribute(target);\n setHoverRowKey(rowKey);\n };\n\n const onMouseLeave: MouseEventHandler<HTMLTableSectionElement> = (event) => {\n setHoverRowKey(undefined);\n };\n\n const onDoubleClick: MouseEventHandler<HTMLTableSectionElement> = (event) => {\n startEditMode();\n };\n\n return (\n <tbody onMouseLeave={onMouseLeave} onDoubleClick={onDoubleClick}>\n {rows.map((row) => {\n const isSelected = selRowIdxs.has(row.index);\n const cursorIdx =\n focusedPart === \"body\" && cursorRowIdx === row.index\n ? cursorColIdx\n : undefined;\n const editorColIdx = editMode ? cursorIdx : undefined;\n return (\n <TableRow\n key={row.key}\n row={row}\n onMouseEnter={onRowMouseEnter}\n columns={columns}\n isHoverOver={row.key === hoverRowKey}\n isSelected={isSelected}\n cursorColIdx={cursorIdx}\n gap={gap}\n zebra={zebra && row.index % 2 == 0}\n editorColIdx={editorColIdx}\n isCellSelected={isCellInSelectedRange}\n headerIsFocusable={headerIsFocusable}\n validationStatus={\n getRowValidationStatus ? getRowValidationStatus(row) : undefined\n }\n />\n );\n })}\n </tbody>\n );\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import styleInject from '../../../../node_modules/style-inject/dist/style-inject.es.js';
2
+
3
+ var css_248z = ".saltGridTableRow {\n height: var(--grid-row-height);\n /* Row border doesn't render properly in Chrome on Windows. Applying borders to cells */\n --grid-row-borderColor: var(--grid-rowSeparator-color);\n --grid-row-background: var(--grid-background);\n}\n\n.saltGridTableRow-first {\n height: calc(var(--grid-row-height) + 1px);\n}\n\n.saltGridTableRow th {\n border-style: solid;\n border-color: var(--grid-row-borderColor);\n border-width: var(--grid-rowSeparator-width) 0 0 0;\n}\n\n.saltGridTableRow-divided {\n --grid-row-borderColor: var(--grid-rowSeparator-color-divided);\n}\n\n.saltGridTableRow-zebra {\n --grid-row-background: var(--grid-zebraColor);\n}\n\n.saltGridTableRow-hover {\n --grid-row-background: var(--grid-row-background-hover);\n}\n\n.saltGridTableRow-selected {\n --grid-row-borderColor: var(--grid-row-borderColor-selected);\n --grid-row-background: var(--grid-row-background-selected);\n}\n\n.saltGridTableRow-selected .saltGridCell:before {\n content: \"\";\n position: absolute;\n top: -1px;\n left: 0;\n right: 0;\n height: 1px;\n background: var(--grid-row-borderColor);\n z-index: var(--salt-zIndex-default);\n}\n\n.saltGridTableRow-zebra.saltGridTableRow-selected {\n --grid-row-background: var(--grid-row-background-selected);\n}\n\n.saltGridTableRow-zebra.saltGridTableRow-hover {\n --grid-row-background: var(--grid-row-background-hover);\n}\n\n.saltGridTableRow-zebra.saltGridTableRow-selected.saltGridTableRow-hover {\n --grid-row-background: var(--grid-row-background-hover);\n}\n\n.saltGridTableRow-selected.saltGridTableRow-hover {\n --grid-row-background: var(--grid-row-background-hover);\n}\n\n.saltGridTableRow-validationStatus-error,\n.saltGridTableRow-validationStatus-error.saltGridTableRow-hover {\n --grid-row-background: var(--salt-status-error-background-emphasize);\n}\n.saltGridTableRow-validationStatus-warning,\n.saltGridTableRow-validationStatus-warning.saltGridTableRow-hover {\n --grid-row-background: var(--salt-status-warning-background-emphasize);\n}\n.saltGridTableRow-validationStatus-success,\n.saltGridTableRow-validationStatus-success.saltGridTableRow-hover {\n --grid-row-background: var(--salt-status-success-background-emphasize);\n}\n\n.saltGridTableRow-validationStatus-error.saltGridTableRow-selected {\n --grid-row-background: var(--salt-status-error-background-selected);\n --grid-row-borderColor: var(--salt-status-error-borderColor);\n}\n.saltGridTableRow-validationStatus-warning.saltGridTableRow-selected {\n --grid-row-background: var(--salt-status-warning-background-selected);\n --grid-row-borderColor: var(--salt-status-warning-borderColor);\n}\n.saltGridTableRow-validationStatus-success.saltGridTableRow-selected {\n --grid-row-background: var(--salt-status-success-background-selected);\n --grid-row-borderColor: var(--salt-status-success-borderColor);\n}\n";
4
+ styleInject(css_248z);
5
+
6
+ export { css_248z as default };
7
+ //# sourceMappingURL=TableRow.css.js.map
@@ -7,13 +7,13 @@ import { clsx } from 'clsx';
7
7
  import { FakeCell } from './FakeCell.js';
8
8
  import { DefaultCellValue } from './DefaultCellValue.js';
9
9
  import { useGridContext } from '../GridContext.js';
10
+ import { RowValidationStatusContext } from '../RowValidationStatus.js';
10
11
 
11
12
  const withBaseName = makePrefixer("saltGridTableRow");
12
13
  function TableRow(props) {
13
14
  const {
14
15
  row,
15
16
  isSelected,
16
- isFollowedBySelected,
17
17
  zebra,
18
18
  isHoverOver,
19
19
  columns,
@@ -23,7 +23,8 @@ function TableRow(props) {
23
23
  gap,
24
24
  editorColIdx,
25
25
  isCellSelected,
26
- headerIsFocusable
26
+ headerIsFocusable,
27
+ validationStatus: rowValidationStatus
27
28
  } = props;
28
29
  const grid = useGridContext();
29
30
  if (!row.key) {
@@ -37,8 +38,8 @@ function TableRow(props) {
37
38
  [withBaseName("zebra")]: zebra,
38
39
  [withBaseName("hover")]: isHoverOver,
39
40
  [withBaseName("selected")]: isSelected,
40
- [withBaseName("followedBySelected")]: isFollowedBySelected && !isSelected,
41
- [withBaseName("first")]: row.index === 0
41
+ [withBaseName("first")]: row.index === 0,
42
+ [withBaseName(`validationStatus-${rowValidationStatus}`)]: rowValidationStatus
42
43
  }),
43
44
  onMouseEnter,
44
45
  onMouseLeave,
@@ -47,6 +48,7 @@ function TableRow(props) {
47
48
  role: "row",
48
49
  children: [
49
50
  columns.map((column, i) => {
51
+ var _a, _b, _c, _d;
50
52
  const colKey = column.info.props.id;
51
53
  const editorInfo = grid.getEditor(column.info.props.id);
52
54
  const isEditable = !!editorInfo;
@@ -67,19 +69,38 @@ function TableRow(props) {
67
69
  const value = column.info.props.getValue && row.data ? column.info.props.getValue(row.data) : null;
68
70
  const isFocused = cursorColIdx === column.index;
69
71
  const isSelected2 = isCellSelected && isCellSelected(row.index, column.index);
70
- return /* @__PURE__ */ jsx(Cell, {
72
+ const validationFnArg = {
71
73
  row,
72
74
  column,
73
75
  isFocused,
74
- isSelected: isSelected2,
75
- isEditable,
76
- children: /* @__PURE__ */ jsx(CellValue, {
77
- column,
76
+ value
77
+ };
78
+ const validationStatus = (_b = (_a = column.info.props).getValidationStatus) == null ? void 0 : _b.call(_a, validationFnArg);
79
+ const validationMessage = validationStatus && ((_d = (_c = column.info.props).getValidationMessage) == null ? void 0 : _d.call(_c, validationFnArg));
80
+ return /* @__PURE__ */ jsx(RowValidationStatusContext.Provider, {
81
+ value: { status: rowValidationStatus },
82
+ children: /* @__PURE__ */ jsx(Cell, {
78
83
  row,
84
+ column,
85
+ isFocused,
86
+ isSelected: isSelected2,
87
+ isEditable,
88
+ validationStatus,
89
+ validationMessage,
90
+ validationType: column.info.props.validationType,
79
91
  value,
80
- isFocused
81
- })
82
- }, colKey);
92
+ align: column.info.props.align,
93
+ children: /* @__PURE__ */ jsx(CellValue, {
94
+ column,
95
+ row,
96
+ value,
97
+ isFocused,
98
+ validationStatus,
99
+ validationMessage,
100
+ validationType: column.info.props.validationType
101
+ })
102
+ }, colKey)
103
+ });
83
104
  }),
84
105
  gap !== void 0 && gap > 0 ? /* @__PURE__ */ jsx(FakeCell, {
85
106
  row
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableRow.js","sources":["../src/internal/TableRow.tsx"],"sourcesContent":["import {\n Children,\n cloneElement,\n isValidElement,\n MouseEventHandler,\n} from \"react\";\nimport \"./TableRow.css\";\nimport { BaseCell } from \"../BaseCell\";\nimport { makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { GridColumnModel, GridRowModel } from \"../Grid\";\nimport { FakeCell } from \"./FakeCell\";\nimport { DefaultCellValue } from \"./DefaultCellValue\";\nimport { useGridContext } from \"../GridContext\";\nimport { CellValidationState } from \"../GridColumn\";\nimport { RowValidationStatusContext } from \"../RowValidationStatus\";\n\nconst withBaseName = makePrefixer(\"saltGridTableRow\");\n\nexport interface TableRowProps<T> {\n row: GridRowModel<T>;\n isSelected?: boolean;\n isHoverOver?: boolean;\n zebra?: boolean;\n columns: GridColumnModel<T>[];\n cursorColIdx?: number;\n onMouseEnter?: MouseEventHandler<HTMLTableRowElement>;\n onMouseLeave?: MouseEventHandler<HTMLTableRowElement>;\n gap?: number;\n editorColIdx?: number;\n isCellSelected?: (rowIdx: number, colIdx: number) => boolean;\n headerIsFocusable?: boolean;\n validationStatus?: CellValidationState;\n}\n\nexport function TableRow<T>(props: TableRowProps<T>) {\n const {\n row,\n isSelected,\n zebra,\n isHoverOver,\n columns,\n onMouseEnter,\n onMouseLeave,\n cursorColIdx,\n gap,\n editorColIdx,\n isCellSelected,\n headerIsFocusable,\n validationStatus: rowValidationStatus,\n } = props;\n\n const grid = useGridContext();\n\n if (!row.key) {\n throw new Error(`Invalid row`);\n }\n\n const ariaRowIndex = headerIsFocusable ? row.index + 2 : row.index + 1;\n\n return (\n <tr\n aria-rowindex={ariaRowIndex}\n aria-selected={isSelected ? true : undefined}\n className={clsx(withBaseName(), {\n [withBaseName(\"zebra\")]: zebra,\n [withBaseName(\"hover\")]: isHoverOver,\n [withBaseName(\"selected\")]: isSelected,\n [withBaseName(\"first\")]: row.index === 0,\n [withBaseName(`validationStatus-${rowValidationStatus}`)]:\n rowValidationStatus,\n })}\n onMouseEnter={onMouseEnter}\n onMouseLeave={onMouseLeave}\n data-row-index={row.index}\n data-row-key={row.key}\n role=\"row\"\n >\n {columns.map((column, i) => {\n const colKey = column.info.props.id;\n const editorInfo = grid.getEditor(column.info.props.id);\n const isEditable = !!editorInfo;\n\n if (editorColIdx === column.index) {\n if (isEditable) {\n if (isValidElement(editorInfo.children)) {\n const editorElement = Children.only(editorInfo.children);\n return cloneElement(editorElement, {\n key: colKey,\n row,\n column,\n } as any);\n }\n }\n }\n\n const Cell = column.info.props.cellComponent || BaseCell;\n const CellValue =\n column.info.props.cellValueComponent || DefaultCellValue;\n const value =\n column.info.props.getValue && row.data\n ? column.info.props.getValue(row.data)\n : null;\n const isFocused = cursorColIdx === column.index;\n const isSelected =\n isCellSelected && isCellSelected(row.index, column.index);\n const validationFnArg = {\n row,\n column,\n isFocused,\n value,\n };\n const validationStatus =\n column.info.props.getValidationStatus?.(validationFnArg);\n const validationMessage =\n validationStatus &&\n column.info.props.getValidationMessage?.(validationFnArg);\n\n return (\n <RowValidationStatusContext.Provider\n value={{ status: rowValidationStatus }}\n >\n <Cell\n key={colKey}\n row={row}\n column={column}\n isFocused={isFocused}\n isSelected={isSelected}\n isEditable={isEditable}\n validationStatus={validationStatus}\n validationMessage={validationMessage}\n validationType={column.info.props.validationType}\n value={value}\n align={column.info.props.align}\n >\n <CellValue\n column={column}\n row={row}\n value={value}\n isFocused={isFocused}\n validationStatus={validationStatus}\n validationMessage={validationMessage}\n validationType={column.info.props.validationType}\n />\n </Cell>\n </RowValidationStatusContext.Provider>\n );\n })}\n {gap !== undefined && gap > 0 ? <FakeCell row={row} /> : null}\n </tr>\n );\n}\n"],"names":["isSelected"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import { useRef, useState, useMemo, useCallback, useEffect, Children, isValidElement } from 'react';
1
+ import { useMemo, useCallback, useRef, useState, useEffect, Children, isValidElement } from 'react';
2
2
  import { NumberRange } from '../NumberRange.js';
3
3
  import { getAttribute, makeMapAdder, makeMapDeleter, getCellPosition } from './utils.js';
4
4
  import { useControlled } from '@salt-ds/core';