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,163 @@
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
+ each,
12
+ emit,
13
+ from_html,
14
+ get,
15
+ if_block,
16
+ index,
17
+ list,
18
+ next,
19
+ pop,
20
+ proxy,
21
+ push,
22
+ reset,
23
+ set,
24
+ set_attribute,
25
+ set_text,
26
+ sibling,
27
+ state,
28
+ template_effect,
29
+ text1 as text,
30
+ user_derived,
31
+ user_effect
32
+ } from "../chunks/accordion-nw12ytps.js";
33
+
34
+ // src/components/entries/accordion.ts
35
+ import { register } from "../runtime.js";
36
+
37
+ // src/components/svelte/disclosure/Accordion.svelte
38
+ var root_1 = from_html(`<section class="slex-accordion-item"><h3 class="slex-accordion-heading"><button type="button" class="slex-accordion-trigger"><span class="slex-accordion-label"><!> <span> </span></span> <span class="slex-accordion-indicator" aria-hidden="true"></span></button></h3> <div class="slex-accordion-content"><div class="slex-accordion-content-inner"> </div></div></section>`);
39
+ var root = from_html(`<div class="slex-accordion" data-scope="accordion"><div class="slex-accordion-inner"></div></div>`);
40
+ function Accordion($$anchor, $$props) {
41
+ push($$props, true);
42
+ let p = state(proxy({}));
43
+ let value = state(undefined);
44
+ let openStates = state(proxy({}));
45
+ const items = user_derived(() => list(get(p).items));
46
+ function keyFor(item) {
47
+ return text(item.value ?? item.label);
48
+ }
49
+ function valueForKey(key) {
50
+ const item = get(items).find((entry) => keyFor(entry) === key);
51
+ return item ? item.value ?? item.label : undefined;
52
+ }
53
+ function selectedKeys(nextValue, multiple) {
54
+ if (multiple && Array.isArray(nextValue))
55
+ return nextValue.map((entry) => text(entry));
56
+ const selected = text(nextValue);
57
+ return selected ? [selected] : [];
58
+ }
59
+ function openValue(states = get(openStates)) {
60
+ const keys = Object.keys(states).filter((key) => states[key]);
61
+ if (get(p).multiple)
62
+ return keys.map((key) => valueForKey(key)).filter((entry) => entry !== undefined);
63
+ return keys.length ? valueForKey(keys[0]) : undefined;
64
+ }
65
+ user_effect(() => bindPropStore($$props.props, (next2) => {
66
+ set(p, next2, true);
67
+ set(value, next2.value, true);
68
+ const selected = selectedKeys(next2.value, next2.multiple === true);
69
+ const nextOpenStates = {};
70
+ for (const item of list(next2.items)) {
71
+ const key = keyFor(item);
72
+ nextOpenStates[key] = selected.includes(key);
73
+ }
74
+ set(openStates, nextOpenStates, true);
75
+ }));
76
+ function toggleItem(key) {
77
+ const open = !!get(openStates)[key];
78
+ let nextStates;
79
+ if (get(p).multiple) {
80
+ nextStates = { ...get(openStates), [key]: !open };
81
+ } else {
82
+ nextStates = {};
83
+ for (const item of get(items))
84
+ nextStates[keyFor(item)] = false;
85
+ nextStates[key] = !open;
86
+ }
87
+ set(openStates, nextStates, true);
88
+ const nextValue = openValue(nextStates);
89
+ set(value, nextValue, true);
90
+ emit($$props.ctx, "change", nextValue);
91
+ }
92
+ var div = root();
93
+ var div_1 = child(div);
94
+ each(div_1, 21, () => get(items), index, ($$anchor2, item) => {
95
+ const key = user_derived(() => keyFor(get(item)));
96
+ const open = user_derived(() => !!get(openStates)[get(key)]);
97
+ var section = root_1();
98
+ var h3 = child(section);
99
+ var button = child(h3);
100
+ var span = child(button);
101
+ var node = child(span);
102
+ {
103
+ var consequent = ($$anchor3) => {
104
+ InlineIcon($$anchor3, {
105
+ get name() {
106
+ return get(item).icon;
107
+ },
108
+ get selected() {
109
+ return get(open);
110
+ },
111
+ className: "slex-accordion-icon"
112
+ });
113
+ };
114
+ if_block(node, ($$render) => {
115
+ if (get(item).icon)
116
+ $$render(consequent);
117
+ });
118
+ }
119
+ var span_1 = sibling(node, 2);
120
+ var text_1 = child(span_1, true);
121
+ reset(span_1);
122
+ reset(span);
123
+ next(2);
124
+ reset(button);
125
+ reset(h3);
126
+ var div_2 = sibling(h3, 2);
127
+ var div_3 = child(div_2);
128
+ var text_2 = child(div_3, true);
129
+ reset(div_3);
130
+ reset(div_2);
131
+ reset(section);
132
+ template_effect(($0, $1) => {
133
+ set_attribute(section, "data-state", get(open) ? "open" : "closed");
134
+ set_attribute(button, "data-state", get(open) ? "open" : "closed");
135
+ set_attribute(button, "aria-expanded", get(open));
136
+ set_attribute(button, "aria-controls", `${$$props.ctx.id}-${get(key)}-content`);
137
+ button.disabled = get(item).disabled === true;
138
+ set_text(text_1, $0);
139
+ set_attribute(div_2, "id", `${$$props.ctx.id}-${get(key)}-content`);
140
+ set_attribute(div_2, "data-state", get(open) ? "open" : "closed");
141
+ set_attribute(div_2, "aria-hidden", !get(open));
142
+ set_text(text_2, $1);
143
+ }, [
144
+ () => text(get(item).label),
145
+ () => text(get(item).content)
146
+ ]);
147
+ delegated("click", button, () => toggleItem(get(key)));
148
+ append($$anchor2, section);
149
+ });
150
+ reset(div_1);
151
+ reset(div);
152
+ append($$anchor, div);
153
+ pop();
154
+ }
155
+ delegate(["click"]);
156
+
157
+ // src/components/entries/accordion.ts
158
+ register("accordion", createSvelteRenderer("accordion", Accordion), { state: "none" });
159
+ var accordion_default = Accordion;
160
+ export {
161
+ accordion_default as default,
162
+ Accordion
163
+ };
@@ -0,0 +1,80 @@
1
+ import {
2
+ InlineIcon
3
+ } from "../chunks/accordion-cw5r75jm.js";
4
+ import {
5
+ append,
6
+ bindPropStore,
7
+ child,
8
+ createSvelteRenderer,
9
+ from_html,
10
+ get,
11
+ if_block,
12
+ pop,
13
+ proxy,
14
+ push,
15
+ reset,
16
+ set,
17
+ set_attribute,
18
+ set_text,
19
+ sibling,
20
+ state,
21
+ template_effect,
22
+ text1 as text,
23
+ user_effect
24
+ } from "../chunks/accordion-nw12ytps.js";
25
+
26
+ // src/components/entries/badge.ts
27
+ import { register } from "../runtime.js";
28
+
29
+ // src/components/svelte/content/Badge.svelte
30
+ var root = from_html(`<span class="slex-badge"><!><span class="slex-badge-label"> </span></span>`);
31
+ function Badge($$anchor, $$props) {
32
+ push($$props, true);
33
+ let p = state(proxy({}));
34
+ user_effect(() => bindPropStore($$props.props, (next) => set(p, next, true)));
35
+ function tone() {
36
+ const raw = text(get(p).tone ?? get(p).type ?? get(p).variant, "neutral").toLowerCase();
37
+ if (raw === "danger" || raw === "error")
38
+ return "destructive";
39
+ if (raw === "muted" || raw === "neutral" || raw === "default")
40
+ return "neutral";
41
+ return raw;
42
+ }
43
+ var span = root();
44
+ var node = child(span);
45
+ {
46
+ var consequent = ($$anchor2) => {
47
+ InlineIcon($$anchor2, {
48
+ get name() {
49
+ return get(p).icon;
50
+ },
51
+ className: "slex-badge-icon"
52
+ });
53
+ };
54
+ if_block(node, ($$render) => {
55
+ if (get(p).icon)
56
+ $$render(consequent);
57
+ });
58
+ }
59
+ var span_1 = sibling(node);
60
+ var text_1 = child(span_1, true);
61
+ reset(span_1);
62
+ reset(span);
63
+ template_effect(($0, $1) => {
64
+ set_attribute(span, "data-tone", $0);
65
+ set_text(text_1, $1);
66
+ }, [
67
+ () => tone(),
68
+ () => text(get(p).label ?? get(p).text ?? get(p).content ?? $$props.componentName)
69
+ ]);
70
+ append($$anchor, span);
71
+ pop();
72
+ }
73
+
74
+ // src/components/entries/badge.ts
75
+ register("badge", createSvelteRenderer("badge", Badge), { state: "readable" });
76
+ var badge_default = Badge;
77
+ export {
78
+ badge_default as default,
79
+ Badge
80
+ };
@@ -0,0 +1,114 @@
1
+ .slex-button {
2
+ display: inline-flex;
3
+ align-items: center;
4
+ justify-content: center;
5
+ gap: 0.5rem;
6
+ max-width: 100%;
7
+ min-width: 0;
8
+ padding: 0.5rem 1rem;
9
+ border: 1px solid transparent;
10
+ border-radius: var(--radius);
11
+ font-family: inherit;
12
+ font-size: 0.875rem;
13
+ font-weight: 500;
14
+ line-height: 1.25;
15
+ white-space: nowrap;
16
+ text-overflow: ellipsis;
17
+ overflow: hidden;
18
+ cursor: pointer;
19
+ user-select: none;
20
+ transition:
21
+ background 150ms ease,
22
+ border-color 150ms ease,
23
+ color 150ms ease,
24
+ box-shadow 150ms ease,
25
+ transform 150ms ease;
26
+ }
27
+
28
+ .slex-button--primary {
29
+ background: var(--primary);
30
+ color: var(--primary-foreground);
31
+ border-color: var(--primary);
32
+ }
33
+
34
+ .slex-button--primary:hover:not(:disabled):not(.slex-button--disabled) {
35
+ background: color-mix(in oklab, var(--primary) 90%, transparent);
36
+ border-color: color-mix(in oklab, var(--primary) 90%, transparent);
37
+ color: var(--primary-foreground);
38
+ transform: translateY(-1px);
39
+ box-shadow: var(--shadow-md);
40
+ }
41
+
42
+ .slex-button--secondary {
43
+ background: var(--secondary);
44
+ color: var(--secondary-foreground);
45
+ border-color: var(--border);
46
+ }
47
+
48
+ .slex-button--secondary:hover:not(:disabled):not(.slex-button--disabled) {
49
+ background: var(--accent);
50
+ color: var(--accent-foreground);
51
+ border-color: var(--border);
52
+ }
53
+
54
+ .slex-button--danger {
55
+ background: var(--destructive);
56
+ color: var(--destructive-foreground);
57
+ border-color: var(--destructive);
58
+ }
59
+
60
+ .slex-button--danger:hover:not(:disabled):not(.slex-button--disabled) {
61
+ background: color-mix(in oklab, var(--destructive) 90%, transparent);
62
+ border-color: color-mix(in oklab, var(--destructive) 90%, transparent);
63
+ }
64
+
65
+ .slex-button--ghost {
66
+ background: transparent;
67
+ color: var(--muted-foreground);
68
+ border-color: transparent;
69
+ }
70
+
71
+ .slex-button--ghost:hover:not(:disabled):not(.slex-button--disabled) {
72
+ background: var(--accent);
73
+ color: var(--accent-foreground);
74
+ }
75
+
76
+ .slex-button:disabled,
77
+ .slex-button[disabled],
78
+ .slex-button--disabled {
79
+ opacity: 0.5;
80
+ cursor: not-allowed;
81
+ pointer-events: none;
82
+ transform: none;
83
+ box-shadow: none;
84
+ }
85
+
86
+ .slex-button:active:not(:disabled):not(.slex-button--disabled) {
87
+ transform: translateY(0);
88
+ box-shadow: var(--shadow-sm);
89
+ }
90
+
91
+ .slex-button:focus-visible {
92
+ outline: 2px solid var(--ring);
93
+ outline-offset: 2px;
94
+ }
95
+
96
+ .slex-button--icon {
97
+ width: var(--slex-control-height, 2.25rem);
98
+ min-height: var(--slex-control-height, 2.25rem);
99
+ padding-inline: 0;
100
+ }
101
+
102
+ .slex-button-icon {
103
+ display: inline-flex;
104
+ width: 1.125rem;
105
+ height: 1.125rem;
106
+ color: currentColor;
107
+ }
108
+
109
+ .slex-button-icon svg {
110
+ display: block;
111
+ width: 100%;
112
+ height: 100%;
113
+ fill: currentColor;
114
+ }
@@ -0,0 +1,16 @@
1
+ import {
2
+ Button
3
+ } from "../chunks/accordion-830dw78f.js";
4
+ import"../chunks/accordion-cw5r75jm.js";
5
+ import {
6
+ createSvelteRenderer
7
+ } from "../chunks/accordion-nw12ytps.js";
8
+
9
+ // src/components/entries/button.ts
10
+ import { register } from "../runtime.js";
11
+ register("button", createSvelteRenderer("button", Button), { state: "none" });
12
+ var button_default = Button;
13
+ export {
14
+ button_default as default,
15
+ Button
16
+ };
@@ -0,0 +1,154 @@
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
+ action,
10
+ append,
11
+ bindPropStore,
12
+ child,
13
+ createSvelteRenderer,
14
+ first_child,
15
+ from_html,
16
+ get,
17
+ if_block,
18
+ pop,
19
+ proxy,
20
+ push,
21
+ renderChildren,
22
+ reset,
23
+ set,
24
+ set_text,
25
+ sibling,
26
+ state,
27
+ template_effect,
28
+ text1 as text,
29
+ user_derived,
30
+ user_effect
31
+ } from "../chunks/accordion-nw12ytps.js";
32
+
33
+ // src/components/entries/callout.ts
34
+ import { register } from "../runtime.js";
35
+
36
+ // src/components/svelte/content/Callout.svelte
37
+ var root_1 = from_html(`<span aria-hidden="true"></span>`);
38
+ var root_3 = from_html(`<div class="slex-callout-title"><!><span> </span></div>`);
39
+ var root_2 = from_html(`<!> <div class="slex-callout-body"> </div>`, 1);
40
+ function Callout($$anchor, $$props) {
41
+ push($$props, true);
42
+ let p = state(proxy({}));
43
+ user_effect(() => bindPropStore($$props.props, (next) => set(p, next, true)));
44
+ function tone() {
45
+ const raw = text(get(p).tone ?? get(p).type, "info").toLowerCase();
46
+ if (raw === "error" || raw === "destructive")
47
+ return "danger";
48
+ if (raw === "neutral" || raw === "default" || raw === "muted")
49
+ return "info";
50
+ return raw;
51
+ }
52
+ function titleText() {
53
+ return text(get(p).title ?? get(p).label ?? get(p).heading);
54
+ }
55
+ function descriptionText() {
56
+ return text(get(p).text ?? get(p).content ?? get(p).description ?? get(p).message);
57
+ }
58
+ function role() {
59
+ return tone() === "danger" ? "alert" : "note";
60
+ }
61
+ function color() {
62
+ const kind = tone();
63
+ if (kind === "success")
64
+ return "green";
65
+ if (kind === "warning")
66
+ return "yellow";
67
+ if (kind === "danger")
68
+ return "red";
69
+ if (kind === "muted" || kind === "neutral")
70
+ return "gray";
71
+ return "blue";
72
+ }
73
+ {
74
+ const icon = ($$anchor2) => {
75
+ var span = root_1();
76
+ append($$anchor2, span);
77
+ };
78
+ let $0 = user_derived(tone);
79
+ let $1 = user_derived(color);
80
+ let $2 = user_derived(role);
81
+ let $3 = user_derived(() => role() === "alert" ? "assertive" : "polite");
82
+ Toast($$anchor, {
83
+ class: "slex-callout",
84
+ "data-scope": "callout",
85
+ get "data-tone"() {
86
+ return get($0);
87
+ },
88
+ get color() {
89
+ return get($1);
90
+ },
91
+ get role() {
92
+ return get($2);
93
+ },
94
+ get "aria-live"() {
95
+ return get($3);
96
+ },
97
+ dismissable: false,
98
+ align: false,
99
+ classes: { icon: "slex-callout-mark", content: "slex-callout-content" },
100
+ icon,
101
+ children: ($$anchor2, $$slotProps) => {
102
+ var fragment_1 = root_2();
103
+ var node = first_child(fragment_1);
104
+ {
105
+ var consequent_1 = ($$anchor3) => {
106
+ var div = root_3();
107
+ var node_1 = child(div);
108
+ {
109
+ var consequent = ($$anchor4) => {
110
+ InlineIcon($$anchor4, {
111
+ get name() {
112
+ return get(p).icon;
113
+ },
114
+ className: "slex-callout-icon"
115
+ });
116
+ };
117
+ if_block(node_1, ($$render) => {
118
+ if (get(p).icon)
119
+ $$render(consequent);
120
+ });
121
+ }
122
+ var span_1 = sibling(node_1);
123
+ var text_1 = child(span_1, true);
124
+ reset(span_1);
125
+ reset(div);
126
+ template_effect(($02) => set_text(text_1, $02), [() => titleText()]);
127
+ append($$anchor3, div);
128
+ };
129
+ var d = user_derived(() => titleText());
130
+ if_block(node, ($$render) => {
131
+ if (get(d))
132
+ $$render(consequent_1);
133
+ });
134
+ }
135
+ var div_1 = sibling(node, 2);
136
+ var text_2 = child(div_1, true);
137
+ reset(div_1);
138
+ action(div_1, ($$node, $$action_arg) => renderChildren?.($$node, $$action_arg), () => $$props.ctx);
139
+ template_effect(($02) => set_text(text_2, $02), [() => descriptionText()]);
140
+ append($$anchor2, fragment_1);
141
+ },
142
+ $$slots: { icon: true, default: true }
143
+ });
144
+ }
145
+ pop();
146
+ }
147
+
148
+ // src/components/entries/callout.ts
149
+ register("callout", createSvelteRenderer("callout", Callout), { state: "readable" });
150
+ var callout_default = Callout;
151
+ export {
152
+ callout_default as default,
153
+ Callout
154
+ };
@@ -0,0 +1,95 @@
1
+ import {
2
+ InlineIcon
3
+ } from "../chunks/accordion-cw5r75jm.js";
4
+ import {
5
+ action,
6
+ append,
7
+ bindPropStore,
8
+ child,
9
+ createSvelteRenderer,
10
+ from_html,
11
+ get,
12
+ if_block,
13
+ pop,
14
+ proxy,
15
+ push,
16
+ renderChildren,
17
+ reset,
18
+ set,
19
+ set_attribute,
20
+ set_text,
21
+ sibling,
22
+ state,
23
+ template_effect,
24
+ text1 as text,
25
+ user_effect
26
+ } from "../chunks/accordion-nw12ytps.js";
27
+
28
+ // src/components/entries/card.ts
29
+ import { register } from "../runtime.js";
30
+
31
+ // src/components/svelte/layout/Card.svelte
32
+ var root_3 = from_html(`<span> </span>`);
33
+ var root_1 = from_html(`<div class="slex-card-title"><!><!></div>`);
34
+ var root = from_html(`<div class="slex-card"><!> <div class="slex-card-body"></div></div>`);
35
+ function Card($$anchor, $$props) {
36
+ push($$props, true);
37
+ let p = state(proxy({}));
38
+ user_effect(() => bindPropStore($$props.props, (next) => set(p, next, true)));
39
+ var div = root();
40
+ var node = child(div);
41
+ {
42
+ var consequent_2 = ($$anchor2) => {
43
+ var div_1 = root_1();
44
+ var node_1 = child(div_1);
45
+ {
46
+ var consequent = ($$anchor3) => {
47
+ InlineIcon($$anchor3, {
48
+ get name() {
49
+ return get(p).icon;
50
+ },
51
+ className: "slex-card-icon"
52
+ });
53
+ };
54
+ if_block(node_1, ($$render) => {
55
+ if (get(p).icon)
56
+ $$render(consequent);
57
+ });
58
+ }
59
+ var node_2 = sibling(node_1);
60
+ {
61
+ var consequent_1 = ($$anchor3) => {
62
+ var span = root_3();
63
+ var text_1 = child(span, true);
64
+ reset(span);
65
+ template_effect(($0) => set_text(text_1, $0), [() => text(get(p).title)]);
66
+ append($$anchor3, span);
67
+ };
68
+ if_block(node_2, ($$render) => {
69
+ if (get(p).title)
70
+ $$render(consequent_1);
71
+ });
72
+ }
73
+ reset(div_1);
74
+ append($$anchor2, div_1);
75
+ };
76
+ if_block(node, ($$render) => {
77
+ if (get(p).title || get(p).icon)
78
+ $$render(consequent_2);
79
+ });
80
+ }
81
+ var div_2 = sibling(node, 2);
82
+ action(div_2, ($$node, $$action_arg) => renderChildren?.($$node, $$action_arg), () => $$props.ctx);
83
+ reset(div);
84
+ template_effect(($0) => set_attribute(div, "data-tone", $0), [() => get(p).tone ? text(get(p).tone) : undefined]);
85
+ append($$anchor, div);
86
+ pop();
87
+ }
88
+
89
+ // src/components/entries/card.ts
90
+ register("card", createSvelteRenderer("card", Card), { state: "none" });
91
+ var card_default = Card;
92
+ export {
93
+ card_default as default,
94
+ Card
95
+ };