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,178 @@
1
+ import {
2
+ InlineIcon
3
+ } from "../chunks/accordion-cw5r75jm.js";
4
+ import {
5
+ append,
6
+ bindPropStore,
7
+ child,
8
+ createSvelteRenderer,
9
+ each,
10
+ from_html,
11
+ get,
12
+ if_block,
13
+ pop,
14
+ proxy,
15
+ push,
16
+ reset,
17
+ set,
18
+ set_attribute,
19
+ set_text,
20
+ sibling,
21
+ state,
22
+ template_effect,
23
+ text1 as text,
24
+ user_derived,
25
+ user_effect
26
+ } from "../chunks/accordion-nw12ytps.js";
27
+
28
+ // src/components/entries/stat.ts
29
+ import { register } from "../runtime.js";
30
+
31
+ // src/components/svelte/display/Stat.svelte
32
+ var root_2 = from_html(`<span class="slex-stat-character"><span class="slex-stat-character-current"> </span></span>`);
33
+ var root_3 = from_html(`<span class="slex-stat-unit"> </span>`);
34
+ var root = from_html(`<div class="slex-stat"><div class="slex-stat-label"><!> <span> </span></div> <div class="slex-stat-value"><span class="slex-stat-number"></span> <!></div></div>`);
35
+ function Stat($$anchor, $$props) {
36
+ push($$props, true);
37
+ let p = state(proxy({}));
38
+ let previousDisplayValue = state("");
39
+ let currentDisplayValue = state("");
40
+ let valueChange = state("changed");
41
+ let hasDisplayValue = false;
42
+ let shouldAnimateValue = state(false);
43
+ let valueAnimationPhase = state("update");
44
+ const valueText = user_derived(() => text(get(p).value));
45
+ const valueSegments = user_derived(() => statSegments(get(previousDisplayValue), get(currentDisplayValue)));
46
+ user_effect(() => bindPropStore($$props.props, (next) => set(p, next, true)));
47
+ function numericValue(value) {
48
+ const parsed = Number.parseFloat(value.replaceAll(",", ""));
49
+ return Number.isFinite(parsed) ? parsed : null;
50
+ }
51
+ function changeDirection(previous, next) {
52
+ const previousNumber = numericValue(previous);
53
+ const nextNumber = numericValue(next);
54
+ if (previousNumber === null || nextNumber === null)
55
+ return "changed";
56
+ if (nextNumber > previousNumber)
57
+ return "up";
58
+ if (nextNumber < previousNumber)
59
+ return "down";
60
+ return "changed";
61
+ }
62
+ function booleanProp(value) {
63
+ return value === true || value === "true" || value === 1 || value === "1";
64
+ }
65
+ function initialPreviousValue(value) {
66
+ return Array.from(value).map((char) => isDigit(char) ? "0" : char).join("");
67
+ }
68
+ user_effect(() => {
69
+ const next = get(valueText);
70
+ if (!hasDisplayValue) {
71
+ set(shouldAnimateValue, booleanProp(get(p).animateInitial), true);
72
+ set(previousDisplayValue, get(shouldAnimateValue) ? initialPreviousValue(next) : next, true);
73
+ set(currentDisplayValue, next, true);
74
+ set(valueChange, "up");
75
+ set(valueAnimationPhase, "initial");
76
+ hasDisplayValue = true;
77
+ return;
78
+ }
79
+ if (next === get(currentDisplayValue))
80
+ return;
81
+ set(valueChange, changeDirection(get(currentDisplayValue), next), true);
82
+ set(previousDisplayValue, get(currentDisplayValue), true);
83
+ set(currentDisplayValue, next, true);
84
+ set(shouldAnimateValue, true);
85
+ set(valueAnimationPhase, "update");
86
+ });
87
+ function isDigit(char) {
88
+ return /^[0-9]$/.test(char);
89
+ }
90
+ function statSegments(previous, current) {
91
+ const previousChars = Array.from(previous);
92
+ const currentChars = Array.from(current);
93
+ const currentOffset = Math.max(0, currentChars.length - previousChars.length);
94
+ const previousOffset = Math.max(0, previousChars.length - currentChars.length);
95
+ return currentChars.map((char, index) => {
96
+ const previousChar = previousChars[index - currentOffset + previousOffset] ?? "";
97
+ return {
98
+ char,
99
+ previousChar,
100
+ changed: previousChar !== char,
101
+ key: `${index}:${char}`,
102
+ kind: isDigit(char) ? "digit" : "symbol"
103
+ };
104
+ });
105
+ }
106
+ var div = root();
107
+ var div_1 = child(div);
108
+ var node = child(div_1);
109
+ {
110
+ var consequent = ($$anchor2) => {
111
+ InlineIcon($$anchor2, {
112
+ get name() {
113
+ return get(p).icon;
114
+ },
115
+ className: "slex-stat-icon"
116
+ });
117
+ };
118
+ if_block(node, ($$render) => {
119
+ if (get(p).icon)
120
+ $$render(consequent);
121
+ });
122
+ }
123
+ var span = sibling(node, 2);
124
+ var text_1 = child(span, true);
125
+ reset(span);
126
+ reset(div_1);
127
+ var div_2 = sibling(div_1, 2);
128
+ var span_1 = child(div_2);
129
+ each(span_1, 21, () => get(valueSegments), (segment) => segment.key, ($$anchor2, segment) => {
130
+ var span_2 = root_2();
131
+ var span_3 = child(span_2);
132
+ var text_2 = child(span_3, true);
133
+ reset(span_3);
134
+ reset(span_2);
135
+ template_effect(() => {
136
+ set_attribute(span_2, "data-stat-kind", get(segment).kind);
137
+ set_attribute(span_2, "data-stat-change", get(segment).changed && get(shouldAnimateValue) ? get(valueChange) : undefined);
138
+ set_attribute(span_2, "data-stat-initial", get(segment).changed && get(shouldAnimateValue) && get(valueAnimationPhase) === "initial" ? "true" : undefined);
139
+ set_attribute(span_2, "data-stat-previous", get(segment).previousChar || undefined);
140
+ set_text(text_2, get(segment).char);
141
+ });
142
+ append($$anchor2, span_2);
143
+ });
144
+ reset(span_1);
145
+ var node_1 = sibling(span_1, 2);
146
+ {
147
+ var consequent_1 = ($$anchor2) => {
148
+ var span_4 = root_3();
149
+ var text_3 = child(span_4, true);
150
+ reset(span_4);
151
+ template_effect(($0) => set_text(text_3, $0), [() => text(get(p).unit)]);
152
+ append($$anchor2, span_4);
153
+ };
154
+ if_block(node_1, ($$render) => {
155
+ if (get(p).unit)
156
+ $$render(consequent_1);
157
+ });
158
+ }
159
+ reset(div_2);
160
+ reset(div);
161
+ template_effect(($0, $1) => {
162
+ set_attribute(div, "data-tone", $0);
163
+ set_text(text_1, $1);
164
+ }, [
165
+ () => get(p).tone || get(p).type ? text(get(p).tone ?? get(p).type) : undefined,
166
+ () => text(get(p).label ?? $$props.componentName)
167
+ ]);
168
+ append($$anchor, div);
169
+ pop();
170
+ }
171
+
172
+ // src/components/entries/stat.ts
173
+ register("stat", createSvelteRenderer("stat", Stat), { state: "readable" });
174
+ var stat_default = Stat;
175
+ export {
176
+ stat_default as default,
177
+ Stat
178
+ };
@@ -0,0 +1,9 @@
1
+ .slex-submit-bar {
2
+ display: flex;
3
+ align-items: center;
4
+ justify-content: flex-end;
5
+ gap: 0.75rem;
6
+ flex-wrap: wrap;
7
+ padding-top: 0.75rem;
8
+ border-top: 1px solid var(--border);
9
+ }
@@ -0,0 +1,77 @@
1
+ import {
2
+ append,
3
+ bindPropStore,
4
+ child,
5
+ createSvelteRenderer,
6
+ delegate,
7
+ delegated,
8
+ from_html,
9
+ get,
10
+ label,
11
+ pop,
12
+ proxy,
13
+ push,
14
+ reset,
15
+ set,
16
+ set_text,
17
+ sibling,
18
+ state,
19
+ template_effect,
20
+ user_effect
21
+ } from "../chunks/accordion-nw12ytps.js";
22
+
23
+ // src/components/entries/submit.ts
24
+ import { register } from "../runtime.js";
25
+
26
+ // src/components/svelte/input/Submit.svelte
27
+ var root = from_html(`<div class="slex-submit-bar"><button type="button" class="slex-button slex-button--ghost"> </button> <button type="button" class="slex-button slex-button--primary"> </button></div>`);
28
+ function Submit($$anchor, $$props) {
29
+ push($$props, true);
30
+ let p = state(proxy({}));
31
+ user_effect(() => bindPropStore($$props.props, (next) => set(p, next, true)));
32
+ function submitTool() {
33
+ if (get(p).disabled)
34
+ return;
35
+ const runtime = $$props.ctx.g.__slexkitTool;
36
+ if (!runtime?.submit)
37
+ return;
38
+ const result = {};
39
+ for (const key of Array.isArray(get(p).returnKeys) ? get(p).returnKeys : []) {
40
+ result[String(key)] = String(key).split(".").reduce((current, part) => current && typeof current === "object" ? current[part] : undefined, $$props.ctx.g);
41
+ }
42
+ runtime.submit(result);
43
+ }
44
+ function ignoreTool() {
45
+ const runtime = $$props.ctx.g.__slexkitTool;
46
+ runtime?.ignore?.();
47
+ }
48
+ var div = root();
49
+ var button = child(div);
50
+ var text = child(button, true);
51
+ reset(button);
52
+ var button_1 = sibling(button, 2);
53
+ var text_1 = child(button_1, true);
54
+ reset(button_1);
55
+ reset(div);
56
+ template_effect(($0, $1) => {
57
+ set_text(text, $0);
58
+ button_1.disabled = !!get(p).disabled;
59
+ set_text(text_1, $1);
60
+ }, [
61
+ () => label($$props.ctx, "submit.ignore", get(p).ignoreLabel, "Ignore"),
62
+ () => label($$props.ctx, "submit.submit", get(p).submitLabel, "Submit")
63
+ ]);
64
+ delegated("click", button, ignoreTool);
65
+ delegated("click", button_1, submitTool);
66
+ append($$anchor, div);
67
+ pop();
68
+ }
69
+ delegate(["click"]);
70
+
71
+ // src/components/entries/submit.ts
72
+ register("submit", createSvelteRenderer("submit", Submit), { state: "none" });
73
+ var submit_default = Submit;
74
+ export {
75
+ submit_default as default,
76
+ Submit
77
+ };
@@ -0,0 +1,114 @@
1
+ .slex-switch {
2
+ display: inline-flex;
3
+ align-items: center;
4
+ gap: 0.5rem;
5
+ cursor: pointer;
6
+ }
7
+
8
+ .slex-switch-event-layer {
9
+ display: inline-flex;
10
+ }
11
+
12
+ .slex-choice-event-layer {
13
+ display: inline-flex;
14
+ }
15
+
16
+ .slex-switch-label {
17
+ display: inline-flex;
18
+ align-items: center;
19
+ gap: 0.375rem;
20
+ min-width: 0;
21
+ color: var(--foreground);
22
+ font-size: 0.8125rem;
23
+ font-weight: 500;
24
+ }
25
+
26
+ .slex-switch-input {
27
+ position: absolute;
28
+ width: 1px;
29
+ height: 1px;
30
+ padding: 0;
31
+ margin: -1px;
32
+ overflow: hidden;
33
+ clip: rect(0, 0, 0, 0);
34
+ white-space: nowrap;
35
+ border: 0;
36
+ }
37
+
38
+ .slex-switch-control {
39
+ box-sizing: border-box;
40
+ position: relative;
41
+ display: inline-flex;
42
+ align-items: center;
43
+ flex: 0 0 auto;
44
+ width: 2.75rem;
45
+ height: 1.5rem;
46
+ margin-inline-end: 0;
47
+ padding: 0;
48
+ border: 2px solid transparent;
49
+ border-radius: 9999px;
50
+ background: var(--input);
51
+ transition: background-color 150ms ease, border-color 150ms ease, box-shadow 150ms ease;
52
+ }
53
+
54
+ .slex-switch-control::after {
55
+ content: "";
56
+ display: block;
57
+ width: 1.25rem;
58
+ height: 1.25rem;
59
+ border: 0;
60
+ border-radius: 9999px;
61
+ background: var(--background);
62
+ box-shadow: 0 1px 2px color-mix(in oklab, var(--foreground) 12%, transparent);
63
+ transition: border-color 150ms ease, background-color 150ms ease, box-shadow 150ms ease, transform 150ms ease;
64
+ transform: translateX(0);
65
+ will-change: transform;
66
+ }
67
+
68
+ .slex-switch:hover .slex-switch-control {
69
+ border-color: color-mix(in oklab, var(--primary) 42%, var(--input));
70
+ box-shadow: 0 0 0 4px color-mix(in oklab, var(--primary) 8%, transparent);
71
+ }
72
+
73
+ .slex-switch:hover .slex-switch-control::after {
74
+ box-shadow: 0 0 0 4px color-mix(in oklab, var(--primary) 10%, transparent);
75
+ }
76
+
77
+ .slex-switch:active .slex-switch-control::after {
78
+ box-shadow: 0 0 0 5px color-mix(in oklab, var(--primary) 16%, transparent);
79
+ }
80
+
81
+ .slex-switch-input:checked + .slex-switch-control {
82
+ border-color: var(--primary);
83
+ background: var(--primary);
84
+ }
85
+
86
+ .slex-switch:hover .slex-switch-input:checked + .slex-switch-control {
87
+ background: color-mix(in oklab, var(--primary) 88%, var(--background));
88
+ }
89
+
90
+ .slex-switch-input:checked + .slex-switch-control::after {
91
+ background: var(--background);
92
+ transform: translateX(1.25rem);
93
+ }
94
+
95
+ .slexkit-root[dir="rtl"] .slex-switch-input:checked + .slex-switch-control::after {
96
+ transform: translateX(-1.25rem);
97
+ }
98
+
99
+ .slex-switch-input:focus-visible + .slex-switch-control {
100
+ box-shadow: 0 0 0 3px color-mix(in oklab, var(--ring) 18%, transparent);
101
+ }
102
+
103
+ .slex-switch-input:disabled + .slex-switch-control {
104
+ opacity: 0.55;
105
+ }
106
+
107
+ .slex-switch:has(.slex-switch-input:disabled) {
108
+ cursor: not-allowed;
109
+ }
110
+
111
+ .slex-switch:has(.slex-switch-input:disabled):hover .slex-switch-control,
112
+ .slex-switch:has(.slex-switch-input:disabled):hover .slex-switch-control::after {
113
+ box-shadow: none;
114
+ }
@@ -0,0 +1,114 @@
1
+ import {
2
+ InlineIcon
3
+ } from "../chunks/accordion-cw5r75jm.js";
4
+ import {
5
+ append,
6
+ bindPropStore,
7
+ bind_checked,
8
+ child,
9
+ createSvelteRenderer,
10
+ delegate,
11
+ delegated,
12
+ emit,
13
+ from_html,
14
+ get,
15
+ if_block,
16
+ pop,
17
+ proxy,
18
+ push,
19
+ remove_input_defaults,
20
+ reset,
21
+ set,
22
+ set_attribute,
23
+ set_text,
24
+ sibling,
25
+ state,
26
+ template_effect,
27
+ text1 as text,
28
+ user_effect
29
+ } from "../chunks/accordion-nw12ytps.js";
30
+
31
+ // src/components/entries/switch.ts
32
+ import { register } from "../runtime.js";
33
+
34
+ // src/components/svelte/input/Switch.svelte
35
+ var root = from_html(`<span class="slex-switch-event-layer"><label class="slex-switch"><input type="checkbox" role="switch" class="slex-switch-input"/> <span class="slex-switch-control" aria-hidden="true"></span> <span class="slex-switch-label"><!> <span> </span></span></label></span>`);
36
+ function Switch($$anchor, $$props) {
37
+ push($$props, true);
38
+ let p = state(proxy({}));
39
+ let enabled = state(false);
40
+ let lastHapticAt = 0;
41
+ user_effect(() => bindPropStore($$props.props, (next) => {
42
+ set(p, next, true);
43
+ set(enabled, !!next.enabled);
44
+ }));
45
+ function toggle(event) {
46
+ if (get(p).disabled)
47
+ return;
48
+ set(enabled, event.target.checked, true);
49
+ emit($$props.ctx, "change", get(enabled));
50
+ }
51
+ function vibrate(duration = 8) {
52
+ if (get(p).haptic === false || get(p).haptics === false || get(p).disabled)
53
+ return;
54
+ const api = globalThis.navigator;
55
+ api?.vibrate?.(duration);
56
+ }
57
+ function haptic(duration = 8) {
58
+ const now = Date.now();
59
+ if (now - lastHapticAt < 80)
60
+ return;
61
+ lastHapticAt = now;
62
+ vibrate(duration);
63
+ }
64
+ var span = root();
65
+ var label = child(span);
66
+ var input = child(label);
67
+ remove_input_defaults(input);
68
+ var span_1 = sibling(input, 4);
69
+ var node = child(span_1);
70
+ {
71
+ var consequent = ($$anchor2) => {
72
+ InlineIcon($$anchor2, {
73
+ get name() {
74
+ return get(p).icon;
75
+ },
76
+ className: "slex-switch-icon"
77
+ });
78
+ };
79
+ if_block(node, ($$render) => {
80
+ if (get(p).icon)
81
+ $$render(consequent);
82
+ });
83
+ }
84
+ var span_2 = sibling(node, 2);
85
+ var text_1 = child(span_2, true);
86
+ reset(span_2);
87
+ reset(span_1);
88
+ reset(label);
89
+ reset(span);
90
+ template_effect(($0, $1) => {
91
+ set_attribute(label, "data-state", get(enabled) ? "on" : "off");
92
+ input.disabled = !!get(p).disabled;
93
+ set_attribute(input, "aria-label", $0);
94
+ set_text(text_1, $1);
95
+ }, [
96
+ () => text(get(p)["aria-label"] ?? get(p).ariaLabel ?? get(p).label) || undefined,
97
+ () => text(get(p).label)
98
+ ]);
99
+ delegated("pointerdown", span, () => haptic(8));
100
+ delegated("click", span, () => haptic(8));
101
+ delegated("change", input, toggle);
102
+ bind_checked(input, () => get(enabled), ($$value) => set(enabled, $$value));
103
+ append($$anchor, span);
104
+ pop();
105
+ }
106
+ delegate(["pointerdown", "click", "change"]);
107
+
108
+ // src/components/entries/switch.ts
109
+ register("switch", createSvelteRenderer("switch", Switch), { state: "enabled" });
110
+ var switch_default = Switch;
111
+ export {
112
+ switch_default as default,
113
+ Switch
114
+ };
@@ -0,0 +1,157 @@
1
+ import {
2
+ InlineIcon
3
+ } from "../chunks/accordion-cw5r75jm.js";
4
+ import {
5
+ append,
6
+ bindPropStore,
7
+ child,
8
+ comment,
9
+ createSvelteRenderer,
10
+ each,
11
+ first_child,
12
+ from_html,
13
+ get,
14
+ if_block,
15
+ index,
16
+ pop,
17
+ proxy,
18
+ push,
19
+ readCell,
20
+ readColumnLabel,
21
+ readColumns,
22
+ reset,
23
+ rows,
24
+ set,
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/table.ts
35
+ import { register } from "../runtime.js";
36
+
37
+ // src/components/svelte/content/Table.svelte
38
+ var root_2 = from_html(`<th scope="col"><span class="slex-table-column-label"><!> <span> </span></span></th>`);
39
+ var root_1 = from_html(`<thead><tr></tr></thead>`);
40
+ var root_6 = from_html(`<td> </td>`);
41
+ var root_8 = from_html(`<td> </td>`);
42
+ var root_9 = from_html(`<td> </td>`);
43
+ var root_4 = from_html(`<tr><!></tr>`);
44
+ var root = from_html(`<div class="slex-table-wrap"><table class="slex-table"><!><tbody></tbody></table></div>`);
45
+ function Table($$anchor, $$props) {
46
+ push($$props, true);
47
+ let p = state(proxy({}));
48
+ user_effect(() => bindPropStore($$props.props, (next) => set(p, next, true)));
49
+ var div = root();
50
+ var table = child(div);
51
+ var node = child(table);
52
+ {
53
+ var consequent_1 = ($$anchor2) => {
54
+ var thead = root_1();
55
+ var tr = child(thead);
56
+ each(tr, 21, () => rows(get(p).columns), index, ($$anchor3, column, index2) => {
57
+ var th = root_2();
58
+ var span = child(th);
59
+ var node_1 = child(span);
60
+ {
61
+ var consequent = ($$anchor4) => {
62
+ InlineIcon($$anchor4, {
63
+ get name() {
64
+ return get(column).icon;
65
+ },
66
+ className: "slex-table-column-icon"
67
+ });
68
+ };
69
+ if_block(node_1, ($$render) => {
70
+ if (get(column) && typeof get(column) === "object" && "icon" in get(column))
71
+ $$render(consequent);
72
+ });
73
+ }
74
+ var span_1 = sibling(node_1, 2);
75
+ var text_1 = child(span_1, true);
76
+ reset(span_1);
77
+ reset(span);
78
+ reset(th);
79
+ template_effect(($0) => set_text(text_1, $0), [
80
+ () => readColumnLabel(get(column), readColumns(get(p).columns)[index2] ?? "")
81
+ ]);
82
+ append($$anchor3, th);
83
+ });
84
+ reset(tr);
85
+ reset(thead);
86
+ append($$anchor2, thead);
87
+ };
88
+ var d = user_derived(() => readColumns(get(p).columns).length);
89
+ if_block(node, ($$render) => {
90
+ if (get(d))
91
+ $$render(consequent_1);
92
+ });
93
+ }
94
+ var tbody = sibling(node);
95
+ each(tbody, 21, () => rows(get(p).rows ?? get(p).items), index, ($$anchor2, row) => {
96
+ var tr_1 = root_4();
97
+ var node_2 = child(tr_1);
98
+ {
99
+ var consequent_2 = ($$anchor3) => {
100
+ var fragment_1 = comment();
101
+ var node_3 = first_child(fragment_1);
102
+ each(node_3, 17, () => readColumns(get(p).columns), index, ($$anchor4, column) => {
103
+ var td = root_6();
104
+ var text_2 = child(td, true);
105
+ reset(td);
106
+ template_effect(($0) => set_text(text_2, $0), [() => readCell(get(row), get(column))]);
107
+ append($$anchor4, td);
108
+ });
109
+ append($$anchor3, fragment_1);
110
+ };
111
+ var d_1 = user_derived(() => readColumns(get(p).columns).length);
112
+ var consequent_3 = ($$anchor3) => {
113
+ var fragment_2 = comment();
114
+ var node_4 = first_child(fragment_2);
115
+ each(node_4, 17, () => get(row), index, ($$anchor4, cell) => {
116
+ var td_1 = root_8();
117
+ var text_3 = child(td_1, true);
118
+ reset(td_1);
119
+ template_effect(($0) => set_text(text_3, $0), [() => text(get(cell))]);
120
+ append($$anchor4, td_1);
121
+ });
122
+ append($$anchor3, fragment_2);
123
+ };
124
+ var d_2 = user_derived(() => Array.isArray(get(row)));
125
+ var alternate = ($$anchor3) => {
126
+ var td_2 = root_9();
127
+ var text_4 = child(td_2, true);
128
+ reset(td_2);
129
+ template_effect(($0) => set_text(text_4, $0), [() => text(get(row))]);
130
+ append($$anchor3, td_2);
131
+ };
132
+ if_block(node_2, ($$render) => {
133
+ if (get(d_1))
134
+ $$render(consequent_2);
135
+ else if (get(d_2))
136
+ $$render(consequent_3, 1);
137
+ else
138
+ $$render(alternate, -1);
139
+ });
140
+ }
141
+ reset(tr_1);
142
+ append($$anchor2, tr_1);
143
+ });
144
+ reset(tbody);
145
+ reset(table);
146
+ reset(div);
147
+ append($$anchor, div);
148
+ pop();
149
+ }
150
+
151
+ // src/components/entries/table.ts
152
+ register("table", createSvelteRenderer("table", Table), { state: "readable" });
153
+ var table_default = Table;
154
+ export {
155
+ table_default as default,
156
+ Table
157
+ };