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
@@ -0,0 +1,649 @@
1
+ import { A as AeicoField } from "./aeico-field.js";
2
+ import { prop, html, tags } from "aeico";
3
+ import { s as styleVariables } from "./variables.js";
4
+ import { s as sizeCSS } from "./size.js";
5
+ import { c as colorCSS } from "./color.js";
6
+ const style = `:host {
7
+ display: block;
8
+ flex: 1;
9
+ min-width: 0;
10
+ font-size: var(--size-base);
11
+
12
+ /* Default color when no [color] attribute — overridden by color.css :host([color=...]) */
13
+ --color-solid: var(--color-primary);
14
+ }
15
+
16
+ .range-container {
17
+ display: flex;
18
+ align-items: center;
19
+ gap: 6px;
20
+ width: 100%;
21
+ height: 26px;
22
+ }
23
+
24
+ input[type="range"] {
25
+ flex: 1;
26
+ margin: 0;
27
+ }
28
+
29
+ .input-range,
30
+ .slider-input,
31
+ input[type="range"] {
32
+ -webkit-appearance: none;
33
+ appearance: none;
34
+ width: 100%;
35
+ height: 0.333em;
36
+ border-radius: 2px;
37
+ background: var(--border-subtle);
38
+ outline: none;
39
+ cursor: pointer;
40
+ margin: 0;
41
+ }
42
+
43
+ .input-range {
44
+ margin: 10px 0;
45
+ }
46
+
47
+ .input-range::-webkit-slider-thumb,
48
+ .slider-input::-webkit-slider-thumb,
49
+ input[type="range"]::-webkit-slider-thumb {
50
+ -webkit-appearance: none;
51
+ appearance: none;
52
+ width: 1.167em;
53
+ height: 1.167em;
54
+ border-radius: 50%;
55
+ background: var(--color-solid);
56
+ cursor: pointer;
57
+ transition: background 0.12s, transform 0.12s;
58
+ }
59
+
60
+ .input-range::-webkit-slider-thumb:hover,
61
+ .slider-input::-webkit-slider-thumb:hover,
62
+ input[type="range"]:hover::-webkit-slider-thumb {
63
+ background: var(--color-solid-hover);
64
+ transform: scale(1.1);
65
+ }
66
+
67
+ .input-range::-webkit-slider-thumb:active,
68
+ .slider-input::-webkit-slider-thumb:active,
69
+ input[type="range"]:active::-webkit-slider-thumb {
70
+ background: var(--color-solid-hover);
71
+ transform: scale(1.2);
72
+ }
73
+
74
+ .input-range:focus::-webkit-slider-thumb,
75
+ .slider-input:focus::-webkit-slider-thumb,
76
+ input[type="range"]:focus::-webkit-slider-thumb {
77
+ background: var(--color-solid);
78
+ outline: none;
79
+ box-shadow: none;
80
+ }
81
+
82
+ .input-range:focus:hover::-webkit-slider-thumb,
83
+ .slider-input:focus:hover::-webkit-slider-thumb,
84
+ input[type="range"]:focus:hover::-webkit-slider-thumb {
85
+ background: var(--color-solid-hover);
86
+ outline: none;
87
+ box-shadow: none;
88
+ }
89
+
90
+ .input-range:focus:active::-webkit-slider-thumb,
91
+ .slider-input:focus:active::-webkit-slider-thumb,
92
+ input[type="range"]:focus:active::-webkit-slider-thumb {
93
+ background: var(--color-solid-hover);
94
+ outline: none;
95
+ box-shadow: none;
96
+ }
97
+
98
+ .input-range::-moz-range-thumb,
99
+ .slider-input::-moz-range-thumb,
100
+ input[type="range"]::-moz-range-thumb {
101
+ width: 1.167em;
102
+ height: 1.167em;
103
+ border: none;
104
+ border-radius: 50%;
105
+ background: var(--color-solid);
106
+ cursor: pointer;
107
+ transition: background 0.12s, transform 0.12s;
108
+ }
109
+
110
+ .input-range::-moz-range-thumb:hover,
111
+ .slider-input::-moz-range-thumb:hover,
112
+ input[type="range"]:hover::-moz-range-thumb {
113
+ background: var(--color-solid-hover);
114
+ transform: scale(1.1);
115
+ }
116
+
117
+ .input-range::-moz-range-thumb:active,
118
+ .slider-input::-moz-range-thumb:active,
119
+ input[type="range"]:active::-moz-range-thumb {
120
+ background: var(--color-solid-hover);
121
+ transform: scale(1.2);
122
+ }
123
+
124
+ .input-range:focus::-moz-range-thumb,
125
+ .slider-input:focus::-moz-range-thumb,
126
+ input[type="range"]:focus::-moz-range-thumb {
127
+ background: var(--color-solid);
128
+ outline: none;
129
+ box-shadow: none;
130
+ }
131
+
132
+ .input-range:focus:hover::-moz-range-thumb,
133
+ .slider-input:focus:hover::-moz-range-thumb,
134
+ input[type="range"]:focus:hover::-moz-range-thumb {
135
+ background: var(--color-solid-hover);
136
+ outline: none;
137
+ box-shadow: none;
138
+ }
139
+
140
+ .input-range:focus:active::-moz-range-thumb,
141
+ .slider-input:focus:active::-moz-range-thumb,
142
+ input[type="range"]:focus:active::-moz-range-thumb {
143
+ background: var(--color-solid-hover);
144
+ outline: none;
145
+ box-shadow: none;
146
+ }
147
+
148
+ .input-range:disabled,
149
+ .slider-input:disabled,
150
+ input[type="range"]:disabled {
151
+ opacity: 0.5;
152
+ cursor: not-allowed;
153
+ }
154
+
155
+ .input-range:disabled::-webkit-slider-thumb,
156
+ .slider-input:disabled::-webkit-slider-thumb,
157
+ input[type="range"]:disabled::-webkit-slider-thumb {
158
+ cursor: not-allowed;
159
+ }
160
+
161
+ .input-range:disabled::-moz-range-thumb,
162
+ .slider-input:disabled::-moz-range-thumb,
163
+ input[type="range"]:disabled::-moz-range-thumb {
164
+ cursor: not-allowed;
165
+ }
166
+
167
+ .value-label {
168
+ min-width: 14px;
169
+ text-align: center;
170
+ font-size: 12px;
171
+ color: var(--color-text-muted);
172
+ font-weight: 500;
173
+ font-variant-numeric: tabular-nums;
174
+ pointer-events: none;
175
+ user-select: none;
176
+ }
177
+
178
+ .reset-btn {
179
+ width: 1.333em;
180
+ height: 1.333em;
181
+ border: none;
182
+ border-radius: var(--reset-btn-border-radius);
183
+ cursor: pointer;
184
+ display: flex;
185
+ align-items: center;
186
+ justify-content: center;
187
+ background: var(--reset-btn-bg);
188
+ color: var(--reset-btn-color);
189
+ transition: var(--reset-btn-transition);
190
+ flex-shrink: 0;
191
+ }
192
+
193
+ .reset-btn:hover {
194
+ background: var(--reset-btn-bg-hover);
195
+ color: var(--reset-btn-color-hover);
196
+ }
197
+
198
+ .clear-btn {
199
+ width: 1.333em;
200
+ height: 1.333em;
201
+ border: none;
202
+ border-radius: var(--clear-btn-border-radius);
203
+ cursor: pointer;
204
+ display: flex;
205
+ align-items: center;
206
+ justify-content: center;
207
+ background: var(--clear-btn-bg);
208
+ color: var(--clear-btn-color);
209
+ transition: var(--clear-btn-transition);
210
+ flex-shrink: 0;
211
+ }
212
+
213
+ .clear-btn:hover {
214
+ background: var(--clear-btn-bg-hover);
215
+ color: var(--clear-btn-color-hover);
216
+ }
217
+
218
+
219
+
220
+ .input-range,
221
+ .slider-input,
222
+ input[type="range"] {
223
+ height: 0.333em;
224
+ }
225
+
226
+ .input-range::-webkit-slider-thumb,
227
+ .slider-input::-webkit-slider-thumb,
228
+ input[type="range"]::-webkit-slider-thumb {
229
+ width: 1.167em;
230
+ height: 1.167em;
231
+ }
232
+
233
+ .input-range::-moz-range-thumb,
234
+ .slider-input::-moz-range-thumb,
235
+ input[type="range"]::-moz-range-thumb {
236
+ width: 1.167em;
237
+ height: 1.167em;
238
+ }
239
+
240
+ .value-label {
241
+ font-size: 1em;
242
+ }
243
+
244
+ .value-input {
245
+ width: 56px;
246
+ padding: 0 4px;
247
+ height: 22px;
248
+ border: 1px solid var(--border-subtle);
249
+ border-radius: 4px;
250
+ background: transparent;
251
+ color: var(--color-text);
252
+ font-size: 12px;
253
+ text-align: center;
254
+ outline: none;
255
+ flex-shrink: 0;
256
+ }
257
+
258
+ .value-input:focus {
259
+ border-color: var(--color-solid);
260
+ }
261
+
262
+ .value-input:disabled {
263
+ opacity: 0.4;
264
+ cursor: not-allowed;
265
+ }
266
+
267
+ :host([tracked]) .input-range,
268
+ :host([tracked]) .slider-input,
269
+ :host([tracked]) input[type="range"] {
270
+ background: linear-gradient(
271
+ to right,
272
+ var(--color-solid) var(--fill-pct, 0%),
273
+ var(--border-subtle) var(--fill-pct, 0%)
274
+ );
275
+ }
276
+
277
+ .range-wrapper {
278
+ flex: 1;
279
+ min-width: 0;
280
+ display: flex;
281
+ flex-direction: column;
282
+ position: relative; /* marks-container positions against this */
283
+ }
284
+
285
+ .range-wrapper input[type="range"] {
286
+ width: 100%;
287
+ flex: none;
288
+ }
289
+
290
+ /* Marks are absolutely positioned so they don't affect range-wrapper's layout height */
291
+ .marks-container {
292
+ position: absolute;
293
+ top: 100%;
294
+ left: 7px; /* inset by half thumb so 0%/100% align with track ends */
295
+ right: 7px;
296
+ height: 18px;
297
+ margin-top: 2px;
298
+ overflow: visible;
299
+ }
300
+
301
+ .mark {
302
+ position: absolute;
303
+ transform: translateX(-50%);
304
+ display: flex;
305
+ flex-direction: column;
306
+ align-items: center;
307
+ gap: 2px;
308
+ pointer-events: none;
309
+ user-select: none;
310
+ }
311
+
312
+ .mark::before {
313
+ content: '';
314
+ display: block;
315
+ width: 1px;
316
+ height: 4px;
317
+ background: var(--border-default, var(--border-subtle));
318
+ border-radius: 1px;
319
+ }
320
+
321
+ .mark-label {
322
+ font-size: 10px;
323
+ color: var(--color-text-muted);
324
+ white-space: nowrap;
325
+ }
326
+
327
+ /* When marks are active, add padding-bottom to make room for the absolute-positioned marks */
328
+ :host([marks]) .range-container {
329
+ padding-bottom: 24px; /* marks-container height (18px) + margin-top (2px) + extra (4px) */
330
+ height: auto;
331
+ }
332
+ `;
333
+ var __create = Object.create;
334
+ var __defProp = Object.defineProperty;
335
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
336
+ var __knownSymbol = (name, symbol) => (symbol = Symbol[name]) ? symbol : Symbol.for("Symbol." + name);
337
+ var __typeError = (msg) => {
338
+ throw TypeError(msg);
339
+ };
340
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
341
+ var __decoratorStart = (base) => [, , , __create((base == null ? void 0 : base[__knownSymbol("metadata")]) ?? null)];
342
+ var __decoratorStrings = ["class", "method", "getter", "setter", "accessor", "field", "value", "get", "set"];
343
+ var __expectFn = (fn) => fn !== void 0 && typeof fn !== "function" ? __typeError("Function expected") : fn;
344
+ var __decoratorContext = (kind, name, done, metadata, fns) => ({ kind: __decoratorStrings[kind], name, metadata, addInitializer: (fn) => done._ ? __typeError("Already initialized") : fns.push(__expectFn(fn || null)) });
345
+ var __decoratorMetadata = (array, target) => __defNormalProp(target, __knownSymbol("metadata"), array[3]);
346
+ var __runInitializers = (array, flags, self, value) => {
347
+ for (var i = 0, fns = array[flags >> 1], n = fns && fns.length; i < n; i++) flags & 1 ? fns[i].call(self) : value = fns[i].call(self, value);
348
+ return value;
349
+ };
350
+ var __decorateElement = (array, flags, name, decorators, target, extra) => {
351
+ var fn, it, done, ctx, access, k = flags & 7, s = false, p = false;
352
+ var j = array.length + 1, key = __decoratorStrings[k + 5];
353
+ var initializers = array[j - 1] = [], extraInitializers = array[j] || (array[j] = []);
354
+ var desc = (target = target.prototype, __getOwnPropDesc({ get [name]() {
355
+ return __privateGet(this, extra);
356
+ }, set [name](x) {
357
+ return __privateSet(this, extra, x);
358
+ } }, name));
359
+ for (var i = decorators.length - 1; i >= 0; i--) {
360
+ ctx = __decoratorContext(k, name, done = {}, array[3], extraInitializers);
361
+ {
362
+ ctx.static = s, ctx.private = p, access = ctx.access = { has: (x) => name in x };
363
+ access.get = (x) => x[name];
364
+ access.set = (x, y) => x[name] = y;
365
+ }
366
+ it = (0, decorators[i])({ get: desc.get, set: desc.set }, ctx), done._ = 1;
367
+ if (it === void 0) __expectFn(it) && (desc[key] = it);
368
+ else if (typeof it !== "object" || it === null) __typeError("Object expected");
369
+ else __expectFn(fn = it.get) && (desc.get = fn), __expectFn(fn = it.set) && (desc.set = fn), __expectFn(fn = it.init) && initializers.unshift(fn);
370
+ }
371
+ return desc && __defProp(target, name, desc), target;
372
+ };
373
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
374
+ var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
375
+ var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), member.get(obj));
376
+ var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
377
+ var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), member.set(obj, value), value);
378
+ var _marks_dec, _tracked_dec, _editable_dec, _step_dec, _max_dec, _min_dec, _percentage_dec, _options_dec, _a, _init, _options, _percentage, _min, _max, _step, _editable, _tracked, _marks;
379
+ class Slider extends (_a = AeicoField, _options_dec = [prop({ type: Array })], _percentage_dec = [prop({ type: Boolean })], _min_dec = [prop({ type: Number })], _max_dec = [prop({ type: Number })], _step_dec = [prop({ type: Number })], _editable_dec = [prop({ type: Boolean })], _tracked_dec = [prop({ type: Boolean })], _marks_dec = [prop({
380
+ type: Array,
381
+ // bare attribute (<ae-slider marks>) → true; JSON array → MarkItem[]
382
+ parser: (value) => {
383
+ if (value === null) return void 0;
384
+ if (value === "" || value === "true") return true;
385
+ if (value === "false") return false;
386
+ try {
387
+ return JSON.parse(value);
388
+ } catch {
389
+ return true;
390
+ }
391
+ }
392
+ })], _a) {
393
+ constructor() {
394
+ super();
395
+ __publicField(this, "fieldElement", null);
396
+ __publicField(this, "_valueLabel", null);
397
+ __publicField(this, "_numberInput", null);
398
+ __publicField(this, "_boundOnRangeInput");
399
+ __publicField(this, "_boundOnNumberInput");
400
+ __privateAdd(this, _options, __runInitializers(_init, 8, this, [])), __runInitializers(_init, 11, this);
401
+ __privateAdd(this, _percentage, __runInitializers(_init, 12, this, false)), __runInitializers(_init, 15, this);
402
+ __privateAdd(this, _min, __runInitializers(_init, 16, this, 0)), __runInitializers(_init, 19, this);
403
+ __privateAdd(this, _max, __runInitializers(_init, 20, this, 100)), __runInitializers(_init, 23, this);
404
+ __privateAdd(this, _step, __runInitializers(_init, 24, this, 1)), __runInitializers(_init, 27, this);
405
+ __privateAdd(this, _editable, __runInitializers(_init, 28, this, false)), __runInitializers(_init, 31, this);
406
+ __privateAdd(this, _tracked, __runInitializers(_init, 32, this, false)), __runInitializers(_init, 35, this);
407
+ __privateAdd(this, _marks, __runInitializers(_init, 36, this)), __runInitializers(_init, 39, this);
408
+ this._boundOnRangeInput = this._onRangeInput.bind(this);
409
+ this._boundOnNumberInput = this._onNumberInput.bind(this);
410
+ }
411
+ _normalizeOptions() {
412
+ if (!Array.isArray(this.options) || this.options.length === 0) return null;
413
+ const opts = this.options.map(
414
+ (opt) => this._isSliderOption(opt) ? { label: opt.label, value: String(opt.value) } : { label: String(opt), value: String(opt) }
415
+ );
416
+ const allNumeric = opts.every((o) => o.value !== "" && !isNaN(Number(o.value)));
417
+ if (allNumeric) {
418
+ return [...opts].sort((a, b) => Number(a.value) - Number(b.value)).map((o) => ({ ...o, rangeValue: Number(o.value) }));
419
+ } else {
420
+ return opts.map((o, i) => ({ ...o, rangeValue: i }));
421
+ }
422
+ }
423
+ _getRangeAttrs(normalized) {
424
+ if (normalized && normalized.length >= 1) {
425
+ const vals = normalized.map((o) => o.rangeValue);
426
+ const min = Math.min(...vals);
427
+ const max = Math.max(...vals);
428
+ const sorted = [...vals].sort((a, b) => a - b);
429
+ let minGap = Infinity;
430
+ for (let i = 1; i < sorted.length; i++) {
431
+ const d = sorted[i] - sorted[i - 1];
432
+ if (d > 0 && d < minGap) minGap = d;
433
+ }
434
+ return {
435
+ min: String(min),
436
+ max: String(max),
437
+ step: minGap === Infinity ? "1" : String(minGap),
438
+ inOptionsMode: true
439
+ };
440
+ }
441
+ return {
442
+ min: String(this.min),
443
+ max: String(this.max),
444
+ step: String(this.step),
445
+ inOptionsMode: false
446
+ };
447
+ }
448
+ _toRangeValue(value, normalized) {
449
+ if (value == null || value === "") return "";
450
+ if (normalized) {
451
+ const found = normalized.find((o) => o.value === value);
452
+ return found !== void 0 ? String(found.rangeValue) : "";
453
+ }
454
+ return value;
455
+ }
456
+ _fromRangeValue(rv, normalized) {
457
+ var _a2, _b;
458
+ if (normalized) {
459
+ const n = Number(rv);
460
+ return ((_a2 = normalized.find((o) => o.rangeValue === n)) == null ? void 0 : _a2.value) ?? ((_b = normalized[0]) == null ? void 0 : _b.value) ?? rv;
461
+ }
462
+ return rv;
463
+ }
464
+ _displayLabel(value, normalized) {
465
+ var _a2;
466
+ if (value == null || value === "") return "";
467
+ const label = normalized ? ((_a2 = normalized.find((o) => o.value === value)) == null ? void 0 : _a2.label) ?? value : value;
468
+ return this.percentage ? `${label}%` : label;
469
+ }
470
+ _maxValueLabelWidth(normalized, attrs) {
471
+ const candidates = normalized ? normalized.map((o) => this._displayLabel(o.value, normalized)) : [this._displayLabel(attrs.min, null), this._displayLabel(attrs.max, null)];
472
+ const maxLen = Math.max(...candidates.map((l) => l.length), 1);
473
+ return `${maxLen}ch`;
474
+ }
475
+ _updateTrackFill() {
476
+ if (!this.tracked || !this.fieldElement) return;
477
+ const min = Number(this.fieldElement.min);
478
+ const max = Number(this.fieldElement.max);
479
+ const val = Number(this.fieldElement.value);
480
+ const range = max - min || 1;
481
+ const pct = Math.max(0, Math.min(100, (val - min) / range * 100));
482
+ this.style.setProperty("--fill-pct", `${pct}%`);
483
+ }
484
+ _getMarksData(normalized, attrs) {
485
+ const minVal = Number(attrs.min);
486
+ const maxVal = Number(attrs.max);
487
+ const range = maxVal - minVal || 1;
488
+ const marks = this.marks;
489
+ if (Array.isArray(marks)) {
490
+ const result = [];
491
+ for (const m of marks) {
492
+ const isObj = m !== null && typeof m === "object";
493
+ const numVal = isObj ? m.value : m;
494
+ if (numVal < minVal || numVal > maxVal) continue;
495
+ const rawLabel = isObj ? m.label ?? String(numVal) : String(numVal);
496
+ result.push({
497
+ value: String(numVal),
498
+ label: this.percentage ? `${rawLabel}%` : rawLabel,
499
+ pct: (numVal - minVal) / range * 100
500
+ });
501
+ }
502
+ return result;
503
+ }
504
+ if (normalized) {
505
+ return normalized.map((o) => ({
506
+ value: o.value,
507
+ label: this.percentage ? `${o.label}%` : o.label,
508
+ pct: (o.rangeValue - minVal) / range * 100
509
+ }));
510
+ }
511
+ return [
512
+ { value: attrs.min, label: this.percentage ? `${minVal}%` : String(minVal), pct: 0 },
513
+ { value: attrs.max, label: this.percentage ? `${maxVal}%` : String(maxVal), pct: 100 }
514
+ ];
515
+ }
516
+ writeValue(value) {
517
+ const normalized = this._normalizeOptions();
518
+ const rv = this._toRangeValue(value, normalized);
519
+ if (this.fieldElement && rv !== "" && this.fieldElement.value !== rv) {
520
+ this.fieldElement.value = rv;
521
+ }
522
+ if (this._valueLabel) {
523
+ this._valueLabel.textContent = this._displayLabel(value, normalized);
524
+ }
525
+ if (this._numberInput && !normalized && this._numberInput.value !== rv) {
526
+ this._numberInput.value = rv;
527
+ }
528
+ this._updateTrackFill();
529
+ }
530
+ getValue() {
531
+ if (!this.fieldElement) return "";
532
+ return this._fromRangeValue(this.fieldElement.value, this._normalizeOptions());
533
+ }
534
+ render() {
535
+ const normalized = this._normalizeOptions();
536
+ const attrs = this._getRangeAttrs(normalized);
537
+ return html(({ div, input, span }) => {
538
+ div({ className: "range-container" }, () => {
539
+ div({ key: "range-wrapper", className: "range-wrapper" }, () => {
540
+ this.fieldElement = input({
541
+ key: "range",
542
+ type: "range",
543
+ min: attrs.min,
544
+ max: attrs.max,
545
+ step: attrs.step,
546
+ "@input": this._boundOnRangeInput,
547
+ "@change": this.boundOnChange
548
+ });
549
+ if (this.marks) {
550
+ const marksData = this._getMarksData(normalized, attrs);
551
+ div({ key: "marks", className: "marks-container" }, () => {
552
+ for (const m of marksData) {
553
+ tags.span(
554
+ {
555
+ key: `mark-${m.value}`,
556
+ className: "mark",
557
+ style: { left: `${m.pct}%` }
558
+ },
559
+ () => {
560
+ tags.span({ className: "mark-label", textContent: m.label });
561
+ }
562
+ );
563
+ }
564
+ });
565
+ }
566
+ });
567
+ this._valueLabel = span({
568
+ key: "label",
569
+ className: "value-label",
570
+ style: { minWidth: this._maxValueLabelWidth(normalized, attrs) },
571
+ textContent: this._displayLabel(this.value, normalized)
572
+ });
573
+ this.renderActionButtons();
574
+ if (this.editable) {
575
+ this._numberInput = input({
576
+ key: "number",
577
+ type: "number",
578
+ className: "value-input",
579
+ min: attrs.min,
580
+ max: attrs.max,
581
+ step: attrs.step,
582
+ // Disabled in options mode: valid values are discrete, free text makes no sense
583
+ disabled: attrs.inOptionsMode,
584
+ "@input": this._boundOnNumberInput
585
+ });
586
+ } else {
587
+ this._numberInput = null;
588
+ }
589
+ });
590
+ if (this.value != null) this.writeValue(this.value);
591
+ });
592
+ }
593
+ _onRangeInput() {
594
+ if (!this.fieldElement) return;
595
+ const normalized = this._normalizeOptions();
596
+ const actualValue = this._fromRangeValue(this.fieldElement.value, normalized);
597
+ if (this._valueLabel) {
598
+ this._valueLabel.textContent = this._displayLabel(actualValue, normalized);
599
+ }
600
+ if (this._numberInput && !normalized) {
601
+ this._numberInput.value = this.fieldElement.value;
602
+ }
603
+ this._updateTrackFill();
604
+ }
605
+ _onNumberInput() {
606
+ if (!this._numberInput || !this.fieldElement) return;
607
+ const v = this._numberInput.value;
608
+ if (this.fieldElement.value === v) return;
609
+ this.fieldElement.value = v;
610
+ if (this._valueLabel) {
611
+ this._valueLabel.textContent = this._displayLabel(v, null);
612
+ }
613
+ }
614
+ clear(options) {
615
+ var _a2, _b;
616
+ const normalized = this._normalizeOptions();
617
+ const attrs = this._getRangeAttrs(normalized);
618
+ const clearTo = normalized ? ((_a2 = normalized.find((o) => String(o.rangeValue) === attrs.min)) == null ? void 0 : _a2.value) ?? ((_b = normalized[0]) == null ? void 0 : _b.value) ?? attrs.min : attrs.min;
619
+ this.setValue(clearTo, { ...options, action: "clear" });
620
+ }
621
+ _isSliderOption(opt) {
622
+ return opt !== null && typeof opt === "object" && "label" in opt && "value" in opt;
623
+ }
624
+ }
625
+ _init = __decoratorStart(_a);
626
+ _options = /* @__PURE__ */ new WeakMap();
627
+ _percentage = /* @__PURE__ */ new WeakMap();
628
+ _min = /* @__PURE__ */ new WeakMap();
629
+ _max = /* @__PURE__ */ new WeakMap();
630
+ _step = /* @__PURE__ */ new WeakMap();
631
+ _editable = /* @__PURE__ */ new WeakMap();
632
+ _tracked = /* @__PURE__ */ new WeakMap();
633
+ _marks = /* @__PURE__ */ new WeakMap();
634
+ __decorateElement(_init, 4, "options", _options_dec, Slider, _options);
635
+ __decorateElement(_init, 4, "percentage", _percentage_dec, Slider, _percentage);
636
+ __decorateElement(_init, 4, "min", _min_dec, Slider, _min);
637
+ __decorateElement(_init, 4, "max", _max_dec, Slider, _max);
638
+ __decorateElement(_init, 4, "step", _step_dec, Slider, _step);
639
+ __decorateElement(_init, 4, "editable", _editable_dec, Slider, _editable);
640
+ __decorateElement(_init, 4, "tracked", _tracked_dec, Slider, _tracked);
641
+ __decorateElement(_init, 4, "marks", _marks_dec, Slider, _marks);
642
+ __decoratorMetadata(_init, Slider);
643
+ __publicField(Slider, "tagName", "slider");
644
+ __publicField(Slider, "styles", [styleVariables, sizeCSS, colorCSS, style]);
645
+ Slider.register();
646
+ export {
647
+ Slider as S
648
+ };
649
+ //# sourceMappingURL=slider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"slider.js","sources":["../../src/slider/slider.ts"],"sourcesContent":["import AeicoField from '../aeico-field';\nimport type { InferProps } from 'aeico';\nimport { html, tags } from 'aeico';\nimport type { NormalizedOption, SliderMarks, SliderOption, SliderOptions } from './defines';\nimport style from '../styles/components/slider.css?inline';\nimport variables from '../styles/variables.css?inline';\nimport sizeCSS from '../styles/size.css?inline';\nimport colorCSS from '../styles/color.css?inline';\nimport { prop } from 'aeico';\n\nclass Slider extends AeicoField {\n protected fieldElement: HTMLInputElement | null = null;\n private _valueLabel: HTMLSpanElement | null = null;\n private _numberInput: HTMLInputElement | null = null;\n\n private _boundOnRangeInput: () => void;\n private _boundOnNumberInput: () => void;\n\n static tagName = 'slider';\n\n @prop({ type: Array })\n accessor options: SliderOptions = [];\n\n @prop({ type: Boolean })\n accessor percentage = false;\n\n @prop({ type: Number })\n accessor min = 0;\n\n @prop({ type: Number })\n accessor max = 100;\n\n @prop({ type: Number })\n accessor step = 1;\n\n @prop({ type: Boolean })\n accessor editable = false;\n\n @prop({ type: Boolean })\n accessor tracked = false;\n\n @prop({\n type: Array,\n // bare attribute (<ae-slider marks>) → true; JSON array → MarkItem[]\n parser: (value: string | null) => {\n if (value === null) return undefined;\n if (value === '' || value === 'true') return true;\n if (value === 'false') return false;\n try {\n return JSON.parse(value);\n } catch {\n return true;\n }\n },\n })\n accessor marks: SliderMarks | undefined;\n\n protected static styles = [variables, sizeCSS, colorCSS, style];\n\n constructor() {\n super();\n this._boundOnRangeInput = this._onRangeInput.bind(this);\n this._boundOnNumberInput = this._onNumberInput.bind(this);\n }\n\n private _normalizeOptions(): NormalizedOption[] | null {\n if (!Array.isArray(this.options) || this.options.length === 0) return null;\n\n const opts = this.options.map((opt) =>\n this._isSliderOption(opt)\n ? { label: opt.label, value: String(opt.value) }\n : { label: String(opt), value: String(opt) },\n );\n\n // Sort by numeric value if all values are numeric; otherwise keep original order\n const allNumeric = opts.every((o) => o.value !== '' && !isNaN(Number(o.value)));\n\n if (allNumeric) {\n return [...opts]\n .sort((a, b) => Number(a.value) - Number(b.value))\n .map((o) => ({ ...o, rangeValue: Number(o.value) }));\n } else {\n return opts.map((o, i) => ({ ...o, rangeValue: i }));\n }\n }\n\n private _getRangeAttrs(normalized: NormalizedOption[] | null): {\n min: string;\n max: string;\n step: string;\n inOptionsMode: boolean;\n } {\n if (normalized && normalized.length >= 1) {\n const vals = normalized.map((o) => o.rangeValue);\n const min = Math.min(...vals);\n const max = Math.max(...vals);\n\n // Compute step from minimum gap between adjacent sorted values\n const sorted = [...vals].sort((a, b) => a - b);\n let minGap = Infinity;\n for (let i = 1; i < sorted.length; i++) {\n const d = sorted[i] - sorted[i - 1];\n if (d > 0 && d < minGap) minGap = d;\n }\n\n return {\n min: String(min),\n max: String(max),\n step: minGap === Infinity ? '1' : String(minGap),\n inOptionsMode: true,\n };\n }\n\n return {\n min: String(this.min),\n max: String(this.max),\n step: String(this.step),\n inOptionsMode: false,\n };\n }\n\n private _toRangeValue(value: string | undefined, normalized: NormalizedOption[] | null): string {\n if (value == null || value === '') return '';\n if (normalized) {\n const found = normalized.find((o) => o.value === value);\n\n return found !== undefined ? String(found.rangeValue) : '';\n }\n\n return value;\n }\n\n private _fromRangeValue(rv: string, normalized: NormalizedOption[] | null): string {\n if (normalized) {\n const n = Number(rv);\n\n return normalized.find((o) => o.rangeValue === n)?.value ?? normalized[0]?.value ?? rv;\n }\n return rv;\n }\n\n private _displayLabel(value: string | undefined, normalized: NormalizedOption[] | null): string {\n if (value == null || value === '') return '';\n const label = normalized ? (normalized.find((o) => o.value === value)?.label ?? value) : value;\n\n return this.percentage ? `${label}%` : label;\n }\n\n private _maxValueLabelWidth(\n normalized: NormalizedOption[] | null,\n attrs: { min: string; max: string },\n ): string {\n const candidates = normalized\n ? normalized.map((o) => this._displayLabel(o.value, normalized))\n : [this._displayLabel(attrs.min, null), this._displayLabel(attrs.max, null)];\n const maxLen = Math.max(...candidates.map((l) => l.length), 1);\n\n return `${maxLen}ch`;\n }\n\n private _updateTrackFill(): void {\n if (!this.tracked || !this.fieldElement) return;\n const min = Number(this.fieldElement.min);\n const max = Number(this.fieldElement.max);\n const val = Number(this.fieldElement.value);\n const range = max - min || 1;\n const pct = Math.max(0, Math.min(100, ((val - min) / range) * 100));\n this.style.setProperty('--fill-pct', `${pct}%`);\n }\n\n private _getMarksData(\n normalized: NormalizedOption[] | null,\n attrs: { min: string; max: string; inOptionsMode: boolean },\n ): Array<{ value: string; label: string; pct: number }> {\n const minVal = Number(attrs.min);\n const maxVal = Number(attrs.max);\n const range = maxVal - minVal || 1;\n\n const marks = this.marks;\n\n // Custom marks array — purely visual, no snapping effect\n if (Array.isArray(marks)) {\n const result: Array<{ value: string; label: string; pct: number }> = [];\n for (const m of marks) {\n const isObj = m !== null && typeof m === 'object';\n const numVal = isObj ? (m as { value: number }).value : m;\n if (numVal < minVal || numVal > maxVal) continue;\n const rawLabel = isObj ? (m.label ?? String(numVal)) : String(numVal);\n result.push({\n value: String(numVal),\n label: this.percentage ? `${rawLabel}%` : rawLabel,\n pct: ((numVal - minVal) / range) * 100,\n });\n }\n\n return result;\n }\n\n // marks === true — auto-generate from options or free-mode endpoints\n if (normalized) {\n return normalized.map((o) => ({\n value: o.value,\n label: this.percentage ? `${o.label}%` : o.label,\n pct: ((o.rangeValue - minVal) / range) * 100,\n }));\n }\n\n // Free mode — show min and max endpoints only\n return [\n { value: attrs.min, label: this.percentage ? `${minVal}%` : String(minVal), pct: 0 },\n { value: attrs.max, label: this.percentage ? `${maxVal}%` : String(maxVal), pct: 100 },\n ];\n }\n\n protected writeValue(value: string): void {\n const normalized = this._normalizeOptions();\n const rv = this._toRangeValue(value, normalized);\n\n if (this.fieldElement && rv !== '' && this.fieldElement.value !== rv) {\n this.fieldElement.value = rv;\n }\n\n if (this._valueLabel) {\n this._valueLabel.textContent = this._displayLabel(value, normalized);\n }\n\n // Sync number input only in free mode (options mode disables it)\n if (this._numberInput && !normalized && this._numberInput.value !== rv) {\n this._numberInput.value = rv;\n }\n\n this._updateTrackFill();\n }\n\n protected getValue(): string {\n if (!this.fieldElement) return '';\n\n return this._fromRangeValue(this.fieldElement.value, this._normalizeOptions());\n }\n\n render() {\n const normalized = this._normalizeOptions();\n const attrs = this._getRangeAttrs(normalized);\n\n return html(({ div, input, span }) => {\n div({ className: 'range-container' }, () => {\n // Wrap range + optional marks in a column so marks don't push siblings\n div({ key: 'range-wrapper', className: 'range-wrapper' }, () => {\n this.fieldElement = input({\n key: 'range',\n type: 'range',\n min: attrs.min,\n max: attrs.max,\n step: attrs.step,\n '@input': this._boundOnRangeInput,\n '@change': this.boundOnChange,\n });\n\n if (this.marks) {\n const marksData = this._getMarksData(normalized, attrs);\n div({ key: 'marks', className: 'marks-container' }, () => {\n for (const m of marksData) {\n tags.span(\n {\n key: `mark-${m.value}`,\n className: 'mark',\n style: { left: `${m.pct}%` },\n },\n () => {\n tags.span({ className: 'mark-label', textContent: m.label });\n },\n );\n }\n });\n }\n });\n\n this._valueLabel = span({\n key: 'label',\n className: 'value-label',\n style: { minWidth: this._maxValueLabelWidth(normalized, attrs) },\n textContent: this._displayLabel(this.value, normalized),\n });\n\n // Action buttons first so the number input can be toggled without disrupting button reuse\n this.renderActionButtons();\n\n if (this.editable) {\n this._numberInput = input({\n key: 'number',\n type: 'number',\n className: 'value-input',\n min: attrs.min,\n max: attrs.max,\n step: attrs.step,\n // Disabled in options mode: valid values are discrete, free text makes no sense\n disabled: attrs.inOptionsMode,\n '@input': this._boundOnNumberInput,\n });\n } else {\n this._numberInput = null;\n }\n });\n\n if (this.value != null) this.writeValue(this.value);\n });\n }\n\n private _onRangeInput(): void {\n if (!this.fieldElement) return;\n\n const normalized = this._normalizeOptions();\n const actualValue = this._fromRangeValue(this.fieldElement.value, normalized);\n\n if (this._valueLabel) {\n this._valueLabel.textContent = this._displayLabel(actualValue, normalized);\n }\n // Keep number input in sync during drag\n if (this._numberInput && !normalized) {\n this._numberInput.value = this.fieldElement.value;\n }\n\n this._updateTrackFill();\n }\n\n private _onNumberInput(): void {\n if (!this._numberInput || !this.fieldElement) return;\n const v = this._numberInput.value;\n\n if (this.fieldElement.value === v) return;\n\n this.fieldElement.value = v;\n if (this._valueLabel) {\n this._valueLabel.textContent = this._displayLabel(v, null);\n }\n }\n\n public clear(options?: { silent?: boolean }): void {\n const normalized = this._normalizeOptions();\n const attrs = this._getRangeAttrs(normalized);\n // Reset to the option whose rangeValue === min, or to attrs.min in free mode\n const clearTo = normalized\n ? (normalized.find((o) => String(o.rangeValue) === attrs.min)?.value ??\n normalized[0]?.value ??\n attrs.min)\n : attrs.min;\n this.setValue(clearTo, { ...options, action: 'clear' });\n }\n\n private _isSliderOption(opt: unknown): opt is SliderOption {\n return opt !== null && typeof opt === 'object' && 'label' in opt && 'value' in opt;\n }\n}\n\nSlider.register();\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ae-slider': Slider;\n }\n}\n\nexport default Slider;\nexport type SliderProps = InferProps<typeof Slider>;\n"],"names":["_a","variables"],"mappings":"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"}