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,240 @@
1
+ import {
2
+ Toast
3
+ } from "../chunks/accordion-ehnhpeca.js";
4
+ import"../chunks/accordion-hzyrngd6.js";
5
+ import {
6
+ InlineIcon
7
+ } from "../chunks/accordion-cw5r75jm.js";
8
+ import {
9
+ append,
10
+ bindPropStore,
11
+ bool,
12
+ child,
13
+ createSvelteRenderer,
14
+ delegate,
15
+ delegated,
16
+ emit,
17
+ first_child,
18
+ from_html,
19
+ get,
20
+ if_block,
21
+ label,
22
+ pop,
23
+ proxy,
24
+ push,
25
+ reset,
26
+ set,
27
+ set_text,
28
+ sibling,
29
+ state,
30
+ template_effect,
31
+ text1 as text,
32
+ user_derived,
33
+ user_effect
34
+ } from "../chunks/accordion-nw12ytps.js";
35
+
36
+ // src/components/entries/toast.ts
37
+ import { register } from "../runtime.js";
38
+
39
+ // src/components/svelte/feedback/Toast.svelte
40
+ var root_2 = from_html(`<span aria-hidden="true"></span>`);
41
+ var root_4 = from_html(`<div class="slex-toast-title"><!><span> </span></div>`);
42
+ var root_6 = from_html(`<div class="slex-toast-description"> </div>`);
43
+ var root_3 = from_html(`<!> <!>`, 1);
44
+ var root = from_html(`<div class="slex-toast-group" data-scope="toast"><!></div>`);
45
+ function Toast2($$anchor, $$props) {
46
+ push($$props, true);
47
+ let p = state(proxy({}));
48
+ let visible = state(true);
49
+ user_effect(() => bindPropStore($$props.props, (next) => set(p, next, true)));
50
+ user_effect(() => {
51
+ const title = titleText();
52
+ const description = descriptionText();
53
+ const type = tone();
54
+ if (!title && !description && !type)
55
+ return;
56
+ set(visible, true);
57
+ const ms = durationMs();
58
+ if (ms <= 0)
59
+ return;
60
+ const timer = setTimeout(() => {
61
+ set(visible, false);
62
+ }, ms);
63
+ return () => clearTimeout(timer);
64
+ });
65
+ function tone() {
66
+ const raw = text(get(p).type ?? get(p).tone ?? "info").toLowerCase();
67
+ if (raw === "error" || raw === "destructive")
68
+ return "danger";
69
+ if (raw === "neutral" || raw === "default")
70
+ return "info";
71
+ return raw;
72
+ }
73
+ function titleText() {
74
+ return text(get(p).title ?? get(p).label ?? get(p).heading);
75
+ }
76
+ function descriptionText() {
77
+ return text(get(p).description ?? get(p).text ?? get(p).message ?? get(p).content);
78
+ }
79
+ function dismissable() {
80
+ if (get(p).dismissable === undefined && get(p).dismissible === undefined)
81
+ return true;
82
+ return bool(get(p).dismissable ?? get(p).dismissible);
83
+ }
84
+ function durationMs() {
85
+ const value = Number(get(p).duration ?? 0);
86
+ return Number.isFinite(value) && value > 0 ? value : 0;
87
+ }
88
+ function close() {
89
+ if (!get(visible))
90
+ return;
91
+ set(visible, false);
92
+ emit($$props.ctx, "close", { type: "close", target: $$props.ctx.id });
93
+ }
94
+ function handleGroupClick(event) {
95
+ const target = event.target;
96
+ if (!(target instanceof Element))
97
+ return;
98
+ if (target.closest(".slex-toast-close"))
99
+ close();
100
+ }
101
+ function role() {
102
+ return tone() === "danger" ? "alert" : "status";
103
+ }
104
+ function color() {
105
+ const kind = tone();
106
+ if (kind === "success")
107
+ return "green";
108
+ if (kind === "warning")
109
+ return "yellow";
110
+ if (kind === "danger")
111
+ return "red";
112
+ if (kind === "muted" || kind === "neutral")
113
+ return "gray";
114
+ return "blue";
115
+ }
116
+ function closeLabel() {
117
+ return label($$props.ctx, "toast.close", get(p).closeLabel ?? get(p).closeAriaLabel, "Close");
118
+ }
119
+ var div = root();
120
+ var node = child(div);
121
+ {
122
+ var consequent_3 = ($$anchor2) => {
123
+ {
124
+ const icon = ($$anchor3) => {
125
+ var span = root_2();
126
+ append($$anchor3, span);
127
+ };
128
+ let $0 = user_derived(tone);
129
+ let $1 = user_derived(color);
130
+ let $2 = user_derived(role);
131
+ let $3 = user_derived(() => role() === "alert" ? "assertive" : "polite");
132
+ let $4 = user_derived(dismissable);
133
+ let $5 = user_derived(closeLabel);
134
+ Toast($$anchor2, {
135
+ class: "slex-toast",
136
+ get "data-tone"() {
137
+ return get($0);
138
+ },
139
+ get color() {
140
+ return get($1);
141
+ },
142
+ get role() {
143
+ return get($2);
144
+ },
145
+ get "aria-live"() {
146
+ return get($3);
147
+ },
148
+ get dismissable() {
149
+ return get($4);
150
+ },
151
+ get closeAriaLabel() {
152
+ return get($5);
153
+ },
154
+ classes: {
155
+ icon: "slex-toast-mark",
156
+ content: "slex-toast-content",
157
+ close: "slex-toast-close"
158
+ },
159
+ onclose: close,
160
+ get toastStatus() {
161
+ return get(visible);
162
+ },
163
+ set toastStatus($$value) {
164
+ set(visible, $$value, true);
165
+ },
166
+ icon,
167
+ children: ($$anchor3, $$slotProps) => {
168
+ var fragment_1 = root_3();
169
+ var node_1 = first_child(fragment_1);
170
+ {
171
+ var consequent_1 = ($$anchor4) => {
172
+ var div_1 = root_4();
173
+ var node_2 = child(div_1);
174
+ {
175
+ var consequent = ($$anchor5) => {
176
+ InlineIcon($$anchor5, {
177
+ get name() {
178
+ return get(p).icon;
179
+ },
180
+ className: "slex-toast-icon"
181
+ });
182
+ };
183
+ if_block(node_2, ($$render) => {
184
+ if (get(p).icon)
185
+ $$render(consequent);
186
+ });
187
+ }
188
+ var span_1 = sibling(node_2);
189
+ var text_1 = child(span_1, true);
190
+ reset(span_1);
191
+ reset(div_1);
192
+ template_effect(($02) => set_text(text_1, $02), [() => titleText()]);
193
+ append($$anchor4, div_1);
194
+ };
195
+ var d = user_derived(() => titleText());
196
+ if_block(node_1, ($$render) => {
197
+ if (get(d))
198
+ $$render(consequent_1);
199
+ });
200
+ }
201
+ var node_3 = sibling(node_1, 2);
202
+ {
203
+ var consequent_2 = ($$anchor4) => {
204
+ var div_2 = root_6();
205
+ var text_2 = child(div_2, true);
206
+ reset(div_2);
207
+ template_effect(($02) => set_text(text_2, $02), [() => descriptionText()]);
208
+ append($$anchor4, div_2);
209
+ };
210
+ var d_1 = user_derived(() => descriptionText());
211
+ if_block(node_3, ($$render) => {
212
+ if (get(d_1))
213
+ $$render(consequent_2);
214
+ });
215
+ }
216
+ append($$anchor3, fragment_1);
217
+ },
218
+ $$slots: { icon: true, default: true }
219
+ });
220
+ }
221
+ };
222
+ if_block(node, ($$render) => {
223
+ if (get(visible))
224
+ $$render(consequent_3);
225
+ });
226
+ }
227
+ reset(div);
228
+ delegated("click", div, handleGroupClick);
229
+ append($$anchor, div);
230
+ pop();
231
+ }
232
+ delegate(["click"]);
233
+
234
+ // src/components/entries/toast.ts
235
+ register("toast", createSvelteRenderer("toast", Toast2), { state: "none" });
236
+ var toast_default = Toast2;
237
+ export {
238
+ toast_default as default,
239
+ Toast2 as Toast
240
+ };