aeico-components 0.1.2 → 0.1.4

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 (224) hide show
  1. package/dist/alert.cjs +6 -0
  2. package/dist/alert.cjs.map +1 -0
  3. package/dist/alert.js +6 -0
  4. package/dist/alert.js.map +1 -0
  5. package/dist/badge.cjs +6 -0
  6. package/dist/badge.cjs.map +1 -0
  7. package/dist/badge.js +6 -0
  8. package/dist/badge.js.map +1 -0
  9. package/dist/breadcrumb.cjs +7 -0
  10. package/dist/breadcrumb.cjs.map +1 -0
  11. package/dist/breadcrumb.js +7 -0
  12. package/dist/breadcrumb.js.map +1 -0
  13. package/dist/button-group.cjs +6 -0
  14. package/dist/button-group.cjs.map +1 -0
  15. package/dist/button-group.js +6 -0
  16. package/dist/button-group.js.map +1 -0
  17. package/dist/button.cjs +6 -0
  18. package/dist/button.cjs.map +1 -0
  19. package/dist/button.js +6 -0
  20. package/dist/button.js.map +1 -0
  21. package/dist/card.cjs +6 -0
  22. package/dist/card.cjs.map +1 -0
  23. package/dist/card.js +6 -0
  24. package/dist/card.js.map +1 -0
  25. package/dist/checkbox.cjs +6 -0
  26. package/dist/checkbox.cjs.map +1 -0
  27. package/dist/checkbox.js +6 -0
  28. package/dist/checkbox.js.map +1 -0
  29. package/dist/chunks/aeico-component.cjs +17 -0
  30. package/dist/chunks/aeico-component.cjs.map +1 -0
  31. package/dist/chunks/aeico-component.js +18 -0
  32. package/dist/chunks/aeico-component.js.map +1 -0
  33. package/dist/chunks/aeico-field.cjs +179 -0
  34. package/dist/chunks/aeico-field.cjs.map +1 -0
  35. package/dist/chunks/aeico-field.js +180 -0
  36. package/dist/chunks/aeico-field.js.map +1 -0
  37. package/dist/chunks/alert.cjs +170 -0
  38. package/dist/chunks/alert.cjs.map +1 -0
  39. package/dist/chunks/alert.js +171 -0
  40. package/dist/chunks/alert.js.map +1 -0
  41. package/dist/chunks/badge.cjs +85 -0
  42. package/dist/chunks/badge.cjs.map +1 -0
  43. package/dist/chunks/badge.js +86 -0
  44. package/dist/chunks/badge.js.map +1 -0
  45. package/dist/chunks/breadcrumb-item.cjs +261 -0
  46. package/dist/chunks/breadcrumb-item.cjs.map +1 -0
  47. package/dist/chunks/breadcrumb-item.js +262 -0
  48. package/dist/chunks/breadcrumb-item.js.map +1 -0
  49. package/dist/chunks/button-group.cjs +79 -0
  50. package/dist/chunks/button-group.cjs.map +1 -0
  51. package/dist/chunks/button-group.js +80 -0
  52. package/dist/chunks/button-group.js.map +1 -0
  53. package/dist/chunks/button.cjs +351 -0
  54. package/dist/chunks/button.cjs.map +1 -0
  55. package/dist/chunks/button.js +352 -0
  56. package/dist/chunks/button.js.map +1 -0
  57. package/dist/chunks/card.cjs +93 -0
  58. package/dist/chunks/card.cjs.map +1 -0
  59. package/dist/chunks/card.js +94 -0
  60. package/dist/chunks/card.js.map +1 -0
  61. package/dist/chunks/checkbox.cjs +73 -0
  62. package/dist/chunks/checkbox.cjs.map +1 -0
  63. package/dist/chunks/checkbox.js +74 -0
  64. package/dist/chunks/checkbox.js.map +1 -0
  65. package/dist/chunks/color.cjs +4 -0
  66. package/dist/chunks/color.cjs.map +1 -0
  67. package/dist/chunks/color.js +5 -0
  68. package/dist/chunks/color.js.map +1 -0
  69. package/dist/chunks/detail.cjs +143 -0
  70. package/dist/chunks/detail.cjs.map +1 -0
  71. package/dist/chunks/detail.js +144 -0
  72. package/dist/chunks/detail.js.map +1 -0
  73. package/dist/chunks/dialog.cjs +117 -0
  74. package/dist/chunks/dialog.cjs.map +1 -0
  75. package/dist/chunks/dialog.js +118 -0
  76. package/dist/chunks/dialog.js.map +1 -0
  77. package/dist/chunks/divider.cjs +80 -0
  78. package/dist/chunks/divider.cjs.map +1 -0
  79. package/dist/chunks/divider.js +81 -0
  80. package/dist/chunks/divider.js.map +1 -0
  81. package/dist/chunks/dropdown-button.cjs +534 -0
  82. package/dist/chunks/dropdown-button.cjs.map +1 -0
  83. package/dist/chunks/dropdown-button.js +535 -0
  84. package/dist/chunks/dropdown-button.js.map +1 -0
  85. package/dist/chunks/icon-button.cjs +35 -0
  86. package/dist/chunks/icon-button.cjs.map +1 -0
  87. package/dist/chunks/icon-button.js +36 -0
  88. package/dist/chunks/icon-button.js.map +1 -0
  89. package/dist/chunks/icon.cjs +78 -0
  90. package/dist/chunks/icon.cjs.map +1 -0
  91. package/dist/chunks/icon.js +79 -0
  92. package/dist/chunks/icon.js.map +1 -0
  93. package/dist/chunks/navbar.cjs +143 -0
  94. package/dist/chunks/navbar.cjs.map +1 -0
  95. package/dist/chunks/navbar.js +144 -0
  96. package/dist/chunks/navbar.js.map +1 -0
  97. package/dist/chunks/radio.cjs +181 -0
  98. package/dist/chunks/radio.cjs.map +1 -0
  99. package/dist/chunks/radio.js +182 -0
  100. package/dist/chunks/radio.js.map +1 -0
  101. package/dist/chunks/select.cjs +350 -0
  102. package/dist/chunks/select.cjs.map +1 -0
  103. package/dist/chunks/select.js +351 -0
  104. package/dist/chunks/select.js.map +1 -0
  105. package/dist/chunks/size.cjs +4 -0
  106. package/dist/chunks/size.cjs.map +1 -0
  107. package/dist/chunks/size.js +5 -0
  108. package/dist/chunks/size.js.map +1 -0
  109. package/dist/chunks/slider.cjs +648 -0
  110. package/dist/chunks/slider.cjs.map +1 -0
  111. package/dist/chunks/slider.js +649 -0
  112. package/dist/chunks/slider.js.map +1 -0
  113. package/dist/chunks/switch.cjs +73 -0
  114. package/dist/chunks/switch.cjs.map +1 -0
  115. package/dist/chunks/switch.js +74 -0
  116. package/dist/chunks/switch.js.map +1 -0
  117. package/dist/chunks/tab-panel.cjs +166 -0
  118. package/dist/chunks/tab-panel.cjs.map +1 -0
  119. package/dist/chunks/tab-panel.js +167 -0
  120. package/dist/chunks/tab-panel.js.map +1 -0
  121. package/dist/chunks/tag.cjs +108 -0
  122. package/dist/chunks/tag.cjs.map +1 -0
  123. package/dist/chunks/tag.js +109 -0
  124. package/dist/chunks/tag.js.map +1 -0
  125. package/dist/chunks/text-input.cjs +59 -0
  126. package/dist/chunks/text-input.cjs.map +1 -0
  127. package/dist/chunks/text-input.js +60 -0
  128. package/dist/chunks/text-input.js.map +1 -0
  129. package/dist/chunks/variables.cjs +372 -0
  130. package/dist/chunks/variables.cjs.map +1 -0
  131. package/dist/chunks/variables.js +373 -0
  132. package/dist/chunks/variables.js.map +1 -0
  133. package/dist/detail.cjs +6 -0
  134. package/dist/detail.cjs.map +1 -0
  135. package/dist/detail.js +6 -0
  136. package/dist/detail.js.map +1 -0
  137. package/dist/dialog.cjs +6 -0
  138. package/dist/dialog.cjs.map +1 -0
  139. package/dist/dialog.js +6 -0
  140. package/dist/dialog.js.map +1 -0
  141. package/dist/divider.cjs +6 -0
  142. package/dist/divider.cjs.map +1 -0
  143. package/dist/divider.js +6 -0
  144. package/dist/divider.js.map +1 -0
  145. package/dist/dropdown.cjs +7 -0
  146. package/dist/dropdown.cjs.map +1 -0
  147. package/dist/dropdown.js +7 -0
  148. package/dist/dropdown.js.map +1 -0
  149. package/dist/icon-button.cjs +6 -0
  150. package/dist/icon-button.cjs.map +1 -0
  151. package/dist/icon-button.js +6 -0
  152. package/dist/icon-button.js.map +1 -0
  153. package/dist/icon.cjs +6 -0
  154. package/dist/icon.cjs.map +1 -0
  155. package/dist/icon.js +6 -0
  156. package/dist/icon.js.map +1 -0
  157. package/dist/index.cjs +49 -4223
  158. package/dist/index.cjs.map +1 -1
  159. package/dist/index.js +49 -4223
  160. package/dist/index.js.map +1 -1
  161. package/dist/navbar.cjs +6 -0
  162. package/dist/navbar.cjs.map +1 -0
  163. package/dist/navbar.js +6 -0
  164. package/dist/navbar.js.map +1 -0
  165. package/dist/radio-group.cjs +7 -0
  166. package/dist/radio-group.cjs.map +1 -0
  167. package/dist/radio-group.js +7 -0
  168. package/dist/radio-group.js.map +1 -0
  169. package/dist/select.cjs +99 -0
  170. package/dist/select.cjs.map +1 -0
  171. package/dist/select.js +99 -0
  172. package/dist/select.js.map +1 -0
  173. package/dist/slider.cjs +6 -0
  174. package/dist/slider.cjs.map +1 -0
  175. package/dist/slider.js +6 -0
  176. package/dist/slider.js.map +1 -0
  177. package/dist/switch.cjs +6 -0
  178. package/dist/switch.cjs.map +1 -0
  179. package/dist/switch.js +6 -0
  180. package/dist/switch.js.map +1 -0
  181. package/dist/tabs.cjs +8 -0
  182. package/dist/tabs.cjs.map +1 -0
  183. package/dist/tabs.js +8 -0
  184. package/dist/tabs.js.map +1 -0
  185. package/dist/tag.cjs +5 -0
  186. package/dist/tag.cjs.map +1 -0
  187. package/dist/tag.js +5 -0
  188. package/dist/tag.js.map +1 -0
  189. package/dist/text-input.cjs +6 -0
  190. package/dist/text-input.cjs.map +1 -0
  191. package/dist/text-input.js +6 -0
  192. package/dist/text-input.js.map +1 -0
  193. package/package.json +75 -63
  194. package/src/styles/color.css +117 -117
  195. package/src/styles/components/alert.css +104 -104
  196. package/src/styles/components/badge.css +67 -67
  197. package/src/styles/components/breadcrumb-item.css +59 -59
  198. package/src/styles/components/breadcrumb.css +19 -19
  199. package/src/styles/components/button-group.css +25 -25
  200. package/src/styles/components/button.css +213 -213
  201. package/src/styles/components/card.css +64 -64
  202. package/src/styles/components/checkbox.css +78 -78
  203. package/src/styles/components/detail.css +127 -127
  204. package/src/styles/components/dialog.css +103 -103
  205. package/src/styles/components/divider.css +18 -18
  206. package/src/styles/components/dropdown-item.css +91 -91
  207. package/src/styles/components/dropdown.css +179 -179
  208. package/src/styles/components/icon-button.css +116 -116
  209. package/src/styles/components/icon.css +29 -29
  210. package/src/styles/components/navbar.css +250 -250
  211. package/src/styles/components/radio-group.css +360 -360
  212. package/src/styles/components/select-option.css +43 -43
  213. package/src/styles/components/select.css +222 -222
  214. package/src/styles/components/slider.css +326 -326
  215. package/src/styles/components/switch.css +117 -117
  216. package/src/styles/components/tab-panel.css +8 -8
  217. package/src/styles/components/tab.css +44 -44
  218. package/src/styles/components/tabs.css +16 -16
  219. package/src/styles/components/tag.css +107 -107
  220. package/src/styles/components/text-input.css +110 -110
  221. package/src/styles/layout.css +43 -43
  222. package/src/styles/size.css +7 -7
  223. package/src/styles/variables.css +368 -368
  224. package/src/utils.ts +1 -0
@@ -1,43 +1,43 @@
1
- :host {
2
- display: block;
3
-
4
- --option-padding: 0.417em 0.667em;
5
- --option-bg: transparent;
6
- --option-bg-hover: var(--surface-raised);
7
- --option-bg-selected: color-mix(in srgb, var(--color-primary) 12%, transparent);
8
- --option-color: var(--color-text-main);
9
- --option-color-disabled: var(--color-text-disabled);
10
- --option-color-selected: var(--color-primary);
11
- --option-font-size: 1em;
12
- --option-transition: background 0.1s;
13
- }
14
-
15
- .option-item {
16
- padding: var(--option-padding);
17
- font-size: var(--option-font-size);
18
- color: var(--option-color);
19
- background: var(--option-bg);
20
- cursor: pointer;
21
- transition: var(--option-transition);
22
- white-space: nowrap;
23
- overflow: hidden;
24
- text-overflow: ellipsis;
25
- user-select: none;
26
- }
27
-
28
- :host(:hover:not([disabled])) .option-item {
29
- background: var(--option-bg-hover);
30
- }
31
-
32
- :host([selected]) .option-item {
33
- background: var(--option-bg-selected);
34
- color: var(--option-color-selected);
35
- }
36
-
37
- :host([disabled]) .option-item {
38
- color: var(--option-color-disabled);
39
- cursor: default;
40
- pointer-events: none;
41
- }
42
-
43
-
1
+ :host {
2
+ display: block;
3
+
4
+ --option-padding: 0.417em 0.667em;
5
+ --option-bg: transparent;
6
+ --option-bg-hover: var(--surface-raised);
7
+ --option-bg-selected: color-mix(in srgb, var(--color-primary) 12%, transparent);
8
+ --option-color: var(--color-text-main);
9
+ --option-color-disabled: var(--color-text-disabled);
10
+ --option-color-selected: var(--color-primary);
11
+ --option-font-size: 1em;
12
+ --option-transition: background 0.1s;
13
+ }
14
+
15
+ .option-item {
16
+ padding: var(--option-padding);
17
+ font-size: var(--option-font-size);
18
+ color: var(--option-color);
19
+ background: var(--option-bg);
20
+ cursor: pointer;
21
+ transition: var(--option-transition);
22
+ white-space: nowrap;
23
+ overflow: hidden;
24
+ text-overflow: ellipsis;
25
+ user-select: none;
26
+ }
27
+
28
+ :host(:hover:not([disabled])) .option-item {
29
+ background: var(--option-bg-hover);
30
+ }
31
+
32
+ :host([selected]) .option-item {
33
+ background: var(--option-bg-selected);
34
+ color: var(--option-color-selected);
35
+ }
36
+
37
+ :host([disabled]) .option-item {
38
+ color: var(--option-color-disabled);
39
+ cursor: default;
40
+ pointer-events: none;
41
+ }
42
+
43
+
@@ -1,222 +1,222 @@
1
- :host {
2
- display: block;
3
- flex: 1;
4
- min-width: 0;
5
- font-size: var(--size-base);
6
-
7
- /* Layout variables */
8
- --select-field-gap: 2px;
9
-
10
- /* Trigger variables */
11
- --select-font-size: 1em;
12
- --select-padding: 0.333em 0.583em;
13
- --select-border-width: 1px;
14
- --select-border-radius: 2px;
15
- --select-border-color: var(--border-subtle);
16
- --select-border-color-hover: var(--border-default);
17
- --select-border-color-focus: var(--border-focus);
18
- --select-bg: var(--surface-base);
19
- --select-bg-hover: var(--surface-raised);
20
- --select-bg-focus: var(--surface-raised);
21
- --select-color: var(--color-text-muted);
22
- --select-transition: border-color 0.12s, background 0.12s;
23
-
24
- /* Arrow */
25
- --select-arrow-color: var(--color-text-muted);
26
- --select-arrow-size: 0.75em;
27
-
28
- /* Dropdown */
29
- --select-dropdown-bg: var(--surface-overlay);
30
- --select-dropdown-border: var(--border-default);
31
- --select-dropdown-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
32
- --select-dropdown-border-radius: 2px;
33
- --select-dropdown-max-height: 240px;
34
- --select-dropdown-z-index: 1000;
35
- }
36
-
37
- .container {
38
- display: flex;
39
- align-items: center;
40
- gap: var(--select-field-gap);
41
- width: 100%;
42
- position: relative;
43
- }
44
-
45
- .trigger {
46
- flex: 1;
47
- min-width: 0;
48
- display: flex;
49
- align-items: center;
50
- flex-wrap: wrap;
51
- gap: 0.333em;
52
- font-size: var(--select-font-size);
53
- padding: var(--select-padding);
54
- border: var(--select-border-width) solid var(--select-border-color);
55
- border-radius: var(--select-border-radius);
56
- background: var(--select-bg);
57
- color: var(--select-color);
58
- cursor: pointer;
59
- transition: var(--select-transition);
60
- user-select: none;
61
- outline: none;
62
- box-sizing: border-box;
63
- }
64
-
65
- .trigger:hover:not(.disabled) {
66
- border-color: var(--select-border-color-hover);
67
- background: var(--select-bg-hover);
68
- }
69
-
70
- .trigger.open {
71
- border-color: var(--select-border-color-focus);
72
- background: var(--select-bg-focus);
73
- }
74
-
75
- .trigger.disabled {
76
- opacity: 0.5;
77
- cursor: default;
78
- pointer-events: none;
79
- }
80
-
81
- .value {
82
- flex: 1;
83
- min-width: 0;
84
- overflow: hidden;
85
- text-overflow: ellipsis;
86
- white-space: nowrap;
87
- }
88
-
89
- .placeholder {
90
- color: var(--color-text-disabled);
91
- }
92
-
93
- .selected-list {
94
- flex: 1;
95
- min-width: 0;
96
- display: flex;
97
- flex-wrap: wrap;
98
- gap: 4px;
99
- align-items: center;
100
- padding: 2px 0;
101
- }
102
-
103
- /* Non-expandable (default): single-row, clip overflow */
104
- .trigger:has(.selected-list--clipped) {
105
- flex-wrap: nowrap;
106
- }
107
-
108
- .selected-list--clipped {
109
- flex-wrap: nowrap;
110
- overflow: hidden;
111
- }
112
-
113
- .overflow-indicator {
114
- flex-shrink: 0;
115
- align-self: center;
116
- padding: 1px 6px;
117
- background: color-mix(in srgb, var(--color-primary) 12%, transparent);
118
- color: var(--color-primary);
119
- border: 1px solid color-mix(in srgb, var(--color-primary) 30%, transparent);
120
- border-radius: 3px;
121
- font-size: 0.82em;
122
- line-height: 1.6;
123
- cursor: default;
124
- user-select: none;
125
- }
126
-
127
- .arrow {
128
- flex-shrink: 0;
129
- align-self: center;
130
- font-size: var(--select-arrow-size);
131
- color: var(--select-arrow-color);
132
- transition: transform 0.12s;
133
- pointer-events: none;
134
- line-height: 1;
135
- }
136
-
137
- .trigger.open .arrow {
138
- transform: rotate(180deg);
139
- }
140
-
141
- .dropdown {
142
- display: none;
143
- position: absolute;
144
- z-index: var(--select-dropdown-z-index);
145
- background: var(--select-dropdown-bg);
146
- border: 1px solid var(--select-dropdown-border);
147
- border-radius: var(--select-dropdown-border-radius);
148
- box-shadow: var(--select-dropdown-shadow);
149
- max-height: var(--select-dropdown-max-height);
150
- overflow-y: auto;
151
- min-width: 100%;
152
- box-sizing: border-box;
153
- }
154
-
155
- .dropdown.open {
156
- display: block;
157
- }
158
-
159
- .dropdown.position-bottom {
160
- top: 100%;
161
- left: 0;
162
- margin-top: 2px;
163
- }
164
-
165
- .dropdown.position-top {
166
- bottom: 100%;
167
- left: 0;
168
- margin-bottom: 2px;
169
- }
170
-
171
- .dropdown.position-left {
172
- right: 100%;
173
- top: 0;
174
- margin-right: 2px;
175
- }
176
-
177
- .dropdown.position-right {
178
- left: 100%;
179
- top: 0;
180
- margin-left: 2px;
181
- }
182
-
183
- .clear-btn {
184
- width: 1.333em;
185
- height: 1.333em;
186
- border: none;
187
- border-radius: var(--clear-btn-border-radius);
188
- cursor: pointer;
189
- display: flex;
190
- align-items: center;
191
- justify-content: center;
192
- background: var(--clear-btn-bg);
193
- color: var(--clear-btn-color);
194
- transition: var(--clear-btn-transition);
195
- flex-shrink: 0;
196
- line-height: 1;
197
- }
198
-
199
- .clear-btn:hover {
200
- background: var(--clear-btn-bg-hover);
201
- color: var(--clear-btn-color-hover);
202
- }
203
-
204
- .reset-btn {
205
- width: 1.333em;
206
- height: 1.333em;
207
- border: none;
208
- border-radius: var(--reset-btn-border-radius);
209
- cursor: pointer;
210
- display: flex;
211
- align-items: center;
212
- justify-content: center;
213
- background: var(--reset-btn-bg);
214
- color: var(--reset-btn-color);
215
- transition: var(--reset-btn-transition);
216
- flex-shrink: 0;
217
- }
218
-
219
- .reset-btn:hover {
220
- background: var(--reset-btn-bg-hover);
221
- color: var(--reset-btn-color-hover);
222
- }
1
+ :host {
2
+ display: block;
3
+ flex: 1;
4
+ min-width: 0;
5
+ font-size: var(--size-base);
6
+
7
+ /* Layout variables */
8
+ --select-field-gap: 2px;
9
+
10
+ /* Trigger variables */
11
+ --select-font-size: 1em;
12
+ --select-padding: 0.333em 0.583em;
13
+ --select-border-width: 1px;
14
+ --select-border-radius: 2px;
15
+ --select-border-color: var(--border-subtle);
16
+ --select-border-color-hover: var(--border-default);
17
+ --select-border-color-focus: var(--border-focus);
18
+ --select-bg: var(--surface-base);
19
+ --select-bg-hover: var(--surface-raised);
20
+ --select-bg-focus: var(--surface-raised);
21
+ --select-color: var(--color-text-muted);
22
+ --select-transition: border-color 0.12s, background 0.12s;
23
+
24
+ /* Arrow */
25
+ --select-arrow-color: var(--color-text-muted);
26
+ --select-arrow-size: 0.75em;
27
+
28
+ /* Dropdown */
29
+ --select-dropdown-bg: var(--surface-overlay);
30
+ --select-dropdown-border: var(--border-default);
31
+ --select-dropdown-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
32
+ --select-dropdown-border-radius: 2px;
33
+ --select-dropdown-max-height: 240px;
34
+ --select-dropdown-z-index: 1000;
35
+ }
36
+
37
+ .container {
38
+ display: flex;
39
+ align-items: center;
40
+ gap: var(--select-field-gap);
41
+ width: 100%;
42
+ position: relative;
43
+ }
44
+
45
+ .trigger {
46
+ flex: 1;
47
+ min-width: 0;
48
+ display: flex;
49
+ align-items: center;
50
+ flex-wrap: wrap;
51
+ gap: 0.333em;
52
+ font-size: var(--select-font-size);
53
+ padding: var(--select-padding);
54
+ border: var(--select-border-width) solid var(--select-border-color);
55
+ border-radius: var(--select-border-radius);
56
+ background: var(--select-bg);
57
+ color: var(--select-color);
58
+ cursor: pointer;
59
+ transition: var(--select-transition);
60
+ user-select: none;
61
+ outline: none;
62
+ box-sizing: border-box;
63
+ }
64
+
65
+ .trigger:hover:not(.disabled) {
66
+ border-color: var(--select-border-color-hover);
67
+ background: var(--select-bg-hover);
68
+ }
69
+
70
+ .trigger.open {
71
+ border-color: var(--select-border-color-focus);
72
+ background: var(--select-bg-focus);
73
+ }
74
+
75
+ .trigger.disabled {
76
+ opacity: 0.5;
77
+ cursor: default;
78
+ pointer-events: none;
79
+ }
80
+
81
+ .value {
82
+ flex: 1;
83
+ min-width: 0;
84
+ overflow: hidden;
85
+ text-overflow: ellipsis;
86
+ white-space: nowrap;
87
+ }
88
+
89
+ .placeholder {
90
+ color: var(--color-text-disabled);
91
+ }
92
+
93
+ .selected-list {
94
+ flex: 1;
95
+ min-width: 0;
96
+ display: flex;
97
+ flex-wrap: wrap;
98
+ gap: 4px;
99
+ align-items: center;
100
+ padding: 2px 0;
101
+ }
102
+
103
+ /* Non-expandable (default): single-row, clip overflow */
104
+ .trigger:has(.selected-list--clipped) {
105
+ flex-wrap: nowrap;
106
+ }
107
+
108
+ .selected-list--clipped {
109
+ flex-wrap: nowrap;
110
+ overflow: hidden;
111
+ }
112
+
113
+ .overflow-indicator {
114
+ flex-shrink: 0;
115
+ align-self: center;
116
+ padding: 1px 6px;
117
+ background: color-mix(in srgb, var(--color-primary) 12%, transparent);
118
+ color: var(--color-primary);
119
+ border: 1px solid color-mix(in srgb, var(--color-primary) 30%, transparent);
120
+ border-radius: 3px;
121
+ font-size: 0.82em;
122
+ line-height: 1.6;
123
+ cursor: default;
124
+ user-select: none;
125
+ }
126
+
127
+ .arrow {
128
+ flex-shrink: 0;
129
+ align-self: center;
130
+ font-size: var(--select-arrow-size);
131
+ color: var(--select-arrow-color);
132
+ transition: transform 0.12s;
133
+ pointer-events: none;
134
+ line-height: 1;
135
+ }
136
+
137
+ .trigger.open .arrow {
138
+ transform: rotate(180deg);
139
+ }
140
+
141
+ .dropdown {
142
+ display: none;
143
+ position: absolute;
144
+ z-index: var(--select-dropdown-z-index);
145
+ background: var(--select-dropdown-bg);
146
+ border: 1px solid var(--select-dropdown-border);
147
+ border-radius: var(--select-dropdown-border-radius);
148
+ box-shadow: var(--select-dropdown-shadow);
149
+ max-height: var(--select-dropdown-max-height);
150
+ overflow-y: auto;
151
+ min-width: 100%;
152
+ box-sizing: border-box;
153
+ }
154
+
155
+ .dropdown.open {
156
+ display: block;
157
+ }
158
+
159
+ .dropdown.position-bottom {
160
+ top: 100%;
161
+ left: 0;
162
+ margin-top: 2px;
163
+ }
164
+
165
+ .dropdown.position-top {
166
+ bottom: 100%;
167
+ left: 0;
168
+ margin-bottom: 2px;
169
+ }
170
+
171
+ .dropdown.position-left {
172
+ right: 100%;
173
+ top: 0;
174
+ margin-right: 2px;
175
+ }
176
+
177
+ .dropdown.position-right {
178
+ left: 100%;
179
+ top: 0;
180
+ margin-left: 2px;
181
+ }
182
+
183
+ .clear-btn {
184
+ width: 1.333em;
185
+ height: 1.333em;
186
+ border: none;
187
+ border-radius: var(--clear-btn-border-radius);
188
+ cursor: pointer;
189
+ display: flex;
190
+ align-items: center;
191
+ justify-content: center;
192
+ background: var(--clear-btn-bg);
193
+ color: var(--clear-btn-color);
194
+ transition: var(--clear-btn-transition);
195
+ flex-shrink: 0;
196
+ line-height: 1;
197
+ }
198
+
199
+ .clear-btn:hover {
200
+ background: var(--clear-btn-bg-hover);
201
+ color: var(--clear-btn-color-hover);
202
+ }
203
+
204
+ .reset-btn {
205
+ width: 1.333em;
206
+ height: 1.333em;
207
+ border: none;
208
+ border-radius: var(--reset-btn-border-radius);
209
+ cursor: pointer;
210
+ display: flex;
211
+ align-items: center;
212
+ justify-content: center;
213
+ background: var(--reset-btn-bg);
214
+ color: var(--reset-btn-color);
215
+ transition: var(--reset-btn-transition);
216
+ flex-shrink: 0;
217
+ }
218
+
219
+ .reset-btn:hover {
220
+ background: var(--reset-btn-bg-hover);
221
+ color: var(--reset-btn-color-hover);
222
+ }