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,6 +1,6 @@
1
1
  import {
2
2
  InlineIcon
3
- } from "../chunks/accordion-cw5r75jm.js";
3
+ } from "../chunks/button-xv2dz7vn.js";
4
4
  import {
5
5
  append,
6
6
  bindPropStore,
@@ -28,7 +28,7 @@ import {
28
28
  text,
29
29
  text1 as text2,
30
30
  user_effect
31
- } from "../chunks/accordion-nw12ytps.js";
31
+ } from "../chunks/button-cr1fhsa7.js";
32
32
 
33
33
  // src/components/entries/slider.ts
34
34
  import { register } from "../runtime.js";
@@ -408,6 +408,37 @@ var dividerSpec = component({
408
408
  })]
409
409
  });
410
410
 
411
+ // src/components/entries/formula.spec.ts
412
+ var formulaSpec = component({
413
+ type: "formula",
414
+ category: "Display",
415
+ title: "Formula",
416
+ summary: "Reactive KaTeX formula display.",
417
+ description: "Use formula to render SlexKit state and computed values through KaTeX.",
418
+ props: {
419
+ tex: { type: "string", dynamic: true, description: "KaTeX source to render." },
420
+ formula: { type: "string", dynamic: true, description: "Alias for tex." },
421
+ value: { type: "string", dynamic: true, description: "Alias for tex." },
422
+ displayMode: { type: "boolean", default: true, description: "Render as display math when true; inline math when false." },
423
+ display: { type: "boolean", default: true, description: "Alias for displayMode." },
424
+ block: { type: "boolean", default: true, description: "Alias for displayMode." }
425
+ },
426
+ children: noChildren,
427
+ examples: [example("formula", {
428
+ namespace: "doc_formula_typical",
429
+ g: {
430
+ r: 1e4,
431
+ c: 100,
432
+ fc: 159.15
433
+ },
434
+ layout: {
435
+ "formula:cutoff": {
436
+ $tex: "'f_c = \\\\frac{1}{2\\\\pi RC} = ' + g.fc + '\\\\text{ Hz}'"
437
+ }
438
+ }
439
+ })]
440
+ });
441
+
411
442
  // src/components/entries/grid.spec.ts
412
443
  var gridSpec = component({
413
444
  type: "grid",
@@ -495,7 +526,6 @@ var inputSpec = component({
495
526
  min: { type: "string | number", dynamic: true, description: "Minimum value used by numeric input controls." },
496
527
  max: { type: "string | number", dynamic: true, description: "Maximum value used by numeric input controls." },
497
528
  step: { type: "string | number", dynamic: true, description: "Step size used by numeric input controls." },
498
- controls: { type: "boolean", default: true, dynamic: true, description: "Show decrement and increment buttons for numeric inputs." },
499
529
  onchange: { type: "write-expression", description: "Write expression invoked when the value changes." }
500
530
  },
501
531
  children: noChildren,
@@ -1003,6 +1033,8 @@ var textSpec = component({
1003
1033
  content: { type: "string", dynamic: true, description: "Alias for text." },
1004
1034
  label: { type: "string", dynamic: true, description: "Alias for text." },
1005
1035
  variant: { type: "string", values: ["default", "muted"], default: "default", description: "Text visual variant." },
1036
+ color: { type: "string", dynamic: true, description: "Optional CSS color for controlled previews." },
1037
+ size: { type: "string | number", dynamic: true, description: "Optional font size. Numbers are treated as px." },
1006
1038
  class: { type: "string", description: "Additional host-controlled CSS class." }
1007
1039
  },
1008
1040
  children: noChildren,
@@ -1066,6 +1098,7 @@ var componentSpecs = [
1066
1098
  collapsibleSpec,
1067
1099
  columnSpec,
1068
1100
  dividerSpec,
1101
+ formulaSpec,
1069
1102
  gridSpec,
1070
1103
  iconSpec,
1071
1104
  inputSpec,
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  InlineIcon
3
- } from "../chunks/accordion-cw5r75jm.js";
3
+ } from "../chunks/button-xv2dz7vn.js";
4
4
  import {
5
5
  append,
6
6
  bindPropStore,
@@ -23,7 +23,7 @@ import {
23
23
  text1 as text,
24
24
  user_derived,
25
25
  user_effect
26
- } from "../chunks/accordion-nw12ytps.js";
26
+ } from "../chunks/button-cr1fhsa7.js";
27
27
 
28
28
  // src/components/entries/stat.ts
29
29
  import { register } from "../runtime.js";
@@ -1,9 +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);
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
9
  }
@@ -18,7 +18,7 @@ import {
18
18
  state,
19
19
  template_effect,
20
20
  user_effect
21
- } from "../chunks/accordion-nw12ytps.js";
21
+ } from "../chunks/button-cr1fhsa7.js";
22
22
 
23
23
  // src/components/entries/submit.ts
24
24
  import { register } from "../runtime.js";
@@ -1,114 +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
-
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
16
  .slex-switch-label {
17
17
  display: inline-flex;
18
18
  align-items: center;
19
19
  gap: 0.375rem;
20
20
  min-width: 0;
21
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;
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
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;
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
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;
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[data-disabled="true"] {
108
+ cursor: not-allowed;
109
+ }
110
+
111
+ .slex-switch[data-disabled="true"]:hover .slex-switch-control,
112
+ .slex-switch[data-disabled="true"]:hover .slex-switch-control::after {
113
+ box-shadow: none;
114
114
  }
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  InlineIcon
3
- } from "../chunks/accordion-cw5r75jm.js";
3
+ } from "../chunks/button-xv2dz7vn.js";
4
4
  import {
5
5
  append,
6
6
  bindPropStore,
@@ -26,7 +26,7 @@ import {
26
26
  template_effect,
27
27
  text1 as text,
28
28
  user_effect
29
- } from "../chunks/accordion-nw12ytps.js";
29
+ } from "../chunks/button-cr1fhsa7.js";
30
30
 
31
31
  // src/components/entries/switch.ts
32
32
  import { register } from "../runtime.js";
@@ -40,7 +40,7 @@ function Switch($$anchor, $$props) {
40
40
  let lastHapticAt = 0;
41
41
  user_effect(() => bindPropStore($$props.props, (next) => {
42
42
  set(p, next, true);
43
- set(enabled, !!next.enabled);
43
+ set(enabled, !!(next.enabled ?? next.checked ?? next.value));
44
44
  }));
45
45
  function toggle(event) {
46
46
  if (get(p).disabled)
@@ -89,6 +89,7 @@ function Switch($$anchor, $$props) {
89
89
  reset(span);
90
90
  template_effect(($0, $1) => {
91
91
  set_attribute(label, "data-state", get(enabled) ? "on" : "off");
92
+ set_attribute(label, "data-disabled", get(p).disabled ? "true" : undefined);
92
93
  input.disabled = !!get(p).disabled;
93
94
  set_attribute(input, "aria-label", $0);
94
95
  set_text(text_1, $1);
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  InlineIcon
3
- } from "../chunks/accordion-cw5r75jm.js";
3
+ } from "../chunks/button-xv2dz7vn.js";
4
4
  import {
5
5
  append,
6
6
  bindPropStore,
@@ -29,7 +29,7 @@ import {
29
29
  text1 as text,
30
30
  user_derived,
31
31
  user_effect
32
- } from "../chunks/accordion-nw12ytps.js";
32
+ } from "../chunks/button-cr1fhsa7.js";
33
33
 
34
34
  // src/components/entries/table.ts
35
35
  import { register } from "../runtime.js";
@@ -99,11 +99,11 @@ function Table($$anchor, $$props) {
99
99
  var consequent_2 = ($$anchor3) => {
100
100
  var fragment_1 = comment();
101
101
  var node_3 = first_child(fragment_1);
102
- each(node_3, 17, () => readColumns(get(p).columns), index, ($$anchor4, column) => {
102
+ each(node_3, 17, () => readColumns(get(p).columns), index, ($$anchor4, column, index2) => {
103
103
  var td = root_6();
104
104
  var text_2 = child(td, true);
105
105
  reset(td);
106
- template_effect(($0) => set_text(text_2, $0), [() => readCell(get(row), get(column))]);
106
+ template_effect(($0) => set_text(text_2, $0), [() => readCell(get(row), get(column), index2)]);
107
107
  append($$anchor4, td);
108
108
  });
109
109
  append($$anchor3, fragment_1);
@@ -1,43 +1,43 @@
1
- .slex-tabs {
2
- display: flex;
3
- flex-direction: column;
4
- width: 100%;
5
- }
6
-
7
- .slex-tabs[data-orientation="vertical"] {
8
- flex-direction: row;
9
- }
10
-
1
+ .slex-tabs {
2
+ display: flex;
3
+ flex-direction: column;
4
+ width: 100%;
5
+ }
6
+
7
+ .slex-tabs[data-orientation="vertical"] {
8
+ flex-direction: row;
9
+ }
10
+
11
11
  .slex-tabs-list {
12
12
  --slex-tabs-indicator-inline-inset: 12px;
13
13
  --slex-tabs-indicator-block-inset: 8px;
14
14
  position: relative;
15
15
  display: flex;
16
- gap: 0;
17
- margin: 0;
18
- padding: 0;
19
- list-style: none;
20
- overflow: hidden;
21
- border-bottom: 1px solid var(--border);
22
- }
23
-
24
- .slexkit-root .slex-tabs-list {
25
- display: flex;
26
- gap: 0;
27
- margin: 0;
28
- padding: 0;
29
- list-style: none;
30
- }
31
-
32
- .slexkit-root .slex-tabs-list li {
33
- margin: 0;
34
- padding: 0;
35
- color: inherit;
36
- font: inherit;
37
- line-height: inherit;
38
- list-style: none;
39
- }
40
-
16
+ gap: 0;
17
+ margin: 0;
18
+ padding: 0;
19
+ list-style: none;
20
+ overflow: hidden;
21
+ border-bottom: 1px solid var(--border);
22
+ }
23
+
24
+ .slexkit-root .slex-tabs-list {
25
+ display: flex;
26
+ gap: 0;
27
+ margin: 0;
28
+ padding: 0;
29
+ list-style: none;
30
+ }
31
+
32
+ .slexkit-root .slex-tabs-list li {
33
+ margin: 0;
34
+ padding: 0;
35
+ color: inherit;
36
+ font: inherit;
37
+ line-height: inherit;
38
+ list-style: none;
39
+ }
40
+
41
41
  .slex-tabs-selected-indicator {
42
42
  position: absolute;
43
43
  z-index: 20;
@@ -63,25 +63,25 @@
63
63
  .slex-tabs[data-orientation="vertical"] .slex-tabs-list {
64
64
  flex-direction: column;
65
65
  border-right: 1px solid var(--border);
66
- border-bottom: none;
67
- }
68
-
69
- .slex-tabs-trigger {
70
- position: relative;
71
- padding: 0.5rem 1rem;
72
- border: none;
73
- border-radius: 0;
74
- background: transparent;
75
- color: var(--muted-foreground);
76
- font-family: inherit;
77
- font-size: 0.875rem;
78
- font-weight: 500;
79
- white-space: nowrap;
66
+ border-bottom: none;
67
+ }
68
+
69
+ .slex-tabs-trigger {
70
+ position: relative;
71
+ padding: 0.5rem 1rem;
72
+ border: none;
73
+ border-radius: 0;
74
+ background: transparent;
75
+ color: var(--muted-foreground);
76
+ font-family: inherit;
77
+ font-size: 0.875rem;
78
+ font-weight: 500;
79
+ white-space: nowrap;
80
80
  cursor: pointer;
81
81
  outline: none;
82
82
  user-select: none;
83
83
  }
84
-
84
+
85
85
  .slex-tabs-trigger--icon {
86
86
  display: inline-grid;
87
87
  width: var(--slex-control-height, 2.25rem);
@@ -123,17 +123,17 @@
123
123
  .slex-tabs-trigger.slex-tabs-trigger--selected:hover:not([data-disabled]) {
124
124
  color: var(--primary);
125
125
  }
126
-
127
- .slex-tabs-trigger[data-disabled] {
128
- opacity: 0.4;
129
- cursor: not-allowed;
130
- }
131
-
132
- .slex-tabs-trigger:focus-visible {
133
- outline: 2px solid var(--ring);
134
- outline-offset: -2px;
135
- }
136
-
126
+
127
+ .slex-tabs-trigger[data-disabled] {
128
+ opacity: 0.4;
129
+ cursor: not-allowed;
130
+ }
131
+
132
+ .slex-tabs-trigger:focus-visible {
133
+ outline: 2px solid var(--ring);
134
+ outline-offset: -2px;
135
+ }
136
+
137
137
  .slex-tabs-content {
138
138
  margin-top: 0.75rem !important;
139
139
  border-radius: 0 !important;
@@ -155,38 +155,38 @@
155
155
  }
156
156
 
157
157
  @keyframes slex-tabs-content-in {
158
- from {
159
- opacity: 0;
160
- transform: translateY(2px);
161
- }
162
- to {
163
- opacity: 1;
164
- transform: translateY(0);
165
- }
166
- }
167
-
168
- .slex-tabs-content[hidden] {
169
- display: none;
170
- }
171
-
172
- @media (max-width: 640px) {
173
- .slex-tabs-list {
174
- overflow-x: auto;
175
- scrollbar-width: none;
176
- }
177
-
178
- .slex-tabs-list::-webkit-scrollbar {
179
- display: none;
180
- }
181
-
182
- .slex-tabs[data-orientation="vertical"] {
183
- flex-direction: column;
184
- }
185
-
186
- .slex-tabs[data-orientation="vertical"] .slex-tabs-list {
187
- flex-direction: row;
188
- border-right: 0;
189
- border-bottom: 1px solid var(--border);
190
- }
191
-
158
+ from {
159
+ opacity: 0;
160
+ transform: translateY(2px);
161
+ }
162
+ to {
163
+ opacity: 1;
164
+ transform: translateY(0);
165
+ }
166
+ }
167
+
168
+ .slex-tabs-content[hidden] {
169
+ display: none;
170
+ }
171
+
172
+ @media (max-width: 640px) {
173
+ .slex-tabs-list {
174
+ overflow-x: auto;
175
+ scrollbar-width: none;
176
+ }
177
+
178
+ .slex-tabs-list::-webkit-scrollbar {
179
+ display: none;
180
+ }
181
+
182
+ .slex-tabs[data-orientation="vertical"] {
183
+ flex-direction: column;
184
+ }
185
+
186
+ .slex-tabs[data-orientation="vertical"] .slex-tabs-list {
187
+ flex-direction: row;
188
+ border-right: 0;
189
+ border-bottom: 1px solid var(--border);
190
+ }
191
+
192
192
  }
@@ -1,11 +1,11 @@
1
1
  import {
2
2
  Tabs
3
- } from "../chunks/accordion-cfjyxw93.js";
4
- import"../chunks/accordion-hzyrngd6.js";
5
- import"../chunks/accordion-cw5r75jm.js";
3
+ } from "../chunks/button-53ccjq5p.js";
4
+ import"../chunks/button-faf563xf.js";
5
+ import"../chunks/button-xv2dz7vn.js";
6
6
  import {
7
7
  createSvelteRenderer
8
- } from "../chunks/accordion-nw12ytps.js";
8
+ } from "../chunks/button-cr1fhsa7.js";
9
9
 
10
10
  // src/components/entries/tabs.ts
11
11
  import { register } from "../runtime.js";