@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,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var def = require('../def.cjs');
|
|
5
|
+
|
|
6
|
+
const fieldSlotRecipe = def.defineSlotRecipe({
|
|
7
|
+
className: "field",
|
|
8
|
+
slots: [
|
|
9
|
+
"root",
|
|
10
|
+
"errorText",
|
|
11
|
+
"helperText",
|
|
12
|
+
"input",
|
|
13
|
+
"label",
|
|
14
|
+
"select",
|
|
15
|
+
"textarea",
|
|
16
|
+
"requiredIndicator",
|
|
17
|
+
"requiredIndicator"
|
|
18
|
+
],
|
|
19
|
+
base: {
|
|
20
|
+
requiredIndicator: {
|
|
21
|
+
color: "fg.error",
|
|
22
|
+
lineHeight: "1"
|
|
23
|
+
},
|
|
24
|
+
root: {
|
|
25
|
+
display: "flex",
|
|
26
|
+
width: "100%",
|
|
27
|
+
position: "relative",
|
|
28
|
+
gap: "1.5"
|
|
29
|
+
},
|
|
30
|
+
label: {
|
|
31
|
+
display: "flex",
|
|
32
|
+
alignItems: "center",
|
|
33
|
+
textAlign: "start",
|
|
34
|
+
textStyle: "sm",
|
|
35
|
+
fontWeight: "medium",
|
|
36
|
+
gap: "1",
|
|
37
|
+
userSelect: "none",
|
|
38
|
+
_disabled: {
|
|
39
|
+
opacity: "0.5"
|
|
40
|
+
}
|
|
41
|
+
},
|
|
42
|
+
errorText: {
|
|
43
|
+
display: "inline-flex",
|
|
44
|
+
alignItems: "center",
|
|
45
|
+
fontWeight: "medium",
|
|
46
|
+
gap: "1",
|
|
47
|
+
color: "fg.error",
|
|
48
|
+
textStyle: "xs"
|
|
49
|
+
},
|
|
50
|
+
helperText: {
|
|
51
|
+
color: "fg.muted",
|
|
52
|
+
textStyle: "xs"
|
|
53
|
+
}
|
|
54
|
+
},
|
|
55
|
+
variants: {
|
|
56
|
+
orientation: {
|
|
57
|
+
vertical: {
|
|
58
|
+
root: {
|
|
59
|
+
flexDirection: "column",
|
|
60
|
+
alignItems: "flex-start"
|
|
61
|
+
}
|
|
62
|
+
},
|
|
63
|
+
horizontal: {
|
|
64
|
+
root: {
|
|
65
|
+
flexDirection: "row",
|
|
66
|
+
alignItems: "center",
|
|
67
|
+
justifyContent: "space-between"
|
|
68
|
+
},
|
|
69
|
+
label: {
|
|
70
|
+
flex: "0 0 var(--field-label-width, 80px)"
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
},
|
|
75
|
+
defaultVariants: {
|
|
76
|
+
orientation: "vertical"
|
|
77
|
+
}
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
exports.fieldSlotRecipe = fieldSlotRecipe;
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var def = require('../def.cjs');
|
|
5
|
+
|
|
6
|
+
const fieldsetSlotRecipe = def.defineSlotRecipe({
|
|
7
|
+
className: "fieldset",
|
|
8
|
+
slots: ["root", "errorText", "helperText", "legend", "content"],
|
|
9
|
+
base: {
|
|
10
|
+
root: {
|
|
11
|
+
display: "flex",
|
|
12
|
+
flexDirection: "column",
|
|
13
|
+
width: "full"
|
|
14
|
+
},
|
|
15
|
+
content: {
|
|
16
|
+
display: "flex",
|
|
17
|
+
flexDirection: "column",
|
|
18
|
+
width: "full"
|
|
19
|
+
},
|
|
20
|
+
legend: {
|
|
21
|
+
color: "fg",
|
|
22
|
+
fontWeight: "medium",
|
|
23
|
+
_disabled: {
|
|
24
|
+
opacity: "0.5"
|
|
25
|
+
}
|
|
26
|
+
},
|
|
27
|
+
helperText: {
|
|
28
|
+
color: "fg.muted",
|
|
29
|
+
textStyle: "sm"
|
|
30
|
+
},
|
|
31
|
+
errorText: {
|
|
32
|
+
display: "inline-flex",
|
|
33
|
+
alignItems: "center",
|
|
34
|
+
color: "fg.error",
|
|
35
|
+
gap: "2",
|
|
36
|
+
fontWeight: "medium",
|
|
37
|
+
textStyle: "sm"
|
|
38
|
+
}
|
|
39
|
+
},
|
|
40
|
+
variants: {
|
|
41
|
+
size: {
|
|
42
|
+
sm: {
|
|
43
|
+
root: {
|
|
44
|
+
spaceY: "2"
|
|
45
|
+
},
|
|
46
|
+
content: {
|
|
47
|
+
gap: "1.5"
|
|
48
|
+
},
|
|
49
|
+
legend: {
|
|
50
|
+
textStyle: "sm"
|
|
51
|
+
}
|
|
52
|
+
},
|
|
53
|
+
md: {
|
|
54
|
+
root: {
|
|
55
|
+
spaceY: "4"
|
|
56
|
+
},
|
|
57
|
+
content: {
|
|
58
|
+
gap: "4"
|
|
59
|
+
},
|
|
60
|
+
legend: {
|
|
61
|
+
textStyle: "sm"
|
|
62
|
+
}
|
|
63
|
+
},
|
|
64
|
+
lg: {
|
|
65
|
+
root: {
|
|
66
|
+
spaceY: "6"
|
|
67
|
+
},
|
|
68
|
+
content: {
|
|
69
|
+
gap: "4"
|
|
70
|
+
},
|
|
71
|
+
legend: {
|
|
72
|
+
textStyle: "md"
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
},
|
|
77
|
+
defaultVariants: {
|
|
78
|
+
size: "md"
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
exports.fieldsetSlotRecipe = fieldsetSlotRecipe;
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var def = require('../def.cjs');
|
|
5
|
+
|
|
6
|
+
const fileUploadSlotRecipe = def.defineSlotRecipe({
|
|
7
|
+
className: "file-upload",
|
|
8
|
+
slots: [
|
|
9
|
+
"root",
|
|
10
|
+
"dropzone",
|
|
11
|
+
"item",
|
|
12
|
+
"itemDeleteTrigger",
|
|
13
|
+
"itemGroup",
|
|
14
|
+
"itemName",
|
|
15
|
+
"itemPreview",
|
|
16
|
+
"itemPreviewImage",
|
|
17
|
+
"itemSizeText",
|
|
18
|
+
"label",
|
|
19
|
+
"trigger",
|
|
20
|
+
"clearTrigger",
|
|
21
|
+
"itemContent",
|
|
22
|
+
"dropzoneContent"
|
|
23
|
+
],
|
|
24
|
+
base: {
|
|
25
|
+
root: {
|
|
26
|
+
display: "flex",
|
|
27
|
+
flexDirection: "column",
|
|
28
|
+
gap: "4",
|
|
29
|
+
width: "100%",
|
|
30
|
+
alignItems: "flex-start"
|
|
31
|
+
},
|
|
32
|
+
label: {
|
|
33
|
+
fontWeight: "medium",
|
|
34
|
+
textStyle: "sm"
|
|
35
|
+
},
|
|
36
|
+
dropzone: {
|
|
37
|
+
background: "bg",
|
|
38
|
+
borderRadius: "l3",
|
|
39
|
+
borderWidth: "2px",
|
|
40
|
+
borderStyle: "dashed",
|
|
41
|
+
display: "flex",
|
|
42
|
+
alignItems: "center",
|
|
43
|
+
flexDirection: "column",
|
|
44
|
+
gap: "4",
|
|
45
|
+
justifyContent: "center",
|
|
46
|
+
minHeight: "2xs",
|
|
47
|
+
px: "3",
|
|
48
|
+
py: "2",
|
|
49
|
+
transition: "backgrounds",
|
|
50
|
+
focusVisibleRing: "outside",
|
|
51
|
+
_hover: {
|
|
52
|
+
bg: "bg.subtle"
|
|
53
|
+
},
|
|
54
|
+
_dragging: {
|
|
55
|
+
bg: "colorPalette.subtle",
|
|
56
|
+
borderStyle: "solid",
|
|
57
|
+
borderColor: "colorPalette.solid"
|
|
58
|
+
}
|
|
59
|
+
},
|
|
60
|
+
dropzoneContent: {
|
|
61
|
+
display: "flex",
|
|
62
|
+
flexDirection: "column",
|
|
63
|
+
alignItems: "center",
|
|
64
|
+
textAlign: "center",
|
|
65
|
+
gap: "1",
|
|
66
|
+
textStyle: "sm"
|
|
67
|
+
},
|
|
68
|
+
item: {
|
|
69
|
+
textStyle: "sm",
|
|
70
|
+
animationName: "fade-in",
|
|
71
|
+
animationDuration: "moderate",
|
|
72
|
+
background: "bg",
|
|
73
|
+
borderRadius: "l2",
|
|
74
|
+
borderWidth: "1px",
|
|
75
|
+
width: "100%",
|
|
76
|
+
display: "flex",
|
|
77
|
+
alignItems: "center",
|
|
78
|
+
gap: "3",
|
|
79
|
+
p: "4"
|
|
80
|
+
},
|
|
81
|
+
itemGroup: {
|
|
82
|
+
width: "100%",
|
|
83
|
+
display: "flex",
|
|
84
|
+
flexDirection: "column",
|
|
85
|
+
gap: "3"
|
|
86
|
+
},
|
|
87
|
+
itemName: {
|
|
88
|
+
color: "fg",
|
|
89
|
+
fontWeight: "medium",
|
|
90
|
+
lineClamp: "1"
|
|
91
|
+
},
|
|
92
|
+
itemContent: {
|
|
93
|
+
display: "flex",
|
|
94
|
+
flexDirection: "column",
|
|
95
|
+
gap: "0.5",
|
|
96
|
+
flex: "1"
|
|
97
|
+
},
|
|
98
|
+
itemSizeText: {
|
|
99
|
+
color: "fg.muted",
|
|
100
|
+
textStyle: "xs"
|
|
101
|
+
},
|
|
102
|
+
itemDeleteTrigger: {
|
|
103
|
+
alignSelf: "flex-start"
|
|
104
|
+
},
|
|
105
|
+
itemPreviewImage: {
|
|
106
|
+
width: "10",
|
|
107
|
+
height: "10",
|
|
108
|
+
objectFit: "scale-down"
|
|
109
|
+
}
|
|
110
|
+
},
|
|
111
|
+
defaultVariants: {}
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
exports.fileUploadSlotRecipe = fileUploadSlotRecipe;
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var def = require('../def.cjs');
|
|
5
|
+
|
|
6
|
+
const hoverCardSlotRecipe = def.defineSlotRecipe({
|
|
7
|
+
className: "hover-card",
|
|
8
|
+
slots: ["arrow", "arrowTip", "trigger", "positioner", "content"],
|
|
9
|
+
base: {
|
|
10
|
+
content: {
|
|
11
|
+
position: "relative",
|
|
12
|
+
display: "flex",
|
|
13
|
+
flexDirection: "column",
|
|
14
|
+
textStyle: "sm",
|
|
15
|
+
"--hovercard-bg": "colors.bg.panel",
|
|
16
|
+
bg: "var(--hovercard-bg)",
|
|
17
|
+
boxShadow: "lg",
|
|
18
|
+
maxWidth: "80",
|
|
19
|
+
borderRadius: "l3",
|
|
20
|
+
zIndex: "popover",
|
|
21
|
+
transformOrigin: "var(--transform-origin)",
|
|
22
|
+
outline: "0",
|
|
23
|
+
_open: {
|
|
24
|
+
animationStyle: "slide-fade-in",
|
|
25
|
+
animationDuration: "fast"
|
|
26
|
+
},
|
|
27
|
+
_closed: {
|
|
28
|
+
animationStyle: "slide-fade-out",
|
|
29
|
+
animationDuration: "faster"
|
|
30
|
+
}
|
|
31
|
+
},
|
|
32
|
+
arrow: {
|
|
33
|
+
"--arrow-size": "sizes.3",
|
|
34
|
+
"--arrow-background": "var(--hovercard-bg)"
|
|
35
|
+
},
|
|
36
|
+
arrowTip: {
|
|
37
|
+
borderTopWidth: "0.5px",
|
|
38
|
+
borderInlineStartWidth: "0.5px"
|
|
39
|
+
}
|
|
40
|
+
},
|
|
41
|
+
variants: {
|
|
42
|
+
size: {
|
|
43
|
+
xs: {
|
|
44
|
+
content: {
|
|
45
|
+
padding: "3"
|
|
46
|
+
}
|
|
47
|
+
},
|
|
48
|
+
sm: {
|
|
49
|
+
content: {
|
|
50
|
+
padding: "4"
|
|
51
|
+
}
|
|
52
|
+
},
|
|
53
|
+
md: {
|
|
54
|
+
content: {
|
|
55
|
+
padding: "5"
|
|
56
|
+
}
|
|
57
|
+
},
|
|
58
|
+
lg: {
|
|
59
|
+
content: {
|
|
60
|
+
padding: "6"
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
},
|
|
65
|
+
defaultVariants: {
|
|
66
|
+
size: "md"
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
exports.hoverCardSlotRecipe = hoverCardSlotRecipe;
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var accordion = require('./accordion.cjs');
|
|
5
|
+
var actionBar = require('./action-bar.cjs');
|
|
6
|
+
var alert = require('./alert.cjs');
|
|
7
|
+
var avatar = require('./avatar.cjs');
|
|
8
|
+
var blockquote = require('./blockquote.cjs');
|
|
9
|
+
var breadcrumb = require('./breadcrumb.cjs');
|
|
10
|
+
var card = require('./card.cjs');
|
|
11
|
+
var checkbox = require('./checkbox.cjs');
|
|
12
|
+
var checkboxCard = require('./checkbox-card.cjs');
|
|
13
|
+
var collapsible = require('./collapsible.cjs');
|
|
14
|
+
var colorPicker = require('./color-picker.cjs');
|
|
15
|
+
var dataList = require('./data-list.cjs');
|
|
16
|
+
var dialog = require('./dialog.cjs');
|
|
17
|
+
var drawer = require('./drawer.cjs');
|
|
18
|
+
var editable = require('./editable.cjs');
|
|
19
|
+
var emptyState = require('./empty-state.cjs');
|
|
20
|
+
var field = require('./field.cjs');
|
|
21
|
+
var fieldset = require('./fieldset.cjs');
|
|
22
|
+
var fileUpload = require('./file-upload.cjs');
|
|
23
|
+
var hoverCard = require('./hover-card.cjs');
|
|
24
|
+
var list = require('./list.cjs');
|
|
25
|
+
var menu = require('./menu.cjs');
|
|
26
|
+
var nativeSelect = require('./native-select.cjs');
|
|
27
|
+
var numberInput = require('./number-input.cjs');
|
|
28
|
+
var pinInput = require('./pin-input.cjs');
|
|
29
|
+
var popover = require('./popover.cjs');
|
|
30
|
+
var progress = require('./progress.cjs');
|
|
31
|
+
var progressCircle = require('./progress-circle.cjs');
|
|
32
|
+
var qrCode = require('./qr-code.cjs');
|
|
33
|
+
var radioCard = require('./radio-card.cjs');
|
|
34
|
+
var radioGroup = require('./radio-group.cjs');
|
|
35
|
+
var ratingGroup = require('./rating-group.cjs');
|
|
36
|
+
var segmentGroup = require('./segment-group.cjs');
|
|
37
|
+
var select = require('./select.cjs');
|
|
38
|
+
var slider = require('./slider.cjs');
|
|
39
|
+
var stat = require('./stat.cjs');
|
|
40
|
+
var status = require('./status.cjs');
|
|
41
|
+
var steps = require('./steps.cjs');
|
|
42
|
+
var _switch = require('./switch.cjs');
|
|
43
|
+
var table = require('./table.cjs');
|
|
44
|
+
var tabs = require('./tabs.cjs');
|
|
45
|
+
var tag = require('./tag.cjs');
|
|
46
|
+
var timeline = require('./timeline.cjs');
|
|
47
|
+
var toast = require('./toast.cjs');
|
|
48
|
+
var tooltip = require('./tooltip.cjs');
|
|
49
|
+
|
|
50
|
+
const slotRecipes = {
|
|
51
|
+
accordion: accordion.accordionSlotRecipe,
|
|
52
|
+
actionBar: actionBar.actionBarSlotRecipe,
|
|
53
|
+
alert: alert.alertSlotRecipe,
|
|
54
|
+
avatar: avatar.avatarSlotRecipe,
|
|
55
|
+
blockquote: blockquote.blockquoteSlotRecipe,
|
|
56
|
+
breadcrumb: breadcrumb.breadcrumbSlotRecipe,
|
|
57
|
+
card: card.cardSlotRecipe,
|
|
58
|
+
checkbox: checkbox.checkboxSlotRecipe,
|
|
59
|
+
checkboxCard: checkboxCard.checkboxCardSlotRecipe,
|
|
60
|
+
collapsible: collapsible.collapsibleSlotRecipe,
|
|
61
|
+
dataList: dataList.dataListSlotRecipe,
|
|
62
|
+
dialog: dialog.dialogSlotRecipe,
|
|
63
|
+
drawer: drawer.drawerSlotRecipe,
|
|
64
|
+
editable: editable.editableSlotRecipe,
|
|
65
|
+
emptyState: emptyState.emptyStateSlotRecipe,
|
|
66
|
+
field: field.fieldSlotRecipe,
|
|
67
|
+
fieldset: fieldset.fieldsetSlotRecipe,
|
|
68
|
+
fileUpload: fileUpload.fileUploadSlotRecipe,
|
|
69
|
+
hoverCard: hoverCard.hoverCardSlotRecipe,
|
|
70
|
+
list: list.listSlotRecipe,
|
|
71
|
+
menu: menu.menuSlotRecipe,
|
|
72
|
+
nativeSelect: nativeSelect.nativeSelectSlotRecipe,
|
|
73
|
+
numberInput: numberInput.numberInputSlotRecipe,
|
|
74
|
+
pinInput: pinInput.pinInputSlotRecipe,
|
|
75
|
+
popover: popover.popoverSlotRecipe,
|
|
76
|
+
progress: progress.progressSlotRecipe,
|
|
77
|
+
progressCircle: progressCircle.progressCircleSlotRecipe,
|
|
78
|
+
radioCard: radioCard.radioCardSlotRecipe,
|
|
79
|
+
radioGroup: radioGroup.radioGroupSlotRecipe,
|
|
80
|
+
ratingGroup: ratingGroup.ratingGroupSlotRecipe,
|
|
81
|
+
segmentGroup: segmentGroup.segmentGroupSlotRecipe,
|
|
82
|
+
select: select.selectSlotRecipe,
|
|
83
|
+
slider: slider.sliderSlotRecipe,
|
|
84
|
+
stat: stat.statSlotRecipe,
|
|
85
|
+
steps: steps.stepsSlotRecipe,
|
|
86
|
+
swittch: _switch.switchSlotRecipe,
|
|
87
|
+
table: table.tableSlotRecipe,
|
|
88
|
+
tabs: tabs.tabsSlotRecipe,
|
|
89
|
+
tag: tag.tagSlotRecipe,
|
|
90
|
+
toast: toast.toastSlotRecipe,
|
|
91
|
+
tooltip: tooltip.tooltipSlotRecipe,
|
|
92
|
+
status: status.statusSlotRecipe,
|
|
93
|
+
timeline: timeline.timelineSlotRecipe,
|
|
94
|
+
colorPicker: colorPicker.colorPickerSlotRecipe,
|
|
95
|
+
qrCode: qrCode.qrCodeSlotRecipe
|
|
96
|
+
};
|
|
97
|
+
|
|
98
|
+
exports.slotRecipes = slotRecipes;
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var def = require('../def.cjs');
|
|
5
|
+
|
|
6
|
+
const listSlotRecipe = def.defineSlotRecipe({
|
|
7
|
+
className: "list",
|
|
8
|
+
slots: ["root", "item", "indicator"],
|
|
9
|
+
base: {
|
|
10
|
+
root: {
|
|
11
|
+
display: "flex",
|
|
12
|
+
flexDirection: "column",
|
|
13
|
+
gap: "var(--list-gap)",
|
|
14
|
+
"& :where(ul, ol)": {
|
|
15
|
+
marginTop: "var(--list-gap)"
|
|
16
|
+
}
|
|
17
|
+
},
|
|
18
|
+
item: {
|
|
19
|
+
whiteSpace: "normal",
|
|
20
|
+
display: "list-item"
|
|
21
|
+
},
|
|
22
|
+
indicator: {
|
|
23
|
+
marginEnd: "2",
|
|
24
|
+
minHeight: "1lh",
|
|
25
|
+
flexShrink: 0,
|
|
26
|
+
display: "inline-block",
|
|
27
|
+
verticalAlign: "middle"
|
|
28
|
+
}
|
|
29
|
+
},
|
|
30
|
+
variants: {
|
|
31
|
+
variant: {
|
|
32
|
+
marker: {
|
|
33
|
+
root: {
|
|
34
|
+
listStyle: "revert",
|
|
35
|
+
listStylePosition: "inside"
|
|
36
|
+
},
|
|
37
|
+
item: {
|
|
38
|
+
_marker: {
|
|
39
|
+
color: "fg.subtle"
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
},
|
|
43
|
+
plain: {
|
|
44
|
+
item: {
|
|
45
|
+
alignItems: "flex-start",
|
|
46
|
+
display: "inline-flex"
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
align: {
|
|
51
|
+
center: {
|
|
52
|
+
item: {
|
|
53
|
+
alignItems: "center"
|
|
54
|
+
}
|
|
55
|
+
},
|
|
56
|
+
start: {
|
|
57
|
+
item: {
|
|
58
|
+
alignItems: "flex-start"
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
end: {
|
|
62
|
+
item: {
|
|
63
|
+
alignItems: "flex-end"
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
},
|
|
68
|
+
defaultVariants: {
|
|
69
|
+
variant: "marker"
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
exports.listSlotRecipe = listSlotRecipe;
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var def = require('../def.cjs');
|
|
5
|
+
|
|
6
|
+
const menuSlotRecipe = def.defineSlotRecipe({
|
|
7
|
+
className: "menu",
|
|
8
|
+
slots: [
|
|
9
|
+
"arrow",
|
|
10
|
+
"arrowTip",
|
|
11
|
+
"content",
|
|
12
|
+
"contextTrigger",
|
|
13
|
+
"indicator",
|
|
14
|
+
"item",
|
|
15
|
+
"itemGroup",
|
|
16
|
+
"itemGroupLabel",
|
|
17
|
+
"itemIndicator",
|
|
18
|
+
"itemText",
|
|
19
|
+
"positioner",
|
|
20
|
+
"separator",
|
|
21
|
+
"trigger",
|
|
22
|
+
"triggerItem",
|
|
23
|
+
"itemCommand"
|
|
24
|
+
],
|
|
25
|
+
base: {
|
|
26
|
+
content: {
|
|
27
|
+
outline: 0,
|
|
28
|
+
bg: "bg.panel",
|
|
29
|
+
boxShadow: "lg",
|
|
30
|
+
color: "fg",
|
|
31
|
+
maxHeight: "var(--available-height)",
|
|
32
|
+
"--menu-z-index": "zIndex.dropdown",
|
|
33
|
+
zIndex: "calc(var(--menu-z-index) + var(--layer-index, 0))",
|
|
34
|
+
borderRadius: "l2",
|
|
35
|
+
overflow: "hidden",
|
|
36
|
+
overflowY: "auto",
|
|
37
|
+
_open: {
|
|
38
|
+
animationStyle: "slide-fade-in",
|
|
39
|
+
animationDuration: "fast"
|
|
40
|
+
},
|
|
41
|
+
_closed: {
|
|
42
|
+
animationStyle: "slide-fade-out",
|
|
43
|
+
animationDuration: "faster"
|
|
44
|
+
}
|
|
45
|
+
},
|
|
46
|
+
item: {
|
|
47
|
+
textDecoration: "none",
|
|
48
|
+
color: "fg",
|
|
49
|
+
userSelect: "none",
|
|
50
|
+
borderRadius: "l1",
|
|
51
|
+
width: "100%",
|
|
52
|
+
display: "flex",
|
|
53
|
+
cursor: "menuitem",
|
|
54
|
+
alignItems: "center",
|
|
55
|
+
textAlign: "start",
|
|
56
|
+
position: "relative",
|
|
57
|
+
flex: "0 0 auto",
|
|
58
|
+
outline: 0,
|
|
59
|
+
_disabled: {
|
|
60
|
+
layerStyle: "disabled"
|
|
61
|
+
}
|
|
62
|
+
},
|
|
63
|
+
itemText: {
|
|
64
|
+
flex: "1"
|
|
65
|
+
},
|
|
66
|
+
itemGroupLabel: {
|
|
67
|
+
px: "2",
|
|
68
|
+
py: "1.5",
|
|
69
|
+
fontWeight: "semibold",
|
|
70
|
+
textStyle: "sm"
|
|
71
|
+
},
|
|
72
|
+
indicator: {
|
|
73
|
+
display: "inline-flex",
|
|
74
|
+
alignItems: "center",
|
|
75
|
+
justifyContent: "center",
|
|
76
|
+
flexShrink: "0"
|
|
77
|
+
},
|
|
78
|
+
itemCommand: {
|
|
79
|
+
opacity: "0.6",
|
|
80
|
+
textStyle: "xs",
|
|
81
|
+
ms: "auto",
|
|
82
|
+
ps: "4",
|
|
83
|
+
letterSpacing: "widest"
|
|
84
|
+
},
|
|
85
|
+
separator: {
|
|
86
|
+
height: "1px",
|
|
87
|
+
bg: "bg.muted",
|
|
88
|
+
my: "1",
|
|
89
|
+
mx: "-1"
|
|
90
|
+
}
|
|
91
|
+
},
|
|
92
|
+
variants: {
|
|
93
|
+
variant: {
|
|
94
|
+
subtle: {
|
|
95
|
+
item: {
|
|
96
|
+
_highlighted: {
|
|
97
|
+
bg: {
|
|
98
|
+
_light: "bg.muted",
|
|
99
|
+
_dark: "bg.emphasized"
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
},
|
|
104
|
+
solid: {
|
|
105
|
+
item: {
|
|
106
|
+
_highlighted: {
|
|
107
|
+
bg: "colorPalette.solid",
|
|
108
|
+
color: "colorPalette.contrast"
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
},
|
|
113
|
+
size: {
|
|
114
|
+
sm: {
|
|
115
|
+
content: {
|
|
116
|
+
minW: "8rem",
|
|
117
|
+
padding: "1"
|
|
118
|
+
},
|
|
119
|
+
item: {
|
|
120
|
+
gap: "1",
|
|
121
|
+
textStyle: "xs",
|
|
122
|
+
py: "1",
|
|
123
|
+
px: "1.5"
|
|
124
|
+
}
|
|
125
|
+
},
|
|
126
|
+
md: {
|
|
127
|
+
content: {
|
|
128
|
+
minW: "8rem",
|
|
129
|
+
padding: "1.5"
|
|
130
|
+
},
|
|
131
|
+
item: {
|
|
132
|
+
gap: "2",
|
|
133
|
+
textStyle: "sm",
|
|
134
|
+
py: "1.5",
|
|
135
|
+
px: "2"
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
},
|
|
140
|
+
defaultVariants: {
|
|
141
|
+
size: "md",
|
|
142
|
+
variant: "subtle"
|
|
143
|
+
}
|
|
144
|
+
});
|
|
145
|
+
|
|
146
|
+
exports.menuSlotRecipe = menuSlotRecipe;
|