Leave Yamada UI a star

Star
Yamada UIYamada UIv1.6.4

Switch

Switch is a component used to toggle between on and off states.

Source@yamada-ui/switch

Theming

The Switch is a multi part component.

export const Switch: ComponentMultiStyle<"Switch"> = {
baseStyle: {
container: {
_disabled: {
cursor: "not-allowed",
opacity: 0.4,
},
_readOnly: { cursor: "auto" },
},
label: {
userSelect: "none",
},
thumb: {
bg: "white",
rounded: "inherit",
},
track: {
bg: ["blackAlpha.400", "whiteAlpha.300"],
rounded: "full",
transitionDuration: "fast",
transitionProperty: "common",
_checked: {
justifyContent: "flex-end",
},
_focusVisible: {
boxShadow: "outline",
},
},
},
sizes: {
sm: ({ variant: v }) => ({
label: { fontSize: "sm" },
thumb: {
h: "3",
w: "3",
},
track: {
h: v === "thin" ? "2" : undefined,
w: "6",
},
}),
md: ({ variant: v }) => ({
label: { fontSize: "md" },
thumb: {
h: "4",
w: "4",
},
track: {
h: v === "thin" ? "3" : undefined,
w: "8",
},
}),
lg: ({ variant: v }) => ({
label: { fontSize: "lg" },
thumb: {
h: "5",
w: "5",
},
track: {
h: v === "thin" ? "4" : undefined,
w: "10",
},
}),
},
variants: {
thin: ({ colorScheme: c = "primary", colorMode: m, theme: t }) => ({
thumb: {
boxShadow: "dark-md",
_checked: {
bg: [`${c}.500`, `${c}.600`],
},
},
track: {
_checked: {
bg: [
isGray(c) ? `${c}.50` : `${c}.100`,
shadeColor(`${c}.300`, 58)(t, m),
],
},
},
}),
thick: ({ colorScheme: c = "primary" }) => ({
track: {
p: "1",
_checked: {
bg: [`${c}.500`, `${c}.600`],
},
},
}),
},
defaultProps: {
colorScheme: "primary",
size: "md",
variant: "thick",
},
}
Copied!

Edit this page on GitHub

PreviousCheckboxCardNextToggle