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,26 @@
1
+ <script lang="ts">
2
+ import SvelteMarkdown from "../../../../node_modules/@humanspeak/svelte-markdown/dist/index.js";
3
+ import { KatexRenderer, markedKatex } from "../../../../node_modules/@humanspeak/svelte-markdown/dist/extensions/index.js";
4
+ import PlaygroundSlexCode from "./PlaygroundSlexCode.svelte";
5
+
6
+ type Props = {
7
+ content: string;
8
+ domain?: string;
9
+ };
10
+
11
+ let { content, domain }: Props = $props();
12
+
13
+ const extensions = [markedKatex({ singleDollarInline: true })];
14
+ const renderers = {
15
+ inlineKatex: KatexRenderer,
16
+ blockKatex: KatexRenderer,
17
+ };
18
+ </script>
19
+
20
+ <div class="slex-doc-streamdown">
21
+ <SvelteMarkdown source={content} {extensions} {renderers}>
22
+ {#snippet code({ lang, text })}
23
+ <PlaygroundSlexCode {lang} {text} {domain} />
24
+ {/snippet}
25
+ </SvelteMarkdown>
26
+ </div>
@@ -0,0 +1,76 @@
1
+ <script lang="ts">
2
+ import { mount, parseSlexSource } from "../../../engine/index";
3
+
4
+ type Props = {
5
+ lang?: string;
6
+ text?: string;
7
+ domain?: string;
8
+ };
9
+
10
+ let { lang = "", text = "", domain }: Props = $props();
11
+ let error = $state<unknown>(null);
12
+
13
+ const language = $derived(String(lang ?? "").trim().split(/\s+/, 1)[0].toLowerCase());
14
+ const isSlexKit = $derived(language === "slex");
15
+ const runtimeInput = $derived(scopedSlexKitInput(text, domain));
16
+
17
+ function renderPreview(node: HTMLElement) {
18
+ let cleanup: (() => void) | undefined;
19
+
20
+ const render = () => {
21
+ cleanup?.();
22
+ node.replaceChildren();
23
+ error = null;
24
+ if (!isSlexKit) return;
25
+
26
+ try {
27
+ cleanup = mount(runtimeInput, node);
28
+ } catch (err) {
29
+ error = err;
30
+ }
31
+ };
32
+
33
+ render();
34
+ return {
35
+ update: render,
36
+ destroy() {
37
+ cleanup?.();
38
+ node.replaceChildren();
39
+ },
40
+ };
41
+ }
42
+
43
+ function scopedSlexKitInput(code: string, scope: string | undefined) {
44
+ if (!scope) return code;
45
+ const parsed = parseSlexSource(code);
46
+ if (!parsed.ok || !parsed.value || typeof parsed.value !== "object") {
47
+ return code;
48
+ }
49
+ const source = parsed.value as Record<string, unknown>;
50
+ if (!("namespace" in source) && !("g" in source) && !("layout" in source) && Object.keys(source).some((key) => key.includes(":"))) {
51
+ const { slex, ...layout } = source;
52
+ return {
53
+ ...(typeof slex === "string" ? { slex } : {}),
54
+ namespace: `${scope}::default`,
55
+ layout,
56
+ };
57
+ }
58
+ return {
59
+ ...source,
60
+ namespace: `${scope}::${String(source.namespace || "default")}`,
61
+ };
62
+ }
63
+ </script>
64
+
65
+ {#if isSlexKit}
66
+ {#if error}
67
+ <div class="slex-streamdown-error" role="alert">
68
+ <div class="slex-streamdown-error-title">Failed to render SlexKit</div>
69
+ <div class="slex-streamdown-error-message">{error instanceof Error ? error.message : String(error)}</div>
70
+ </div>
71
+ {:else}
72
+ <div use:renderPreview={runtimeInput}></div>
73
+ {/if}
74
+ {:else}
75
+ <pre class={lang}><code>{text}</code></pre>
76
+ {/if}
@@ -0,0 +1,17 @@
1
+ import type { Component } from "svelte";
2
+ import type { RenderContext } from "../../engine/types";
3
+
4
+ export type PropValues = Record<string, unknown>;
5
+
6
+ export type PropStore = {
7
+ subscribe(run: (value: PropValues) => void): () => void;
8
+ };
9
+
10
+ export type SvelteComponentProps = {
11
+ componentName: string;
12
+ ctx: RenderContext;
13
+ props: PropStore;
14
+ };
15
+
16
+ export type SvelteBuiltinComponent = Component<SvelteComponentProps>;
17
+
@@ -0,0 +1,98 @@
1
+ @keyframes slex-fade-in {
2
+ from {
3
+ opacity: 0;
4
+ transform: translateY(4px);
5
+ }
6
+ to {
7
+ opacity: 1;
8
+ transform: translateY(0);
9
+ }
10
+ }
11
+
12
+ @keyframes slex-fade-out {
13
+ from {
14
+ opacity: 1;
15
+ transform: translateY(0);
16
+ }
17
+ to {
18
+ opacity: 0;
19
+ transform: translateY(4px);
20
+ }
21
+ }
22
+
23
+ @keyframes slex-slide-in {
24
+ from {
25
+ opacity: 0;
26
+ transform: translateX(-8px);
27
+ }
28
+ to {
29
+ opacity: 1;
30
+ transform: translateX(0);
31
+ }
32
+ }
33
+
34
+ @keyframes slex-slide-out {
35
+ from {
36
+ opacity: 1;
37
+ transform: translateX(0);
38
+ }
39
+ to {
40
+ opacity: 0;
41
+ transform: translateX(-8px);
42
+ }
43
+ }
44
+
45
+ @keyframes slex-pulse {
46
+ 0%, 100% { opacity: 1; }
47
+ 50% { opacity: 0.6; }
48
+ }
49
+
50
+ .slex-fade-in {
51
+ animation: slex-fade-in 0.3s ease-out;
52
+ }
53
+
54
+ .slex-fade-out {
55
+ animation: slex-fade-out 0.3s ease-out;
56
+ }
57
+
58
+ .slex-slide-in {
59
+ animation: slex-slide-in 0.3s ease-out;
60
+ }
61
+
62
+ .slex-slide-out {
63
+ animation: slex-slide-out 0.3s ease-out;
64
+ }
65
+
66
+ .slex-pulse {
67
+ animation: slex-pulse 2s ease-in-out infinite;
68
+ }
69
+
70
+ .slex-enter {
71
+ animation-duration: 0.3s;
72
+ animation-fill-mode: both;
73
+ }
74
+
75
+ @keyframes slex-scale-in {
76
+ from {
77
+ opacity: 0;
78
+ transform: scale(0.95);
79
+ }
80
+ to {
81
+ opacity: 1;
82
+ transform: scale(1);
83
+ }
84
+ }
85
+
86
+ .slex-scale-in {
87
+ animation-name: slex-scale-in;
88
+ }
89
+
90
+ @media (max-width: 640px) {
91
+ .slex-card {
92
+ padding: 1rem;
93
+ }
94
+
95
+ .slex-stat-value {
96
+ font-size: 1.25rem;
97
+ }
98
+ }
@@ -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,165 @@
1
+ .slex-checkbox-field,
2
+ .slex-radio-field {
3
+ display: inline-flex;
4
+ align-items: center;
5
+ gap: 0.5rem;
6
+ color: var(--foreground);
7
+ font-size: 0.875rem;
8
+ cursor: pointer;
9
+ user-select: none;
10
+ transition: color 150ms ease, opacity 150ms ease;
11
+ }
12
+
13
+ .slex-checkbox-label,
14
+ .slex-radio-label {
15
+ display: inline-flex;
16
+ align-items: center;
17
+ gap: 0.375rem;
18
+ min-width: 0;
19
+ color: var(--foreground);
20
+ line-height: 1.35;
21
+ transition: color 150ms ease;
22
+ }
23
+
24
+ .slex-checkbox,
25
+ .slex-radio {
26
+ box-sizing: border-box;
27
+ position: relative;
28
+ display: inline-grid;
29
+ place-items: center;
30
+ flex: 0 0 auto;
31
+ width: 1rem;
32
+ height: 1rem;
33
+ margin: 0;
34
+ border: 1.5px solid var(--input);
35
+ color: var(--primary);
36
+ accent-color: var(--primary);
37
+ background: var(--background);
38
+ cursor: pointer;
39
+ appearance: none;
40
+ -webkit-appearance: none;
41
+ transition:
42
+ background-color 150ms ease,
43
+ border-color 150ms ease,
44
+ box-shadow 150ms ease,
45
+ transform 120ms ease;
46
+ }
47
+
48
+ .slex-checkbox {
49
+ border-radius: calc(var(--radius) - 4px);
50
+ }
51
+
52
+ .slex-radio {
53
+ border-radius: 999px;
54
+ }
55
+
56
+ .slex-checkbox::after,
57
+ .slex-radio::after {
58
+ content: "";
59
+ display: block;
60
+ opacity: 0;
61
+ transform: scale(0.5);
62
+ transition: opacity 120ms ease, transform 140ms ease;
63
+ }
64
+
65
+ .slex-checkbox::after {
66
+ width: 0.55rem;
67
+ height: 0.34rem;
68
+ border: solid var(--primary-foreground);
69
+ border-width: 0 0 2px 2px;
70
+ transform: translateY(-0.08rem) rotate(-45deg) scale(0.5);
71
+ }
72
+
73
+ .slex-radio::after {
74
+ width: 0.45rem;
75
+ height: 0.45rem;
76
+ border-radius: 999px;
77
+ background: var(--primary-foreground);
78
+ }
79
+
80
+ .slex-checkbox-field:hover .slex-checkbox:not(:disabled),
81
+ .slex-radio-field:hover .slex-radio:not(:disabled) {
82
+ border-color: color-mix(in oklab, var(--primary) 48%, var(--input));
83
+ box-shadow: 0 0 0 4px color-mix(in oklab, var(--primary) 8%, transparent);
84
+ }
85
+
86
+ .slex-checkbox-field:active .slex-checkbox:not(:disabled),
87
+ .slex-radio-field:active .slex-radio:not(:disabled) {
88
+ transform: scale(0.92);
89
+ box-shadow: 0 0 0 5px color-mix(in oklab, var(--primary) 12%, transparent);
90
+ }
91
+
92
+ .slex-checkbox:checked,
93
+ .slex-radio:checked {
94
+ border-color: var(--primary);
95
+ background: var(--primary);
96
+ }
97
+
98
+ .slex-checkbox:checked::after,
99
+ .slex-radio:checked::after {
100
+ opacity: 1;
101
+ }
102
+
103
+ .slex-checkbox:checked::after {
104
+ transform: translateY(-0.08rem) rotate(-45deg) scale(1);
105
+ }
106
+
107
+ .slex-radio:checked::after {
108
+ transform: scale(1);
109
+ }
110
+
111
+ .slex-checkbox-field:hover .slex-checkbox-label,
112
+ .slex-radio-field:hover .slex-radio-label {
113
+ color: var(--foreground);
114
+ }
115
+
116
+ .slex-checkbox:focus-visible,
117
+ .slex-radio:focus-visible {
118
+ outline: 2px solid var(--ring);
119
+ outline-offset: 2px;
120
+ }
121
+
122
+ .slex-radio-group {
123
+ display: flex;
124
+ flex-direction: column;
125
+ gap: 0.625rem;
126
+ }
127
+
128
+ .slex-radio-group-label {
129
+ display: inline-flex;
130
+ align-items: center;
131
+ gap: 0.375rem;
132
+ min-width: 0;
133
+ color: var(--foreground);
134
+ font-size: 0.875rem;
135
+ font-weight: 500;
136
+ }
137
+
138
+ .slex-radio-group-list {
139
+ display: flex;
140
+ flex-direction: column;
141
+ gap: 0.5rem;
142
+ }
143
+
144
+ .slex-radio-group[data-orientation="horizontal"] .slex-radio-group-list {
145
+ flex-direction: row;
146
+ flex-wrap: wrap;
147
+ }
148
+
149
+ .slex-checkbox:disabled,
150
+ .slex-radio:disabled {
151
+ cursor: not-allowed;
152
+ opacity: 0.5;
153
+ box-shadow: none;
154
+ transform: none;
155
+ }
156
+
157
+ .slex-checkbox-field:has(.slex-checkbox:disabled),
158
+ .slex-radio-field:has(.slex-radio:disabled) {
159
+ cursor: not-allowed;
160
+ opacity: 0.65;
161
+ }
162
+
163
+ .slex-radio-indicator {
164
+ display: none;
165
+ }