@rokkit/themes 1.0.0-next.125 → 1.0.0-next.128

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 (137) hide show
  1. package/README.md +118 -9
  2. package/build.mjs +237 -0
  3. package/package.json +43 -28
  4. package/src/base/breadcrumbs.css +46 -0
  5. package/src/base/button.css +247 -0
  6. package/src/base/card.css +36 -0
  7. package/src/base/carousel.css +122 -12
  8. package/src/base/connector.css +92 -0
  9. package/src/base/display.css +91 -0
  10. package/src/base/floating-action.css +388 -0
  11. package/src/base/floating-navigation.css +381 -0
  12. package/src/base/grid.css +93 -0
  13. package/src/base/index.css +39 -0
  14. package/src/base/input.css +198 -39
  15. package/src/base/item.css +78 -0
  16. package/src/base/list.css +179 -0
  17. package/src/base/menu.css +274 -0
  18. package/src/base/pill.css +57 -0
  19. package/src/base/progress.css +28 -15
  20. package/src/base/range.css +121 -0
  21. package/src/base/rating.css +40 -0
  22. package/src/base/reveal.css +37 -0
  23. package/src/base/search-filter.css +132 -0
  24. package/src/base/select.css +411 -0
  25. package/src/base/shine.css +14 -0
  26. package/src/base/stepper.css +140 -0
  27. package/src/base/switch.css +152 -0
  28. package/src/base/table.css +143 -33
  29. package/src/base/tabs.css +171 -0
  30. package/src/base/tilt.css +14 -0
  31. package/src/base/timeline.css +84 -0
  32. package/src/base/toggle.css +138 -0
  33. package/src/base/toolbar.css +337 -0
  34. package/src/base/tree.css +195 -11
  35. package/src/base/upload-progress.css +155 -0
  36. package/src/base/upload-target.css +67 -0
  37. package/src/glass/button.css +152 -0
  38. package/src/glass/floating-action.css +61 -0
  39. package/src/glass/floating-navigation.css +74 -0
  40. package/src/glass/index.css +23 -0
  41. package/src/glass/input.css +124 -0
  42. package/src/glass/list.css +122 -0
  43. package/src/glass/menu.css +92 -0
  44. package/src/glass/range.css +61 -0
  45. package/src/glass/search-filter.css +49 -0
  46. package/src/glass/select.css +178 -0
  47. package/src/glass/switch.css +28 -0
  48. package/src/glass/table.css +87 -0
  49. package/src/glass/tabs.css +58 -0
  50. package/src/glass/timeline.css +46 -0
  51. package/src/glass/toggle.css +48 -0
  52. package/src/glass/toolbar.css +84 -0
  53. package/src/glass/tree.css +104 -0
  54. package/src/index.css +18 -0
  55. package/src/index.js +25 -2
  56. package/src/material/button.css +153 -0
  57. package/src/material/floating-action.css +60 -0
  58. package/src/material/floating-navigation.css +74 -0
  59. package/src/material/index.css +23 -0
  60. package/src/material/input.css +118 -40
  61. package/src/material/list.css +90 -64
  62. package/src/material/menu.css +92 -0
  63. package/src/material/range.css +62 -0
  64. package/src/material/search-filter.css +49 -0
  65. package/src/material/select.css +170 -0
  66. package/src/material/switch.css +28 -0
  67. package/src/material/table.css +87 -0
  68. package/src/material/tabs.css +62 -0
  69. package/src/material/timeline.css +46 -0
  70. package/src/material/toggle.css +48 -0
  71. package/src/material/toolbar.css +84 -0
  72. package/src/material/tree.css +100 -0
  73. package/src/minimal/button.css +152 -0
  74. package/src/minimal/floating-action.css +59 -0
  75. package/src/minimal/floating-navigation.css +70 -0
  76. package/src/minimal/index.css +23 -0
  77. package/src/minimal/input.css +81 -120
  78. package/src/minimal/list.css +90 -104
  79. package/src/minimal/menu.css +88 -0
  80. package/src/minimal/range.css +61 -0
  81. package/src/minimal/search-filter.css +49 -0
  82. package/src/minimal/select.css +168 -0
  83. package/src/minimal/switch.css +28 -0
  84. package/src/minimal/table.css +87 -0
  85. package/src/minimal/tabs.css +53 -31
  86. package/src/minimal/timeline.css +45 -0
  87. package/src/minimal/toggle.css +48 -0
  88. package/src/minimal/toolbar.css +84 -0
  89. package/src/minimal/tree.css +100 -0
  90. package/src/rokkit/button.css +225 -0
  91. package/src/rokkit/connector.css +11 -0
  92. package/src/rokkit/floating-action.css +65 -0
  93. package/src/rokkit/floating-navigation.css +83 -0
  94. package/src/rokkit/grid.css +46 -0
  95. package/src/rokkit/index.css +27 -0
  96. package/src/rokkit/input.css +130 -0
  97. package/src/rokkit/list.css +127 -0
  98. package/src/rokkit/menu.css +93 -0
  99. package/src/rokkit/range.css +62 -0
  100. package/src/rokkit/search-filter.css +49 -0
  101. package/src/rokkit/select.css +185 -0
  102. package/src/rokkit/switch.css +28 -0
  103. package/src/rokkit/table.css +68 -38
  104. package/src/rokkit/tabs.css +82 -0
  105. package/src/rokkit/timeline.css +46 -0
  106. package/src/rokkit/toggle.css +36 -52
  107. package/src/rokkit/toolbar.css +84 -0
  108. package/src/rokkit/tree.css +123 -0
  109. package/src/rokkit/upload-progress.css +102 -0
  110. package/src/rokkit/upload-target.css +50 -0
  111. package/src/base/alert.css +0 -30
  112. package/src/base/animation.css +0 -37
  113. package/src/base/atoms.css +0 -58
  114. package/src/base/core.css +0 -107
  115. package/src/base/layout.css +0 -65
  116. package/src/base/molecules.css +0 -109
  117. package/src/base/organisms.css +0 -66
  118. package/src/base/scrollbar.css +0 -16
  119. package/src/base/toggles.css +0 -17
  120. package/src/base.css +0 -13
  121. package/src/markdown.css +0 -955
  122. package/src/material/base.css +0 -12
  123. package/src/material/form.css +0 -30
  124. package/src/material.css +0 -9
  125. package/src/minimal/base.css +0 -8
  126. package/src/minimal/form.css +0 -87
  127. package/src/minimal.css +0 -11
  128. package/src/mixins/mixins.scss +0 -66
  129. package/src/mixins/palette.scss +0 -48
  130. package/src/prism.css +0 -102
  131. package/src/rokkit/alert.css +0 -4
  132. package/src/rokkit/atoms.css +0 -52
  133. package/src/rokkit/carousel.css +0 -19
  134. package/src/rokkit/layout.css +0 -17
  135. package/src/rokkit/molecules.css +0 -124
  136. package/src/rokkit/organisms.css +0 -307
  137. package/src/rokkit.css +0 -11
@@ -0,0 +1,337 @@
1
+ /**
2
+ * Toolbar - Base Structural Styles
3
+ *
4
+ * These styles provide layout, positioning, and basic structure.
5
+ * No colors, shadows, or visual theming - those belong in theme styles.
6
+ */
7
+
8
+ /* =============================================================================
9
+ Toolbar Container
10
+ ============================================================================= */
11
+
12
+ [data-toolbar] {
13
+ display: flex;
14
+ align-items: center;
15
+ gap: 0.25rem;
16
+ }
17
+
18
+ [data-toolbar][data-toolbar-disabled='true'] {
19
+ pointer-events: none;
20
+ opacity: 0.5;
21
+ }
22
+
23
+ /* Position variants - horizontal */
24
+ [data-toolbar][data-toolbar-position='top'],
25
+ [data-toolbar][data-toolbar-position='bottom'],
26
+ [data-toolbar]:not([data-toolbar-position]) {
27
+ flex-direction: row;
28
+ }
29
+
30
+ /* Position variants - vertical */
31
+ [data-toolbar][data-toolbar-position='left'],
32
+ [data-toolbar][data-toolbar-position='right'] {
33
+ flex-direction: column;
34
+ height: 100%;
35
+ width: auto;
36
+ }
37
+
38
+ /* Sticky positioning */
39
+ [data-toolbar][data-toolbar-sticky='true'] {
40
+ position: sticky;
41
+ z-index: 10;
42
+ }
43
+
44
+ [data-toolbar][data-toolbar-sticky='true'][data-toolbar-position='top'],
45
+ [data-toolbar][data-toolbar-sticky='true']:not([data-toolbar-position]) {
46
+ top: 0;
47
+ }
48
+
49
+ [data-toolbar][data-toolbar-sticky='true'][data-toolbar-position='bottom'] {
50
+ bottom: 0;
51
+ }
52
+
53
+ [data-toolbar][data-toolbar-sticky='true'][data-toolbar-position='left'] {
54
+ left: 0;
55
+ }
56
+
57
+ [data-toolbar][data-toolbar-sticky='true'][data-toolbar-position='right'] {
58
+ right: 0;
59
+ }
60
+
61
+ /* Size variants - horizontal */
62
+ [data-toolbar][data-toolbar-size='sm'],
63
+ [data-toolbar][data-size='sm'] {
64
+ height: 2rem;
65
+ padding-inline: 0.5rem;
66
+ gap: 0.25rem;
67
+ }
68
+
69
+ [data-toolbar][data-toolbar-size='md'],
70
+ [data-toolbar][data-size='md'],
71
+ [data-toolbar]:not([data-toolbar-size]):not([data-size]) {
72
+ height: 2.5rem;
73
+ padding-inline: 0.75rem;
74
+ gap: 0.5rem;
75
+ }
76
+
77
+ [data-toolbar][data-toolbar-size='lg'],
78
+ [data-toolbar][data-size='lg'] {
79
+ height: 3rem;
80
+ padding-inline: 1rem;
81
+ gap: 0.75rem;
82
+ }
83
+
84
+ /* Compact mode */
85
+ [data-toolbar][data-toolbar-compact='true'] {
86
+ padding-block: 0;
87
+ }
88
+
89
+ [data-toolbar]:not([data-toolbar-compact='true']) {
90
+ padding-block: 0.25rem;
91
+ }
92
+
93
+ /* Vertical toolbar size adjustments */
94
+ [data-toolbar][data-toolbar-position='left'],
95
+ [data-toolbar][data-toolbar-position='right'] {
96
+ height: auto;
97
+ padding-block: 0.5rem;
98
+ padding-inline: 0.25rem;
99
+ }
100
+
101
+ /* =============================================================================
102
+ Toolbar Items (buttons, toggles)
103
+ ============================================================================= */
104
+
105
+ [data-toolbar-item] {
106
+ display: inline-flex;
107
+ align-items: center;
108
+ justify-content: center;
109
+ border: none;
110
+ background: transparent;
111
+ cursor: pointer;
112
+ border-radius: 0.25rem;
113
+ transition: all 150ms ease;
114
+ }
115
+
116
+ [data-toolbar-item]:focus {
117
+ outline: none;
118
+ }
119
+
120
+ [data-toolbar-item][data-disabled='true'],
121
+ [data-toolbar-item]:disabled {
122
+ pointer-events: none;
123
+ opacity: 0.5;
124
+ cursor: not-allowed;
125
+ }
126
+
127
+ /* Size variants for items */
128
+ [data-toolbar][data-toolbar-size='sm'] [data-toolbar-item],
129
+ [data-toolbar][data-size='sm'] [data-toolbar-item] {
130
+ min-width: 1.5rem;
131
+ height: 1.5rem;
132
+ padding: 0.25rem;
133
+ }
134
+
135
+ [data-toolbar][data-toolbar-size='md'] [data-toolbar-item],
136
+ [data-toolbar][data-size='md'] [data-toolbar-item],
137
+ [data-toolbar]:not([data-toolbar-size]):not([data-size]) [data-toolbar-item] {
138
+ min-width: 2rem;
139
+ height: 2rem;
140
+ padding: 0.375rem;
141
+ }
142
+
143
+ [data-toolbar][data-toolbar-size='lg'] [data-toolbar-item],
144
+ [data-toolbar][data-size='lg'] [data-toolbar-item] {
145
+ min-width: 2.5rem;
146
+ height: 2.5rem;
147
+ padding: 0.5rem;
148
+ }
149
+
150
+ /* =============================================================================
151
+ Toolbar Item Elements (icon, label)
152
+ ============================================================================= */
153
+
154
+ [data-toolbar-icon] {
155
+ flex-shrink: 0;
156
+ }
157
+
158
+ [data-toolbar-label] {
159
+ white-space: nowrap;
160
+ font-weight: 500;
161
+ }
162
+
163
+ /* Icon sizes */
164
+ [data-toolbar][data-toolbar-size='sm'] [data-toolbar-icon],
165
+ [data-toolbar][data-size='sm'] [data-toolbar-icon] {
166
+ font-size: 0.875rem;
167
+ }
168
+
169
+ [data-toolbar][data-toolbar-size='md'] [data-toolbar-icon],
170
+ [data-toolbar][data-size='md'] [data-toolbar-icon],
171
+ [data-toolbar]:not([data-toolbar-size]):not([data-size]) [data-toolbar-icon] {
172
+ font-size: 1rem;
173
+ }
174
+
175
+ [data-toolbar][data-toolbar-size='lg'] [data-toolbar-icon],
176
+ [data-toolbar][data-size='lg'] [data-toolbar-icon] {
177
+ font-size: 1.25rem;
178
+ }
179
+
180
+ /* Label sizes */
181
+ [data-toolbar][data-toolbar-size='sm'] [data-toolbar-label],
182
+ [data-toolbar][data-size='sm'] [data-toolbar-label] {
183
+ font-size: 0.75rem;
184
+ padding-inline: 0.25rem;
185
+ }
186
+
187
+ [data-toolbar][data-toolbar-size='md'] [data-toolbar-label],
188
+ [data-toolbar][data-size='md'] [data-toolbar-label],
189
+ [data-toolbar]:not([data-toolbar-size]):not([data-size]) [data-toolbar-label] {
190
+ font-size: 0.875rem;
191
+ padding-inline: 0.375rem;
192
+ }
193
+
194
+ [data-toolbar][data-toolbar-size='lg'] [data-toolbar-label],
195
+ [data-toolbar][data-size='lg'] [data-toolbar-label] {
196
+ font-size: 1rem;
197
+ padding-inline: 0.5rem;
198
+ }
199
+
200
+ /* =============================================================================
201
+ Separator
202
+ ============================================================================= */
203
+
204
+ [data-toolbar-separator] {
205
+ flex-shrink: 0;
206
+ }
207
+
208
+ /* Horizontal toolbar separator (vertical line) */
209
+ [data-toolbar][data-toolbar-position='top'] [data-toolbar-separator],
210
+ [data-toolbar][data-toolbar-position='bottom'] [data-toolbar-separator],
211
+ [data-toolbar]:not([data-toolbar-position]) [data-toolbar-separator] {
212
+ width: 1px;
213
+ margin-inline: 0.5rem;
214
+ }
215
+
216
+ [data-toolbar][data-toolbar-size='sm'] [data-toolbar-separator],
217
+ [data-toolbar][data-size='sm'] [data-toolbar-separator] {
218
+ height: 1rem;
219
+ }
220
+
221
+ [data-toolbar][data-toolbar-size='md'] [data-toolbar-separator],
222
+ [data-toolbar][data-size='md'] [data-toolbar-separator],
223
+ [data-toolbar]:not([data-toolbar-size]):not([data-size]) [data-toolbar-separator] {
224
+ height: 1.25rem;
225
+ }
226
+
227
+ [data-toolbar][data-toolbar-size='lg'] [data-toolbar-separator],
228
+ [data-toolbar][data-size='lg'] [data-toolbar-separator] {
229
+ height: 1.5rem;
230
+ }
231
+
232
+ /* Vertical toolbar separator (horizontal line) */
233
+ [data-toolbar][data-toolbar-position='left'] [data-toolbar-separator],
234
+ [data-toolbar][data-toolbar-position='right'] [data-toolbar-separator] {
235
+ height: 1px;
236
+ width: 1.5rem;
237
+ margin-block: 0.5rem;
238
+ }
239
+
240
+ /* =============================================================================
241
+ Divider (between sections)
242
+ ============================================================================= */
243
+
244
+ [data-toolbar-divider] {
245
+ flex-shrink: 0;
246
+ }
247
+
248
+ /* Horizontal toolbar divider (vertical line) */
249
+ [data-toolbar][data-toolbar-position='top'] [data-toolbar-divider],
250
+ [data-toolbar][data-toolbar-position='bottom'] [data-toolbar-divider],
251
+ [data-toolbar]:not([data-toolbar-position]) [data-toolbar-divider] {
252
+ width: 1px;
253
+ height: 1.5rem;
254
+ margin-inline: 0.5rem;
255
+ }
256
+
257
+ /* Vertical toolbar divider (horizontal line) */
258
+ [data-toolbar][data-toolbar-position='left'] [data-toolbar-divider],
259
+ [data-toolbar][data-toolbar-position='right'] [data-toolbar-divider] {
260
+ height: 1px;
261
+ width: 1.5rem;
262
+ margin-block: 0.5rem;
263
+ }
264
+
265
+ /* =============================================================================
266
+ Spacer
267
+ ============================================================================= */
268
+
269
+ [data-toolbar-spacer] {
270
+ flex: 1;
271
+ }
272
+
273
+ /* =============================================================================
274
+ Sections
275
+ ============================================================================= */
276
+
277
+ [data-toolbar-section] {
278
+ display: flex;
279
+ align-items: center;
280
+ gap: 0.5rem;
281
+ }
282
+
283
+ [data-toolbar-section='center'] {
284
+ flex: 1;
285
+ justify-content: center;
286
+ }
287
+
288
+ [data-toolbar-section='content'] {
289
+ flex: 1;
290
+ }
291
+
292
+ /* Vertical toolbar sections */
293
+ [data-toolbar][data-toolbar-position='left'] [data-toolbar-section],
294
+ [data-toolbar][data-toolbar-position='right'] [data-toolbar-section] {
295
+ flex-direction: column;
296
+ }
297
+
298
+ /* =============================================================================
299
+ Toolbar Group
300
+ ============================================================================= */
301
+
302
+ [data-toolbar-group] {
303
+ display: flex;
304
+ align-items: center;
305
+ min-width: 0;
306
+ }
307
+
308
+ [data-toolbar-group][data-toolbar-group-gap='none'] {
309
+ gap: 0;
310
+ }
311
+
312
+ [data-toolbar-group][data-toolbar-group-gap='sm'],
313
+ [data-toolbar-group]:not([data-toolbar-group-gap]) {
314
+ gap: 0.25rem;
315
+ }
316
+
317
+ [data-toolbar-group][data-toolbar-group-gap='md'] {
318
+ gap: 0.5rem;
319
+ }
320
+
321
+ [data-toolbar-group][data-toolbar-group-gap='lg'] {
322
+ gap: 0.75rem;
323
+ }
324
+
325
+ /* Vertical toolbar groups */
326
+ [data-toolbar][data-toolbar-position='left'] [data-toolbar-group],
327
+ [data-toolbar][data-toolbar-position='right'] [data-toolbar-group] {
328
+ flex-direction: column;
329
+ }
330
+
331
+ /* =============================================================================
332
+ Custom Item Wrapper
333
+ ============================================================================= */
334
+
335
+ [data-toolbar-item-custom] {
336
+ display: contents;
337
+ }
package/src/base/tree.css CHANGED
@@ -1,18 +1,202 @@
1
- rk-tree,
2
- rk-nested-list {
3
- @apply flex w-full flex-col text-sm;
1
+ /**
2
+ * Tree - Base Structural Styles
3
+ *
4
+ * These styles provide layout, positioning, and basic structure.
5
+ * No colors, shadows, or visual theming - those belong in theme styles.
6
+ *
7
+ * Note: Connector styles are in connector.css
8
+ */
9
+
10
+ /* =============================================================================
11
+ Tree Container
12
+ ============================================================================= */
13
+
14
+ [data-tree] {
15
+ display: flex;
16
+ flex-direction: column;
17
+ }
18
+
19
+ /* =============================================================================
20
+ Tree Node
21
+ ============================================================================= */
22
+
23
+ [data-tree-node] {
24
+ display: flex;
25
+ flex-direction: column;
26
+ }
27
+
28
+ [data-tree-node]:focus {
29
+ outline: none;
30
+ }
31
+
32
+ [data-tree-node-row] {
33
+ display: flex;
34
+ align-items: stretch;
35
+ }
36
+
37
+ /* =============================================================================
38
+ Tree Toggle Button (Expand/Collapse)
39
+ ============================================================================= */
40
+
41
+ [data-tree-toggle-btn] {
42
+ display: flex;
43
+ align-items: center;
44
+ justify-content: center;
45
+ flex-shrink: 0;
46
+ align-self: center;
47
+ padding: 0;
48
+ border: none;
49
+ background: transparent;
50
+ cursor: pointer;
51
+ border-radius: 0.25rem;
52
+ transition: background-color 150ms ease;
53
+ }
54
+
55
+ /* Size variants for toggle */
56
+ [data-tree][data-size='sm'] [data-tree-toggle-btn] {
57
+ width: 1rem;
58
+ height: 1rem;
59
+ }
60
+
61
+ [data-tree][data-size='md'] [data-tree-toggle-btn],
62
+ [data-tree]:not([data-size]) [data-tree-toggle-btn] {
63
+ width: 1.25rem;
64
+ height: 1.25rem;
65
+ }
66
+
67
+ [data-tree][data-size='lg'] [data-tree-toggle-btn] {
68
+ width: 1.5rem;
69
+ height: 1.5rem;
70
+ }
71
+
72
+ /* Toggle icon container */
73
+ [data-tree-toggle] {
74
+ display: flex;
75
+ align-items: center;
76
+ justify-content: center;
77
+ width: 100%;
78
+ height: 100%;
79
+ }
80
+
81
+ [data-tree-toggle]:not([data-tree-has-children]) {
82
+ /* Leaf node - no toggle needed */
83
+ visibility: hidden;
4
84
  }
5
- rk-nested-list rk-node > div {
6
- @apply h-8 px-2;
85
+
86
+ /* =============================================================================
87
+ Line Style Variants
88
+ Connectors have no borders by default. data-line-style activates them.
89
+ 'none' keeps connectors in DOM for spacing but lines stay invisible.
90
+ ============================================================================= */
91
+
92
+ /* Shared: activate 1px border for all visible line styles (solid/dashed/dotted).
93
+ Uses longhand width+style so theme border-color is not overridden. */
94
+ [data-tree]:not([data-line-style='none']) [data-connector-v] {
95
+ border-right-width: 1px;
96
+ }
97
+ [data-tree]:not([data-line-style='none']) [data-connector-h] {
98
+ border-bottom-width: 1px;
99
+ }
100
+ [data-tree]:not([data-line-style='none']) [data-connector-corner] {
101
+ border-bottom-width: 1px;
102
+ border-right-width: 1px;
103
+ }
104
+ [data-tree]:not([data-line-style='none']) [data-connector-rtl] [data-connector-v] {
105
+ border-right-width: 0;
106
+ border-left-width: 1px;
107
+ }
108
+ [data-tree]:not([data-line-style='none']) [data-connector-rtl] [data-connector-corner] {
109
+ border-right-width: 0;
110
+ border-left-width: 1px;
111
+ }
112
+
113
+ /* Solid (default visible style) */
114
+ [data-tree][data-line-style='solid'] [data-connector-v] { border-right-style: solid; }
115
+ [data-tree][data-line-style='solid'] [data-connector-h] { border-bottom-style: solid; }
116
+ [data-tree][data-line-style='solid'] [data-connector-corner] { border-bottom-style: solid; border-right-style: solid; }
117
+ [data-tree][data-line-style='solid'] [data-connector-rtl] [data-connector-v] { border-left-style: solid; }
118
+ [data-tree][data-line-style='solid'] [data-connector-rtl] [data-connector-corner] { border-left-style: solid; }
119
+
120
+ /* Dashed */
121
+ [data-tree][data-line-style='dashed'] [data-connector-v] { border-right-style: dashed; }
122
+ [data-tree][data-line-style='dashed'] [data-connector-h] { border-bottom-style: dashed; }
123
+ [data-tree][data-line-style='dashed'] [data-connector-corner] { border-bottom-style: dashed; border-right-style: dashed; }
124
+ [data-tree][data-line-style='dashed'] [data-connector-rtl] [data-connector-v] { border-left-style: dashed; }
125
+ [data-tree][data-line-style='dashed'] [data-connector-rtl] [data-connector-corner] { border-left-style: dashed; }
126
+
127
+ /* Dotted */
128
+ [data-tree][data-line-style='dotted'] [data-connector-v] { border-right-style: dotted; }
129
+ [data-tree][data-line-style='dotted'] [data-connector-h] { border-bottom-style: dotted; }
130
+ [data-tree][data-line-style='dotted'] [data-connector-corner] { border-bottom-style: dotted; border-right-style: dotted; }
131
+ [data-tree][data-line-style='dotted'] [data-connector-rtl] [data-connector-v] { border-left-style: dotted; }
132
+ [data-tree][data-line-style='dotted'] [data-connector-rtl] [data-connector-corner] { border-left-style: dotted; }
133
+
134
+ /* =============================================================================
135
+ Tree Item Content
136
+ ============================================================================= */
137
+
138
+ [data-tree-item-content] {
139
+ display: flex;
140
+ align-items: center;
141
+ align-self: center;
142
+ flex: 1;
143
+ min-width: 0;
144
+ padding: 0.25rem 0.375rem;
145
+ border: none;
146
+ background: transparent;
147
+ text-align: left;
148
+ cursor: pointer;
149
+ border-radius: 0.25rem;
150
+ font: inherit;
151
+ color: inherit;
152
+ transition:
153
+ background-color 150ms ease,
154
+ color 150ms ease;
155
+ }
156
+
157
+ /* Size variants for item content */
158
+ [data-tree][data-size='sm'] [data-tree-item-content] {
159
+ gap: 0.375rem;
160
+ font-size: 0.75rem;
7
161
  }
8
162
 
9
- rk-nested-list rk-node {
10
- @apply flex flex-col;
163
+ [data-tree][data-size='md'] [data-tree-item-content],
164
+ [data-tree]:not([data-size]) [data-tree-item-content] {
165
+ gap: 0.5rem;
166
+ font-size: 0.875rem;
11
167
  }
12
168
 
13
- rk-node > div > rk-item {
14
- @apply px-1;
169
+ [data-tree][data-size='lg'] [data-tree-item-content] {
170
+ gap: 0.625rem;
171
+ font-size: 1rem;
15
172
  }
16
- rk-node > div > span {
17
- @apply flex-shrink-0;
173
+
174
+ /* Item elements use shared [data-item-*] from item.css */
175
+
176
+ /* =============================================================================
177
+ Loading Spinner
178
+ ============================================================================= */
179
+
180
+ [data-tree-spinner] {
181
+ width: 1em;
182
+ height: 1em;
183
+ border: 2px solid currentColor;
184
+ border-right-color: transparent;
185
+ border-radius: 50%;
186
+ animation: tree-spin 0.6s linear infinite;
187
+ flex-shrink: 0;
188
+ }
189
+
190
+ @keyframes tree-spin {
191
+ to {
192
+ transform: rotate(360deg);
193
+ }
194
+ }
195
+
196
+ /* =============================================================================
197
+ Multi-selection
198
+ ============================================================================= */
199
+
200
+ [data-tree][data-multiselect='true'] [data-tree-item-content] {
201
+ user-select: none;
18
202
  }
@@ -0,0 +1,155 @@
1
+ /**
2
+ * UploadProgress - Base Structural Styles
3
+ *
4
+ * Layout: header flex, file row layout, progress bar track, action positioning.
5
+ * No colors or visual theming - those belong in theme styles.
6
+ */
7
+
8
+ /* =============================================================================
9
+ Container
10
+ ============================================================================= */
11
+
12
+ [data-upload-progress] {
13
+ display: flex;
14
+ flex-direction: column;
15
+ gap: 0.25rem;
16
+ }
17
+
18
+ /* =============================================================================
19
+ Header
20
+ ============================================================================= */
21
+
22
+ [data-upload-header] {
23
+ display: flex;
24
+ align-items: center;
25
+ justify-content: space-between;
26
+ gap: 0.75rem;
27
+ padding: 0.5rem 0.75rem;
28
+ font-size: 0.875rem;
29
+ font-weight: 500;
30
+ }
31
+
32
+ [data-upload-clear] {
33
+ padding: 0.25rem 0.5rem;
34
+ border-radius: 0.25rem;
35
+ font-size: 0.75rem;
36
+ cursor: pointer;
37
+ border: 1px solid currentColor;
38
+ background: transparent;
39
+ transition:
40
+ background-color 150ms ease,
41
+ color 150ms ease;
42
+ }
43
+
44
+ /* =============================================================================
45
+ File Status
46
+ ============================================================================= */
47
+
48
+ [data-upload-file-status] {
49
+ display: flex;
50
+ align-items: center;
51
+ gap: 0.75rem;
52
+ padding: 0.375rem 0.75rem;
53
+ font-size: 0.875rem;
54
+ transition: background-color 150ms ease;
55
+ }
56
+
57
+ /* =============================================================================
58
+ File Elements
59
+ ============================================================================= */
60
+
61
+ [data-upload-file-icon] {
62
+ flex-shrink: 0;
63
+ font-size: 1.25rem;
64
+ }
65
+
66
+ [data-upload-file-name] {
67
+ flex: 1;
68
+ min-width: 0;
69
+ overflow: hidden;
70
+ text-overflow: ellipsis;
71
+ white-space: nowrap;
72
+ }
73
+
74
+ [data-upload-file-size] {
75
+ flex-shrink: 0;
76
+ font-size: 0.75rem;
77
+ white-space: nowrap;
78
+ }
79
+
80
+ /* =============================================================================
81
+ Progress Bar
82
+ ============================================================================= */
83
+
84
+ [data-upload-bar] {
85
+ position: relative;
86
+ width: 6rem;
87
+ height: 0.375rem;
88
+ border-radius: 9999px;
89
+ overflow: hidden;
90
+ flex-shrink: 0;
91
+ }
92
+
93
+ [data-upload-fill] {
94
+ height: 100%;
95
+ border-radius: 9999px;
96
+ transition: width 0.3s ease;
97
+ }
98
+
99
+ /* =============================================================================
100
+ Status Badge
101
+ ============================================================================= */
102
+
103
+ [data-upload-status] {
104
+ flex-shrink: 0;
105
+ font-size: 0.75rem;
106
+ font-weight: 500;
107
+ text-transform: capitalize;
108
+ }
109
+
110
+ /* =============================================================================
111
+ Action Buttons
112
+ ============================================================================= */
113
+
114
+ [data-upload-actions] {
115
+ display: flex;
116
+ gap: 0.25rem;
117
+ flex-shrink: 0;
118
+ }
119
+
120
+ [data-upload-actions] button {
121
+ display: inline-flex;
122
+ align-items: center;
123
+ justify-content: center;
124
+ width: 1.5rem;
125
+ height: 1.5rem;
126
+ padding: 0;
127
+ border: none;
128
+ border-radius: 0.25rem;
129
+ cursor: pointer;
130
+ background: transparent;
131
+ font-size: 0.875rem;
132
+ transition:
133
+ background-color 150ms ease,
134
+ color 150ms ease;
135
+ }
136
+
137
+ /* =============================================================================
138
+ Grid View Tiles
139
+ ============================================================================= */
140
+
141
+ [data-grid] [data-upload-file-status] {
142
+ flex-direction: column;
143
+ align-items: center;
144
+ text-align: center;
145
+ padding: 1rem;
146
+ gap: 0.5rem;
147
+ }
148
+
149
+ [data-grid] [data-upload-file-status] [data-upload-file-icon] {
150
+ font-size: 2rem;
151
+ }
152
+
153
+ [data-grid] [data-upload-file-status] [data-upload-bar] {
154
+ width: 100%;
155
+ }