slexkit 0.2.0 → 0.3.1

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 (104) hide show
  1. package/CHANGELOG.md +70 -0
  2. package/LICENSE +21 -21
  3. package/README.md +4 -3
  4. package/README.zh-CN.md +4 -3
  5. package/dist/ai/llms-authoring.txt +2 -0
  6. package/dist/ai/llms-capabilities.txt +126 -0
  7. package/dist/ai/llms-components.txt +29 -7
  8. package/dist/ai/llms-full.txt +1909 -153
  9. package/dist/ai/llms-runtime.txt +18 -13
  10. package/dist/ai/llms.txt +22 -1
  11. package/dist/ai/slexkit-ai-manifest.json +717 -62
  12. package/dist/base.css +359 -359
  13. package/dist/chunks/{accordion-cfjyxw93.js → button-53ccjq5p.js} +11 -11
  14. package/dist/chunks/{accordion-nw12ytps.js → button-cr1fhsa7.js} +48 -2
  15. package/dist/chunks/{accordion-5f0nvjjm.js → button-dsftwzvg.js} +4 -3
  16. package/dist/chunks/{accordion-hzyrngd6.js → button-faf563xf.js} +2 -2
  17. package/dist/chunks/{accordion-ehnhpeca.js → button-jxv4c65t.js} +2 -2
  18. package/dist/chunks/{accordion-cw5r75jm.js → button-xv2dz7vn.js} +1 -1
  19. package/dist/chunks/{accordion-830dw78f.js → button-z5yv24ks.js} +2 -2
  20. package/dist/components/accordion.js +2 -2
  21. package/dist/components/badge.js +2 -2
  22. package/dist/components/button.css +101 -101
  23. package/dist/components/button.js +3 -3
  24. package/dist/components/callout.js +4 -4
  25. package/dist/components/card.js +2 -2
  26. package/dist/components/checkbox.js +3 -2
  27. package/dist/components/choice.css +151 -151
  28. package/dist/components/code-block.js +2 -2
  29. package/dist/components/collapsible.js +2 -2
  30. package/dist/components/column.js +1 -1
  31. package/dist/components/content.css +273 -250
  32. package/dist/components/display.css +1 -1
  33. package/dist/components/divider.js +2 -2
  34. package/dist/components/grid.js +1 -1
  35. package/dist/components/index.js +13994 -172
  36. package/dist/components/input.css +786 -852
  37. package/dist/components/input.js +34 -144
  38. package/dist/components/link.js +2 -2
  39. package/dist/components/progress.js +2 -2
  40. package/dist/components/radio-group.js +3 -2
  41. package/dist/components/row.js +1 -1
  42. package/dist/components/section.js +2 -2
  43. package/dist/components/select.css +175 -181
  44. package/dist/components/select.js +3 -3
  45. package/dist/components/slider.css +125 -116
  46. package/dist/components/slider.js +2 -2
  47. package/dist/components/specs.js +34 -1
  48. package/dist/components/stat.js +2 -2
  49. package/dist/components/submit.css +8 -8
  50. package/dist/components/submit.js +1 -1
  51. package/dist/components/switch.css +105 -105
  52. package/dist/components/switch.js +4 -3
  53. package/dist/components/table.js +4 -4
  54. package/dist/components/tabs.css +95 -95
  55. package/dist/components/tabs.js +4 -4
  56. package/dist/components/text-input.css +26 -95
  57. package/dist/components/text.js +13 -1
  58. package/dist/components/toast.js +4 -4
  59. package/dist/components/tooling.css +0 -1
  60. package/dist/components/tooling.js +73 -8
  61. package/dist/runtime.cjs +1610 -17
  62. package/dist/runtime.js +1609 -16
  63. package/dist/slexkit.cjs +28191 -13865
  64. package/dist/slexkit.css +1525 -1569
  65. package/dist/slexkit.js +28190 -13864
  66. package/dist/tooling.js +117 -11
  67. package/dist/types/components/svelte/helpers.d.ts +8 -1
  68. package/dist/types/engine/capabilities.d.ts +54 -0
  69. package/dist/types/engine/index.d.ts +6 -0
  70. package/dist/types/engine/secure-runtime.d.ts +9 -1
  71. package/dist/types/engine/stdlib.d.ts +30 -0
  72. package/dist/types/engine/types.d.ts +1 -0
  73. package/dist/types/engine/validation.d.ts +28 -0
  74. package/dist/types/index.d.ts +6 -3
  75. package/dist/types/runtime.d.ts +6 -3
  76. package/dist/types/version.d.ts +2 -2
  77. package/dist/umd/slexkit.tooling.umd.js +45084 -44775
  78. package/dist/umd/slexkit.umd.js +28191 -13865
  79. package/package.json +5 -3
  80. package/skills/slexkit-host-integration/SKILL.md +1 -1
  81. package/src/components/svelte/content/Formula.svelte +27 -0
  82. package/src/components/svelte/content/Table.svelte +1 -1
  83. package/src/components/svelte/display/Text.svelte +14 -1
  84. package/src/components/svelte/helpers.ts +56 -1
  85. package/src/components/svelte/input/Checkbox.svelte +1 -1
  86. package/src/components/svelte/input/Input.svelte +0 -110
  87. package/src/components/svelte/input/RadioGroup.svelte +1 -1
  88. package/src/components/svelte/input/Select.svelte +2 -2
  89. package/src/components/svelte/input/Switch.svelte +2 -2
  90. package/src/components/svelte/input/Tabs.svelte +7 -7
  91. package/src/components/svelte/tooling/PlaygroundMarkdown.svelte +84 -2
  92. package/src/styles/components/button.css +101 -101
  93. package/src/styles/components/choice.css +152 -152
  94. package/src/styles/components/select.css +175 -181
  95. package/src/styles/components/slider.css +125 -116
  96. package/src/styles/components/submit.css +8 -8
  97. package/src/styles/components/switch.css +105 -105
  98. package/src/styles/components/tabs.css +95 -95
  99. package/src/styles/components/text-input.css +26 -95
  100. package/src/styles/content.css +274 -251
  101. package/src/styles/display.css +1 -1
  102. package/src/styles/input.css +8 -8
  103. package/src/styles/layout.css +360 -360
  104. package/src/styles/tooling.css +0 -1
@@ -1,104 +1,104 @@
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
-
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
102
  .slex-button-icon {
103
103
  display: inline-flex;
104
104
  width: 1.125rem;
@@ -1,15 +1,15 @@
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
-
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
13
  .slex-checkbox-label,
14
14
  .slex-radio-label {
15
15
  display: inline-flex;
@@ -17,149 +17,149 @@
17
17
  gap: 0.375rem;
18
18
  min-width: 0;
19
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
-
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
128
  .slex-radio-group-label {
129
129
  display: inline-flex;
130
130
  align-items: center;
131
131
  gap: 0.375rem;
132
132
  min-width: 0;
133
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
- }
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[data-disabled="true"],
158
+ .slex-radio-field[data-disabled="true"] {
159
+ cursor: not-allowed;
160
+ opacity: 0.65;
161
+ }
162
+
163
+ .slex-radio-indicator {
164
+ display: none;
165
+ }