@nuxt/ui
Version:
A UI Library for Modern Web Apps, powered by Vue & Tailwind CSS.
378 lines (375 loc) • 16.9 kB
text/typescript
const color = [
"primary",
"secondary",
"success",
"info",
"warning",
"error",
"neutral"
] as const
const variant = [
"solid",
"outline",
"soft",
"subtle",
"ghost",
"link"
] as const
const size = [
"xs",
"sm",
"md",
"lg",
"xl"
] as const
export default {
"slots": {
"base": [
"rounded-md font-medium inline-flex items-center disabled:cursor-not-allowed aria-disabled:cursor-not-allowed disabled:opacity-75 aria-disabled:opacity-75",
"transition-colors"
],
"label": "truncate",
"leadingIcon": "shrink-0",
"leadingAvatar": "shrink-0",
"leadingAvatarSize": "",
"trailingIcon": "shrink-0"
},
"variants": {
"buttonGroup": {
"horizontal": "not-only:first:rounded-e-none not-only:last:rounded-s-none not-last:not-first:rounded-none focus-visible:z-[1]",
"vertical": "not-only:first:rounded-b-none not-only:last:rounded-t-none not-last:not-first:rounded-none focus-visible:z-[1]"
},
"color": {
"primary": "",
"secondary": "",
"success": "",
"info": "",
"warning": "",
"error": "",
"neutral": ""
},
"variant": {
"solid": "",
"outline": "",
"soft": "",
"subtle": "",
"ghost": "",
"link": ""
},
"size": {
"xs": {
"base": "px-2 py-1 text-xs gap-1",
"leadingIcon": "size-4",
"leadingAvatarSize": "3xs",
"trailingIcon": "size-4"
},
"sm": {
"base": "px-2.5 py-1.5 text-xs gap-1.5",
"leadingIcon": "size-4",
"leadingAvatarSize": "3xs",
"trailingIcon": "size-4"
},
"md": {
"base": "px-2.5 py-1.5 text-sm gap-1.5",
"leadingIcon": "size-5",
"leadingAvatarSize": "2xs",
"trailingIcon": "size-5"
},
"lg": {
"base": "px-3 py-2 text-sm gap-2",
"leadingIcon": "size-5",
"leadingAvatarSize": "2xs",
"trailingIcon": "size-5"
},
"xl": {
"base": "px-3 py-2 text-base gap-2",
"leadingIcon": "size-6",
"leadingAvatarSize": "xs",
"trailingIcon": "size-6"
}
},
"block": {
"true": {
"base": "w-full justify-center",
"trailingIcon": "ms-auto"
}
},
"square": {
"true": ""
},
"leading": {
"true": ""
},
"trailing": {
"true": ""
},
"loading": {
"true": ""
},
"active": {
"true": {
"base": ""
},
"false": {
"base": ""
}
}
},
"compoundVariants": [
{
"color": "primary" as typeof color[number],
"variant": "solid" as typeof variant[number],
"class": "text-inverted bg-primary hover:bg-primary/75 disabled:bg-primary aria-disabled:bg-primary focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-primary"
},
{
"color": "secondary" as typeof color[number],
"variant": "solid" as typeof variant[number],
"class": "text-inverted bg-secondary hover:bg-secondary/75 disabled:bg-secondary aria-disabled:bg-secondary focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-secondary"
},
{
"color": "success" as typeof color[number],
"variant": "solid" as typeof variant[number],
"class": "text-inverted bg-success hover:bg-success/75 disabled:bg-success aria-disabled:bg-success focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-success"
},
{
"color": "info" as typeof color[number],
"variant": "solid" as typeof variant[number],
"class": "text-inverted bg-info hover:bg-info/75 disabled:bg-info aria-disabled:bg-info focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-info"
},
{
"color": "warning" as typeof color[number],
"variant": "solid" as typeof variant[number],
"class": "text-inverted bg-warning hover:bg-warning/75 disabled:bg-warning aria-disabled:bg-warning focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-warning"
},
{
"color": "error" as typeof color[number],
"variant": "solid" as typeof variant[number],
"class": "text-inverted bg-error hover:bg-error/75 disabled:bg-error aria-disabled:bg-error focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-error"
},
{
"color": "primary" as typeof color[number],
"variant": "outline" as typeof variant[number],
"class": "ring ring-inset ring-primary/50 text-primary hover:bg-primary/10 disabled:bg-transparent aria-disabled:bg-transparent dark:disabled:bg-transparent dark:aria-disabled:bg-transparent focus:outline-none focus-visible:ring-2 focus-visible:ring-primary"
},
{
"color": "secondary" as typeof color[number],
"variant": "outline" as typeof variant[number],
"class": "ring ring-inset ring-secondary/50 text-secondary hover:bg-secondary/10 disabled:bg-transparent aria-disabled:bg-transparent dark:disabled:bg-transparent dark:aria-disabled:bg-transparent focus:outline-none focus-visible:ring-2 focus-visible:ring-secondary"
},
{
"color": "success" as typeof color[number],
"variant": "outline" as typeof variant[number],
"class": "ring ring-inset ring-success/50 text-success hover:bg-success/10 disabled:bg-transparent aria-disabled:bg-transparent dark:disabled:bg-transparent dark:aria-disabled:bg-transparent focus:outline-none focus-visible:ring-2 focus-visible:ring-success"
},
{
"color": "info" as typeof color[number],
"variant": "outline" as typeof variant[number],
"class": "ring ring-inset ring-info/50 text-info hover:bg-info/10 disabled:bg-transparent aria-disabled:bg-transparent dark:disabled:bg-transparent dark:aria-disabled:bg-transparent focus:outline-none focus-visible:ring-2 focus-visible:ring-info"
},
{
"color": "warning" as typeof color[number],
"variant": "outline" as typeof variant[number],
"class": "ring ring-inset ring-warning/50 text-warning hover:bg-warning/10 disabled:bg-transparent aria-disabled:bg-transparent dark:disabled:bg-transparent dark:aria-disabled:bg-transparent focus:outline-none focus-visible:ring-2 focus-visible:ring-warning"
},
{
"color": "error" as typeof color[number],
"variant": "outline" as typeof variant[number],
"class": "ring ring-inset ring-error/50 text-error hover:bg-error/10 disabled:bg-transparent aria-disabled:bg-transparent dark:disabled:bg-transparent dark:aria-disabled:bg-transparent focus:outline-none focus-visible:ring-2 focus-visible:ring-error"
},
{
"color": "primary" as typeof color[number],
"variant": "soft" as typeof variant[number],
"class": "text-primary bg-primary/10 hover:bg-primary/15 focus:outline-none focus-visible:bg-primary/15 disabled:bg-primary/10 aria-disabled:bg-primary/10"
},
{
"color": "secondary" as typeof color[number],
"variant": "soft" as typeof variant[number],
"class": "text-secondary bg-secondary/10 hover:bg-secondary/15 focus:outline-none focus-visible:bg-secondary/15 disabled:bg-secondary/10 aria-disabled:bg-secondary/10"
},
{
"color": "success" as typeof color[number],
"variant": "soft" as typeof variant[number],
"class": "text-success bg-success/10 hover:bg-success/15 focus:outline-none focus-visible:bg-success/15 disabled:bg-success/10 aria-disabled:bg-success/10"
},
{
"color": "info" as typeof color[number],
"variant": "soft" as typeof variant[number],
"class": "text-info bg-info/10 hover:bg-info/15 focus:outline-none focus-visible:bg-info/15 disabled:bg-info/10 aria-disabled:bg-info/10"
},
{
"color": "warning" as typeof color[number],
"variant": "soft" as typeof variant[number],
"class": "text-warning bg-warning/10 hover:bg-warning/15 focus:outline-none focus-visible:bg-warning/15 disabled:bg-warning/10 aria-disabled:bg-warning/10"
},
{
"color": "error" as typeof color[number],
"variant": "soft" as typeof variant[number],
"class": "text-error bg-error/10 hover:bg-error/15 focus:outline-none focus-visible:bg-error/15 disabled:bg-error/10 aria-disabled:bg-error/10"
},
{
"color": "primary" as typeof color[number],
"variant": "subtle" as typeof variant[number],
"class": "text-primary ring ring-inset ring-primary/25 bg-primary/10 hover:bg-primary/15 disabled:bg-primary/10 aria-disabled:bg-primary/10 focus:outline-none focus-visible:ring-2 focus-visible:ring-primary"
},
{
"color": "secondary" as typeof color[number],
"variant": "subtle" as typeof variant[number],
"class": "text-secondary ring ring-inset ring-secondary/25 bg-secondary/10 hover:bg-secondary/15 disabled:bg-secondary/10 aria-disabled:bg-secondary/10 focus:outline-none focus-visible:ring-2 focus-visible:ring-secondary"
},
{
"color": "success" as typeof color[number],
"variant": "subtle" as typeof variant[number],
"class": "text-success ring ring-inset ring-success/25 bg-success/10 hover:bg-success/15 disabled:bg-success/10 aria-disabled:bg-success/10 focus:outline-none focus-visible:ring-2 focus-visible:ring-success"
},
{
"color": "info" as typeof color[number],
"variant": "subtle" as typeof variant[number],
"class": "text-info ring ring-inset ring-info/25 bg-info/10 hover:bg-info/15 disabled:bg-info/10 aria-disabled:bg-info/10 focus:outline-none focus-visible:ring-2 focus-visible:ring-info"
},
{
"color": "warning" as typeof color[number],
"variant": "subtle" as typeof variant[number],
"class": "text-warning ring ring-inset ring-warning/25 bg-warning/10 hover:bg-warning/15 disabled:bg-warning/10 aria-disabled:bg-warning/10 focus:outline-none focus-visible:ring-2 focus-visible:ring-warning"
},
{
"color": "error" as typeof color[number],
"variant": "subtle" as typeof variant[number],
"class": "text-error ring ring-inset ring-error/25 bg-error/10 hover:bg-error/15 disabled:bg-error/10 aria-disabled:bg-error/10 focus:outline-none focus-visible:ring-2 focus-visible:ring-error"
},
{
"color": "primary" as typeof color[number],
"variant": "ghost" as typeof variant[number],
"class": "text-primary hover:bg-primary/10 focus:outline-none focus-visible:bg-primary/10 disabled:bg-transparent aria-disabled:bg-transparent dark:disabled:bg-transparent dark:aria-disabled:bg-transparent"
},
{
"color": "secondary" as typeof color[number],
"variant": "ghost" as typeof variant[number],
"class": "text-secondary hover:bg-secondary/10 focus:outline-none focus-visible:bg-secondary/10 disabled:bg-transparent aria-disabled:bg-transparent dark:disabled:bg-transparent dark:aria-disabled:bg-transparent"
},
{
"color": "success" as typeof color[number],
"variant": "ghost" as typeof variant[number],
"class": "text-success hover:bg-success/10 focus:outline-none focus-visible:bg-success/10 disabled:bg-transparent aria-disabled:bg-transparent dark:disabled:bg-transparent dark:aria-disabled:bg-transparent"
},
{
"color": "info" as typeof color[number],
"variant": "ghost" as typeof variant[number],
"class": "text-info hover:bg-info/10 focus:outline-none focus-visible:bg-info/10 disabled:bg-transparent aria-disabled:bg-transparent dark:disabled:bg-transparent dark:aria-disabled:bg-transparent"
},
{
"color": "warning" as typeof color[number],
"variant": "ghost" as typeof variant[number],
"class": "text-warning hover:bg-warning/10 focus:outline-none focus-visible:bg-warning/10 disabled:bg-transparent aria-disabled:bg-transparent dark:disabled:bg-transparent dark:aria-disabled:bg-transparent"
},
{
"color": "error" as typeof color[number],
"variant": "ghost" as typeof variant[number],
"class": "text-error hover:bg-error/10 focus:outline-none focus-visible:bg-error/10 disabled:bg-transparent aria-disabled:bg-transparent dark:disabled:bg-transparent dark:aria-disabled:bg-transparent"
},
{
"color": "primary" as typeof color[number],
"variant": "link" as typeof variant[number],
"class": "text-primary hover:text-primary/75 disabled:text-primary aria-disabled:text-primary focus:outline-none focus-visible:ring-2 focus-visible:ring-inset focus-visible:ring-primary"
},
{
"color": "secondary" as typeof color[number],
"variant": "link" as typeof variant[number],
"class": "text-secondary hover:text-secondary/75 disabled:text-secondary aria-disabled:text-secondary focus:outline-none focus-visible:ring-2 focus-visible:ring-inset focus-visible:ring-secondary"
},
{
"color": "success" as typeof color[number],
"variant": "link" as typeof variant[number],
"class": "text-success hover:text-success/75 disabled:text-success aria-disabled:text-success focus:outline-none focus-visible:ring-2 focus-visible:ring-inset focus-visible:ring-success"
},
{
"color": "info" as typeof color[number],
"variant": "link" as typeof variant[number],
"class": "text-info hover:text-info/75 disabled:text-info aria-disabled:text-info focus:outline-none focus-visible:ring-2 focus-visible:ring-inset focus-visible:ring-info"
},
{
"color": "warning" as typeof color[number],
"variant": "link" as typeof variant[number],
"class": "text-warning hover:text-warning/75 disabled:text-warning aria-disabled:text-warning focus:outline-none focus-visible:ring-2 focus-visible:ring-inset focus-visible:ring-warning"
},
{
"color": "error" as typeof color[number],
"variant": "link" as typeof variant[number],
"class": "text-error hover:text-error/75 disabled:text-error aria-disabled:text-error focus:outline-none focus-visible:ring-2 focus-visible:ring-inset focus-visible:ring-error"
},
{
"color": "neutral" as typeof color[number],
"variant": "solid" as typeof variant[number],
"class": "text-inverted bg-inverted hover:bg-inverted/90 disabled:bg-inverted aria-disabled:bg-inverted focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-inverted"
},
{
"color": "neutral" as typeof color[number],
"variant": "outline" as typeof variant[number],
"class": "ring ring-inset ring-accented text-default bg-default hover:bg-elevated disabled:bg-default aria-disabled:bg-default focus:outline-none focus-visible:ring-2 focus-visible:ring-inverted"
},
{
"color": "neutral" as typeof color[number],
"variant": "soft" as typeof variant[number],
"class": "text-default bg-elevated hover:bg-accented/75 focus:outline-none focus-visible:bg-accented/75 disabled:bg-elevated aria-disabled:bg-elevated"
},
{
"color": "neutral" as typeof color[number],
"variant": "subtle" as typeof variant[number],
"class": "ring ring-inset ring-accented text-default bg-elevated hover:bg-accented/75 disabled:bg-elevated aria-disabled:bg-elevated focus:outline-none focus-visible:ring-2 focus-visible:ring-inverted"
},
{
"color": "neutral" as typeof color[number],
"variant": "ghost" as typeof variant[number],
"class": "text-default hover:bg-elevated focus:outline-none focus-visible:bg-elevated hover:disabled:bg-transparent dark:hover:disabled:bg-transparent hover:aria-disabled:bg-transparent dark:hover:aria-disabled:bg-transparent"
},
{
"color": "neutral" as typeof color[number],
"variant": "link" as typeof variant[number],
"class": "text-muted hover:text-default disabled:text-muted aria-disabled:text-muted focus:outline-none focus-visible:ring-inset focus-visible:ring-2 focus-visible:ring-inverted"
},
{
"size": "xs" as typeof size[number],
"square": true,
"class": "p-1"
},
{
"size": "sm" as typeof size[number],
"square": true,
"class": "p-1.5"
},
{
"size": "md" as typeof size[number],
"square": true,
"class": "p-1.5"
},
{
"size": "lg" as typeof size[number],
"square": true,
"class": "p-2"
},
{
"size": "xl" as typeof size[number],
"square": true,
"class": "p-2"
},
{
"loading": true,
"leading": true,
"class": {
"leadingIcon": "animate-spin"
}
},
{
"loading": true,
"leading": false,
"trailing": true,
"class": {
"trailingIcon": "animate-spin"
}
}
],
"defaultVariants": {
"color": "primary" as typeof color[number],
"variant": "solid" as typeof variant[number],
"size": "md" as typeof size[number]
}
}