@nextui-org/theme
Version:
The default theme for NextUI components
366 lines (363 loc) • 8.23 kB
JavaScript
import {
tv
} from "./chunk-UWE6H66T.mjs";
import {
dataFocusVisibleClasses
} from "./chunk-GH5E4FQB.mjs";
// src/components/dropdown.ts
var dropdown = tv({
base: ["w-full", "p-1", "min-w-[200px]"]
});
var dropdownItem = tv({
slots: {
base: [
"flex",
"group",
"gap-2",
"items-center",
"justify-between",
"relative",
"px-2",
"py-1.5",
"w-full",
"h-full",
"box-border",
"rounded-small",
"outline-none",
"cursor-pointer",
"tap-highlight-transparent",
"data-[pressed=true]:opacity-70",
...dataFocusVisibleClasses,
"data-[focus-visible=true]:dark:ring-offset-background-content1"
],
wrapper: "w-full flex flex-col items-start justify-center",
title: "flex-1 text-small font-normal truncate",
description: ["w-full", "text-tiny", "text-foreground-500", "group-hover:text-current"],
selectedIcon: ["text-inherit", "w-3", "h-3", "flex-shrink-0"],
shortcut: [
"px-1",
"py-0.5",
"rounded",
"font-sans",
"text-foreground-500",
"text-tiny",
"border-small",
"border-default-300",
"group-hover:border-current"
]
},
variants: {
variant: {
solid: {
base: ""
},
bordered: {
base: "border-medium border-transparent bg-transparent"
},
light: {
base: "bg-transparent"
},
faded: {
base: "border-small border-transparent hover:border-default data-[hover=true]:bg-default-100"
},
flat: {
base: ""
},
shadow: {
base: "data-[hover=true]:shadow-lg"
}
},
color: {
default: {},
primary: {},
secondary: {},
success: {},
warning: {},
danger: {}
},
isDisabled: {
true: {
base: "opacity-disabled pointer-events-none"
}
},
disableAnimation: {
true: {},
false: {}
}
},
defaultVariants: {
variant: "solid",
color: "default"
},
compoundVariants: [
{
variant: "solid",
color: "default",
class: {
base: "data-[hover=true]:bg-default data-[hover=true]:text-default-foreground"
}
},
{
variant: "solid",
color: "primary",
class: {
base: "data-[hover=true]:bg-primary data-[hover=true]:text-primary-foreground"
}
},
{
variant: "solid",
color: "secondary",
class: {
base: "data-[hover=true]:bg-secondary data-[hover=true]:text-secondary-foreground"
}
},
{
variant: "solid",
color: "success",
class: {
base: "data-[hover=true]:bg-success data-[hover=true]:text-success-foreground"
}
},
{
variant: "solid",
color: "warning",
class: {
base: "data-[hover=true]:bg-warning data-[hover=true]:text-warning-foreground"
}
},
{
variant: "solid",
color: "danger",
class: {
base: "data-[hover=true]:bg-danger data-[hover=true]:text-danger-foreground"
}
},
{
variant: "shadow",
color: "default",
class: {
base: "data-[hover=true]:shadow-default/50 data-[hover=true]:bg-default data-[hover=true]:text-default-foreground"
}
},
{
variant: "shadow",
color: "primary",
class: {
base: "data-[hover=true]:shadow-primary/30 data-[hover=true]:bg-primary data-[hover=true]:text-primary-foreground"
}
},
{
variant: "shadow",
color: "secondary",
class: {
base: "data-[hover=true]:shadow-secondary/30 data-[hover=true]:bg-secondary data-[hover=true]:text-secondary-foreground"
}
},
{
variant: "shadow",
color: "success",
class: {
base: "data-[hover=true]:shadow-success/30 data-[hover=true]:bg-success data-[hover=true]:text-success-foreground"
}
},
{
variant: "shadow",
color: "warning",
class: {
base: "data-[hover=true]:shadow-warning/30 data-[hover=true]:bg-warning data-[hover=true]:text-warning-foreground"
}
},
{
variant: "shadow",
color: "danger",
class: {
base: "data-[hover=true]:shadow-danger/30 data-[hover=true]:bg-danger data-[hover=true]:text-danger-foreground"
}
},
{
variant: "bordered",
color: "default",
class: {
base: "data-[hover=true]:border-default"
}
},
{
variant: "bordered",
color: "primary",
class: {
base: "data-[hover=true]:border-primary data-[hover=true]:text-primary"
}
},
{
variant: "bordered",
color: "secondary",
class: {
base: "data-[hover=true]:border-secondary data-[hover=true]:text-secondary"
}
},
{
variant: "bordered",
color: "success",
class: {
base: "data-[hover=true]:border-success data-[hover=true]:text-success"
}
},
{
variant: "bordered",
color: "warning",
class: {
base: "data-[hover=true]:border-warning data-[hover=true]:text-warning"
}
},
{
variant: "bordered",
color: "danger",
class: {
base: "data-[hover=true]:border-danger data-[hover=true]:text-danger"
}
},
{
variant: "flat",
color: "default",
class: {
base: "data-[hover=true]:bg-default/40 data-[hover=true]:text-default-foreground"
}
},
{
variant: "flat",
color: "primary",
class: {
base: "data-[hover=true]:bg-primary/20 data-[hover=true]:text-primary"
}
},
{
variant: "flat",
color: "secondary",
class: {
base: "data-[hover=true]:bg-secondary/20 data-[hover=true]:text-secondary"
}
},
{
variant: "flat",
color: "success",
class: {
base: "data-[hover=true]:bg-success/20 data-[hover=true]:text-success "
}
},
{
variant: "flat",
color: "warning",
class: {
base: "data-[hover=true]:bg-warning/20 data-[hover=true]:text-warning"
}
},
{
variant: "flat",
color: "danger",
class: {
base: "data-[hover=true]:bg-danger/20 data-[hover=true]:text-danger"
}
},
{
variant: "faded",
color: "default",
class: {
base: "data-[hover=true]:text-default-foreground"
}
},
{
variant: "faded",
color: "primary",
class: {
base: "data-[hover=true]:text-primary"
}
},
{
variant: "faded",
color: "secondary",
class: {
base: "data-[hover=true]:text-secondary"
}
},
{
variant: "faded",
color: "success",
class: {
base: "data-[hover=true]:text-success"
}
},
{
variant: "faded",
color: "warning",
class: {
base: "data-[hover=true]:text-warning"
}
},
{
variant: "faded",
color: "danger",
class: {
base: "data-[hover=true]:text-danger"
}
},
{
variant: "light",
color: "default",
class: {
base: "data-[hover=true]:text-default-500"
}
},
{
variant: "light",
color: "primary",
class: {
base: "data-[hover=true]:text-primary"
}
},
{
variant: "light",
color: "secondary",
class: {
base: "data-[hover=true]:text-secondary"
}
},
{
variant: "light",
color: "success",
class: {
base: "data-[hover=true]:text-success"
}
},
{
variant: "light",
color: "warning",
class: {
base: "data-[hover=true]:text-warning"
}
},
{
variant: "light",
color: "danger",
class: {
base: "data-[hover=true]:text-danger"
}
}
]
});
var dropdownSection = tv({
slots: {
base: "relative mb-2",
heading: "pl-1 text-tiny text-foreground-500",
group: "data-[has-title=true]:pt-1",
divider: "mt-2"
}
});
var dropdownMenu = tv({
base: "w-full flex flex-col gap-0.5 p-1"
});
export {
dropdown,
dropdownItem,
dropdownSection,
dropdownMenu
};