slexkit 0.2.0

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 (221) hide show
  1. package/AGENTS.slexkit.md +29 -0
  2. package/CHANGELOG.md +90 -0
  3. package/LICENSE +21 -0
  4. package/README.md +165 -0
  5. package/README.zh-CN.md +165 -0
  6. package/dist/ai/llms-authoring.txt +44 -0
  7. package/dist/ai/llms-components.txt +669 -0
  8. package/dist/ai/llms-full.txt +6586 -0
  9. package/dist/ai/llms-runtime.txt +1475 -0
  10. package/dist/ai/llms-toolhost.txt +295 -0
  11. package/dist/ai/llms.txt +69 -0
  12. package/dist/ai/slexkit-ai-manifest.json +2922 -0
  13. package/dist/base.css +621 -0
  14. package/dist/chunks/accordion-5f0nvjjm.js +376 -0
  15. package/dist/chunks/accordion-830dw78f.js +221 -0
  16. package/dist/chunks/accordion-cfjyxw93.js +630 -0
  17. package/dist/chunks/accordion-cw5r75jm.js +424 -0
  18. package/dist/chunks/accordion-ehnhpeca.js +492 -0
  19. package/dist/chunks/accordion-hzyrngd6.js +2377 -0
  20. package/dist/chunks/accordion-nw12ytps.js +6823 -0
  21. package/dist/components/accordion.js +163 -0
  22. package/dist/components/badge.js +80 -0
  23. package/dist/components/button.css +114 -0
  24. package/dist/components/button.js +16 -0
  25. package/dist/components/callout.js +154 -0
  26. package/dist/components/card.js +95 -0
  27. package/dist/components/checkbox.js +114 -0
  28. package/dist/components/choice.css +165 -0
  29. package/dist/components/code-block.js +264 -0
  30. package/dist/components/collapsible.js +111 -0
  31. package/dist/components/column.js +49 -0
  32. package/dist/components/content.css +474 -0
  33. package/dist/components/disclosure.css +162 -0
  34. package/dist/components/display.css +259 -0
  35. package/dist/components/divider.js +98 -0
  36. package/dist/components/feedback.css +219 -0
  37. package/dist/components/grid.js +67 -0
  38. package/dist/components/index.js +13364 -0
  39. package/dist/components/input.css +1247 -0
  40. package/dist/components/input.js +384 -0
  41. package/dist/components/link.js +77 -0
  42. package/dist/components/progress.js +111 -0
  43. package/dist/components/radio-group.js +189 -0
  44. package/dist/components/row.js +200 -0
  45. package/dist/components/section.js +161 -0
  46. package/dist/components/select.css +260 -0
  47. package/dist/components/select.js +16 -0
  48. package/dist/components/slider.css +125 -0
  49. package/dist/components/slider.js +175 -0
  50. package/dist/components/specs.js +1090 -0
  51. package/dist/components/stat.js +178 -0
  52. package/dist/components/submit.css +9 -0
  53. package/dist/components/submit.js +77 -0
  54. package/dist/components/switch.css +114 -0
  55. package/dist/components/switch.js +114 -0
  56. package/dist/components/table.js +157 -0
  57. package/dist/components/tabs.css +192 -0
  58. package/dist/components/tabs.js +17 -0
  59. package/dist/components/text-input.css +245 -0
  60. package/dist/components/text.js +50 -0
  61. package/dist/components/toast.js +240 -0
  62. package/dist/components/tooling.css +1009 -0
  63. package/dist/components/tooling.js +48951 -0
  64. package/dist/runtime.cjs +3728 -0
  65. package/dist/runtime.js +3686 -0
  66. package/dist/slexkit.cjs +18539 -0
  67. package/dist/slexkit.css +4776 -0
  68. package/dist/slexkit.js +18497 -0
  69. package/dist/tooling.js +59141 -0
  70. package/dist/types/components/accordion.d.ts +2 -0
  71. package/dist/types/components/badge.d.ts +2 -0
  72. package/dist/types/components/button.d.ts +2 -0
  73. package/dist/types/components/callout.d.ts +2 -0
  74. package/dist/types/components/card.d.ts +2 -0
  75. package/dist/types/components/checkbox.d.ts +2 -0
  76. package/dist/types/components/code-block.d.ts +2 -0
  77. package/dist/types/components/collapsible.d.ts +2 -0
  78. package/dist/types/components/column.d.ts +2 -0
  79. package/dist/types/components/divider.d.ts +2 -0
  80. package/dist/types/components/entries/accordion.d.ts +3 -0
  81. package/dist/types/components/entries/badge.d.ts +3 -0
  82. package/dist/types/components/entries/button.d.ts +3 -0
  83. package/dist/types/components/entries/callout.d.ts +3 -0
  84. package/dist/types/components/entries/card.d.ts +3 -0
  85. package/dist/types/components/entries/checkbox.d.ts +3 -0
  86. package/dist/types/components/entries/code-block.d.ts +3 -0
  87. package/dist/types/components/entries/collapsible.d.ts +3 -0
  88. package/dist/types/components/entries/column.d.ts +3 -0
  89. package/dist/types/components/entries/divider.d.ts +3 -0
  90. package/dist/types/components/entries/grid.d.ts +3 -0
  91. package/dist/types/components/entries/input.d.ts +3 -0
  92. package/dist/types/components/entries/link.d.ts +3 -0
  93. package/dist/types/components/entries/progress.d.ts +3 -0
  94. package/dist/types/components/entries/radio-group.d.ts +3 -0
  95. package/dist/types/components/entries/row.d.ts +3 -0
  96. package/dist/types/components/entries/section.d.ts +3 -0
  97. package/dist/types/components/entries/select.d.ts +3 -0
  98. package/dist/types/components/entries/slider.d.ts +3 -0
  99. package/dist/types/components/entries/specs.d.ts +1 -0
  100. package/dist/types/components/entries/stat.d.ts +3 -0
  101. package/dist/types/components/entries/submit.d.ts +3 -0
  102. package/dist/types/components/entries/switch.d.ts +3 -0
  103. package/dist/types/components/entries/table.d.ts +3 -0
  104. package/dist/types/components/entries/tabs.d.ts +3 -0
  105. package/dist/types/components/entries/text.d.ts +3 -0
  106. package/dist/types/components/entries/toast.d.ts +3 -0
  107. package/dist/types/components/entries/tooling.d.ts +1 -0
  108. package/dist/types/components/grid.d.ts +2 -0
  109. package/dist/types/components/index.d.ts +6 -0
  110. package/dist/types/components/input.d.ts +2 -0
  111. package/dist/types/components/link.d.ts +2 -0
  112. package/dist/types/components/progress.d.ts +2 -0
  113. package/dist/types/components/radio-group.d.ts +2 -0
  114. package/dist/types/components/row.d.ts +2 -0
  115. package/dist/types/components/section.d.ts +2 -0
  116. package/dist/types/components/select.d.ts +2 -0
  117. package/dist/types/components/slider.d.ts +2 -0
  118. package/dist/types/components/spec-helpers.d.ts +23 -0
  119. package/dist/types/components/spec-registry.d.ts +12 -0
  120. package/dist/types/components/spec-schema.d.ts +74 -0
  121. package/dist/types/components/specs.d.ts +2 -0
  122. package/dist/types/components/stat.d.ts +2 -0
  123. package/dist/types/components/submit.d.ts +2 -0
  124. package/dist/types/components/svelte/adapter.d.ts +3 -0
  125. package/dist/types/components/svelte/bindProps.d.ts +2 -0
  126. package/dist/types/components/svelte/helpers.d.ts +33 -0
  127. package/dist/types/components/svelte/layout/balancedTiles.d.ts +14 -0
  128. package/dist/types/components/svelte/types.d.ts +12 -0
  129. package/dist/types/components/switch.d.ts +2 -0
  130. package/dist/types/components/table.d.ts +2 -0
  131. package/dist/types/components/tabs.d.ts +2 -0
  132. package/dist/types/components/text.d.ts +2 -0
  133. package/dist/types/components/toast.d.ts +2 -0
  134. package/dist/types/components/tooling.d.ts +2 -0
  135. package/dist/types/components-svelte.d.ts +5 -0
  136. package/dist/types/engine/component-scope.d.ts +14 -0
  137. package/dist/types/engine/component-state.d.ts +9 -0
  138. package/dist/types/engine/diagnostics.d.ts +24 -0
  139. package/dist/types/engine/engineering.d.ts +11 -0
  140. package/dist/types/engine/eval.d.ts +5 -0
  141. package/dist/types/engine/index.d.ts +26 -0
  142. package/dist/types/engine/markdown-runtime.d.ts +33 -0
  143. package/dist/types/engine/merge.d.ts +1 -0
  144. package/dist/types/engine/reactive.d.ts +11 -0
  145. package/dist/types/engine/registry.d.ts +4 -0
  146. package/dist/types/engine/renderer.d.ts +6 -0
  147. package/dist/types/engine/sandbox-runner.d.ts +2 -0
  148. package/dist/types/engine/secure-runtime.d.ts +214 -0
  149. package/dist/types/engine/store.d.ts +12 -0
  150. package/dist/types/engine/types.d.ts +58 -0
  151. package/dist/types/icons/manager.d.ts +17 -0
  152. package/dist/types/icons/phosphor.d.ts +45 -0
  153. package/dist/types/index.d.ts +61 -0
  154. package/dist/types/runtime.d.ts +32 -0
  155. package/dist/types/toolhost/index.d.ts +78 -0
  156. package/dist/types/tooling-umd.d.ts +47 -0
  157. package/dist/types/version.d.ts +8 -0
  158. package/dist/umd/slexkit.tooling.umd.js +66553 -0
  159. package/dist/umd/slexkit.umd.js +18552 -0
  160. package/package.json +136 -0
  161. package/scripts/cli.mjs +47 -0
  162. package/skills/slexkit/SKILL.md +27 -0
  163. package/skills/slexkit-author/SKILL.md +50 -0
  164. package/skills/slexkit-host-integration/SKILL.md +33 -0
  165. package/skills/slexkit-secure-runtime/SKILL.md +31 -0
  166. package/skills/slexkit-toolhost/SKILL.md +38 -0
  167. package/skills/slexkit-update/SKILL.md +23 -0
  168. package/src/components/svelte/InlineIcon.svelte +66 -0
  169. package/src/components/svelte/adapter.ts +76 -0
  170. package/src/components/svelte/bindProps.ts +9 -0
  171. package/src/components/svelte/content/Badge.svelte +19 -0
  172. package/src/components/svelte/content/Callout.svelte +57 -0
  173. package/src/components/svelte/content/CodeBlock.svelte +130 -0
  174. package/src/components/svelte/content/Divider.svelte +21 -0
  175. package/src/components/svelte/content/Link.svelte +21 -0
  176. package/src/components/svelte/content/Section.svelte +24 -0
  177. package/src/components/svelte/content/Table.svelte +44 -0
  178. package/src/components/svelte/disclosure/Accordion.svelte +100 -0
  179. package/src/components/svelte/disclosure/Collapsible.svelte +45 -0
  180. package/src/components/svelte/display/Stat.svelte +102 -0
  181. package/src/components/svelte/display/Text.svelte +11 -0
  182. package/src/components/svelte/feedback/Progress.svelte +34 -0
  183. package/src/components/svelte/feedback/Toast.svelte +105 -0
  184. package/src/components/svelte/helpers.ts +148 -0
  185. package/src/components/svelte/input/Button.svelte +78 -0
  186. package/src/components/svelte/input/Checkbox.svelte +52 -0
  187. package/src/components/svelte/input/Input.svelte +202 -0
  188. package/src/components/svelte/input/RadioGroup.svelte +71 -0
  189. package/src/components/svelte/input/Select.svelte +220 -0
  190. package/src/components/svelte/input/Slider.svelte +96 -0
  191. package/src/components/svelte/input/Submit.svelte +32 -0
  192. package/src/components/svelte/input/Switch.svelte +53 -0
  193. package/src/components/svelte/input/Tabs.svelte +188 -0
  194. package/src/components/svelte/layout/Card.svelte +17 -0
  195. package/src/components/svelte/layout/Column.svelte +15 -0
  196. package/src/components/svelte/layout/Grid.svelte +26 -0
  197. package/src/components/svelte/layout/Row.svelte +105 -0
  198. package/src/components/svelte/layout/balancedTiles.ts +85 -0
  199. package/src/components/svelte/tooling/CodeMirror.svelte +91 -0
  200. package/src/components/svelte/tooling/Playground.svelte +765 -0
  201. package/src/components/svelte/tooling/PlaygroundMarkdown.svelte +26 -0
  202. package/src/components/svelte/tooling/PlaygroundSlexCode.svelte +76 -0
  203. package/src/components/svelte/types.ts +17 -0
  204. package/src/styles/animation.css +98 -0
  205. package/src/styles/components/button.css +114 -0
  206. package/src/styles/components/choice.css +165 -0
  207. package/src/styles/components/select.css +260 -0
  208. package/src/styles/components/slider.css +125 -0
  209. package/src/styles/components/submit.css +9 -0
  210. package/src/styles/components/switch.css +114 -0
  211. package/src/styles/components/tabs.css +192 -0
  212. package/src/styles/components/text-input.css +245 -0
  213. package/src/styles/content.css +474 -0
  214. package/src/styles/disclosure.css +162 -0
  215. package/src/styles/display.css +259 -0
  216. package/src/styles/entry.css +34 -0
  217. package/src/styles/feedback.css +219 -0
  218. package/src/styles/input.css +8 -0
  219. package/src/styles/layout.css +365 -0
  220. package/src/styles/theme.css +31 -0
  221. package/src/styles/tooling.css +1009 -0
@@ -0,0 +1,260 @@
1
+ .slex-select {
2
+ position: relative;
3
+ display: flex;
4
+ width: 100%;
5
+ min-width: 0;
6
+ flex-direction: column;
7
+ gap: 0.5rem;
8
+ }
9
+
10
+ .slex-select-label {
11
+ display: inline-flex;
12
+ align-items: center;
13
+ gap: 0.375rem;
14
+ min-width: 0;
15
+ color: var(--foreground);
16
+ font-size: 0.875rem;
17
+ font-weight: 500;
18
+ line-height: 1;
19
+ }
20
+
21
+ .slex-select-control {
22
+ width: 100%;
23
+ min-width: 0;
24
+ }
25
+
26
+ .slex-select .slex-select-trigger {
27
+ box-sizing: border-box;
28
+ display: flex;
29
+ align-items: center;
30
+ justify-content: space-between;
31
+ gap: 0.75rem;
32
+ width: 100%;
33
+ min-width: 0;
34
+ min-height: 2.5rem;
35
+ margin: 0;
36
+ padding: 0.5rem 1rem;
37
+ border: 1px solid var(--input);
38
+ border-radius: var(--radius);
39
+ background: var(--background);
40
+ color: var(--foreground);
41
+ font: inherit;
42
+ font-size: 0.875rem;
43
+ line-height: 1.25rem;
44
+ outline: none;
45
+ box-shadow: 0 1px 2px color-mix(in oklab, var(--foreground) 8%, transparent);
46
+ cursor: pointer;
47
+ transition:
48
+ border-color 150ms ease,
49
+ background-color 150ms ease,
50
+ box-shadow 150ms ease,
51
+ color 150ms ease;
52
+ appearance: none;
53
+ text-align: left;
54
+ }
55
+
56
+ .slex-select .slex-select-trigger:hover:not(:disabled) {
57
+ background: color-mix(in oklab, var(--accent) 34%, var(--background));
58
+ }
59
+
60
+ .slex-select .slex-select-trigger:focus-visible {
61
+ border-color: var(--ring);
62
+ box-shadow: 0 0 0 2px color-mix(in oklab, var(--ring) 20%, transparent);
63
+ }
64
+
65
+ .slex-select .slex-select-trigger:disabled {
66
+ cursor: not-allowed;
67
+ opacity: 0.5;
68
+ }
69
+
70
+ .slex-select-value {
71
+ display: inline-flex;
72
+ align-items: center;
73
+ gap: 0.375rem;
74
+ min-width: 0;
75
+ overflow: hidden;
76
+ text-overflow: ellipsis;
77
+ white-space: nowrap;
78
+ }
79
+
80
+ .slex-select-value[data-placeholder] {
81
+ color: var(--muted-foreground);
82
+ }
83
+
84
+ .slex-select-icon {
85
+ position: relative;
86
+ flex: 0 0 auto;
87
+ width: 0.75rem;
88
+ height: 0.75rem;
89
+ opacity: 0.72;
90
+ }
91
+
92
+ .slex-select-icon::before {
93
+ position: absolute;
94
+ top: 0.2rem;
95
+ left: 0.125rem;
96
+ width: 0.45rem;
97
+ height: 0.45rem;
98
+ border-right: 1.5px solid currentColor;
99
+ border-bottom: 1.5px solid currentColor;
100
+ content: "";
101
+ transform: rotate(45deg);
102
+ }
103
+
104
+ .slex-select-native {
105
+ position: absolute;
106
+ width: 1px;
107
+ height: 1px;
108
+ margin: -1px;
109
+ padding: 0;
110
+ border: 0;
111
+ overflow: hidden;
112
+ clip: rect(0 0 0 0);
113
+ clip-path: inset(50%);
114
+ white-space: nowrap;
115
+ }
116
+
117
+ .slex-select-menu {
118
+ position: absolute;
119
+ z-index: 40;
120
+ top: calc(100% + 0.375rem);
121
+ left: 0;
122
+ right: 0;
123
+ width: 100%;
124
+ max-height: 14rem;
125
+ margin: 0;
126
+ padding: 0.25rem;
127
+ overflow-y: auto;
128
+ border: 1px solid color-mix(in oklab, var(--border) 82%, transparent);
129
+ border-radius: var(--radius);
130
+ background: var(--popover, var(--background));
131
+ color: var(--popover-foreground, var(--foreground));
132
+ box-shadow: var(
133
+ --shadow-md,
134
+ 0 6px 16px rgb(0 0 0 / 0.12),
135
+ 0 2px 4px rgb(0 0 0 / 0.08)
136
+ );
137
+ list-style: none;
138
+ }
139
+
140
+ .slexkit-root .slex-select-menu {
141
+ margin: 0;
142
+ padding: 0.25rem;
143
+ list-style: none;
144
+ }
145
+
146
+ .slexkit-root .slex-select-menu li {
147
+ margin: 0;
148
+ list-style: none;
149
+ }
150
+
151
+ .slex-select-option {
152
+ display: flex;
153
+ align-items: center;
154
+ justify-content: space-between;
155
+ gap: 0.75rem;
156
+ min-height: 2rem;
157
+ padding: 0.5rem 0.75rem;
158
+ border-radius: calc(var(--radius) - 2px);
159
+ color: var(--popover-foreground, var(--foreground));
160
+ font-size: 0.875rem;
161
+ line-height: 1.25rem;
162
+ cursor: pointer;
163
+ user-select: none;
164
+ }
165
+
166
+ .slex-select-option:hover:not([data-disabled]),
167
+ .slex-select-option--active:not([data-disabled]) {
168
+ background: var(--accent);
169
+ color: var(--accent-foreground);
170
+ }
171
+
172
+ .slex-select-menu:has(.slex-select-option:hover) .slex-select-option--active:not(:hover) {
173
+ background: transparent;
174
+ color: var(--popover-foreground, var(--foreground));
175
+ }
176
+
177
+ .slex-select-option--selected {
178
+ font-weight: 500;
179
+ }
180
+
181
+ .slex-select-option[data-disabled] {
182
+ color: var(--muted-foreground);
183
+ cursor: not-allowed;
184
+ opacity: 0.52;
185
+ }
186
+
187
+ .slex-select-option-label {
188
+ display: inline-flex;
189
+ align-items: center;
190
+ gap: 0.375rem;
191
+ min-width: 0;
192
+ overflow: hidden;
193
+ text-overflow: ellipsis;
194
+ white-space: nowrap;
195
+ }
196
+
197
+ .slex-select-check {
198
+ position: relative;
199
+ flex: 0 0 auto;
200
+ width: 0.875rem;
201
+ height: 0.875rem;
202
+ color: currentColor;
203
+ }
204
+
205
+ .slex-select-check::before {
206
+ position: absolute;
207
+ top: 0.25rem;
208
+ left: 0.18rem;
209
+ width: 0.5rem;
210
+ height: 0.28rem;
211
+ border-left: 1.75px solid currentColor;
212
+ border-bottom: 1.75px solid currentColor;
213
+ content: "";
214
+ transform: rotate(-45deg);
215
+ }
216
+
217
+ .slex-select[data-variant="toolbar"] {
218
+ height: 100%;
219
+ gap: 0;
220
+ }
221
+
222
+ .slex-select[data-variant="toolbar"] .slex-select-trigger {
223
+ height: var(--slex-control-height, 2.25rem);
224
+ min-height: 0;
225
+ border-width: 0 1px 0 0;
226
+ border-color: color-mix(in oklab, var(--border) 58%, transparent);
227
+ border-radius: 0;
228
+ background: transparent;
229
+ padding: 0 0.75rem 0 0.875rem;
230
+ font-size: 0.8125rem;
231
+ line-height: 1;
232
+ box-shadow: none;
233
+ }
234
+
235
+ .slex-select[data-variant="toolbar"] .slex-select-trigger:hover:not(:disabled) {
236
+ background: color-mix(in oklab, var(--muted) 36%, var(--background));
237
+ }
238
+
239
+ .slex-select[data-variant="toolbar"] .slex-select-menu {
240
+ top: calc(100% + 0.25rem);
241
+ left: 0;
242
+ right: auto;
243
+ width: 100%;
244
+ min-width: 100%;
245
+ border-color: color-mix(in oklab, var(--border) 76%, transparent);
246
+ border-radius: calc(var(--radius) - 2px);
247
+ padding: 0.25rem;
248
+ box-shadow: var(
249
+ --shadow-sm,
250
+ 0 4px 10px rgb(0 0 0 / 0.1),
251
+ 0 1px 3px rgb(0 0 0 / 0.06)
252
+ );
253
+ }
254
+
255
+ .slex-select[data-variant="toolbar"] .slex-select-option {
256
+ height: 1.875rem;
257
+ border-radius: calc(var(--radius) - 4px);
258
+ font-size: 0.8125rem;
259
+ padding-inline: 0.75rem;
260
+ }
@@ -0,0 +1,16 @@
1
+ import {
2
+ Select
3
+ } from "../chunks/accordion-5f0nvjjm.js";
4
+ import"../chunks/accordion-cw5r75jm.js";
5
+ import {
6
+ createSvelteRenderer
7
+ } from "../chunks/accordion-nw12ytps.js";
8
+
9
+ // src/components/entries/select.ts
10
+ import { register } from "../runtime.js";
11
+ register("select", createSvelteRenderer("select", Select), { state: "value" });
12
+ var select_default = Select;
13
+ export {
14
+ select_default as default,
15
+ Select
16
+ };
@@ -0,0 +1,125 @@
1
+ .slex-slider-container,
2
+ .slex-slider-field {
3
+ display: flex;
4
+ flex-direction: column;
5
+ gap: 0.5rem;
6
+ width: 100%;
7
+ }
8
+
9
+ .slex-slider-field {
10
+ padding: 0.25rem 0;
11
+ }
12
+
13
+ .slex-slider-label {
14
+ display: flex;
15
+ align-items: center;
16
+ justify-content: space-between;
17
+ color: var(--muted-foreground);
18
+ font-size: 0.875rem;
19
+ font-weight: 500;
20
+ }
21
+
22
+ .slex-slider-value {
23
+ padding: 0.125rem 0.5rem;
24
+ border: 1px solid var(--border);
25
+ border-radius: calc(var(--radius) - 2px);
26
+ background: var(--secondary);
27
+ color: var(--secondary-foreground);
28
+ font-family: var(--font-mono, "Geist Mono", "Noto Sans Mono", "Noto Sans Mono CJK SC", "SFMono-Regular", "Cascadia Code", Consolas, monospace);
29
+ font-size: 0.875rem;
30
+ font-weight: 600;
31
+ }
32
+
33
+ .slex-slider {
34
+ box-sizing: border-box;
35
+ width: 100%;
36
+ height: 0.5rem;
37
+ border-radius: 999px;
38
+ -webkit-appearance: none;
39
+ appearance: none;
40
+ background: linear-gradient(
41
+ to right,
42
+ var(--primary) 0%,
43
+ var(--primary) var(--slex-slider-progress, 0%),
44
+ var(--secondary) var(--slex-slider-progress, 0%),
45
+ var(--secondary) 100%
46
+ );
47
+ accent-color: var(--primary);
48
+ cursor: pointer;
49
+ transition: box-shadow 150ms ease, filter 150ms ease;
50
+ }
51
+
52
+ .slex-slider:hover {
53
+ box-shadow: 0 0 0 4px color-mix(in oklab, var(--primary) 8%, transparent);
54
+ }
55
+
56
+ .slex-slider:active {
57
+ box-shadow: 0 0 0 5px color-mix(in oklab, var(--primary) 12%, transparent);
58
+ }
59
+
60
+ .slex-slider:focus-visible {
61
+ outline: 2px solid var(--ring);
62
+ outline-offset: 4px;
63
+ }
64
+
65
+ .slex-slider::-webkit-slider-thumb {
66
+ width: 1rem;
67
+ height: 1rem;
68
+ border: 2px solid var(--primary);
69
+ border-radius: 999px;
70
+ background: var(--background) !important;
71
+ box-shadow: 0 1px 2px color-mix(in oklab, var(--foreground) 14%, transparent);
72
+ -webkit-appearance: none;
73
+ appearance: none;
74
+ transition: border-color 150ms ease, background-color 150ms ease, box-shadow 150ms ease, transform 120ms ease;
75
+ }
76
+
77
+ .slex-slider::-moz-range-thumb {
78
+ width: 1rem;
79
+ height: 1rem;
80
+ border: 2px solid var(--primary);
81
+ border-radius: 999px;
82
+ background: var(--background) !important;
83
+ box-shadow: 0 1px 2px color-mix(in oklab, var(--foreground) 14%, transparent);
84
+ transition: border-color 150ms ease, background-color 150ms ease, box-shadow 150ms ease, transform 120ms ease;
85
+ }
86
+
87
+ .slex-slider:hover::-webkit-slider-thumb {
88
+ box-shadow: 0 0 0 5px color-mix(in oklab, var(--primary) 12%, transparent);
89
+ transform: scale(1.06);
90
+ }
91
+
92
+ .slex-slider:hover::-moz-range-thumb {
93
+ box-shadow: 0 0 0 5px color-mix(in oklab, var(--primary) 12%, transparent);
94
+ transform: scale(1.06);
95
+ }
96
+
97
+ .slex-slider:active::-webkit-slider-thumb {
98
+ box-shadow: 0 0 0 6px color-mix(in oklab, var(--primary) 16%, transparent);
99
+ transform: scale(1.12);
100
+ }
101
+
102
+ .slex-slider:active::-moz-range-thumb {
103
+ box-shadow: 0 0 0 6px color-mix(in oklab, var(--primary) 16%, transparent);
104
+ transform: scale(1.12);
105
+ }
106
+
107
+ .slex-slider::-moz-range-track {
108
+ height: 0.5rem;
109
+ border: 0;
110
+ border-radius: 999px;
111
+ background: var(--secondary);
112
+ }
113
+
114
+ .slex-slider::-moz-range-progress {
115
+ height: 0.5rem;
116
+ border-radius: 999px;
117
+ background: var(--primary);
118
+ }
119
+
120
+ .slex-slider-label-text {
121
+ display: inline-flex;
122
+ min-width: 0;
123
+ align-items: center;
124
+ gap: 0.375rem;
125
+ }
@@ -0,0 +1,175 @@
1
+ import {
2
+ InlineIcon
3
+ } from "../chunks/accordion-cw5r75jm.js";
4
+ import {
5
+ append,
6
+ bindPropStore,
7
+ child,
8
+ createSvelteRenderer,
9
+ delegate,
10
+ delegated,
11
+ emit,
12
+ from_html,
13
+ get,
14
+ if_block,
15
+ pop,
16
+ proxy,
17
+ push,
18
+ remove_input_defaults,
19
+ reset,
20
+ set,
21
+ set_attribute,
22
+ set_style,
23
+ set_text,
24
+ set_value,
25
+ sibling,
26
+ state,
27
+ template_effect,
28
+ text,
29
+ text1 as text2,
30
+ user_effect
31
+ } from "../chunks/accordion-nw12ytps.js";
32
+
33
+ // src/components/entries/slider.ts
34
+ import { register } from "../runtime.js";
35
+
36
+ // src/components/svelte/input/Slider.svelte
37
+ var root = from_html(`<div class="slex-slider-field"><div class="slex-slider-label"><span class="slex-slider-label-text"><!> <span> </span></span> <span class="slex-slider-value"> <!></span></div> <input type="range" class="slex-slider"/></div>`);
38
+ function Slider($$anchor, $$props) {
39
+ push($$props, true);
40
+ let p = state(proxy({}));
41
+ let value = state(0);
42
+ let lastHapticTick = state(null);
43
+ user_effect(() => bindPropStore($$props.props, (next) => {
44
+ set(p, next, true);
45
+ set(value, next.value ?? 0, true);
46
+ }));
47
+ function choose(next) {
48
+ set(value, next, true);
49
+ vibrateStep(next);
50
+ emit($$props.ctx, "change", next);
51
+ }
52
+ function numberProp(input, fallback) {
53
+ const next = Number(input ?? fallback);
54
+ return Number.isFinite(next) ? next : fallback;
55
+ }
56
+ function sliderProgress(current, min, max) {
57
+ const low = numberProp(min, 0);
58
+ const high = numberProp(max, 100);
59
+ const next = numberProp(current, low);
60
+ if (high <= low)
61
+ return "0%";
62
+ const ratio = Math.min(1, Math.max(0, (next - low) / (high - low)));
63
+ return `${Math.round(ratio * 1e4) / 100}%`;
64
+ }
65
+ function stepSize() {
66
+ const step = numberProp(get(p).step, 1);
67
+ return step > 0 ? step : 1;
68
+ }
69
+ function tickCount() {
70
+ const low = numberProp(get(p).min, 0);
71
+ const high = numberProp(get(p).max, 100);
72
+ if (high <= low)
73
+ return 0;
74
+ return Math.round((high - low) / stepSize());
75
+ }
76
+ function tickIndex(current) {
77
+ const low = numberProp(get(p).min, 0);
78
+ return Math.round((numberProp(current, low) - low) / stepSize());
79
+ }
80
+ function vibrate(duration = 8) {
81
+ if (get(p).haptic === false || get(p).haptics === false)
82
+ return;
83
+ const api = globalThis.navigator;
84
+ api?.vibrate?.(duration);
85
+ }
86
+ function grabSlider() {
87
+ set(lastHapticTick, tickIndex(get(value)), true);
88
+ vibrate(8);
89
+ }
90
+ function vibrateStep(next) {
91
+ if (tickCount() > 20)
92
+ return;
93
+ const tick = tickIndex(next);
94
+ if (tick === get(lastHapticTick))
95
+ return;
96
+ set(lastHapticTick, tick, true);
97
+ vibrate(5);
98
+ }
99
+ var div = root();
100
+ var div_1 = child(div);
101
+ var span = child(div_1);
102
+ var node = child(span);
103
+ {
104
+ var consequent = ($$anchor2) => {
105
+ InlineIcon($$anchor2, {
106
+ get name() {
107
+ return get(p).icon;
108
+ },
109
+ className: "slex-slider-icon"
110
+ });
111
+ };
112
+ if_block(node, ($$render) => {
113
+ if (get(p).icon)
114
+ $$render(consequent);
115
+ });
116
+ }
117
+ var span_1 = sibling(node, 2);
118
+ var text_1 = child(span_1, true);
119
+ reset(span_1);
120
+ reset(span);
121
+ var span_2 = sibling(span, 2);
122
+ var text_2 = child(span_2, true);
123
+ var node_1 = sibling(text_2);
124
+ {
125
+ var consequent_1 = ($$anchor2) => {
126
+ var text_3 = text();
127
+ template_effect(($0) => set_text(text_3, $0), [() => text2(get(p).unit)]);
128
+ append($$anchor2, text_3);
129
+ };
130
+ if_block(node_1, ($$render) => {
131
+ if (get(p).unit)
132
+ $$render(consequent_1);
133
+ });
134
+ }
135
+ reset(span_2);
136
+ reset(div_1);
137
+ var input_1 = sibling(div_1, 2);
138
+ remove_input_defaults(input_1);
139
+ reset(div);
140
+ template_effect(($0, $1, $2, $3, $4, $5, $6, $7, $8) => {
141
+ set_attribute(div, "data-orientation", $0);
142
+ set_text(text_1, $1);
143
+ set_text(text_2, $2);
144
+ set_attribute(input_1, "min", $3);
145
+ set_attribute(input_1, "max", $4);
146
+ set_attribute(input_1, "step", $5);
147
+ set_value(input_1, $6);
148
+ input_1.disabled = !!get(p).disabled;
149
+ set_attribute(input_1, "aria-label", $7);
150
+ set_style(input_1, $8);
151
+ }, [
152
+ () => text2(get(p).orientation, "horizontal"),
153
+ () => text2(get(p).label ?? $$props.componentName),
154
+ () => text2(get(value) ?? 0),
155
+ () => Number(get(p).min ?? 0),
156
+ () => Number(get(p).max ?? 100),
157
+ () => Number(get(p).step ?? 1),
158
+ () => Number(get(value) ?? 0),
159
+ () => text2(get(p)["aria-label"] ?? get(p).ariaLabel ?? get(p).label ?? $$props.componentName),
160
+ () => `--slex-slider-progress: ${sliderProgress(get(value), get(p).min, get(p).max)}`
161
+ ]);
162
+ delegated("pointerdown", input_1, grabSlider);
163
+ delegated("input", input_1, (event) => choose(Number(event.target.value)));
164
+ append($$anchor, div);
165
+ pop();
166
+ }
167
+ delegate(["pointerdown", "input"]);
168
+
169
+ // src/components/entries/slider.ts
170
+ register("slider", createSvelteRenderer("slider", Slider), { state: "value" });
171
+ var slider_default = Slider;
172
+ export {
173
+ slider_default as default,
174
+ Slider
175
+ };