@plumile/ui 0.1.55 → 0.1.56

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 (218) hide show
  1. package/lib/atomic/atoms/button/Button.d.ts.map +1 -1
  2. package/lib/atomic/atoms/button/Button.js +5 -2
  3. package/lib/atomic/atoms/formatted-date/FormattedDate.d.ts +14 -0
  4. package/lib/atomic/atoms/formatted-date/FormattedDate.d.ts.map +1 -0
  5. package/lib/atomic/atoms/formatted-date/FormattedDate.js +29 -0
  6. package/lib/atomic/atoms/icon-button/IconMenuButton.d.ts +8 -0
  7. package/lib/atomic/atoms/icon-button/IconMenuButton.d.ts.map +1 -0
  8. package/lib/atomic/atoms/icon-button/IconMenuButton.js +10 -0
  9. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuDropdown.d.ts +14 -0
  10. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuDropdown.d.ts.map +1 -0
  11. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuDropdown.js +16 -0
  12. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuPopover.d.ts +13 -0
  13. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuPopover.d.ts.map +1 -0
  14. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuPopover.js +42 -0
  15. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbNavigation.d.ts +13 -0
  16. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbNavigation.d.ts.map +1 -0
  17. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbNavigation.js +37 -0
  18. package/lib/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.d.ts +25 -0
  19. package/lib/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.d.ts.map +1 -0
  20. package/lib/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.js +221 -0
  21. package/lib/atomic/molecules/breadcrumb_navigation/types.d.ts +15 -0
  22. package/lib/atomic/molecules/breadcrumb_navigation/types.d.ts.map +1 -0
  23. package/lib/atomic/molecules/breadcrumb_navigation/types.js +2 -0
  24. package/lib/atomic/molecules/dropdown/Dropdown.d.ts +26 -0
  25. package/lib/atomic/molecules/dropdown/Dropdown.d.ts.map +1 -0
  26. package/lib/atomic/molecules/dropdown/Dropdown.js +271 -0
  27. package/lib/atomic/molecules/dropdown/dropdown.css.d.ts +8 -0
  28. package/lib/atomic/molecules/dropdown/dropdown.css.d.ts.map +1 -0
  29. package/lib/atomic/molecules/dropdown/dropdown.css.js +30 -0
  30. package/lib/atomic/molecules/form-actions/FormActions.d.ts +16 -0
  31. package/lib/atomic/molecules/form-actions/FormActions.d.ts.map +1 -0
  32. package/lib/atomic/molecules/form-actions/FormActions.js +27 -0
  33. package/lib/atomic/molecules/toast/ToastProvider.d.ts +19 -0
  34. package/lib/atomic/molecules/toast/ToastProvider.d.ts.map +1 -0
  35. package/lib/atomic/molecules/toast/ToastProvider.js +113 -0
  36. package/lib/atomic/molecules/toast/ToastViewport.d.ts +24 -0
  37. package/lib/atomic/molecules/toast/ToastViewport.d.ts.map +1 -0
  38. package/lib/atomic/molecules/toast/ToastViewport.js +40 -0
  39. package/lib/atomic/molecules/toast/constants.d.ts +2 -0
  40. package/lib/atomic/molecules/toast/constants.d.ts.map +1 -0
  41. package/lib/atomic/molecules/toast/constants.js +2 -0
  42. package/lib/atomic/molecules/toast/toast.css.d.ts +25 -0
  43. package/lib/atomic/molecules/toast/toast.css.d.ts.map +1 -0
  44. package/lib/atomic/molecules/toast/toast.css.js +106 -0
  45. package/lib/components/data-table/DataTable.css.d.ts +61 -0
  46. package/lib/components/data-table/DataTable.css.d.ts.map +1 -0
  47. package/lib/components/data-table/DataTable.css.js +285 -0
  48. package/lib/components/data-table/DataTable.d.ts +32 -0
  49. package/lib/components/data-table/DataTable.d.ts.map +1 -0
  50. package/lib/components/data-table/DataTable.js +95 -0
  51. package/lib/components/data-table/TableCell.css.d.ts +26 -0
  52. package/lib/components/data-table/TableCell.css.d.ts.map +1 -0
  53. package/lib/components/data-table/TableCell.css.js +45 -0
  54. package/lib/components/data-table/TableCell.d.ts +46 -0
  55. package/lib/components/data-table/TableCell.d.ts.map +1 -0
  56. package/lib/components/data-table/TableCell.js +72 -0
  57. package/lib/components/data-table/TableCellBase.d.ts +13 -0
  58. package/lib/components/data-table/TableCellBase.d.ts.map +1 -0
  59. package/lib/components/data-table/TableCellBase.js +11 -0
  60. package/lib/components/data-table/VirtualizedConnectionTable.css.d.ts +5 -0
  61. package/lib/components/data-table/VirtualizedConnectionTable.css.d.ts.map +1 -0
  62. package/lib/components/data-table/VirtualizedConnectionTable.css.js +18 -0
  63. package/lib/components/data-table/VirtualizedConnectionTable.d.ts +32 -0
  64. package/lib/components/data-table/VirtualizedConnectionTable.d.ts.map +1 -0
  65. package/lib/components/data-table/VirtualizedConnectionTable.js +304 -0
  66. package/lib/components/data-table/tableBreakpoints.d.ts +9 -0
  67. package/lib/components/data-table/tableBreakpoints.d.ts.map +1 -0
  68. package/lib/components/data-table/tableBreakpoints.js +34 -0
  69. package/lib/components/select/SimpleSelect.css.d.ts +23 -0
  70. package/lib/components/select/SimpleSelect.css.d.ts.map +1 -0
  71. package/lib/components/select/SimpleSelect.css.js +175 -0
  72. package/lib/components/select/SimpleSelect.d.ts +22 -0
  73. package/lib/components/select/SimpleSelect.d.ts.map +1 -0
  74. package/lib/components/select/SimpleSelect.js +218 -0
  75. package/lib/components/subscriptions/RefetchNeededBanner.css.d.ts +5 -0
  76. package/lib/components/subscriptions/RefetchNeededBanner.css.d.ts.map +1 -0
  77. package/lib/components/subscriptions/RefetchNeededBanner.css.js +32 -0
  78. package/lib/components/subscriptions/RefetchNeededBanner.d.ts +9 -0
  79. package/lib/components/subscriptions/RefetchNeededBanner.d.ts.map +1 -0
  80. package/lib/components/subscriptions/RefetchNeededBanner.js +17 -0
  81. package/lib/esm/atomic/atoms/button/Button.js +35 -33
  82. package/lib/esm/atomic/atoms/button/Button.js.map +1 -1
  83. package/lib/esm/atomic/atoms/formatted-date/FormattedDate.js +32 -0
  84. package/lib/esm/atomic/atoms/formatted-date/FormattedDate.js.map +1 -0
  85. package/lib/esm/atomic/atoms/icon-button/IconMenuButton.js +26 -0
  86. package/lib/esm/atomic/atoms/icon-button/IconMenuButton.js.map +1 -0
  87. package/lib/esm/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuDropdown.js +55 -0
  88. package/lib/esm/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuDropdown.js.map +1 -0
  89. package/lib/esm/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuPopover.js +61 -0
  90. package/lib/esm/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuPopover.js.map +1 -0
  91. package/lib/esm/atomic/molecules/breadcrumb_navigation/BreadcrumbNavigation.js +64 -0
  92. package/lib/esm/atomic/molecules/breadcrumb_navigation/BreadcrumbNavigation.js.map +1 -0
  93. package/lib/esm/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.js +30 -0
  94. package/lib/esm/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.js.map +1 -0
  95. package/lib/esm/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.ts.vanilla-Bhz61Foa.css +1 -0
  96. package/lib/esm/atomic/molecules/breadcrumb_navigation/types.js +2 -0
  97. package/lib/esm/atomic/molecules/breadcrumb_navigation/types.js.map +1 -0
  98. package/lib/esm/atomic/molecules/dropdown/Dropdown.js +178 -0
  99. package/lib/esm/atomic/molecules/dropdown/Dropdown.js.map +1 -0
  100. package/lib/esm/atomic/molecules/dropdown/dropdown.css.js +13 -0
  101. package/lib/esm/atomic/molecules/dropdown/dropdown.css.js.map +1 -0
  102. package/lib/esm/atomic/molecules/form-actions/FormActions.js +57 -0
  103. package/lib/esm/atomic/molecules/form-actions/FormActions.js.map +1 -0
  104. package/lib/esm/atomic/molecules/toast/ToastProvider.js +78 -0
  105. package/lib/esm/atomic/molecules/toast/ToastProvider.js.map +1 -0
  106. package/lib/esm/atomic/molecules/toast/ToastViewport.js +71 -0
  107. package/lib/esm/atomic/molecules/toast/ToastViewport.js.map +1 -0
  108. package/lib/esm/atomic/molecules/toast/constants.js +5 -0
  109. package/lib/esm/atomic/molecules/toast/constants.js.map +1 -0
  110. package/lib/esm/atomic/molecules/toast/toast.css.js +17 -0
  111. package/lib/esm/atomic/molecules/toast/toast.css.js.map +1 -0
  112. package/lib/esm/atomic/molecules/toast/toast.css.ts.vanilla-2GtcGJsi.css +1 -0
  113. package/lib/esm/components/data-table/DataTable.css.js +24 -0
  114. package/lib/esm/components/data-table/DataTable.css.js.map +1 -0
  115. package/lib/esm/components/data-table/DataTable.css.ts.vanilla-BLE98fwj.css +1 -0
  116. package/lib/esm/components/data-table/DataTable.js +141 -0
  117. package/lib/esm/components/data-table/DataTable.js.map +1 -0
  118. package/lib/esm/components/data-table/TableCell.css.js +15 -0
  119. package/lib/esm/components/data-table/TableCell.css.js.map +1 -0
  120. package/lib/esm/components/data-table/TableCell.css.ts.vanilla-i5QJvdbl.css +1 -0
  121. package/lib/esm/components/data-table/TableCell.js +74 -0
  122. package/lib/esm/components/data-table/TableCell.js.map +1 -0
  123. package/lib/esm/components/data-table/TableCellBase.js +16 -0
  124. package/lib/esm/components/data-table/TableCellBase.js.map +1 -0
  125. package/lib/esm/components/data-table/VirtualizedConnectionTable.css.js +10 -0
  126. package/lib/esm/components/data-table/VirtualizedConnectionTable.css.js.map +1 -0
  127. package/lib/esm/components/data-table/VirtualizedConnectionTable.js +249 -0
  128. package/lib/esm/components/data-table/VirtualizedConnectionTable.js.map +1 -0
  129. package/lib/esm/components/data-table/tableBreakpoints.js +37 -0
  130. package/lib/esm/components/data-table/tableBreakpoints.js.map +1 -0
  131. package/lib/esm/components/select/SimpleSelect.css.js +22 -0
  132. package/lib/esm/components/select/SimpleSelect.css.js.map +1 -0
  133. package/lib/esm/components/select/SimpleSelect.css.ts.vanilla-Bil1v8q6.css +1 -0
  134. package/lib/esm/components/select/SimpleSelect.js +185 -0
  135. package/lib/esm/components/select/SimpleSelect.js.map +1 -0
  136. package/lib/esm/components/subscriptions/RefetchNeededBanner.css.js +10 -0
  137. package/lib/esm/components/subscriptions/RefetchNeededBanner.css.js.map +1 -0
  138. package/lib/esm/components/subscriptions/RefetchNeededBanner.js +24 -0
  139. package/lib/esm/components/subscriptions/RefetchNeededBanner.js.map +1 -0
  140. package/lib/esm/i18n/useUiTranslation.js +8 -0
  141. package/lib/esm/i18n/useUiTranslation.js.map +1 -0
  142. package/lib/esm/index.js +68 -47
  143. package/lib/esm/index.js.map +1 -1
  144. package/lib/esm/styles/slots.js +2 -0
  145. package/lib/esm/styles/slots.js.map +1 -0
  146. package/lib/i18n/useUiTranslation.d.ts +3 -0
  147. package/lib/i18n/useUiTranslation.d.ts.map +1 -0
  148. package/lib/i18n/useUiTranslation.js +5 -0
  149. package/lib/index.d.ts +10 -0
  150. package/lib/index.d.ts.map +1 -1
  151. package/lib/index.js +11 -1
  152. package/lib/styles/slots.d.ts +2 -0
  153. package/lib/styles/slots.d.ts.map +1 -0
  154. package/lib/styles/slots.js +2 -0
  155. package/lib/types/atomic/atoms/button/Button.d.ts.map +1 -1
  156. package/lib/types/atomic/atoms/formatted-date/FormattedDate.d.ts +14 -0
  157. package/lib/types/atomic/atoms/formatted-date/FormattedDate.d.ts.map +1 -0
  158. package/lib/types/atomic/atoms/icon-button/IconMenuButton.d.ts +8 -0
  159. package/lib/types/atomic/atoms/icon-button/IconMenuButton.d.ts.map +1 -0
  160. package/lib/types/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuDropdown.d.ts +14 -0
  161. package/lib/types/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuDropdown.d.ts.map +1 -0
  162. package/lib/types/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuPopover.d.ts +13 -0
  163. package/lib/types/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuPopover.d.ts.map +1 -0
  164. package/lib/types/atomic/molecules/breadcrumb_navigation/BreadcrumbNavigation.d.ts +13 -0
  165. package/lib/types/atomic/molecules/breadcrumb_navigation/BreadcrumbNavigation.d.ts.map +1 -0
  166. package/lib/types/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.d.ts +25 -0
  167. package/lib/types/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.d.ts.map +1 -0
  168. package/lib/types/atomic/molecules/breadcrumb_navigation/types.d.ts +15 -0
  169. package/lib/types/atomic/molecules/breadcrumb_navigation/types.d.ts.map +1 -0
  170. package/lib/types/atomic/molecules/dropdown/Dropdown.d.ts +26 -0
  171. package/lib/types/atomic/molecules/dropdown/Dropdown.d.ts.map +1 -0
  172. package/lib/types/atomic/molecules/dropdown/dropdown.css.d.ts +8 -0
  173. package/lib/types/atomic/molecules/dropdown/dropdown.css.d.ts.map +1 -0
  174. package/lib/types/atomic/molecules/form-actions/FormActions.d.ts +16 -0
  175. package/lib/types/atomic/molecules/form-actions/FormActions.d.ts.map +1 -0
  176. package/lib/types/atomic/molecules/toast/ToastProvider.d.ts +19 -0
  177. package/lib/types/atomic/molecules/toast/ToastProvider.d.ts.map +1 -0
  178. package/lib/types/atomic/molecules/toast/ToastViewport.d.ts +24 -0
  179. package/lib/types/atomic/molecules/toast/ToastViewport.d.ts.map +1 -0
  180. package/lib/types/atomic/molecules/toast/constants.d.ts +2 -0
  181. package/lib/types/atomic/molecules/toast/constants.d.ts.map +1 -0
  182. package/lib/types/atomic/molecules/toast/toast.css.d.ts +25 -0
  183. package/lib/types/atomic/molecules/toast/toast.css.d.ts.map +1 -0
  184. package/lib/types/components/data-table/DataTable.css.d.ts +61 -0
  185. package/lib/types/components/data-table/DataTable.css.d.ts.map +1 -0
  186. package/lib/types/components/data-table/DataTable.d.ts +32 -0
  187. package/lib/types/components/data-table/DataTable.d.ts.map +1 -0
  188. package/lib/types/components/data-table/TableCell.css.d.ts +26 -0
  189. package/lib/types/components/data-table/TableCell.css.d.ts.map +1 -0
  190. package/lib/types/components/data-table/TableCell.d.ts +46 -0
  191. package/lib/types/components/data-table/TableCell.d.ts.map +1 -0
  192. package/lib/types/components/data-table/TableCellBase.d.ts +13 -0
  193. package/lib/types/components/data-table/TableCellBase.d.ts.map +1 -0
  194. package/lib/types/components/data-table/VirtualizedConnectionTable.css.d.ts +5 -0
  195. package/lib/types/components/data-table/VirtualizedConnectionTable.css.d.ts.map +1 -0
  196. package/lib/types/components/data-table/VirtualizedConnectionTable.d.ts +32 -0
  197. package/lib/types/components/data-table/VirtualizedConnectionTable.d.ts.map +1 -0
  198. package/lib/types/components/data-table/tableBreakpoints.d.ts +9 -0
  199. package/lib/types/components/data-table/tableBreakpoints.d.ts.map +1 -0
  200. package/lib/types/components/select/SimpleSelect.css.d.ts +23 -0
  201. package/lib/types/components/select/SimpleSelect.css.d.ts.map +1 -0
  202. package/lib/types/components/select/SimpleSelect.d.ts +22 -0
  203. package/lib/types/components/select/SimpleSelect.d.ts.map +1 -0
  204. package/lib/types/components/subscriptions/RefetchNeededBanner.css.d.ts +5 -0
  205. package/lib/types/components/subscriptions/RefetchNeededBanner.css.d.ts.map +1 -0
  206. package/lib/types/components/subscriptions/RefetchNeededBanner.d.ts +9 -0
  207. package/lib/types/components/subscriptions/RefetchNeededBanner.d.ts.map +1 -0
  208. package/lib/types/i18n/useUiTranslation.d.ts +3 -0
  209. package/lib/types/i18n/useUiTranslation.d.ts.map +1 -0
  210. package/lib/types/index.d.ts +10 -0
  211. package/lib/types/index.d.ts.map +1 -1
  212. package/lib/types/styles/slots.d.ts +2 -0
  213. package/lib/types/styles/slots.d.ts.map +1 -0
  214. package/package.json +10 -3
  215. package/src/i18n/locales/en/ui.json +53 -0
  216. package/src/i18n/locales/fr/ui.json +53 -0
  217. package/src/i18n/useUiTranslation.ts +6 -0
  218. /package/lib/esm/components/layout/{TabsContentLayout.css.ts.vanilla-tn0RQdqM.css → ContentLayout.css.ts.vanilla-tn0RQdqM.css} +0 -0
@@ -0,0 +1,285 @@
1
+ import { createVar, fallbackVar, style, } from '@vanilla-extract/css';
2
+ import { recipe } from '@vanilla-extract/recipes';
3
+ import { vars } from '../../theme/themeContract.js';
4
+ import { DATA_TABLE_BREAKPOINT_ENTRIES, } from './tableBreakpoints.js';
5
+ import { sprinkles } from '../../theme/sprinkles.css.js';
6
+ export const container = recipe({
7
+ base: sprinkles({
8
+ display: 'flex',
9
+ flexDirection: 'column',
10
+ width: 'full',
11
+ containerType: 'inline-size',
12
+ }),
13
+ variants: {
14
+ kind: {
15
+ default: sprinkles({
16
+ backgroundColor: 'white',
17
+ borderColor: 'border',
18
+ borderRadius: 'lg',
19
+ borderStyle: 'solid',
20
+ borderWidth: 'default',
21
+ overflow: 'hidden',
22
+ }),
23
+ brandTable: sprinkles({
24
+ backgroundColor: 'transparent',
25
+ borderRadius: 'none',
26
+ borderStyle: 'none',
27
+ borderWidth: 0,
28
+ overflow: 'visible',
29
+ }),
30
+ },
31
+ },
32
+ defaultVariants: {
33
+ kind: 'default',
34
+ },
35
+ });
36
+ export const header = recipe({
37
+ variants: {
38
+ kind: {
39
+ default: sprinkles({
40
+ borderWidth: 0,
41
+ borderStyle: 'solid',
42
+ borderBottomWidth: 'default',
43
+ borderBottomColor: 'border',
44
+ backgroundColor: 'surfaceSecondary',
45
+ }),
46
+ brandTable: sprinkles({
47
+ backgroundColor: 'transparent',
48
+ borderWidth: 0,
49
+ borderStyle: 'solid',
50
+ borderBottomWidth: 'default',
51
+ borderBottomColor: 'brandSecondaryOrange-20',
52
+ }),
53
+ },
54
+ },
55
+ defaultVariants: {
56
+ kind: 'default',
57
+ },
58
+ });
59
+ export const headerRow = sprinkles({
60
+ display: 'grid',
61
+ width: 'full',
62
+ alignItems: 'stretch',
63
+ });
64
+ export const tableCellPaddingVar = createVar();
65
+ export const tableCellFontSizeVar = createVar();
66
+ export const tableEmptyRowPaddingVar = createVar();
67
+ export const headerCell = recipe({
68
+ base: sprinkles({
69
+ alignItems: 'center',
70
+ display: 'flex',
71
+ flexShrink: 0,
72
+ gap: 2,
73
+ overflow: 'hidden',
74
+ textOverflow: 'ellipsis',
75
+ whiteSpace: 'nowrap',
76
+ }),
77
+ variants: {
78
+ kind: {
79
+ default: style([
80
+ sprinkles({
81
+ color: 'text',
82
+ fontWeight: 'semibold',
83
+ }),
84
+ {
85
+ padding: fallbackVar(tableCellPaddingVar, `${vars.spacing[3]} ${vars.spacing[4]}`),
86
+ fontSize: fallbackVar(tableCellFontSizeVar, vars.fontSize.sm),
87
+ borderRight: `1px solid ${vars.colors.border}`,
88
+ selectors: {
89
+ '&:last-child': {
90
+ borderRight: 'none',
91
+ },
92
+ },
93
+ },
94
+ ]),
95
+ brandTable: sprinkles({
96
+ color: 'black-300',
97
+ fontWeight: 'bold',
98
+ fontSize: 'xs',
99
+ letterSpacing: 'caps',
100
+ textTransform: 'uppercase',
101
+ paddingY: 4,
102
+ paddingX: 0,
103
+ borderRightWidth: 0,
104
+ }),
105
+ },
106
+ },
107
+ defaultVariants: {
108
+ kind: 'default',
109
+ },
110
+ });
111
+ export const body = recipe({
112
+ base: sprinkles({
113
+ display: 'flex',
114
+ flexDirection: 'column',
115
+ }),
116
+ variants: {
117
+ kind: {
118
+ default: {},
119
+ brandTable: sprinkles({
120
+ backgroundColor: 'transparent',
121
+ }),
122
+ },
123
+ },
124
+ defaultVariants: {
125
+ kind: 'default',
126
+ },
127
+ });
128
+ export const row = recipe({
129
+ base: sprinkles({
130
+ alignItems: 'stretch',
131
+ borderStyle: 'solid',
132
+ borderWidth: 0,
133
+ display: 'grid',
134
+ transitionProperty: 'colors',
135
+ transitionDuration: 150,
136
+ transitionTimingFunction: 'ease',
137
+ }),
138
+ variants: {
139
+ kind: {
140
+ default: style([
141
+ sprinkles({
142
+ backgroundColor: 'surface',
143
+ borderBottomColor: 'borderLight',
144
+ borderBottomWidth: 'default',
145
+ }),
146
+ {
147
+ selectors: {
148
+ '&:last-child': {
149
+ borderBottomWidth: 0,
150
+ },
151
+ '&:hover': {
152
+ backgroundColor: vars.colors.surfaceSecondary,
153
+ },
154
+ },
155
+ },
156
+ ]),
157
+ brandTable: style([
158
+ sprinkles({
159
+ backgroundColor: 'transparent',
160
+ borderBottomColor: 'brandSecondaryOrange-20',
161
+ borderBottomWidth: 'default',
162
+ }),
163
+ {
164
+ selectors: {
165
+ '&:last-child': {
166
+ borderBottomWidth: 0,
167
+ },
168
+ '&:hover': {
169
+ backgroundColor: 'transparent',
170
+ },
171
+ },
172
+ },
173
+ ]),
174
+ },
175
+ },
176
+ defaultVariants: {
177
+ kind: 'default',
178
+ },
179
+ });
180
+ export const rowEven = recipe({
181
+ variants: {
182
+ kind: {
183
+ default: sprinkles({
184
+ backgroundColor: 'surfaceMuted',
185
+ }),
186
+ brandTable: sprinkles({
187
+ backgroundColor: 'transparent',
188
+ }),
189
+ },
190
+ },
191
+ defaultVariants: {
192
+ kind: 'default',
193
+ },
194
+ });
195
+ export const rowOdd = recipe({
196
+ variants: {
197
+ kind: {
198
+ default: sprinkles({
199
+ backgroundColor: 'surface',
200
+ }),
201
+ brandTable: sprinkles({
202
+ backgroundColor: 'transparent',
203
+ }),
204
+ },
205
+ },
206
+ defaultVariants: {
207
+ kind: 'default',
208
+ },
209
+ });
210
+ export const cell = recipe({
211
+ base: sprinkles({
212
+ alignItems: 'center',
213
+ display: 'flex',
214
+ gap: 2,
215
+ minWidth: 0,
216
+ overflow: 'hidden',
217
+ }),
218
+ variants: {
219
+ kind: {
220
+ default: style([
221
+ sprinkles({
222
+ color: 'textSecondary',
223
+ }),
224
+ {
225
+ padding: fallbackVar(tableCellPaddingVar, `${vars.spacing[3]} ${vars.spacing[4]}`),
226
+ fontSize: fallbackVar(tableCellFontSizeVar, vars.fontSize.sm),
227
+ borderRight: `1px solid ${vars.colors.borderLight}`,
228
+ selectors: {
229
+ '&:last-child': {
230
+ borderRight: 'none',
231
+ },
232
+ },
233
+ },
234
+ ]),
235
+ brandTable: sprinkles({
236
+ color: 'text',
237
+ fontWeight: 'semibold',
238
+ fontSize: 'sm',
239
+ paddingY: 4,
240
+ paddingX: 0,
241
+ borderRightWidth: 0,
242
+ }),
243
+ },
244
+ },
245
+ defaultVariants: {
246
+ kind: 'default',
247
+ },
248
+ });
249
+ export const primaryCell = sprinkles({
250
+ fontWeight: 'semibold',
251
+ color: 'text',
252
+ });
253
+ export const primaryHeaderCell = sprinkles({
254
+ color: 'text',
255
+ });
256
+ export const emptyRow = style({
257
+ padding: fallbackVar(tableEmptyRowPaddingVar, `${vars.spacing[6]} ${vars.spacing[4]}`),
258
+ });
259
+ export const emptyCell = sprinkles({
260
+ fontSize: 'base',
261
+ color: 'textSecondary',
262
+ textAlign: 'center',
263
+ });
264
+ const hideBelowMap = {};
265
+ DATA_TABLE_BREAKPOINT_ENTRIES.forEach(([breakpoint, width]) => {
266
+ hideBelowMap[breakpoint] = {
267
+ '@container': {
268
+ [`(max-width: ${width - 0.5}px)`]: {
269
+ visibility: 'hidden',
270
+ opacity: 0,
271
+ pointerEvents: 'none',
272
+ paddingInline: 0,
273
+ paddingBlock: 0,
274
+ borderRight: 'none',
275
+ overflow: 'hidden',
276
+ },
277
+ },
278
+ };
279
+ });
280
+ export const hideBelowRecipe = recipe({
281
+ variants: {
282
+ minVisibleAt: hideBelowMap,
283
+ },
284
+ });
285
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DataTable.css.js","sourceRoot":"","sources":["../../../src/components/data-table/DataTable.css.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  createVar,\n  fallbackVar,\n  style,\n  type StyleRule,\n} from '@vanilla-extract/css';\nimport { recipe } from '@vanilla-extract/recipes';\n\nimport { vars } from '../../theme/themeContract.js';\n\nimport {\n  DATA_TABLE_BREAKPOINT_ENTRIES,\n  type DataTableBreakpoint,\n} from './tableBreakpoints.js';\nimport { sprinkles } from '../../theme/sprinkles.css.js';\n\nexport const container = recipe({\n  base: sprinkles({\n    display: 'flex',\n    flexDirection: 'column',\n    width: 'full',\n    containerType: 'inline-size',\n  }),\n  variants: {\n    kind: {\n      default: sprinkles({\n        backgroundColor: 'white',\n        borderColor: 'border',\n        borderRadius: 'lg',\n        borderStyle: 'solid',\n        borderWidth: 'default',\n        overflow: 'hidden',\n      }),\n      brandTable: sprinkles({\n        backgroundColor: 'transparent',\n        borderRadius: 'none',\n        borderStyle: 'none',\n        borderWidth: 0,\n        overflow: 'visible',\n      }),\n    },\n  },\n  defaultVariants: {\n    kind: 'default',\n  },\n});\n\nexport const header = recipe({\n  variants: {\n    kind: {\n      default: sprinkles({\n        borderWidth: 0,\n        borderStyle: 'solid',\n        borderBottomWidth: 'default',\n        borderBottomColor: 'border',\n        backgroundColor: 'surfaceSecondary',\n      }),\n      brandTable: sprinkles({\n        backgroundColor: 'transparent',\n        borderWidth: 0,\n        borderStyle: 'solid',\n        borderBottomWidth: 'default',\n        borderBottomColor: 'brandSecondaryOrange-20',\n      }),\n    },\n  },\n  defaultVariants: {\n    kind: 'default',\n  },\n});\n\nexport const headerRow = sprinkles({\n  display: 'grid',\n  width: 'full',\n  alignItems: 'stretch',\n});\n\nexport const tableCellPaddingVar = createVar();\nexport const tableCellFontSizeVar = createVar();\nexport const tableEmptyRowPaddingVar = createVar();\n\nexport const headerCell = recipe({\n  base: sprinkles({\n    alignItems: 'center',\n    display: 'flex',\n    flexShrink: 0,\n    gap: 2,\n    overflow: 'hidden',\n    textOverflow: 'ellipsis',\n    whiteSpace: 'nowrap',\n  }),\n  variants: {\n    kind: {\n      default: style([\n        sprinkles({\n          color: 'text',\n          fontWeight: 'semibold',\n        }),\n        {\n          padding: fallbackVar(\n            tableCellPaddingVar,\n            `${vars.spacing[3]} ${vars.spacing[4]}`,\n          ),\n          fontSize: fallbackVar(tableCellFontSizeVar, vars.fontSize.sm),\n          borderRight: `1px solid ${vars.colors.border}`,\n          selectors: {\n            '&:last-child': {\n              borderRight: 'none',\n            },\n          },\n        },\n      ]),\n      brandTable: sprinkles({\n        color: 'black-300',\n        fontWeight: 'bold',\n        fontSize: 'xs',\n        letterSpacing: 'caps',\n        textTransform: 'uppercase',\n        paddingY: 4,\n        paddingX: 0,\n        borderRightWidth: 0,\n      }),\n    },\n  },\n  defaultVariants: {\n    kind: 'default',\n  },\n});\n\nexport const body = recipe({\n  base: sprinkles({\n    display: 'flex',\n    flexDirection: 'column',\n  }),\n  variants: {\n    kind: {\n      default: {},\n      brandTable: sprinkles({\n        backgroundColor: 'transparent',\n      }),\n    },\n  },\n  defaultVariants: {\n    kind: 'default',\n  },\n});\n\nexport const row = recipe({\n  base: sprinkles({\n    alignItems: 'stretch',\n    borderStyle: 'solid',\n    borderWidth: 0,\n    display: 'grid',\n    transitionProperty: 'colors',\n    transitionDuration: 150,\n    transitionTimingFunction: 'ease',\n  }),\n  variants: {\n    kind: {\n      default: style([\n        sprinkles({\n          backgroundColor: 'surface',\n          borderBottomColor: 'borderLight',\n          borderBottomWidth: 'default',\n        }),\n        {\n          selectors: {\n            '&:last-child': {\n              borderBottomWidth: 0,\n            },\n            '&:hover': {\n              backgroundColor: vars.colors.surfaceSecondary,\n            },\n          },\n        },\n      ]),\n      brandTable: style([\n        sprinkles({\n          backgroundColor: 'transparent',\n          borderBottomColor: 'brandSecondaryOrange-20',\n          borderBottomWidth: 'default',\n        }),\n        {\n          selectors: {\n            '&:last-child': {\n              borderBottomWidth: 0,\n            },\n            '&:hover': {\n              backgroundColor: 'transparent',\n            },\n          },\n        },\n      ]),\n    },\n  },\n  defaultVariants: {\n    kind: 'default',\n  },\n});\n\nexport const rowEven = recipe({\n  variants: {\n    kind: {\n      default: sprinkles({\n        backgroundColor: 'surfaceMuted',\n      }),\n      brandTable: sprinkles({\n        backgroundColor: 'transparent',\n      }),\n    },\n  },\n  defaultVariants: {\n    kind: 'default',\n  },\n});\n\nexport const rowOdd = recipe({\n  variants: {\n    kind: {\n      default: sprinkles({\n        backgroundColor: 'surface',\n      }),\n      brandTable: sprinkles({\n        backgroundColor: 'transparent',\n      }),\n    },\n  },\n  defaultVariants: {\n    kind: 'default',\n  },\n});\n\nexport const cell = recipe({\n  base: sprinkles({\n    alignItems: 'center',\n    display: 'flex',\n    gap: 2,\n    minWidth: 0,\n    overflow: 'hidden',\n  }),\n  variants: {\n    kind: {\n      default: style([\n        sprinkles({\n          color: 'textSecondary',\n        }),\n        {\n          padding: fallbackVar(\n            tableCellPaddingVar,\n            `${vars.spacing[3]} ${vars.spacing[4]}`,\n          ),\n          fontSize: fallbackVar(tableCellFontSizeVar, vars.fontSize.sm),\n          borderRight: `1px solid ${vars.colors.borderLight}`,\n          selectors: {\n            '&:last-child': {\n              borderRight: 'none',\n            },\n          },\n        },\n      ]),\n      brandTable: sprinkles({\n        color: 'text',\n        fontWeight: 'semibold',\n        fontSize: 'sm',\n        paddingY: 4,\n        paddingX: 0,\n        borderRightWidth: 0,\n      }),\n    },\n  },\n  defaultVariants: {\n    kind: 'default',\n  },\n});\n\nexport const primaryCell = sprinkles({\n  fontWeight: 'semibold',\n  color: 'text',\n});\n\nexport const primaryHeaderCell = sprinkles({\n  color: 'text',\n});\n\nexport const emptyRow = style({\n  padding: fallbackVar(\n    tableEmptyRowPaddingVar,\n    `${vars.spacing[6]} ${vars.spacing[4]}`,\n  ),\n});\n\nexport const emptyCell = sprinkles({\n  fontSize: 'base',\n  color: 'textSecondary',\n  textAlign: 'center',\n});\n\nconst hideBelowMap: Record<DataTableBreakpoint, StyleRule> = {} as Record<\n  DataTableBreakpoint,\n  StyleRule\n>;\n\nDATA_TABLE_BREAKPOINT_ENTRIES.forEach(([breakpoint, width]) => {\n  hideBelowMap[breakpoint] = {\n    '@container': {\n      [`(max-width: ${width - 0.5}px)`]: {\n        visibility: 'hidden',\n        opacity: 0,\n        pointerEvents: 'none',\n        paddingInline: 0,\n        paddingBlock: 0,\n        borderRight: 'none',\n        overflow: 'hidden',\n      },\n    },\n  };\n});\n\nexport const hideBelowRecipe = recipe({\n  variants: {\n    minVisibleAt: hideBelowMap,\n  },\n});\n"]}
@@ -0,0 +1,32 @@
1
+ import { type JSX } from 'react';
2
+ import * as styles from './DataTable.css.js';
3
+ import type { DataTableBreakpoint } from './tableBreakpoints.js';
4
+ import type { SlotClasses } from '../../styles/slots.js';
5
+ export type DataTableColumn<Row> = {
6
+ id: string;
7
+ header: JSX.Element | string;
8
+ cell: (row: Row) => JSX.Element | string | null;
9
+ minVisibleAt?: DataTableBreakpoint;
10
+ className?: string;
11
+ isPrimary?: boolean;
12
+ };
13
+ export type GetRowId<Row> = (row: Row, index: number) => string;
14
+ export type DataTableKind = NonNullable<Parameters<typeof styles.container>[0]>['kind'];
15
+ type DataTableSlot = 'container' | 'header' | 'headerRow' | 'headerCell' | 'primaryHeaderCell' | 'body' | 'row' | 'rowEven' | 'rowOdd' | 'cell' | 'primaryCell' | 'emptyRow' | 'emptyCell';
16
+ export type DataTableProps<Row> = {
17
+ columns: readonly DataTableColumn<Row>[];
18
+ rows: readonly Row[];
19
+ getRowId: GetRowId<Row>;
20
+ emptyState?: JSX.Element;
21
+ className?: string;
22
+ headerClassName?: string;
23
+ bodyClassName?: string;
24
+ rowClassName?: (row: Row, index: number) => string | null | undefined;
25
+ gridTemplateClassName?: string;
26
+ gridTemplateColumns?: string;
27
+ kind?: DataTableKind;
28
+ classes?: SlotClasses<DataTableSlot>;
29
+ };
30
+ export declare const DataTable: <Row>({ columns, rows, getRowId, emptyState, className, headerClassName, bodyClassName, rowClassName, gridTemplateClassName, gridTemplateColumns, kind, classes, }: DataTableProps<Row>) => JSX.Element;
31
+ export {};
32
+ //# sourceMappingURL=DataTable.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DataTable.d.ts","sourceRoot":"","sources":["../../../src/components/data-table/DataTable.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAsB,KAAK,GAAG,EAAE,MAAM,OAAO,CAAC;AAErD,OAAO,KAAK,MAAM,MAAM,oBAAoB,CAAC;AAC7C,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAGjE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEzD,MAAM,MAAM,eAAe,CAAC,GAAG,IAAI;IACjC,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,GAAG,CAAC,OAAO,GAAG,MAAM,CAAC;IAC7B,IAAI,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,GAAG,CAAC,OAAO,GAAG,MAAM,GAAG,IAAI,CAAC;IAChD,YAAY,CAAC,EAAE,mBAAmB,CAAC;IACnC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,QAAQ,CAAC,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;AAEhE,MAAM,MAAM,aAAa,GAAG,WAAW,CACrC,UAAU,CAAC,OAAO,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CACvC,CAAC,MAAM,CAAC,CAAC;AAEV,KAAK,aAAa,GACd,WAAW,GACX,QAAQ,GACR,WAAW,GACX,YAAY,GACZ,mBAAmB,GACnB,MAAM,GACN,KAAK,GACL,SAAS,GACT,QAAQ,GACR,MAAM,GACN,aAAa,GACb,UAAU,GACV,WAAW,CAAC;AAEhB,MAAM,MAAM,cAAc,CAAC,GAAG,IAAI;IAChC,OAAO,EAAE,SAAS,eAAe,CAAC,GAAG,CAAC,EAAE,CAAC;IACzC,IAAI,EAAE,SAAS,GAAG,EAAE,CAAC;IACrB,QAAQ,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC;IACxB,UAAU,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,YAAY,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IACtE,qBAAqB,CAAC,EAAE,MAAM,CAAC;IAC/B,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,IAAI,CAAC,EAAE,aAAa,CAAC;IACrB,OAAO,CAAC,EAAE,WAAW,CAAC,aAAa,CAAC,CAAC;CACtC,CAAC;AA2BF,eAAO,MAAM,SAAS,GAAI,GAAG,EAAG,8JAa7B,cAAc,CAAC,GAAG,CAAC,KAAG,GAAG,CAAC,OA8K5B,CAAC"}
@@ -0,0 +1,95 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import * as styles from './DataTable.css.js';
3
+ import { cx } from '../../theme/tools.js';
4
+ import { useUiTranslation } from '../../i18n/useUiTranslation.js';
5
+ const DEFAULT_TEMPLATE_CELL = 'minmax(0, 1fr)';
6
+ const getVisibilityClass = (minVisibleAt) => {
7
+ if (minVisibleAt == null) {
8
+ return null;
9
+ }
10
+ return styles.hideBelowRecipe({ minVisibleAt });
11
+ };
12
+ const buildInlineTemplate = (columnCount, gridTemplateColumns) => {
13
+ if (typeof gridTemplateColumns === 'string' && gridTemplateColumns !== '') {
14
+ return { gridTemplateColumns };
15
+ }
16
+ return {
17
+ gridTemplateColumns: `repeat(${columnCount}, ${DEFAULT_TEMPLATE_CELL})`,
18
+ };
19
+ };
20
+ export const DataTable = ({ columns, rows, getRowId, emptyState, className, headerClassName, bodyClassName, rowClassName, gridTemplateClassName, gridTemplateColumns, kind, classes, }) => {
21
+ const { t } = useUiTranslation();
22
+ const resolvedKind = kind ?? 'default';
23
+ const defaultEmptyState = (_jsx("div", { className: cx(styles.emptyCell, classes?.emptyCell), children: t('common.table.empty') }));
24
+ const resolvedEmptyState = emptyState ?? defaultEmptyState;
25
+ const showEmpty = rows.length === 0;
26
+ let inlineTemplateStyle;
27
+ if (gridTemplateClassName == null) {
28
+ inlineTemplateStyle = buildInlineTemplate(columns.length, gridTemplateColumns);
29
+ }
30
+ const sharedRowClasses = [];
31
+ if (gridTemplateClassName != null) {
32
+ sharedRowClasses.push(gridTemplateClassName);
33
+ }
34
+ let rowsContent;
35
+ if (showEmpty) {
36
+ rowsContent = (_jsx("div", { className: cx(styles.emptyRow, classes?.emptyRow), role: "row", children: _jsx("div", { role: "cell", children: resolvedEmptyState }) }));
37
+ }
38
+ else {
39
+ rowsContent = (_jsx(_Fragment, { children: rows.map((row, index) => {
40
+ const rowId = getRowId(row, index);
41
+ const rowClasses = [styles.row({ kind: resolvedKind }), classes?.row];
42
+ if (index % 2 === 0) {
43
+ rowClasses.push(styles.rowEven({ kind: resolvedKind }), classes?.rowEven);
44
+ }
45
+ else {
46
+ rowClasses.push(styles.rowOdd({ kind: resolvedKind }), classes?.rowOdd);
47
+ }
48
+ for (const sharedClass of sharedRowClasses) {
49
+ rowClasses.push(sharedClass);
50
+ }
51
+ if (rowClassName != null) {
52
+ const customClass = rowClassName(row, index);
53
+ if (customClass != null) {
54
+ rowClasses.push(customClass);
55
+ }
56
+ }
57
+ return (_jsx("div", { role: "row", className: cx(...rowClasses), style: inlineTemplateStyle, children: columns.map((column) => {
58
+ const cellClasses = [
59
+ styles.cell({ kind: resolvedKind }),
60
+ classes?.cell,
61
+ ];
62
+ const visibilityClass = getVisibilityClass(column.minVisibleAt);
63
+ if (visibilityClass != null) {
64
+ cellClasses.push(visibilityClass);
65
+ }
66
+ if (column.className != null) {
67
+ cellClasses.push(column.className);
68
+ }
69
+ if (column.isPrimary) {
70
+ cellClasses.push(styles.primaryCell, classes?.primaryCell);
71
+ }
72
+ const content = column.cell(row);
73
+ return (_jsx("div", { role: "cell", className: cx(...cellClasses), children: content }, column.id));
74
+ }) }, rowId));
75
+ }) }));
76
+ }
77
+ return (_jsxs("div", { className: cx(styles.container({ kind: resolvedKind }), classes?.container, className), role: "table", children: [_jsx("div", { className: cx(styles.header({ kind: resolvedKind }), classes?.header, headerClassName), role: "rowgroup", children: _jsx("div", { className: cx(styles.headerRow, classes?.headerRow, ...sharedRowClasses), role: "row", style: inlineTemplateStyle, children: columns.map((column) => {
78
+ const headerClasses = [
79
+ styles.headerCell({ kind: resolvedKind }),
80
+ classes?.headerCell,
81
+ ];
82
+ const visibilityClass = getVisibilityClass(column.minVisibleAt);
83
+ if (visibilityClass != null) {
84
+ headerClasses.push(visibilityClass);
85
+ }
86
+ if (column.className != null) {
87
+ headerClasses.push(column.className);
88
+ }
89
+ if (column.isPrimary) {
90
+ headerClasses.push(styles.primaryHeaderCell, classes?.primaryHeaderCell);
91
+ }
92
+ return (_jsx("div", { role: "columnheader", className: cx(...headerClasses), children: column.header }, column.id));
93
+ }) }) }), _jsx("div", { className: cx(styles.body({ kind: resolvedKind }), classes?.body, bodyClassName), role: "rowgroup", children: rowsContent })] }));
94
+ };
95
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DataTable.js","sourceRoot":"","sources":["../../../src/components/data-table/DataTable.tsx"],"names":[],"mappings":";AAEA,OAAO,KAAK,MAAM,MAAM,oBAAoB,CAAC;AAE7C,OAAO,EAAE,EAAE,EAAE,MAAM,sBAAsB,CAAC;AAC1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAgDlE,MAAM,qBAAqB,GAAG,gBAAgB,CAAC;AAE/C,MAAM,kBAAkB,GAAG,CAAC,YAAkC,EAAE,EAAE;IAChE,IAAI,YAAY,IAAI,IAAI,EAAE,CAAC;QACzB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO,MAAM,CAAC,eAAe,CAAC,EAAE,YAAY,EAAE,CAAC,CAAC;AAClD,CAAC,CAAC;AAEF,MAAM,mBAAmB,GAAG,CAC1B,WAAmB,EACnB,mBAA4B,EACb,EAAE;IACjB,IAAI,OAAO,mBAAmB,KAAK,QAAQ,IAAI,mBAAmB,KAAK,EAAE,EAAE,CAAC;QAC1E,OAAO,EAAE,mBAAmB,EAAE,CAAC;IACjC,CAAC;IACD,OAAO;QACL,mBAAmB,EAAE,UAAU,WAAW,KAAK,qBAAqB,GAAG;KACxE,CAAC;AACJ,CAAC,CAAC;AAKF,MAAM,CAAC,MAAM,SAAS,GAAG,CAAO,EAC9B,OAAO,EACP,IAAI,EACJ,QAAQ,EACR,UAAU,EACV,SAAS,EACT,eAAe,EACf,aAAa,EACb,YAAY,EACZ,qBAAqB,EACrB,mBAAmB,EACnB,IAAI,EACJ,OAAO,GACa,EAAe,EAAE;IACrC,MAAM,EAAE,CAAC,EAAE,GAAG,gBAAgB,EAAE,CAAC;IACjC,MAAM,YAAY,GAAkB,IAAI,IAAI,SAAS,CAAC;IACtD,MAAM,iBAAiB,GAAG,CACxB,cAAK,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,OAAO,EAAE,SAAS,CAAC,YACrD,CAAC,CAAC,oBAAoB,CAAC,GACpB,CACQ,CAAC;IACjB,MAAM,kBAAkB,GAAG,UAAU,IAAI,iBAAiB,CAAC;IAC3D,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,KAAK,CAAC,CAAC;IAEpC,IAAI,mBAA8C,CAAC;IACnD,IAAI,qBAAqB,IAAI,IAAI,EAAE,CAAC;QAClC,mBAAmB,GAAG,mBAAmB,CACvC,OAAO,CAAC,MAAM,EACd,mBAAmB,CACpB,CAAC;IACJ,CAAC;IAED,MAAM,gBAAgB,GAAa,EAAE,CAAC;IACtC,IAAI,qBAAqB,IAAI,IAAI,EAAE,CAAC;QAClC,gBAAgB,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;IAC/C,CAAC;IAED,IAAI,WAAwB,CAAC;IAC7B,IAAI,SAAS,EAAE,CAAC;QACd,WAAW,GAAG,CACZ,cAAK,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,QAAQ,EAAE,OAAO,EAAE,QAAQ,CAAC,EAAE,IAAI,EAAC,KAAK,YAChE,cAAK,IAAI,EAAC,MAAM,YAAE,kBAAkB,GAAO,GACvC,CACP,CAAC;IACJ,CAAC;SAAM,CAAC;QACN,WAAW,GAAG,CACZ,4BACG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;gBACvB,MAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;gBACnC,MAAM,UAAU,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,EAAE,OAAO,EAAE,GAAG,CAAC,CAAC;gBACtE,IAAI,KAAK,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;oBACpB,UAAU,CAAC,IAAI,CACb,MAAM,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,EACtC,OAAO,EAAE,OAAO,CACjB,CAAC;gBACJ,CAAC;qBAAM,CAAC;oBACN,UAAU,CAAC,IAAI,CACb,MAAM,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,EACrC,OAAO,EAAE,MAAM,CAChB,CAAC;gBACJ,CAAC;gBACD,KAAK,MAAM,WAAW,IAAI,gBAAgB,EAAE,CAAC;oBAC3C,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBAC/B,CAAC;gBAED,IAAI,YAAY,IAAI,IAAI,EAAE,CAAC;oBACzB,MAAM,WAAW,GAAG,YAAY,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;oBAC7C,IAAI,WAAW,IAAI,IAAI,EAAE,CAAC;wBACxB,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;oBAC/B,CAAC;gBACH,CAAC;gBAED,OAAO,CACL,cAEE,IAAI,EAAC,KAAK,EACV,SAAS,EAAE,EAAE,CAAC,GAAG,UAAU,CAAC,EAC5B,KAAK,EAAE,mBAAmB,YAEzB,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;wBACtB,MAAM,WAAW,GAAG;4BAClB,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;4BACnC,OAAO,EAAE,IAAI;yBACd,CAAC;wBACF,MAAM,eAAe,GAAG,kBAAkB,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;wBAEhE,IAAI,eAAe,IAAI,IAAI,EAAE,CAAC;4BAC5B,WAAW,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;wBACpC,CAAC;wBAED,IAAI,MAAM,CAAC,SAAS,IAAI,IAAI,EAAE,CAAC;4BAC7B,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;wBACrC,CAAC;wBACD,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;4BACrB,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,OAAO,EAAE,WAAW,CAAC,CAAC;wBAC7D,CAAC;wBAED,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;wBAEjC,OAAO,CACL,cAEE,IAAI,EAAC,MAAM,EACX,SAAS,EAAE,EAAE,CAAC,GAAG,WAAW,CAAC,YAE5B,OAAO,IAJH,MAAM,CAAC,EAAE,CAKV,CACP,CAAC;oBACJ,CAAC,CAAC,IAlCG,KAAK,CAmCN,CACP,CAAC;YACJ,CAAC,CAAC,GACD,CACJ,CAAC;IACJ,CAAC;IAED,OAAO,CACL,eACE,SAAS,EAAE,EAAE,CACX,MAAM,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,EACxC,OAAO,EAAE,SAAS,EAClB,SAAS,CACV,EACD,IAAI,EAAC,OAAO,aAEZ,cACE,SAAS,EAAE,EAAE,CACX,MAAM,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,EACrC,OAAO,EAAE,MAAM,EACf,eAAe,CAChB,EACD,IAAI,EAAC,UAAU,YAEf,cACE,SAAS,EAAE,EAAE,CACX,MAAM,CAAC,SAAS,EAChB,OAAO,EAAE,SAAS,EAClB,GAAG,gBAAgB,CACpB,EACD,IAAI,EAAC,KAAK,EACV,KAAK,EAAE,mBAAmB,YAEzB,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;wBACtB,MAAM,aAAa,GAAG;4BACpB,MAAM,CAAC,UAAU,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;4BACzC,OAAO,EAAE,UAAU;yBACpB,CAAC;wBACF,MAAM,eAAe,GAAG,kBAAkB,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;wBAChE,IAAI,eAAe,IAAI,IAAI,EAAE,CAAC;4BAC5B,aAAa,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;wBACtC,CAAC;wBAED,IAAI,MAAM,CAAC,SAAS,IAAI,IAAI,EAAE,CAAC;4BAC7B,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;wBACvC,CAAC;wBACD,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;4BACrB,aAAa,CAAC,IAAI,CAChB,MAAM,CAAC,iBAAiB,EACxB,OAAO,EAAE,iBAAiB,CAC3B,CAAC;wBACJ,CAAC;wBAED,OAAO,CACL,cAEE,IAAI,EAAC,cAAc,EACnB,SAAS,EAAE,EAAE,CAAC,GAAG,aAAa,CAAC,YAE9B,MAAM,CAAC,MAAM,IAJT,MAAM,CAAC,EAAE,CAKV,CACP,CAAC;oBACJ,CAAC,CAAC,GACE,GACF,EAEN,cACE,SAAS,EAAE,EAAE,CACX,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,EACnC,OAAO,EAAE,IAAI,EACb,aAAa,CACd,EACD,IAAI,EAAC,UAAU,YAEd,WAAW,GACR,IACF,CACP,CAAC;AACJ,CAAC,CAAC","sourcesContent":["import { type CSSProperties, type JSX } from 'react';\n\nimport * as styles from './DataTable.css.js';\nimport type { DataTableBreakpoint } from './tableBreakpoints.js';\nimport { cx } from '../../theme/tools.js';\nimport { useUiTranslation } from '../../i18n/useUiTranslation.js';\nimport type { SlotClasses } from '../../styles/slots.js';\n\nexport type DataTableColumn<Row> = {\n  id: string;\n  header: JSX.Element | string;\n  cell: (row: Row) => JSX.Element | string | null;\n  minVisibleAt?: DataTableBreakpoint;\n  className?: string;\n  isPrimary?: boolean;\n};\n\nexport type GetRowId<Row> = (row: Row, index: number) => string;\n\nexport type DataTableKind = NonNullable<\n  Parameters<typeof styles.container>[0]\n>['kind'];\n\ntype DataTableSlot =\n  | 'container'\n  | 'header'\n  | 'headerRow'\n  | 'headerCell'\n  | 'primaryHeaderCell'\n  | 'body'\n  | 'row'\n  | 'rowEven'\n  | 'rowOdd'\n  | 'cell'\n  | 'primaryCell'\n  | 'emptyRow'\n  | 'emptyCell';\n\nexport type DataTableProps<Row> = {\n  columns: readonly DataTableColumn<Row>[];\n  rows: readonly Row[];\n  getRowId: GetRowId<Row>;\n  emptyState?: JSX.Element;\n  className?: string;\n  headerClassName?: string;\n  bodyClassName?: string;\n  rowClassName?: (row: Row, index: number) => string | null | undefined;\n  gridTemplateClassName?: string;\n  gridTemplateColumns?: string;\n  kind?: DataTableKind;\n  classes?: SlotClasses<DataTableSlot>;\n};\n\nconst DEFAULT_TEMPLATE_CELL = 'minmax(0, 1fr)';\n\nconst getVisibilityClass = (minVisibleAt?: DataTableBreakpoint) => {\n  if (minVisibleAt == null) {\n    return null;\n  }\n\n  return styles.hideBelowRecipe({ minVisibleAt });\n};\n\nconst buildInlineTemplate = (\n  columnCount: number,\n  gridTemplateColumns?: string,\n): CSSProperties => {\n  if (typeof gridTemplateColumns === 'string' && gridTemplateColumns !== '') {\n    return { gridTemplateColumns };\n  }\n  return {\n    gridTemplateColumns: `repeat(${columnCount}, ${DEFAULT_TEMPLATE_CELL})`,\n  };\n};\n\n/**\n * Generic responsive data table component.\n */\nexport const DataTable = <Row,>({\n  columns,\n  rows,\n  getRowId,\n  emptyState,\n  className,\n  headerClassName,\n  bodyClassName,\n  rowClassName,\n  gridTemplateClassName,\n  gridTemplateColumns,\n  kind,\n  classes,\n}: DataTableProps<Row>): JSX.Element => {\n  const { t } = useUiTranslation();\n  const resolvedKind: DataTableKind = kind ?? 'default';\n  const defaultEmptyState = (\n    <div className={cx(styles.emptyCell, classes?.emptyCell)}>\n      {t('common.table.empty')}\n    </div>\n  ) as JSX.Element;\n  const resolvedEmptyState = emptyState ?? defaultEmptyState;\n  const showEmpty = rows.length === 0;\n\n  let inlineTemplateStyle: CSSProperties | undefined;\n  if (gridTemplateClassName == null) {\n    inlineTemplateStyle = buildInlineTemplate(\n      columns.length,\n      gridTemplateColumns,\n    );\n  }\n\n  const sharedRowClasses: string[] = [];\n  if (gridTemplateClassName != null) {\n    sharedRowClasses.push(gridTemplateClassName);\n  }\n\n  let rowsContent: JSX.Element;\n  if (showEmpty) {\n    rowsContent = (\n      <div className={cx(styles.emptyRow, classes?.emptyRow)} role=\"row\">\n        <div role=\"cell\">{resolvedEmptyState}</div>\n      </div>\n    );\n  } else {\n    rowsContent = (\n      <>\n        {rows.map((row, index) => {\n          const rowId = getRowId(row, index);\n          const rowClasses = [styles.row({ kind: resolvedKind }), classes?.row];\n          if (index % 2 === 0) {\n            rowClasses.push(\n              styles.rowEven({ kind: resolvedKind }),\n              classes?.rowEven,\n            );\n          } else {\n            rowClasses.push(\n              styles.rowOdd({ kind: resolvedKind }),\n              classes?.rowOdd,\n            );\n          }\n          for (const sharedClass of sharedRowClasses) {\n            rowClasses.push(sharedClass);\n          }\n\n          if (rowClassName != null) {\n            const customClass = rowClassName(row, index);\n            if (customClass != null) {\n              rowClasses.push(customClass);\n            }\n          }\n\n          return (\n            <div\n              key={rowId}\n              role=\"row\"\n              className={cx(...rowClasses)}\n              style={inlineTemplateStyle}\n            >\n              {columns.map((column) => {\n                const cellClasses = [\n                  styles.cell({ kind: resolvedKind }),\n                  classes?.cell,\n                ];\n                const visibilityClass = getVisibilityClass(column.minVisibleAt);\n\n                if (visibilityClass != null) {\n                  cellClasses.push(visibilityClass);\n                }\n\n                if (column.className != null) {\n                  cellClasses.push(column.className);\n                }\n                if (column.isPrimary) {\n                  cellClasses.push(styles.primaryCell, classes?.primaryCell);\n                }\n\n                const content = column.cell(row);\n\n                return (\n                  <div\n                    key={column.id}\n                    role=\"cell\"\n                    className={cx(...cellClasses)}\n                  >\n                    {content}\n                  </div>\n                );\n              })}\n            </div>\n          );\n        })}\n      </>\n    );\n  }\n\n  return (\n    <div\n      className={cx(\n        styles.container({ kind: resolvedKind }),\n        classes?.container,\n        className,\n      )}\n      role=\"table\"\n    >\n      <div\n        className={cx(\n          styles.header({ kind: resolvedKind }),\n          classes?.header,\n          headerClassName,\n        )}\n        role=\"rowgroup\"\n      >\n        <div\n          className={cx(\n            styles.headerRow,\n            classes?.headerRow,\n            ...sharedRowClasses,\n          )}\n          role=\"row\"\n          style={inlineTemplateStyle}\n        >\n          {columns.map((column) => {\n            const headerClasses = [\n              styles.headerCell({ kind: resolvedKind }),\n              classes?.headerCell,\n            ];\n            const visibilityClass = getVisibilityClass(column.minVisibleAt);\n            if (visibilityClass != null) {\n              headerClasses.push(visibilityClass);\n            }\n\n            if (column.className != null) {\n              headerClasses.push(column.className);\n            }\n            if (column.isPrimary) {\n              headerClasses.push(\n                styles.primaryHeaderCell,\n                classes?.primaryHeaderCell,\n              );\n            }\n\n            return (\n              <div\n                key={column.id}\n                role=\"columnheader\"\n                className={cx(...headerClasses)}\n              >\n                {column.header}\n              </div>\n            );\n          })}\n        </div>\n      </div>\n\n      <div\n        className={cx(\n          styles.body({ kind: resolvedKind }),\n          classes?.body,\n          bodyClassName,\n        )}\n        role=\"rowgroup\"\n      >\n        {rowsContent}\n      </div>\n    </div>\n  );\n};\n"]}
@@ -0,0 +1,26 @@
1
+ import { type RecipeVariants } from '@vanilla-extract/recipes';
2
+ export declare const base: string;
3
+ export declare const alignRecipe: import("@vanilla-extract/recipes").RuntimeFn<{
4
+ align: {
5
+ start: {
6
+ justifyContent: "flex-start";
7
+ textAlign: "left";
8
+ };
9
+ center: {
10
+ justifyContent: "center";
11
+ textAlign: "center";
12
+ };
13
+ end: {
14
+ justifyContent: "flex-end";
15
+ textAlign: "right";
16
+ };
17
+ };
18
+ }>;
19
+ export type AlignRecipeVariants = RecipeVariants<typeof alignRecipe>;
20
+ export declare const text: string;
21
+ export declare const number: string;
22
+ export declare const date: string;
23
+ export declare const muted: string;
24
+ export declare const ellipsis: string;
25
+ export declare const summary: string;
26
+ //# sourceMappingURL=TableCell.css.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableCell.css.d.ts","sourceRoot":"","sources":["../../../src/components/data-table/TableCell.css.ts"],"names":[],"mappings":"AAAA,OAAO,EAAU,KAAK,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAIvE,eAAO,MAAM,IAAI,QAMf,CAAC;AAEH,eAAO,MAAM,WAAW;;;;;;;;;;;;;;;EAWtB,CAAC;AAEH,MAAM,MAAM,mBAAmB,GAAG,cAAc,CAAC,OAAO,WAAW,CAAC,CAAC;AAErE,eAAO,MAAM,IAAI,QAEf,CAAC;AAEH,eAAO,MAAM,MAAM,QAGjB,CAAC;AAEH,eAAO,MAAM,IAAI,QAGf,CAAC;AAEH,eAAO,MAAM,KAAK,QAGhB,CAAC;AAEH,eAAO,MAAM,QAAQ,QAInB,CAAC;AAEH,eAAO,MAAM,OAAO,QAElB,CAAC"}
@@ -0,0 +1,45 @@
1
+ import { recipe } from '@vanilla-extract/recipes';
2
+ import { sprinkles } from '../../theme/sprinkles.css.js';
3
+ export const base = sprinkles({
4
+ width: 'full',
5
+ display: 'flex',
6
+ alignItems: 'center',
7
+ gap: 2,
8
+ color: 'text',
9
+ });
10
+ export const alignRecipe = recipe({
11
+ variants: {
12
+ align: {
13
+ start: { justifyContent: 'flex-start', textAlign: 'left' },
14
+ center: { justifyContent: 'center', textAlign: 'center' },
15
+ end: { justifyContent: 'flex-end', textAlign: 'right' },
16
+ },
17
+ },
18
+ defaultVariants: {
19
+ align: 'start',
20
+ },
21
+ });
22
+ export const text = sprinkles({
23
+ color: 'text',
24
+ });
25
+ export const number = sprinkles({
26
+ color: 'text',
27
+ whiteSpace: 'nowrap',
28
+ });
29
+ export const date = sprinkles({
30
+ color: 'text',
31
+ whiteSpace: 'nowrap',
32
+ });
33
+ export const muted = sprinkles({
34
+ color: 'textSecondary',
35
+ fontSize: 'xs',
36
+ });
37
+ export const ellipsis = sprinkles({
38
+ overflow: 'hidden',
39
+ textOverflow: 'ellipsis',
40
+ whiteSpace: 'nowrap',
41
+ });
42
+ export const summary = sprinkles({
43
+ whiteSpace: 'pre-wrap',
44
+ });
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGFibGVDZWxsLmNzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL2RhdGEtdGFibGUvVGFibGVDZWxsLmNzcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUF1QixNQUFNLDBCQUEwQixDQUFDO0FBRXZFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUV6RCxNQUFNLENBQUMsTUFBTSxJQUFJLEdBQUcsU0FBUyxDQUFDO0lBQzVCLEtBQUssRUFBRSxNQUFNO0lBQ2IsT0FBTyxFQUFFLE1BQU07SUFDZixVQUFVLEVBQUUsUUFBUTtJQUNwQixHQUFHLEVBQUUsQ0FBQztJQUNOLEtBQUssRUFBRSxNQUFNO0NBQ2QsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLE1BQU0sQ0FBQztJQUNoQyxRQUFRLEVBQUU7UUFDUixLQUFLLEVBQUU7WUFDTCxLQUFLLEVBQUUsRUFBRSxjQUFjLEVBQUUsWUFBWSxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUU7WUFDMUQsTUFBTSxFQUFFLEVBQUUsY0FBYyxFQUFFLFFBQVEsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFO1lBQ3pELEdBQUcsRUFBRSxFQUFFLGNBQWMsRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRTtTQUN4RDtLQUNGO0lBQ0QsZUFBZSxFQUFFO1FBQ2YsS0FBSyxFQUFFLE9BQU87S0FDZjtDQUNGLENBQUMsQ0FBQztBQUlILE1BQU0sQ0FBQyxNQUFNLElBQUksR0FBRyxTQUFTLENBQUM7SUFDNUIsS0FBSyxFQUFFLE1BQU07Q0FDZCxDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSxNQUFNLEdBQUcsU0FBUyxDQUFDO0lBQzlCLEtBQUssRUFBRSxNQUFNO0lBQ2IsVUFBVSxFQUFFLFFBQVE7Q0FDckIsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sSUFBSSxHQUFHLFNBQVMsQ0FBQztJQUM1QixLQUFLLEVBQUUsTUFBTTtJQUNiLFVBQVUsRUFBRSxRQUFRO0NBQ3JCLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLEtBQUssR0FBRyxTQUFTLENBQUM7SUFDN0IsS0FBSyxFQUFFLGVBQWU7SUFDdEIsUUFBUSxFQUFFLElBQUk7Q0FDZixDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSxRQUFRLEdBQUcsU0FBUyxDQUFDO0lBQ2hDLFFBQVEsRUFBRSxRQUFRO0lBQ2xCLFlBQVksRUFBRSxVQUFVO0lBQ3hCLFVBQVUsRUFBRSxRQUFRO0NBQ3JCLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxTQUFTLENBQUM7SUFDL0IsVUFBVSxFQUFFLFVBQVU7Q0FDdkIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcmVjaXBlLCB0eXBlIFJlY2lwZVZhcmlhbnRzIH0gZnJvbSAnQHZhbmlsbGEtZXh0cmFjdC9yZWNpcGVzJztcblxuaW1wb3J0IHsgc3ByaW5rbGVzIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3ByaW5rbGVzLmNzcy5qcyc7XG5cbmV4cG9ydCBjb25zdCBiYXNlID0gc3ByaW5rbGVzKHtcbiAgd2lkdGg6ICdmdWxsJyxcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgZ2FwOiAyLFxuICBjb2xvcjogJ3RleHQnLFxufSk7XG5cbmV4cG9ydCBjb25zdCBhbGlnblJlY2lwZSA9IHJlY2lwZSh7XG4gIHZhcmlhbnRzOiB7XG4gICAgYWxpZ246IHtcbiAgICAgIHN0YXJ0OiB7IGp1c3RpZnlDb250ZW50OiAnZmxleC1zdGFydCcsIHRleHRBbGlnbjogJ2xlZnQnIH0sXG4gICAgICBjZW50ZXI6IHsganVzdGlmeUNvbnRlbnQ6ICdjZW50ZXInLCB0ZXh0QWxpZ246ICdjZW50ZXInIH0sXG4gICAgICBlbmQ6IHsganVzdGlmeUNvbnRlbnQ6ICdmbGV4LWVuZCcsIHRleHRBbGlnbjogJ3JpZ2h0JyB9LFxuICAgIH0sXG4gIH0sXG4gIGRlZmF1bHRWYXJpYW50czoge1xuICAgIGFsaWduOiAnc3RhcnQnLFxuICB9LFxufSk7XG5cbmV4cG9ydCB0eXBlIEFsaWduUmVjaXBlVmFyaWFudHMgPSBSZWNpcGVWYXJpYW50czx0eXBlb2YgYWxpZ25SZWNpcGU+O1xuXG5leHBvcnQgY29uc3QgdGV4dCA9IHNwcmlua2xlcyh7XG4gIGNvbG9yOiAndGV4dCcsXG59KTtcblxuZXhwb3J0IGNvbnN0IG51bWJlciA9IHNwcmlua2xlcyh7XG4gIGNvbG9yOiAndGV4dCcsXG4gIHdoaXRlU3BhY2U6ICdub3dyYXAnLFxufSk7XG5cbmV4cG9ydCBjb25zdCBkYXRlID0gc3ByaW5rbGVzKHtcbiAgY29sb3I6ICd0ZXh0JyxcbiAgd2hpdGVTcGFjZTogJ25vd3JhcCcsXG59KTtcblxuZXhwb3J0IGNvbnN0IG11dGVkID0gc3ByaW5rbGVzKHtcbiAgY29sb3I6ICd0ZXh0U2Vjb25kYXJ5JyxcbiAgZm9udFNpemU6ICd4cycsXG59KTtcblxuZXhwb3J0IGNvbnN0IGVsbGlwc2lzID0gc3ByaW5rbGVzKHtcbiAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gIHdoaXRlU3BhY2U6ICdub3dyYXAnLFxufSk7XG5cbmV4cG9ydCBjb25zdCBzdW1tYXJ5ID0gc3ByaW5rbGVzKHtcbiAgd2hpdGVTcGFjZTogJ3ByZS13cmFwJyxcbn0pO1xuIl19
@@ -0,0 +1,46 @@
1
+ import { type JSX, type ReactNode } from 'react';
2
+ import { type TableCellBaseProps } from './TableCellBase.js';
3
+ type BadgeTone = 'neutral' | 'info' | 'success' | 'warning' | 'danger' | 'accent';
4
+ type TextCellProps = {
5
+ value?: string | null | undefined;
6
+ fallback?: string;
7
+ children?: ReactNode;
8
+ ellipsis?: boolean;
9
+ className?: string;
10
+ };
11
+ type NumberCellProps = {
12
+ value: number | null | undefined;
13
+ fallback?: string;
14
+ locale?: string;
15
+ formatOptions?: Intl.NumberFormatOptions;
16
+ };
17
+ type StatusCellProps = {
18
+ label: string;
19
+ tone: BadgeTone;
20
+ isLoading?: boolean;
21
+ };
22
+ type DateCellProps = {
23
+ value: string | null | undefined;
24
+ fallback?: string;
25
+ locale?: string;
26
+ options?: Intl.DateTimeFormatOptions;
27
+ };
28
+ type BadgeCellProps = {
29
+ label: string;
30
+ tone: BadgeTone;
31
+ };
32
+ type ActionsCellProps = TableCellBaseProps;
33
+ export declare const TableCell: {
34
+ Base: ({ children, className, align, ellipsis, }: TableCellBaseProps) => JSX.Element;
35
+ Text: ({ value, fallback, children, ellipsis, className, }: TextCellProps) => JSX.Element;
36
+ Number: ({ value, fallback, locale, formatOptions, }: NumberCellProps) => JSX.Element;
37
+ Status: ({ label, tone, isLoading, }: StatusCellProps) => JSX.Element;
38
+ Date: ({ value, fallback, locale, options, }: DateCellProps) => JSX.Element;
39
+ Badge: ({ label, tone }: BadgeCellProps) => JSX.Element;
40
+ Actions: ({ children, className }: ActionsCellProps) => JSX.Element;
41
+ Muted: ({ children }: {
42
+ children: ReactNode;
43
+ }) => JSX.Element;
44
+ };
45
+ export type { TextCellProps, NumberCellProps, StatusCellProps, DateCellProps };
46
+ //# sourceMappingURL=TableCell.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableCell.d.ts","sourceRoot":"","sources":["../../../src/components/data-table/TableCell.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,GAAG,EAAE,KAAK,SAAS,EAAW,MAAM,OAAO,CAAC;AAM1D,OAAO,EAAiB,KAAK,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAG5E,KAAK,SAAS,GACV,SAAS,GACT,MAAM,GACN,SAAS,GACT,SAAS,GACT,QAAQ,GACR,QAAQ,CAAC;AAEb,KAAK,aAAa,GAAG;IACnB,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IAClC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,SAAS,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,KAAK,eAAe,GAAG;IACrB,KAAK,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IACjC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,aAAa,CAAC,EAAE,IAAI,CAAC,mBAAmB,CAAC;CAC1C,CAAC;AAEF,KAAK,eAAe,GAAG;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,SAAS,CAAC;IAChB,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB,CAAC;AAEF,KAAK,aAAa,GAAG;IACnB,KAAK,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IACjC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,IAAI,CAAC,qBAAqB,CAAC;CACtC,CAAC;AAEF,KAAK,cAAc,GAAG;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,SAAS,CAAC;CACjB,CAAC;AAEF,KAAK,gBAAgB,GAAG,kBAAkB,CAAC;AAsH3C,eAAO,MAAM,SAAS;;gEAlGnB,aAAa,KAAG,GAAG,CAAC,OAAO;0DA0B3B,eAAe,KAAG,GAAG,CAAC,OAAO;0CAwB7B,eAAe,KAAG,GAAG,CAAC,OAAO;kDAe7B,aAAa,KAAG,GAAG,CAAC,OAAO;6BAaM,cAAc,KAAG,GAAG,CAAC,OAAO;uCAQtB,gBAAgB,KAAG,GAAG,CAAC,OAAO;0BAQ3C;QAAE,QAAQ,EAAE,SAAS,CAAA;KAAE,KAAG,GAAG,CAAC,OAAO;CAajE,CAAC;AAEF,YAAY,EAAE,aAAa,EAAE,eAAe,EAAE,eAAe,EAAE,aAAa,EAAE,CAAC"}