@chakra-ui/panda-preset 3.3.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.
- package/LICENSE +21 -0
- package/README.md +20 -0
- package/dist/cjs/animation-styles.cjs +55 -0
- package/dist/cjs/breakpoints.cjs +12 -0
- package/dist/cjs/def.cjs +34 -0
- package/dist/cjs/global-css.cjs +50 -0
- package/dist/cjs/index.cjs +43 -0
- package/dist/cjs/keyframes.cjs +260 -0
- package/dist/cjs/layer-styles.cjs +114 -0
- package/dist/cjs/recipes/badge.cjs +72 -0
- package/dist/cjs/recipes/button.cjs +180 -0
- package/dist/cjs/recipes/checkmark.cjs +89 -0
- package/dist/cjs/recipes/code.cjs +68 -0
- package/dist/cjs/recipes/color-swatch.cjs +68 -0
- package/dist/cjs/recipes/container.cjs +35 -0
- package/dist/cjs/recipes/heading.cjs +54 -0
- package/dist/cjs/recipes/icon.cjs +47 -0
- package/dist/cjs/recipes/index.cjs +46 -0
- package/dist/cjs/recipes/input-addon.cjs +81 -0
- package/dist/cjs/recipes/input.cjs +98 -0
- package/dist/cjs/recipes/kbd.cjs +62 -0
- package/dist/cjs/recipes/link.cjs +40 -0
- package/dist/cjs/recipes/mark.cjs +31 -0
- package/dist/cjs/recipes/radiomark.cjs +102 -0
- package/dist/cjs/recipes/separator.cjs +56 -0
- package/dist/cjs/recipes/skeleton.cjs +55 -0
- package/dist/cjs/recipes/skip-nav-link.cjs +36 -0
- package/dist/cjs/recipes/spinner.cjs +49 -0
- package/dist/cjs/recipes/textarea.cjs +91 -0
- package/dist/cjs/semantic-tokens/colors.cjs +617 -0
- package/dist/cjs/semantic-tokens/index.cjs +14 -0
- package/dist/cjs/semantic-tokens/radii.cjs +18 -0
- package/dist/cjs/semantic-tokens/shadows.cjs +57 -0
- package/dist/cjs/slot-recipes/accordion.cjs +150 -0
- package/dist/cjs/slot-recipes/action-bar.cjs +65 -0
- package/dist/cjs/slot-recipes/alert.cjs +165 -0
- package/dist/cjs/slot-recipes/avatar.cjs +144 -0
- package/dist/cjs/slot-recipes/blockquote.cjs +82 -0
- package/dist/cjs/slot-recipes/breadcrumb.cjs +105 -0
- package/dist/cjs/slot-recipes/card.cjs +102 -0
- package/dist/cjs/slot-recipes/checkbox-card.cjs +287 -0
- package/dist/cjs/slot-recipes/checkbox.cjs +132 -0
- package/dist/cjs/slot-recipes/collapsible.cjs +24 -0
- package/dist/cjs/slot-recipes/color-picker.cjs +384 -0
- package/dist/cjs/slot-recipes/data-list.cjs +98 -0
- package/dist/cjs/slot-recipes/dialog.cjs +256 -0
- package/dist/cjs/slot-recipes/drawer.cjs +218 -0
- package/dist/cjs/slot-recipes/editable.cjs +114 -0
- package/dist/cjs/slot-recipes/empty-state.cjs +90 -0
- package/dist/cjs/slot-recipes/field.cjs +80 -0
- package/dist/cjs/slot-recipes/fieldset.cjs +82 -0
- package/dist/cjs/slot-recipes/file-upload.cjs +114 -0
- package/dist/cjs/slot-recipes/hover-card.cjs +70 -0
- package/dist/cjs/slot-recipes/index.cjs +98 -0
- package/dist/cjs/slot-recipes/list.cjs +73 -0
- package/dist/cjs/slot-recipes/menu.cjs +146 -0
- package/dist/cjs/slot-recipes/native-select.cjs +152 -0
- package/dist/cjs/slot-recipes/number-input.cjs +200 -0
- package/dist/cjs/slot-recipes/pin-input.cjs +121 -0
- package/dist/cjs/slot-recipes/popover.cjs +104 -0
- package/dist/cjs/slot-recipes/progress-circle.cjs +106 -0
- package/dist/cjs/slot-recipes/progress.cjs +147 -0
- package/dist/cjs/slot-recipes/qr-code.cjs +80 -0
- package/dist/cjs/slot-recipes/radio-card.cjs +317 -0
- package/dist/cjs/slot-recipes/radio-group.cjs +151 -0
- package/dist/cjs/slot-recipes/rating-group.cjs +88 -0
- package/dist/cjs/slot-recipes/segment-group.cjs +119 -0
- package/dist/cjs/slot-recipes/select.cjs +305 -0
- package/dist/cjs/slot-recipes/slider.cjs +218 -0
- package/dist/cjs/slot-recipes/stat.cjs +84 -0
- package/dist/cjs/slot-recipes/status.cjs +48 -0
- package/dist/cjs/slot-recipes/steps.cjs +231 -0
- package/dist/cjs/slot-recipes/switch.cjs +163 -0
- package/dist/cjs/slot-recipes/table.cjs +175 -0
- package/dist/cjs/slot-recipes/tabs.cjs +281 -0
- package/dist/cjs/slot-recipes/tag.cjs +147 -0
- package/dist/cjs/slot-recipes/timeline.cjs +151 -0
- package/dist/cjs/slot-recipes/toast.cjs +106 -0
- package/dist/cjs/slot-recipes/tooltip.cjs +44 -0
- package/dist/cjs/text-styles.cjs +88 -0
- package/dist/cjs/tokens/animations.cjs +21 -0
- package/dist/cjs/tokens/aspect-ratios.cjs +27 -0
- package/dist/cjs/tokens/blurs.cjs +33 -0
- package/dist/cjs/tokens/borders.cjs +24 -0
- package/dist/cjs/tokens/colors.cjs +441 -0
- package/dist/cjs/tokens/cursor.cjs +33 -0
- package/dist/cjs/tokens/durations.cjs +30 -0
- package/dist/cjs/tokens/easings.cjs +21 -0
- package/dist/cjs/tokens/font-sizes.cjs +51 -0
- package/dist/cjs/tokens/font-weights.cjs +36 -0
- package/dist/cjs/tokens/fonts.cjs +18 -0
- package/dist/cjs/tokens/index.cjs +42 -0
- package/dist/cjs/tokens/letter-spacings.cjs +24 -0
- package/dist/cjs/tokens/line-heights.cjs +24 -0
- package/dist/cjs/tokens/radii.cjs +42 -0
- package/dist/cjs/tokens/sizes.cjs +267 -0
- package/dist/cjs/tokens/spacing.cjs +111 -0
- package/dist/cjs/tokens/z-index.cjs +48 -0
- package/dist/cjs/utilities.cjs +85 -0
- package/dist/esm/animation-styles.js +53 -0
- package/dist/esm/breakpoints.js +10 -0
- package/dist/esm/def.js +22 -0
- package/dist/esm/global-css.js +48 -0
- package/dist/esm/index.js +39 -0
- package/dist/esm/keyframes.js +258 -0
- package/dist/esm/layer-styles.js +112 -0
- package/dist/esm/recipes/badge.js +70 -0
- package/dist/esm/recipes/button.js +178 -0
- package/dist/esm/recipes/checkmark.js +87 -0
- package/dist/esm/recipes/code.js +66 -0
- package/dist/esm/recipes/color-swatch.js +66 -0
- package/dist/esm/recipes/container.js +33 -0
- package/dist/esm/recipes/heading.js +52 -0
- package/dist/esm/recipes/icon.js +45 -0
- package/dist/esm/recipes/index.js +44 -0
- package/dist/esm/recipes/input-addon.js +79 -0
- package/dist/esm/recipes/input.js +96 -0
- package/dist/esm/recipes/kbd.js +60 -0
- package/dist/esm/recipes/link.js +38 -0
- package/dist/esm/recipes/mark.js +29 -0
- package/dist/esm/recipes/radiomark.js +100 -0
- package/dist/esm/recipes/separator.js +54 -0
- package/dist/esm/recipes/skeleton.js +53 -0
- package/dist/esm/recipes/skip-nav-link.js +34 -0
- package/dist/esm/recipes/spinner.js +47 -0
- package/dist/esm/recipes/textarea.js +89 -0
- package/dist/esm/semantic-tokens/colors.js +615 -0
- package/dist/esm/semantic-tokens/index.js +12 -0
- package/dist/esm/semantic-tokens/radii.js +16 -0
- package/dist/esm/semantic-tokens/shadows.js +55 -0
- package/dist/esm/slot-recipes/accordion.js +148 -0
- package/dist/esm/slot-recipes/action-bar.js +63 -0
- package/dist/esm/slot-recipes/alert.js +163 -0
- package/dist/esm/slot-recipes/avatar.js +142 -0
- package/dist/esm/slot-recipes/blockquote.js +80 -0
- package/dist/esm/slot-recipes/breadcrumb.js +103 -0
- package/dist/esm/slot-recipes/card.js +100 -0
- package/dist/esm/slot-recipes/checkbox-card.js +285 -0
- package/dist/esm/slot-recipes/checkbox.js +130 -0
- package/dist/esm/slot-recipes/collapsible.js +22 -0
- package/dist/esm/slot-recipes/color-picker.js +382 -0
- package/dist/esm/slot-recipes/data-list.js +96 -0
- package/dist/esm/slot-recipes/dialog.js +254 -0
- package/dist/esm/slot-recipes/drawer.js +216 -0
- package/dist/esm/slot-recipes/editable.js +112 -0
- package/dist/esm/slot-recipes/empty-state.js +88 -0
- package/dist/esm/slot-recipes/field.js +78 -0
- package/dist/esm/slot-recipes/fieldset.js +80 -0
- package/dist/esm/slot-recipes/file-upload.js +112 -0
- package/dist/esm/slot-recipes/hover-card.js +68 -0
- package/dist/esm/slot-recipes/index.js +96 -0
- package/dist/esm/slot-recipes/list.js +71 -0
- package/dist/esm/slot-recipes/menu.js +144 -0
- package/dist/esm/slot-recipes/native-select.js +150 -0
- package/dist/esm/slot-recipes/number-input.js +198 -0
- package/dist/esm/slot-recipes/pin-input.js +119 -0
- package/dist/esm/slot-recipes/popover.js +102 -0
- package/dist/esm/slot-recipes/progress-circle.js +104 -0
- package/dist/esm/slot-recipes/progress.js +145 -0
- package/dist/esm/slot-recipes/qr-code.js +78 -0
- package/dist/esm/slot-recipes/radio-card.js +315 -0
- package/dist/esm/slot-recipes/radio-group.js +149 -0
- package/dist/esm/slot-recipes/rating-group.js +86 -0
- package/dist/esm/slot-recipes/segment-group.js +117 -0
- package/dist/esm/slot-recipes/select.js +303 -0
- package/dist/esm/slot-recipes/slider.js +216 -0
- package/dist/esm/slot-recipes/stat.js +82 -0
- package/dist/esm/slot-recipes/status.js +46 -0
- package/dist/esm/slot-recipes/steps.js +229 -0
- package/dist/esm/slot-recipes/switch.js +161 -0
- package/dist/esm/slot-recipes/table.js +173 -0
- package/dist/esm/slot-recipes/tabs.js +279 -0
- package/dist/esm/slot-recipes/tag.js +145 -0
- package/dist/esm/slot-recipes/timeline.js +149 -0
- package/dist/esm/slot-recipes/toast.js +104 -0
- package/dist/esm/slot-recipes/tooltip.js +42 -0
- package/dist/esm/text-styles.js +86 -0
- package/dist/esm/tokens/animations.js +19 -0
- package/dist/esm/tokens/aspect-ratios.js +25 -0
- package/dist/esm/tokens/blurs.js +31 -0
- package/dist/esm/tokens/borders.js +22 -0
- package/dist/esm/tokens/colors.js +439 -0
- package/dist/esm/tokens/cursor.js +31 -0
- package/dist/esm/tokens/durations.js +28 -0
- package/dist/esm/tokens/easings.js +19 -0
- package/dist/esm/tokens/font-sizes.js +49 -0
- package/dist/esm/tokens/font-weights.js +34 -0
- package/dist/esm/tokens/fonts.js +16 -0
- package/dist/esm/tokens/index.js +40 -0
- package/dist/esm/tokens/letter-spacings.js +22 -0
- package/dist/esm/tokens/line-heights.js +22 -0
- package/dist/esm/tokens/radii.js +40 -0
- package/dist/esm/tokens/sizes.js +265 -0
- package/dist/esm/tokens/spacing.js +109 -0
- package/dist/esm/tokens/z-index.js +46 -0
- package/dist/esm/utilities.js +83 -0
- package/dist/types/animation-styles.d.ts +1 -0
- package/dist/types/breakpoints.d.ts +7 -0
- package/dist/types/def.d.ts +18 -0
- package/dist/types/global-css.d.ts +1 -0
- package/dist/types/index.d.mts +2 -0
- package/dist/types/index.d.ts +2 -0
- package/dist/types/keyframes.d.ts +255 -0
- package/dist/types/layer-styles.d.ts +1 -0
- package/dist/types/recipes/badge.d.ts +1 -0
- package/dist/types/recipes/button.d.ts +1 -0
- package/dist/types/recipes/checkmark.d.ts +1 -0
- package/dist/types/recipes/code.d.ts +1 -0
- package/dist/types/recipes/color-swatch.d.ts +1 -0
- package/dist/types/recipes/container.d.ts +1 -0
- package/dist/types/recipes/heading.d.ts +1 -0
- package/dist/types/recipes/icon.d.ts +1 -0
- package/dist/types/recipes/index.d.ts +21 -0
- package/dist/types/recipes/input-addon.d.ts +1 -0
- package/dist/types/recipes/input.d.ts +1 -0
- package/dist/types/recipes/kbd.d.ts +1 -0
- package/dist/types/recipes/link.d.ts +1 -0
- package/dist/types/recipes/mark.d.ts +1 -0
- package/dist/types/recipes/radiomark.d.ts +1 -0
- package/dist/types/recipes/separator.d.ts +1 -0
- package/dist/types/recipes/skeleton.d.ts +1 -0
- package/dist/types/recipes/skip-nav-link.d.ts +1 -0
- package/dist/types/recipes/spinner.d.ts +1 -0
- package/dist/types/recipes/textarea.d.ts +1 -0
- package/dist/types/semantic-tokens/colors.d.ts +610 -0
- package/dist/types/semantic-tokens/index.d.ts +673 -0
- package/dist/types/semantic-tokens/radii.d.ts +11 -0
- package/dist/types/semantic-tokens/shadows.d.ts +50 -0
- package/dist/types/slot-recipes/accordion.d.ts +1 -0
- package/dist/types/slot-recipes/action-bar.d.ts +1 -0
- package/dist/types/slot-recipes/alert.d.ts +1 -0
- package/dist/types/slot-recipes/avatar.d.ts +1 -0
- package/dist/types/slot-recipes/blockquote.d.ts +1 -0
- package/dist/types/slot-recipes/breadcrumb.d.ts +1 -0
- package/dist/types/slot-recipes/card.d.ts +1 -0
- package/dist/types/slot-recipes/checkbox-card.d.ts +1 -0
- package/dist/types/slot-recipes/checkbox.d.ts +1 -0
- package/dist/types/slot-recipes/collapsible.d.ts +1 -0
- package/dist/types/slot-recipes/color-picker.d.ts +1 -0
- package/dist/types/slot-recipes/data-list.d.ts +1 -0
- package/dist/types/slot-recipes/dialog.d.ts +1 -0
- package/dist/types/slot-recipes/drawer.d.ts +1 -0
- package/dist/types/slot-recipes/editable.d.ts +1 -0
- package/dist/types/slot-recipes/empty-state.d.ts +1 -0
- package/dist/types/slot-recipes/field.d.ts +1 -0
- package/dist/types/slot-recipes/fieldset.d.ts +1 -0
- package/dist/types/slot-recipes/file-upload.d.ts +1 -0
- package/dist/types/slot-recipes/hover-card.d.ts +1 -0
- package/dist/types/slot-recipes/index.d.ts +47 -0
- package/dist/types/slot-recipes/list.d.ts +1 -0
- package/dist/types/slot-recipes/menu.d.ts +1 -0
- package/dist/types/slot-recipes/native-select.d.ts +1 -0
- package/dist/types/slot-recipes/number-input.d.ts +1 -0
- package/dist/types/slot-recipes/pin-input.d.ts +1 -0
- package/dist/types/slot-recipes/popover.d.ts +1 -0
- package/dist/types/slot-recipes/progress-circle.d.ts +1 -0
- package/dist/types/slot-recipes/progress.d.ts +1 -0
- package/dist/types/slot-recipes/qr-code.d.ts +1 -0
- package/dist/types/slot-recipes/radio-card.d.ts +1 -0
- package/dist/types/slot-recipes/radio-group.d.ts +1 -0
- package/dist/types/slot-recipes/rating-group.d.ts +1 -0
- package/dist/types/slot-recipes/segment-group.d.ts +1 -0
- package/dist/types/slot-recipes/select.d.ts +1 -0
- package/dist/types/slot-recipes/slider.d.ts +1 -0
- package/dist/types/slot-recipes/stat.d.ts +1 -0
- package/dist/types/slot-recipes/status.d.ts +1 -0
- package/dist/types/slot-recipes/steps.d.ts +1 -0
- package/dist/types/slot-recipes/switch.d.ts +1 -0
- package/dist/types/slot-recipes/table.d.ts +1 -0
- package/dist/types/slot-recipes/tabs.d.ts +1 -0
- package/dist/types/slot-recipes/tag.d.ts +1 -0
- package/dist/types/slot-recipes/timeline.d.ts +1 -0
- package/dist/types/slot-recipes/toast.d.ts +1 -0
- package/dist/types/slot-recipes/tooltip.d.ts +1 -0
- package/dist/types/text-styles.d.ts +1 -0
- package/dist/types/tokens/animations.d.ts +14 -0
- package/dist/types/tokens/aspect-ratios.d.ts +20 -0
- package/dist/types/tokens/blurs.d.ts +26 -0
- package/dist/types/tokens/borders.d.ts +17 -0
- package/dist/types/tokens/colors.d.ts +434 -0
- package/dist/types/tokens/cursor.d.ts +26 -0
- package/dist/types/tokens/durations.d.ts +23 -0
- package/dist/types/tokens/easings.d.ts +14 -0
- package/dist/types/tokens/font-sizes.d.ts +44 -0
- package/dist/types/tokens/font-weights.d.ts +29 -0
- package/dist/types/tokens/fonts.d.ts +11 -0
- package/dist/types/tokens/index.d.ts +1134 -0
- package/dist/types/tokens/letter-spacings.d.ts +17 -0
- package/dist/types/tokens/line-heights.d.ts +17 -0
- package/dist/types/tokens/radii.d.ts +35 -0
- package/dist/types/tokens/sizes.d.ts +260 -0
- package/dist/types/tokens/spacing.d.ts +104 -0
- package/dist/types/tokens/z-index.d.ts +41 -0
- package/dist/types/utilities.d.ts +1 -0
- package/package.json +65 -0
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
import { defineSlotRecipe } from '../def.js';
|
|
3
|
+
|
|
4
|
+
const ratingGroupSlotRecipe = defineSlotRecipe({
|
|
5
|
+
className: "rating-group",
|
|
6
|
+
slots: ["root", "label", "item", "control", "itemIndicator"],
|
|
7
|
+
base: {
|
|
8
|
+
root: {
|
|
9
|
+
display: "inline-flex"
|
|
10
|
+
},
|
|
11
|
+
control: {
|
|
12
|
+
display: "inline-flex",
|
|
13
|
+
alignItems: "center"
|
|
14
|
+
},
|
|
15
|
+
item: {
|
|
16
|
+
display: "inline-flex",
|
|
17
|
+
alignItems: "center",
|
|
18
|
+
justifyContent: "center",
|
|
19
|
+
userSelect: "none"
|
|
20
|
+
},
|
|
21
|
+
itemIndicator: {
|
|
22
|
+
display: "inline-flex",
|
|
23
|
+
alignItems: "center",
|
|
24
|
+
justifyContent: "center",
|
|
25
|
+
width: "1em",
|
|
26
|
+
height: "1em",
|
|
27
|
+
position: "relative",
|
|
28
|
+
_icon: {
|
|
29
|
+
stroke: "currentColor",
|
|
30
|
+
width: "100%",
|
|
31
|
+
height: "100%",
|
|
32
|
+
display: "inline-block",
|
|
33
|
+
flexShrink: 0,
|
|
34
|
+
position: "absolute",
|
|
35
|
+
left: 0,
|
|
36
|
+
top: 0
|
|
37
|
+
},
|
|
38
|
+
"& [data-bg]": {
|
|
39
|
+
color: "bg.emphasized"
|
|
40
|
+
},
|
|
41
|
+
"& [data-fg]": {
|
|
42
|
+
color: "transparent"
|
|
43
|
+
},
|
|
44
|
+
"&[data-highlighted]:not([data-half])": {
|
|
45
|
+
"& [data-fg]": {
|
|
46
|
+
color: "colorPalette.solid"
|
|
47
|
+
}
|
|
48
|
+
},
|
|
49
|
+
"&[data-half]": {
|
|
50
|
+
"& [data-fg]": {
|
|
51
|
+
color: "colorPalette.solid",
|
|
52
|
+
clipPath: "inset(0 50% 0 0)"
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
},
|
|
57
|
+
variants: {
|
|
58
|
+
size: {
|
|
59
|
+
xs: {
|
|
60
|
+
item: {
|
|
61
|
+
textStyle: "sm"
|
|
62
|
+
}
|
|
63
|
+
},
|
|
64
|
+
sm: {
|
|
65
|
+
item: {
|
|
66
|
+
textStyle: "md"
|
|
67
|
+
}
|
|
68
|
+
},
|
|
69
|
+
md: {
|
|
70
|
+
item: {
|
|
71
|
+
textStyle: "xl"
|
|
72
|
+
}
|
|
73
|
+
},
|
|
74
|
+
lg: {
|
|
75
|
+
item: {
|
|
76
|
+
textStyle: "2xl"
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
},
|
|
81
|
+
defaultVariants: {
|
|
82
|
+
size: "md"
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
export { ratingGroupSlotRecipe };
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
import { defineSlotRecipe } from '../def.js';
|
|
3
|
+
|
|
4
|
+
const segmentGroupSlotRecipe = defineSlotRecipe({
|
|
5
|
+
className: "segment-group",
|
|
6
|
+
slots: ["root", "label", "item", "itemText", "itemControl", "indicator"],
|
|
7
|
+
base: {
|
|
8
|
+
root: {
|
|
9
|
+
"--segment-radius": "radii.l2",
|
|
10
|
+
borderRadius: "l2",
|
|
11
|
+
display: "inline-flex",
|
|
12
|
+
boxShadow: "inset",
|
|
13
|
+
minW: "max-content",
|
|
14
|
+
textAlign: "center",
|
|
15
|
+
position: "relative",
|
|
16
|
+
isolation: "isolate",
|
|
17
|
+
bg: "bg.muted"
|
|
18
|
+
},
|
|
19
|
+
item: {
|
|
20
|
+
display: "flex",
|
|
21
|
+
alignItems: "center",
|
|
22
|
+
userSelect: "none",
|
|
23
|
+
fontSize: "sm",
|
|
24
|
+
position: "relative",
|
|
25
|
+
color: "fg",
|
|
26
|
+
borderRadius: "var(--segment-radius)",
|
|
27
|
+
_disabled: {
|
|
28
|
+
opacity: "0.5"
|
|
29
|
+
},
|
|
30
|
+
"&:has(input:focus-visible)": {
|
|
31
|
+
focusRing: "outside"
|
|
32
|
+
},
|
|
33
|
+
_before: {
|
|
34
|
+
content: '""',
|
|
35
|
+
position: "absolute",
|
|
36
|
+
insetInlineStart: 0,
|
|
37
|
+
insetBlock: "1.5",
|
|
38
|
+
bg: "border",
|
|
39
|
+
width: "1px",
|
|
40
|
+
transition: "opacity 0.2s"
|
|
41
|
+
},
|
|
42
|
+
"& + &[data-state=checked], &[data-state=checked] + &, &:first-of-type": {
|
|
43
|
+
_before: {
|
|
44
|
+
opacity: "0"
|
|
45
|
+
}
|
|
46
|
+
},
|
|
47
|
+
"&[data-state=checked][data-ssr]": {
|
|
48
|
+
shadow: "sm",
|
|
49
|
+
bg: "bg",
|
|
50
|
+
borderRadius: "var(--segment-radius)"
|
|
51
|
+
}
|
|
52
|
+
},
|
|
53
|
+
indicator: {
|
|
54
|
+
shadow: "sm",
|
|
55
|
+
pos: "absolute",
|
|
56
|
+
bg: {
|
|
57
|
+
_light: "bg",
|
|
58
|
+
_dark: "bg.emphasized"
|
|
59
|
+
},
|
|
60
|
+
width: "var(--width)",
|
|
61
|
+
height: "var(--height)",
|
|
62
|
+
top: "var(--top)",
|
|
63
|
+
left: "var(--left)",
|
|
64
|
+
zIndex: -1,
|
|
65
|
+
borderRadius: "var(--segment-radius)"
|
|
66
|
+
}
|
|
67
|
+
},
|
|
68
|
+
variants: {
|
|
69
|
+
size: {
|
|
70
|
+
xs: {
|
|
71
|
+
root: {
|
|
72
|
+
height: "6"
|
|
73
|
+
},
|
|
74
|
+
item: {
|
|
75
|
+
textStyle: "xs",
|
|
76
|
+
px: "3",
|
|
77
|
+
gap: "1"
|
|
78
|
+
}
|
|
79
|
+
},
|
|
80
|
+
sm: {
|
|
81
|
+
root: {
|
|
82
|
+
height: "8"
|
|
83
|
+
},
|
|
84
|
+
item: {
|
|
85
|
+
textStyle: "sm",
|
|
86
|
+
px: "4",
|
|
87
|
+
gap: "2"
|
|
88
|
+
}
|
|
89
|
+
},
|
|
90
|
+
md: {
|
|
91
|
+
root: {
|
|
92
|
+
height: "10"
|
|
93
|
+
},
|
|
94
|
+
item: {
|
|
95
|
+
textStyle: "sm",
|
|
96
|
+
px: "4",
|
|
97
|
+
gap: "2"
|
|
98
|
+
}
|
|
99
|
+
},
|
|
100
|
+
lg: {
|
|
101
|
+
root: {
|
|
102
|
+
height: "10"
|
|
103
|
+
},
|
|
104
|
+
item: {
|
|
105
|
+
textStyle: "md",
|
|
106
|
+
px: "5",
|
|
107
|
+
gap: "3"
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
},
|
|
112
|
+
defaultVariants: {
|
|
113
|
+
size: "md"
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
|
|
117
|
+
export { segmentGroupSlotRecipe };
|
|
@@ -0,0 +1,303 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
import { defineSlotRecipe } from '../def.js';
|
|
3
|
+
|
|
4
|
+
const selectSlotRecipe = defineSlotRecipe({
|
|
5
|
+
className: "select",
|
|
6
|
+
slots: [
|
|
7
|
+
"label",
|
|
8
|
+
"positioner",
|
|
9
|
+
"trigger",
|
|
10
|
+
"indicator",
|
|
11
|
+
"clearTrigger",
|
|
12
|
+
"item",
|
|
13
|
+
"itemText",
|
|
14
|
+
"itemIndicator",
|
|
15
|
+
"itemGroup",
|
|
16
|
+
"itemGroupLabel",
|
|
17
|
+
"list",
|
|
18
|
+
"content",
|
|
19
|
+
"root",
|
|
20
|
+
"control",
|
|
21
|
+
"valueText",
|
|
22
|
+
"indicatorGroup"
|
|
23
|
+
],
|
|
24
|
+
base: {
|
|
25
|
+
root: {
|
|
26
|
+
display: "flex",
|
|
27
|
+
flexDirection: "column",
|
|
28
|
+
gap: "1.5",
|
|
29
|
+
width: "full"
|
|
30
|
+
},
|
|
31
|
+
trigger: {
|
|
32
|
+
display: "flex",
|
|
33
|
+
alignItems: "center",
|
|
34
|
+
justifyContent: "space-between",
|
|
35
|
+
width: "full",
|
|
36
|
+
minH: "var(--select-trigger-height)",
|
|
37
|
+
px: "var(--select-trigger-padding-x)",
|
|
38
|
+
borderRadius: "l2",
|
|
39
|
+
userSelect: "none",
|
|
40
|
+
textAlign: "start",
|
|
41
|
+
focusVisibleRing: "inside",
|
|
42
|
+
_placeholderShown: {
|
|
43
|
+
color: "fg.muted"
|
|
44
|
+
},
|
|
45
|
+
_disabled: {
|
|
46
|
+
layerStyle: "disabled"
|
|
47
|
+
},
|
|
48
|
+
_invalid: {
|
|
49
|
+
borderColor: "border.error"
|
|
50
|
+
}
|
|
51
|
+
},
|
|
52
|
+
indicatorGroup: {
|
|
53
|
+
display: "flex",
|
|
54
|
+
alignItems: "center",
|
|
55
|
+
gap: "1",
|
|
56
|
+
pos: "absolute",
|
|
57
|
+
right: "0",
|
|
58
|
+
top: "0",
|
|
59
|
+
bottom: "0",
|
|
60
|
+
px: "var(--select-trigger-padding-x)",
|
|
61
|
+
pointerEvents: "none"
|
|
62
|
+
},
|
|
63
|
+
indicator: {
|
|
64
|
+
display: "flex",
|
|
65
|
+
alignItems: "center",
|
|
66
|
+
justifyContent: "center",
|
|
67
|
+
color: {
|
|
68
|
+
base: "fg.muted",
|
|
69
|
+
_disabled: "fg.subtle",
|
|
70
|
+
_invalid: "fg.error"
|
|
71
|
+
}
|
|
72
|
+
},
|
|
73
|
+
content: {
|
|
74
|
+
background: "bg.panel",
|
|
75
|
+
display: "flex",
|
|
76
|
+
flexDirection: "column",
|
|
77
|
+
zIndex: "dropdown",
|
|
78
|
+
borderRadius: "l2",
|
|
79
|
+
outline: 0,
|
|
80
|
+
maxH: "96",
|
|
81
|
+
overflowY: "auto",
|
|
82
|
+
boxShadow: "md",
|
|
83
|
+
_open: {
|
|
84
|
+
animationStyle: "slide-fade-in",
|
|
85
|
+
animationDuration: "fast"
|
|
86
|
+
},
|
|
87
|
+
_closed: {
|
|
88
|
+
animationStyle: "slide-fade-out",
|
|
89
|
+
animationDuration: "fastest"
|
|
90
|
+
}
|
|
91
|
+
},
|
|
92
|
+
item: {
|
|
93
|
+
position: "relative",
|
|
94
|
+
userSelect: "none",
|
|
95
|
+
display: "flex",
|
|
96
|
+
alignItems: "center",
|
|
97
|
+
gap: "2",
|
|
98
|
+
cursor: "option",
|
|
99
|
+
justifyContent: "space-between",
|
|
100
|
+
flex: "1",
|
|
101
|
+
textAlign: "start",
|
|
102
|
+
borderRadius: "l1",
|
|
103
|
+
_highlighted: {
|
|
104
|
+
bg: {
|
|
105
|
+
_light: "bg.muted",
|
|
106
|
+
_dark: "bg.emphasized"
|
|
107
|
+
}
|
|
108
|
+
},
|
|
109
|
+
_disabled: {
|
|
110
|
+
pointerEvents: "none",
|
|
111
|
+
opacity: "0.5"
|
|
112
|
+
},
|
|
113
|
+
_icon: {
|
|
114
|
+
width: "4",
|
|
115
|
+
height: "4"
|
|
116
|
+
}
|
|
117
|
+
},
|
|
118
|
+
control: {
|
|
119
|
+
pos: "relative"
|
|
120
|
+
},
|
|
121
|
+
itemText: {
|
|
122
|
+
flex: "1"
|
|
123
|
+
},
|
|
124
|
+
itemGroup: {
|
|
125
|
+
_first: {
|
|
126
|
+
mt: "0"
|
|
127
|
+
}
|
|
128
|
+
},
|
|
129
|
+
itemGroupLabel: {
|
|
130
|
+
py: "1",
|
|
131
|
+
fontWeight: "medium"
|
|
132
|
+
},
|
|
133
|
+
label: {
|
|
134
|
+
fontWeight: "medium",
|
|
135
|
+
userSelect: "none",
|
|
136
|
+
textStyle: "sm",
|
|
137
|
+
_disabled: {
|
|
138
|
+
layerStyle: "disabled"
|
|
139
|
+
}
|
|
140
|
+
},
|
|
141
|
+
valueText: {
|
|
142
|
+
lineClamp: "1",
|
|
143
|
+
maxW: "80%"
|
|
144
|
+
}
|
|
145
|
+
},
|
|
146
|
+
variants: {
|
|
147
|
+
variant: {
|
|
148
|
+
outline: {
|
|
149
|
+
trigger: {
|
|
150
|
+
bg: "transparent",
|
|
151
|
+
borderWidth: "1px",
|
|
152
|
+
borderColor: "border",
|
|
153
|
+
_expanded: {
|
|
154
|
+
borderColor: "border.emphasized"
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
},
|
|
158
|
+
subtle: {
|
|
159
|
+
trigger: {
|
|
160
|
+
borderWidth: "1px",
|
|
161
|
+
borderColor: "transparent",
|
|
162
|
+
bg: "bg.muted"
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
},
|
|
166
|
+
size: {
|
|
167
|
+
xs: {
|
|
168
|
+
root: {
|
|
169
|
+
"--select-trigger-height": "sizes.8",
|
|
170
|
+
"--select-trigger-padding-x": "spacing.2"
|
|
171
|
+
},
|
|
172
|
+
content: {
|
|
173
|
+
p: "1",
|
|
174
|
+
gap: "1",
|
|
175
|
+
textStyle: "xs"
|
|
176
|
+
},
|
|
177
|
+
trigger: {
|
|
178
|
+
textStyle: "xs",
|
|
179
|
+
gap: "1"
|
|
180
|
+
},
|
|
181
|
+
item: {
|
|
182
|
+
py: "1",
|
|
183
|
+
px: "2"
|
|
184
|
+
},
|
|
185
|
+
itemGroupLabel: {
|
|
186
|
+
py: "1",
|
|
187
|
+
px: "2"
|
|
188
|
+
},
|
|
189
|
+
indicator: {
|
|
190
|
+
_icon: {
|
|
191
|
+
width: "3.5",
|
|
192
|
+
height: "3.5"
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
},
|
|
196
|
+
sm: {
|
|
197
|
+
root: {
|
|
198
|
+
"--select-trigger-height": "sizes.9",
|
|
199
|
+
"--select-trigger-padding-x": "spacing.2.5"
|
|
200
|
+
},
|
|
201
|
+
content: {
|
|
202
|
+
p: "1",
|
|
203
|
+
textStyle: "sm"
|
|
204
|
+
},
|
|
205
|
+
trigger: {
|
|
206
|
+
textStyle: "sm",
|
|
207
|
+
gap: "1"
|
|
208
|
+
},
|
|
209
|
+
indicator: {
|
|
210
|
+
_icon: {
|
|
211
|
+
width: "4",
|
|
212
|
+
height: "4"
|
|
213
|
+
}
|
|
214
|
+
},
|
|
215
|
+
item: {
|
|
216
|
+
py: "1",
|
|
217
|
+
px: "1.5"
|
|
218
|
+
},
|
|
219
|
+
itemGroup: {
|
|
220
|
+
mt: "1"
|
|
221
|
+
},
|
|
222
|
+
itemGroupLabel: {
|
|
223
|
+
py: "1",
|
|
224
|
+
px: "1.5"
|
|
225
|
+
}
|
|
226
|
+
},
|
|
227
|
+
md: {
|
|
228
|
+
root: {
|
|
229
|
+
"--select-trigger-height": "sizes.10",
|
|
230
|
+
"--select-trigger-padding-x": "spacing.3"
|
|
231
|
+
},
|
|
232
|
+
content: {
|
|
233
|
+
p: "1",
|
|
234
|
+
textStyle: "sm"
|
|
235
|
+
},
|
|
236
|
+
itemGroup: {
|
|
237
|
+
mt: "1.5"
|
|
238
|
+
},
|
|
239
|
+
item: {
|
|
240
|
+
py: "1.5",
|
|
241
|
+
px: "2"
|
|
242
|
+
},
|
|
243
|
+
itemIndicator: {
|
|
244
|
+
display: "flex",
|
|
245
|
+
alignItems: "center",
|
|
246
|
+
justifyContent: "center"
|
|
247
|
+
},
|
|
248
|
+
itemGroupLabel: {
|
|
249
|
+
py: "1.5",
|
|
250
|
+
px: "2"
|
|
251
|
+
},
|
|
252
|
+
trigger: {
|
|
253
|
+
textStyle: "sm",
|
|
254
|
+
gap: "2"
|
|
255
|
+
},
|
|
256
|
+
indicator: {
|
|
257
|
+
_icon: {
|
|
258
|
+
width: "4",
|
|
259
|
+
height: "4"
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
},
|
|
263
|
+
lg: {
|
|
264
|
+
root: {
|
|
265
|
+
"--select-trigger-height": "sizes.12",
|
|
266
|
+
"--select-trigger-padding-x": "spacing.4"
|
|
267
|
+
},
|
|
268
|
+
content: {
|
|
269
|
+
p: "1.5",
|
|
270
|
+
textStyle: "md"
|
|
271
|
+
},
|
|
272
|
+
itemGroup: {
|
|
273
|
+
mt: "2"
|
|
274
|
+
},
|
|
275
|
+
item: {
|
|
276
|
+
py: "2",
|
|
277
|
+
px: "3"
|
|
278
|
+
},
|
|
279
|
+
itemGroupLabel: {
|
|
280
|
+
py: "2",
|
|
281
|
+
px: "3"
|
|
282
|
+
},
|
|
283
|
+
trigger: {
|
|
284
|
+
textStyle: "md",
|
|
285
|
+
py: "3",
|
|
286
|
+
gap: "2"
|
|
287
|
+
},
|
|
288
|
+
indicator: {
|
|
289
|
+
_icon: {
|
|
290
|
+
width: "5",
|
|
291
|
+
height: "5"
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
},
|
|
297
|
+
defaultVariants: {
|
|
298
|
+
size: "md",
|
|
299
|
+
variant: "outline"
|
|
300
|
+
}
|
|
301
|
+
});
|
|
302
|
+
|
|
303
|
+
export { selectSlotRecipe };
|
|
@@ -0,0 +1,216 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
import { defineSlotRecipe } from '../def.js';
|
|
3
|
+
|
|
4
|
+
const sliderSlotRecipe = defineSlotRecipe({
|
|
5
|
+
className: "slider",
|
|
6
|
+
slots: [
|
|
7
|
+
"root",
|
|
8
|
+
"label",
|
|
9
|
+
"thumb",
|
|
10
|
+
"valueText",
|
|
11
|
+
"track",
|
|
12
|
+
"range",
|
|
13
|
+
"control",
|
|
14
|
+
"markerGroup",
|
|
15
|
+
"marker",
|
|
16
|
+
"draggingIndicator",
|
|
17
|
+
"markerIndicator"
|
|
18
|
+
],
|
|
19
|
+
base: {
|
|
20
|
+
root: {
|
|
21
|
+
display: "flex",
|
|
22
|
+
flexDirection: "column",
|
|
23
|
+
gap: "1",
|
|
24
|
+
textStyle: "sm",
|
|
25
|
+
position: "relative",
|
|
26
|
+
isolation: "isolate",
|
|
27
|
+
touchAction: "none"
|
|
28
|
+
},
|
|
29
|
+
label: {
|
|
30
|
+
fontWeight: "medium",
|
|
31
|
+
textStyle: "sm"
|
|
32
|
+
},
|
|
33
|
+
control: {
|
|
34
|
+
display: "inline-flex",
|
|
35
|
+
alignItems: "center",
|
|
36
|
+
position: "relative"
|
|
37
|
+
},
|
|
38
|
+
track: {
|
|
39
|
+
overflow: "hidden",
|
|
40
|
+
borderRadius: "full",
|
|
41
|
+
flex: "1"
|
|
42
|
+
},
|
|
43
|
+
range: {
|
|
44
|
+
width: "inherit",
|
|
45
|
+
height: "inherit",
|
|
46
|
+
_disabled: {
|
|
47
|
+
bg: "border.emphasized!"
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
markerGroup: {
|
|
51
|
+
position: "absolute!",
|
|
52
|
+
zIndex: "1"
|
|
53
|
+
},
|
|
54
|
+
marker: {
|
|
55
|
+
"--marker-bg": {
|
|
56
|
+
base: "white",
|
|
57
|
+
_underValue: "colors.bg"
|
|
58
|
+
},
|
|
59
|
+
display: "flex",
|
|
60
|
+
alignItems: "center",
|
|
61
|
+
gap: "calc(var(--slider-thumb-size) / 2)",
|
|
62
|
+
color: "fg.muted",
|
|
63
|
+
textStyle: "xs"
|
|
64
|
+
},
|
|
65
|
+
markerIndicator: {
|
|
66
|
+
width: "var(--slider-marker-size)",
|
|
67
|
+
height: "var(--slider-marker-size)",
|
|
68
|
+
borderRadius: "full",
|
|
69
|
+
bg: "var(--marker-bg)"
|
|
70
|
+
},
|
|
71
|
+
thumb: {
|
|
72
|
+
width: "var(--slider-thumb-size)",
|
|
73
|
+
height: "var(--slider-thumb-size)",
|
|
74
|
+
display: "flex",
|
|
75
|
+
alignItems: "center",
|
|
76
|
+
justifyContent: "center",
|
|
77
|
+
outline: 0,
|
|
78
|
+
zIndex: "2",
|
|
79
|
+
borderRadius: "full",
|
|
80
|
+
_focusVisible: {
|
|
81
|
+
ring: "2px",
|
|
82
|
+
ringColor: "colorPalette.focusRing",
|
|
83
|
+
ringOffset: "2px",
|
|
84
|
+
ringOffsetColor: "bg"
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
},
|
|
88
|
+
variants: {
|
|
89
|
+
size: {
|
|
90
|
+
sm: {
|
|
91
|
+
root: {
|
|
92
|
+
"--slider-thumb-size": "sizes.4",
|
|
93
|
+
"--slider-track-size": "sizes.1.5",
|
|
94
|
+
"--slider-marker-center": "6px",
|
|
95
|
+
"--slider-marker-size": "sizes.1",
|
|
96
|
+
"--slider-marker-inset": "3px"
|
|
97
|
+
}
|
|
98
|
+
},
|
|
99
|
+
md: {
|
|
100
|
+
root: {
|
|
101
|
+
"--slider-thumb-size": "sizes.5",
|
|
102
|
+
"--slider-track-size": "sizes.2",
|
|
103
|
+
"--slider-marker-center": "8px",
|
|
104
|
+
"--slider-marker-size": "sizes.1",
|
|
105
|
+
"--slider-marker-inset": "4px"
|
|
106
|
+
}
|
|
107
|
+
},
|
|
108
|
+
lg: {
|
|
109
|
+
root: {
|
|
110
|
+
"--slider-thumb-size": "sizes.6",
|
|
111
|
+
"--slider-track-size": "sizes.2.5",
|
|
112
|
+
"--slider-marker-center": "9px",
|
|
113
|
+
"--slider-marker-size": "sizes.1.5",
|
|
114
|
+
"--slider-marker-inset": "5px"
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
},
|
|
118
|
+
variant: {
|
|
119
|
+
outline: {
|
|
120
|
+
track: {
|
|
121
|
+
shadow: "inset",
|
|
122
|
+
bg: "bg.emphasized/72"
|
|
123
|
+
},
|
|
124
|
+
range: {
|
|
125
|
+
bg: "colorPalette.solid"
|
|
126
|
+
},
|
|
127
|
+
thumb: {
|
|
128
|
+
borderWidth: "2px",
|
|
129
|
+
borderColor: "colorPalette.solid",
|
|
130
|
+
bg: "bg",
|
|
131
|
+
_disabled: {
|
|
132
|
+
bg: "border.emphasized",
|
|
133
|
+
borderColor: "border.emphasized"
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
},
|
|
137
|
+
solid: {
|
|
138
|
+
track: {
|
|
139
|
+
bg: "colorPalette.subtle",
|
|
140
|
+
_disabled: {
|
|
141
|
+
bg: "bg.muted"
|
|
142
|
+
}
|
|
143
|
+
},
|
|
144
|
+
range: {
|
|
145
|
+
bg: "colorPalette.solid"
|
|
146
|
+
},
|
|
147
|
+
thumb: {
|
|
148
|
+
bg: "colorPalette.solid",
|
|
149
|
+
_disabled: {
|
|
150
|
+
bg: "border.emphasized"
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
},
|
|
155
|
+
orientation: {
|
|
156
|
+
vertical: {
|
|
157
|
+
root: {
|
|
158
|
+
display: "inline-flex"
|
|
159
|
+
},
|
|
160
|
+
control: {
|
|
161
|
+
flexDirection: "column",
|
|
162
|
+
height: "100%",
|
|
163
|
+
minWidth: "var(--slider-thumb-size)",
|
|
164
|
+
"&[data-has-mark-label]": {
|
|
165
|
+
marginEnd: "4"
|
|
166
|
+
}
|
|
167
|
+
},
|
|
168
|
+
track: {
|
|
169
|
+
width: "var(--slider-track-size)"
|
|
170
|
+
},
|
|
171
|
+
thumb: {
|
|
172
|
+
left: "50%",
|
|
173
|
+
translate: "-50% 0"
|
|
174
|
+
},
|
|
175
|
+
markerGroup: {
|
|
176
|
+
insetStart: "var(--slider-marker-center)",
|
|
177
|
+
insetBlock: "var(--slider-marker-inset)"
|
|
178
|
+
},
|
|
179
|
+
marker: {
|
|
180
|
+
flexDirection: "row"
|
|
181
|
+
}
|
|
182
|
+
},
|
|
183
|
+
horizontal: {
|
|
184
|
+
control: {
|
|
185
|
+
flexDirection: "row",
|
|
186
|
+
width: "100%",
|
|
187
|
+
minHeight: "var(--slider-thumb-size)",
|
|
188
|
+
"&[data-has-mark-label]": {
|
|
189
|
+
marginBottom: "4"
|
|
190
|
+
}
|
|
191
|
+
},
|
|
192
|
+
track: {
|
|
193
|
+
height: "var(--slider-track-size)"
|
|
194
|
+
},
|
|
195
|
+
thumb: {
|
|
196
|
+
top: "50%",
|
|
197
|
+
translate: "0 -50%"
|
|
198
|
+
},
|
|
199
|
+
markerGroup: {
|
|
200
|
+
top: "var(--slider-marker-center)",
|
|
201
|
+
insetInline: "var(--slider-marker-inset)"
|
|
202
|
+
},
|
|
203
|
+
marker: {
|
|
204
|
+
flexDirection: "column"
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
},
|
|
209
|
+
defaultVariants: {
|
|
210
|
+
size: "md",
|
|
211
|
+
variant: "outline",
|
|
212
|
+
orientation: "horizontal"
|
|
213
|
+
}
|
|
214
|
+
});
|
|
215
|
+
|
|
216
|
+
export { sliderSlotRecipe };
|