@nextui-org/theme
Version:
The default theme for NextUI components
2,126 lines (2,107 loc) • 264 kB
JavaScript
"use strict";
var __create = Object.create;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getProtoOf = Object.getPrototypeOf;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
mod
));
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
// src/index.ts
var src_exports = {};
__export(src_exports, {
COMMON_UNITS: () => COMMON_UNITS,
absoluteFullClasses: () => absoluteFullClasses,
accordion: () => accordion,
accordionItem: () => accordionItem,
alert: () => alert,
autocomplete: () => autocomplete,
avatar: () => avatar,
avatarGroup: () => avatarGroup,
badge: () => badge,
baseStyles: () => baseStyles,
breadcrumbItem: () => breadcrumbItem,
breadcrumbs: () => breadcrumbs,
button: () => button,
buttonGroup: () => buttonGroup,
calendar: () => calendar,
card: () => card,
checkbox: () => checkbox,
checkboxGroup: () => checkboxGroup,
chip: () => chip,
circularProgress: () => circularProgress,
cn: () => cn,
code: () => code,
collapseAdjacentVariantBorders: () => collapseAdjacentVariantBorders,
colorVariants: () => colorVariants,
colors: () => colors,
commonColors: () => commonColors,
darkLayout: () => darkLayout,
dataFocusVisibleClasses: () => dataFocusVisibleClasses,
dateInput: () => dateInput,
datePicker: () => datePicker,
dateRangePicker: () => dateRangePicker,
defaultLayout: () => defaultLayout,
divider: () => divider,
drawer: () => drawer,
drip: () => drip,
dropdown: () => dropdown,
dropdownItem: () => dropdownItem,
dropdownMenu: () => dropdownMenu,
dropdownSection: () => dropdownSection,
focusVisibleClasses: () => focusVisibleClasses,
form: () => form,
groupDataFocusVisibleClasses: () => groupDataFocusVisibleClasses,
hiddenInputClasses: () => hiddenInputClasses,
image: () => image,
input: () => input,
inputOtp: () => inputOtp,
kbd: () => kbd,
lightLayout: () => lightLayout,
link: () => link,
linkAnchorClasses: () => linkAnchorClasses,
listbox: () => menu,
listboxItem: () => menuItem,
listboxSection: () => menuSection,
menu: () => menu,
menuItem: () => menuItem,
menuSection: () => menuSection,
mergeClasses: () => mergeClasses,
modal: () => modal,
navbar: () => navbar,
nextui: () => nextui,
pagination: () => pagination,
popover: () => popover,
progress: () => progress,
radio: () => radio,
radioGroup: () => radioGroup,
ringClasses: () => ringClasses,
scrollShadow: () => scrollShadow,
select: () => select,
semanticColors: () => semanticColors,
skeleton: () => skeleton,
slider: () => slider,
snippet: () => snippet,
spacer: () => spacer,
spinner: () => spinner,
table: () => table,
tabs: () => tabs,
toggle: () => toggle,
translateCenterClasses: () => translateCenterClasses,
tv: () => tv,
twMergeConfig: () => twMergeConfig,
user: () => user
});
module.exports = __toCommonJS(src_exports);
// src/utils/tv.ts
var import_tailwind_variants = require("tailwind-variants");
// src/utils/tw-merge-config.ts
var COMMON_UNITS = ["small", "medium", "large"];
var twMergeConfig = {
theme: {
opacity: ["disabled"],
spacing: ["divider"],
borderWidth: COMMON_UNITS,
borderRadius: COMMON_UNITS
},
classGroups: {
shadow: [{ shadow: COMMON_UNITS }],
"font-size": [{ text: ["tiny", ...COMMON_UNITS] }],
"bg-image": [
"bg-stripe-gradient-default",
"bg-stripe-gradient-primary",
"bg-stripe-gradient-secondary",
"bg-stripe-gradient-success",
"bg-stripe-gradient-warning",
"bg-stripe-gradient-danger"
]
}
};
// src/utils/tv.ts
var tv = (options, config) => {
var _a, _b, _c;
return (0, import_tailwind_variants.tv)(options, {
...config,
twMerge: (_a = config == null ? void 0 : config.twMerge) != null ? _a : true,
twMergeConfig: {
...config == null ? void 0 : config.twMergeConfig,
theme: {
...(_b = config == null ? void 0 : config.twMergeConfig) == null ? void 0 : _b.theme,
...twMergeConfig.theme
},
classGroups: {
...(_c = config == null ? void 0 : config.twMergeConfig) == null ? void 0 : _c.classGroups,
...twMergeConfig.classGroups
}
}
});
};
// src/utils/classes.ts
var baseStyles = (prefix) => ({
color: `hsl(var(--${prefix}-foreground))`,
backgroundColor: `hsl(var(--${prefix}-background))`
});
var focusVisibleClasses = [
"focus-visible:z-10",
"focus-visible:outline-2",
"focus-visible:outline-focus",
"focus-visible:outline-offset-2"
];
var dataFocusVisibleClasses = [
"outline-none",
"data-[focus-visible=true]:z-10",
"data-[focus-visible=true]:outline-2",
"data-[focus-visible=true]:outline-focus",
"data-[focus-visible=true]:outline-offset-2"
];
var groupDataFocusVisibleClasses = [
"outline-none",
"group-data-[focus-visible=true]:z-10",
"group-data-[focus-visible=true]:ring-2",
"group-data-[focus-visible=true]:ring-focus",
"group-data-[focus-visible=true]:ring-offset-2",
"group-data-[focus-visible=true]:ring-offset-background"
];
var ringClasses = [
"outline-none",
"ring-2",
"ring-focus",
"ring-offset-2",
"ring-offset-background"
];
var translateCenterClasses = [
"absolute",
"top-1/2",
"left-1/2",
"-translate-x-1/2",
"-translate-y-1/2"
];
var absoluteFullClasses = ["absolute", "inset-0"];
var collapseAdjacentVariantBorders = {
default: ["[&+.border-medium.border-default]:ms-[calc(theme(borderWidth.medium)*-1)]"],
primary: ["[&+.border-medium.border-primary]:ms-[calc(theme(borderWidth.medium)*-1)]"],
secondary: ["[&+.border-medium.border-secondary]:ms-[calc(theme(borderWidth.medium)*-1)]"],
success: ["[&+.border-medium.border-success]:ms-[calc(theme(borderWidth.medium)*-1)]"],
warning: ["[&+.border-medium.border-warning]:ms-[calc(theme(borderWidth.medium)*-1)]"],
danger: ["[&+.border-medium.border-danger]:ms-[calc(theme(borderWidth.medium)*-1)]"]
};
var hiddenInputClasses = [
"[--cursor-hit-x:8px]",
"font-inherit",
"text-[100%]",
"leading-[1.15]",
"m-0",
"p-0",
"overflow-visible",
"box-border",
"absolute",
"top-0",
"start-[calc(var(--cursor-hit-x)*-1)]",
"w-[calc(100%+var(--cursor-hit-x)*2)]",
"h-full",
"opacity-[0.0001]",
"z-[1]",
"cursor-pointer",
"disabled:cursor-default"
];
// src/utils/variants.ts
var solid = {
default: "bg-default text-default-foreground",
primary: "bg-primary text-primary-foreground",
secondary: "bg-secondary text-secondary-foreground",
success: "bg-success text-success-foreground",
warning: "bg-warning text-warning-foreground",
danger: "bg-danger text-danger-foreground",
foreground: "bg-foreground text-background"
};
var shadow = {
default: "shadow-lg shadow-default/50 bg-default text-default-foreground",
primary: "shadow-lg shadow-primary/40 bg-primary text-primary-foreground",
secondary: "shadow-lg shadow-secondary/40 bg-secondary text-secondary-foreground",
success: "shadow-lg shadow-success/40 bg-success text-success-foreground",
warning: "shadow-lg shadow-warning/40 bg-warning text-warning-foreground",
danger: "shadow-lg shadow-danger/40 bg-danger text-danger-foreground",
foreground: "shadow-lg shadow-foreground/40 bg-foreground text-background"
};
var bordered = {
default: "bg-transparent border-default text-foreground",
primary: "bg-transparent border-primary text-primary",
secondary: "bg-transparent border-secondary text-secondary",
success: "bg-transparent border-success text-success",
warning: "bg-transparent border-warning text-warning",
danger: "bg-transparent border-danger text-danger",
foreground: "bg-transparent border-foreground text-foreground"
};
var flat = {
default: "bg-default/40 text-default-700",
primary: "bg-primary/20 text-primary-600",
secondary: "bg-secondary/20 text-secondary-600",
success: "bg-success/20 text-success-700 dark:text-success",
warning: "bg-warning/20 text-warning-700 dark:text-warning",
danger: "bg-danger/20 text-danger-600 dark:text-danger-500",
foreground: "bg-foreground/10 text-foreground"
};
var faded = {
default: "border-default bg-default-100 text-default-foreground",
primary: "border-default bg-default-100 text-primary",
secondary: "border-default bg-default-100 text-secondary",
success: "border-default bg-default-100 text-success",
warning: "border-default bg-default-100 text-warning",
danger: "border-default bg-default-100 text-danger",
foreground: "border-default bg-default-100 text-foreground"
};
var light = {
default: "bg-transparent text-default-foreground",
primary: "bg-transparent text-primary",
secondary: "bg-transparent text-secondary",
success: "bg-transparent text-success",
warning: "bg-transparent text-warning",
danger: "bg-transparent text-danger",
foreground: "bg-transparent text-foreground"
};
var ghost = {
default: "border-default text-default-foreground",
primary: "border-primary text-primary",
secondary: "border-secondary text-secondary",
success: "border-success text-success",
warning: "border-warning text-warning",
danger: "border-danger text-danger",
foreground: "border-foreground text-foreground hover:!bg-foreground"
};
var colorVariants = {
solid,
shadow,
bordered,
flat,
faded,
light,
ghost
};
// src/utils/merge-classes.ts
var import_shared_utils = require("@nextui-org/shared-utils");
var mergeClasses = (itemClasses, itemPropsClasses) => {
if (!itemClasses && !itemPropsClasses)
return {};
const keys = /* @__PURE__ */ new Set([...Object.keys(itemClasses || {}), ...Object.keys(itemPropsClasses || {})]);
return Array.from(keys).reduce(
(acc, key) => ({
...acc,
[key]: (0, import_shared_utils.clsx)(itemClasses == null ? void 0 : itemClasses[key], itemPropsClasses == null ? void 0 : itemPropsClasses[key])
}),
{}
);
};
// src/utils/cn.ts
var import_clsx = __toESM(require("clsx"));
var import_tailwind_merge = require("tailwind-merge");
var twMerge = (0, import_tailwind_merge.extendTailwindMerge)({ extend: twMergeConfig });
function cn(...inputs) {
return twMerge((0, import_clsx.default)(inputs));
}
// src/components/avatar.ts
var avatar = tv({
slots: {
base: [
"flex",
"relative",
"justify-center",
"items-center",
"box-border",
"overflow-hidden",
"align-middle",
"text-white",
"z-0",
...dataFocusVisibleClasses
],
img: [
"flex",
"object-cover",
"w-full",
"h-full",
"transition-opacity",
"!duration-500",
"opacity-0",
"data-[loaded=true]:opacity-100"
],
fallback: [...translateCenterClasses, "flex", "items-center", "justify-center"],
name: [...translateCenterClasses, "font-normal", "text-center", "text-inherit"],
icon: [
...translateCenterClasses,
"flex",
"items-center",
"justify-center",
"text-inherit",
"w-full",
"h-full"
]
},
variants: {
size: {
sm: {
base: "w-8 h-8 text-tiny"
},
md: {
base: "w-10 h-10 text-tiny"
},
lg: {
base: "w-14 h-14 text-small"
}
},
color: {
default: {
base: colorVariants.solid.default
},
primary: {
base: colorVariants.solid.primary
},
secondary: {
base: colorVariants.solid.secondary
},
success: {
base: colorVariants.solid.success
},
warning: {
base: colorVariants.solid.warning
},
danger: {
base: colorVariants.solid.danger
}
},
radius: {
none: {
base: "rounded-none"
},
sm: {
base: "rounded-small"
},
md: {
base: "rounded-medium"
},
lg: {
base: "rounded-large"
},
full: {
base: "rounded-full"
}
},
isBordered: {
true: {
base: "ring-2 ring-offset-2 ring-offset-background dark:ring-offset-background-dark"
}
},
isDisabled: {
true: {
base: "opacity-disabled"
}
},
isInGroup: {
true: {
base: [
"-ms-2 data-[hover=true]:-translate-x-3 rtl:data-[hover=true]:translate-x-3 transition-transform",
"data-[focus-visible=true]:-translate-x-3 rtl:data-[focus-visible=true]:translate-x-3"
]
}
},
isInGridGroup: {
true: {
base: "m-0 data-[hover=true]:translate-x-0"
}
},
disableAnimation: {
true: {
base: "transition-none",
img: "transition-none"
},
false: {}
}
},
defaultVariants: {
size: "md",
color: "default",
radius: "full"
},
compoundVariants: [
{
color: "default",
isBordered: true,
class: {
base: "ring-default"
}
},
{
color: "primary",
isBordered: true,
class: {
base: "ring-primary"
}
},
{
color: "secondary",
isBordered: true,
class: {
base: "ring-secondary"
}
},
{
color: "success",
isBordered: true,
class: {
base: "ring-success"
}
},
{
color: "warning",
isBordered: true,
class: {
base: "ring-warning"
}
},
{
color: "danger",
isBordered: true,
class: {
base: "ring-danger"
}
}
]
});
var avatarGroup = tv({
slots: {
base: "flex items-center justify-center h-auto w-max",
count: "hover:-translate-x-0"
},
variants: {
isGrid: {
true: "inline-grid grid-cols-4 gap-3"
}
}
});
// src/components/card.ts
var card = tv({
slots: {
base: [
"flex",
"flex-col",
"relative",
"overflow-hidden",
"h-auto",
"outline-none",
"text-foreground",
"box-border",
"bg-content1",
...dataFocusVisibleClasses
],
header: [
"flex",
"p-3",
"z-10",
"w-full",
"justify-start",
"items-center",
"shrink-0",
"overflow-inherit",
"color-inherit",
"subpixel-antialiased"
],
body: [
"relative",
"flex",
"flex-1",
"w-full",
"p-3",
"flex-auto",
"flex-col",
"place-content-inherit",
"align-items-inherit",
"h-auto",
"break-words",
"text-left",
"overflow-y-auto",
"subpixel-antialiased"
],
footer: [
"p-3",
"h-auto",
"flex",
"w-full",
"items-center",
"overflow-hidden",
"color-inherit",
"subpixel-antialiased"
]
},
variants: {
shadow: {
none: {
base: "shadow-none"
},
sm: {
base: "shadow-small"
},
md: {
base: "shadow-medium"
},
lg: {
base: "shadow-large"
}
},
radius: {
none: {
base: "rounded-none",
header: "rounded-none",
footer: "rounded-none"
},
sm: {
base: "rounded-small",
header: "rounded-t-small",
footer: "rounded-b-small"
},
md: {
base: "rounded-medium",
header: "rounded-t-medium",
footer: "rounded-b-medium"
},
lg: {
base: "rounded-large",
header: "rounded-t-large",
footer: "rounded-b-large"
}
},
fullWidth: {
true: {
base: "w-full"
}
},
isHoverable: {
true: {
base: "data-[hover=true]:bg-content2 dark:data-[hover=true]:bg-content2"
}
},
isPressable: {
true: { base: "cursor-pointer" }
},
isBlurred: {
true: {
base: [
"bg-background/80",
"dark:bg-background/20",
"backdrop-blur-md",
"backdrop-saturate-150"
]
}
},
isFooterBlurred: {
true: {
footer: ["bg-background/10", "backdrop-blur", "backdrop-saturate-150"]
}
},
isDisabled: {
true: {
base: "opacity-disabled cursor-not-allowed"
}
},
disableAnimation: {
true: "",
false: { base: "transition-transform-background motion-reduce:transition-none" }
}
},
compoundVariants: [
{
isPressable: true,
class: "data-[pressed=true]:scale-[0.97] tap-highlight-transparent"
}
],
defaultVariants: {
radius: "lg",
shadow: "md",
fullWidth: false,
isHoverable: false,
isPressable: false,
isDisabled: false,
isFooterBlurred: false
}
});
// src/components/link.ts
var link = tv({
base: [
"relative inline-flex items-center outline-none tap-highlight-transparent",
...dataFocusVisibleClasses
],
variants: {
size: {
sm: "text-small",
md: "text-medium",
lg: "text-large"
},
color: {
foreground: "text-foreground",
primary: "text-primary",
secondary: "text-secondary",
success: "text-success",
warning: "text-warning",
danger: "text-danger"
},
underline: {
none: "no-underline",
hover: "hover:underline",
always: "underline",
active: "active:underline",
focus: "focus:underline"
},
isBlock: {
true: [
"px-2",
"py-1",
"hover:after:opacity-100",
"after:content-['']",
"after:inset-0",
"after:opacity-0",
"after:w-full",
"after:h-full",
"after:rounded-xl",
"after:transition-background",
"after:absolute"
],
false: "hover:opacity-80 active:opacity-disabled transition-opacity"
},
isDisabled: {
true: "opacity-disabled cursor-default pointer-events-none"
},
disableAnimation: {
true: "after:transition-none transition-none"
}
},
compoundVariants: [
{
isBlock: true,
color: "foreground",
class: "hover:after:bg-foreground/10"
},
{
isBlock: true,
color: "primary",
class: "hover:after:bg-primary/20"
},
{
isBlock: true,
color: "secondary",
class: "hover:after:bg-secondary/20"
},
{
isBlock: true,
color: "success",
class: "hover:after:bg-success/20"
},
{
isBlock: true,
color: "warning",
class: "hover:after:bg-warning/20"
},
{
isBlock: true,
color: "danger",
class: "hover:after:bg-danger/20"
},
{
underline: ["hover", "always", "active", "focus"],
class: "underline-offset-4"
}
],
defaultVariants: {
color: "primary",
size: "md",
isBlock: false,
underline: "none",
isDisabled: false
}
});
var linkAnchorClasses = "flex mx-1 text-current self-center";
// src/components/user.ts
var user = tv({
slots: {
base: [
"inline-flex items-center justify-center gap-2 rounded-small outline-none",
...dataFocusVisibleClasses
],
wrapper: "inline-flex flex-col items-start",
name: "text-small text-inherit",
description: "text-tiny text-foreground-400"
}
});
// src/components/button.ts
var button = tv({
base: [
"z-0",
"group",
"relative",
"inline-flex",
"items-center",
"justify-center",
"box-border",
"appearance-none",
"outline-none",
"select-none",
"whitespace-nowrap",
"min-w-max",
"font-normal",
"subpixel-antialiased",
"overflow-hidden",
"tap-highlight-transparent",
"data-[pressed=true]:scale-[0.97]",
...dataFocusVisibleClasses
],
variants: {
variant: {
solid: "",
bordered: "border-medium bg-transparent",
light: "bg-transparent",
flat: "",
faded: "border-medium",
shadow: "",
ghost: "border-medium bg-transparent"
},
size: {
sm: "px-3 min-w-16 h-8 text-tiny gap-2 rounded-small",
md: "px-4 min-w-20 h-10 text-small gap-2 rounded-medium",
lg: "px-6 min-w-24 h-12 text-medium gap-3 rounded-large"
},
color: {
default: "",
primary: "",
secondary: "",
success: "",
warning: "",
danger: ""
},
radius: {
none: "rounded-none",
sm: "rounded-small",
md: "rounded-medium",
lg: "rounded-large",
full: "rounded-full"
},
fullWidth: {
true: "w-full"
},
isDisabled: {
true: "opacity-disabled pointer-events-none"
},
isInGroup: {
true: "[&:not(:first-child):not(:last-child)]:rounded-none"
},
isIconOnly: {
true: "px-0 !gap-0",
false: "[&>svg]:max-w-[theme(spacing.8)]"
},
disableAnimation: {
true: "!transition-none data-[pressed=true]:scale-100",
false: "transition-transform-colors-opacity motion-reduce:transition-none"
}
},
defaultVariants: {
size: "md",
variant: "solid",
color: "default",
fullWidth: false,
isDisabled: false,
isInGroup: false
},
compoundVariants: [
{
variant: "solid",
color: "default",
class: colorVariants.solid.default
},
{
variant: "solid",
color: "primary",
class: colorVariants.solid.primary
},
{
variant: "solid",
color: "secondary",
class: colorVariants.solid.secondary
},
{
variant: "solid",
color: "success",
class: colorVariants.solid.success
},
{
variant: "solid",
color: "warning",
class: colorVariants.solid.warning
},
{
variant: "solid",
color: "danger",
class: colorVariants.solid.danger
},
{
variant: "shadow",
color: "default",
class: colorVariants.shadow.default
},
{
variant: "shadow",
color: "primary",
class: colorVariants.shadow.primary
},
{
variant: "shadow",
color: "secondary",
class: colorVariants.shadow.secondary
},
{
variant: "shadow",
color: "success",
class: colorVariants.shadow.success
},
{
variant: "shadow",
color: "warning",
class: colorVariants.shadow.warning
},
{
variant: "shadow",
color: "danger",
class: colorVariants.shadow.danger
},
{
variant: "bordered",
color: "default",
class: colorVariants.bordered.default
},
{
variant: "bordered",
color: "primary",
class: colorVariants.bordered.primary
},
{
variant: "bordered",
color: "secondary",
class: colorVariants.bordered.secondary
},
{
variant: "bordered",
color: "success",
class: colorVariants.bordered.success
},
{
variant: "bordered",
color: "warning",
class: colorVariants.bordered.warning
},
{
variant: "bordered",
color: "danger",
class: colorVariants.bordered.danger
},
{
variant: "flat",
color: "default",
class: colorVariants.flat.default
},
{
variant: "flat",
color: "primary",
class: colorVariants.flat.primary
},
{
variant: "flat",
color: "secondary",
class: colorVariants.flat.secondary
},
{
variant: "flat",
color: "success",
class: colorVariants.flat.success
},
{
variant: "flat",
color: "warning",
class: colorVariants.flat.warning
},
{
variant: "flat",
color: "danger",
class: colorVariants.flat.danger
},
{
variant: "faded",
color: "default",
class: colorVariants.faded.default
},
{
variant: "faded",
color: "primary",
class: colorVariants.faded.primary
},
{
variant: "faded",
color: "secondary",
class: colorVariants.faded.secondary
},
{
variant: "faded",
color: "success",
class: colorVariants.faded.success
},
{
variant: "faded",
color: "warning",
class: colorVariants.faded.warning
},
{
variant: "faded",
color: "danger",
class: colorVariants.faded.danger
},
{
variant: "light",
color: "default",
class: [colorVariants.light.default, "data-[hover=true]:bg-default/40"]
},
{
variant: "light",
color: "primary",
class: [colorVariants.light.primary, "data-[hover=true]:bg-primary/20"]
},
{
variant: "light",
color: "secondary",
class: [colorVariants.light.secondary, "data-[hover=true]:bg-secondary/20"]
},
{
variant: "light",
color: "success",
class: [colorVariants.light.success, "data-[hover=true]:bg-success/20"]
},
{
variant: "light",
color: "warning",
class: [colorVariants.light.warning, "data-[hover=true]:bg-warning/20"]
},
{
variant: "light",
color: "danger",
class: [colorVariants.light.danger, "data-[hover=true]:bg-danger/20"]
},
{
variant: "ghost",
color: "default",
class: [colorVariants.ghost.default, "data-[hover=true]:!bg-default"]
},
{
variant: "ghost",
color: "primary",
class: [
colorVariants.ghost.primary,
"data-[hover=true]:!bg-primary data-[hover=true]:!text-primary-foreground"
]
},
{
variant: "ghost",
color: "secondary",
class: [
colorVariants.ghost.secondary,
"data-[hover=true]:!bg-secondary data-[hover=true]:!text-secondary-foreground"
]
},
{
variant: "ghost",
color: "success",
class: [
colorVariants.ghost.success,
"data-[hover=true]:!bg-success data-[hover=true]:!text-success-foreground"
]
},
{
variant: "ghost",
color: "warning",
class: [
colorVariants.ghost.warning,
"data-[hover=true]:!bg-warning data-[hover=true]:!text-warning-foreground"
]
},
{
variant: "ghost",
color: "danger",
class: [
colorVariants.ghost.danger,
"data-[hover=true]:!bg-danger data-[hover=true]:!text-danger-foreground"
]
},
{
isInGroup: true,
class: "rounded-none first:rounded-s-medium last:rounded-e-medium"
},
{
isInGroup: true,
size: "sm",
class: "rounded-none first:rounded-s-small last:rounded-e-small"
},
{
isInGroup: true,
size: "md",
class: "rounded-none first:rounded-s-medium last:rounded-e-medium"
},
{
isInGroup: true,
size: "lg",
class: "rounded-none first:rounded-s-large last:rounded-e-large"
},
{
isInGroup: true,
isRounded: true,
class: "rounded-none first:rounded-s-full last:rounded-e-full"
},
{
isInGroup: true,
radius: "none",
class: "rounded-none first:rounded-s-none last:rounded-e-none"
},
{
isInGroup: true,
radius: "sm",
class: "rounded-none first:rounded-s-small last:rounded-e-small"
},
{
isInGroup: true,
radius: "md",
class: "rounded-none first:rounded-s-medium last:rounded-e-medium"
},
{
isInGroup: true,
radius: "lg",
class: "rounded-none first:rounded-s-large last:rounded-e-large"
},
{
isInGroup: true,
radius: "full",
class: "rounded-none first:rounded-s-full last:rounded-e-full"
},
{
isInGroup: true,
variant: ["ghost", "bordered"],
color: "default",
className: collapseAdjacentVariantBorders.default
},
{
isInGroup: true,
variant: ["ghost", "bordered"],
color: "primary",
className: collapseAdjacentVariantBorders.primary
},
{
isInGroup: true,
variant: ["ghost", "bordered"],
color: "secondary",
className: collapseAdjacentVariantBorders.secondary
},
{
isInGroup: true,
variant: ["ghost", "bordered"],
color: "success",
className: collapseAdjacentVariantBorders.success
},
{
isInGroup: true,
variant: ["ghost", "bordered"],
color: "warning",
className: collapseAdjacentVariantBorders.warning
},
{
isInGroup: true,
variant: ["ghost", "bordered"],
color: "danger",
className: collapseAdjacentVariantBorders.danger
},
{
isIconOnly: true,
size: "sm",
class: "min-w-8 w-8 h-8"
},
{
isIconOnly: true,
size: "md",
class: "min-w-10 w-10 h-10"
},
{
isIconOnly: true,
size: "lg",
class: "min-w-12 w-12 h-12"
},
{
variant: ["solid", "faded", "flat", "bordered", "shadow"],
class: "data-[hover=true]:opacity-hover"
}
]
});
var buttonGroup = tv({
base: "inline-flex items-center justify-center h-auto",
variants: {
fullWidth: {
true: "w-full"
}
},
defaultVariants: {
fullWidth: false
}
});
// src/components/drip.ts
var drip = tv({
base: ["absolute", "will-change-transform", "bg-current", "rounded-full", "animate-drip-expand"]
});
// src/components/spinner.ts
var spinner = tv({
slots: {
base: "relative inline-flex flex-col gap-2 items-center justify-center",
wrapper: "relative flex",
circle1: [
"absolute",
"w-full",
"h-full",
"rounded-full",
"animate-spinner-ease-spin",
"border-2",
"border-solid",
"border-t-transparent",
"border-l-transparent",
"border-r-transparent"
],
circle2: [
"absolute",
"w-full",
"h-full",
"rounded-full",
"opacity-75",
"animate-spinner-linear-spin",
"border-2",
"border-dotted",
"border-t-transparent",
"border-l-transparent",
"border-r-transparent"
],
label: "text-foreground dark:text-foreground-dark font-regular"
},
variants: {
size: {
sm: {
wrapper: "w-5 h-5",
circle1: "border-2",
circle2: "border-2",
label: "text-small"
},
md: {
wrapper: "w-8 h-8",
circle1: "border-3",
circle2: "border-3",
label: "text-medium"
},
lg: {
wrapper: "w-10 h-10",
circle1: "border-3",
circle2: "border-3",
label: "text-large"
}
},
color: {
current: {
circle1: "border-b-current",
circle2: "border-b-current"
},
white: {
circle1: "border-b-white",
circle2: "border-b-white"
},
default: {
circle1: "border-b-default",
circle2: "border-b-default"
},
primary: {
circle1: "border-b-primary",
circle2: "border-b-primary"
},
secondary: {
circle1: "border-b-secondary",
circle2: "border-b-secondary"
},
success: {
circle1: "border-b-success",
circle2: "border-b-success"
},
warning: {
circle1: "border-b-warning",
circle2: "border-b-warning"
},
danger: {
circle1: "border-b-danger",
circle2: "border-b-danger"
}
},
labelColor: {
foreground: {
label: "text-foreground"
},
primary: {
label: "text-primary"
},
secondary: {
label: "text-secondary"
},
success: {
label: "text-success"
},
warning: {
label: "text-warning"
},
danger: {
label: "text-danger"
}
}
},
defaultVariants: {
size: "md",
color: "primary",
labelColor: "foreground"
}
});
// src/components/code.ts
var code = tv({
base: ["px-2", "py-1", "h-fit", "font-mono", "font-normal", "inline-block", "whitespace-nowrap"],
variants: {
color: {
default: colorVariants.flat.default,
primary: colorVariants.flat.primary,
secondary: colorVariants.flat.secondary,
success: colorVariants.flat.success,
warning: colorVariants.flat.warning,
danger: colorVariants.flat.danger
},
size: {
sm: "text-small",
md: "text-medium",
lg: "text-large"
},
radius: {
none: "rounded-none",
sm: "rounded-small",
md: "rounded-medium",
lg: "rounded-large",
full: "rounded-full"
}
},
defaultVariants: {
color: "default",
size: "sm",
radius: "sm"
}
});
// src/components/popover.ts
var popover = tv({
slots: {
base: [
"z-0",
"relative",
"bg-transparent",
"before:content-['']",
"before:hidden",
"before:z-[-1]",
"before:absolute",
"before:rotate-45",
"before:w-2.5",
"before:h-2.5",
"before:rounded-sm",
"data-[arrow=true]:before:block",
"data-[placement=top]:before:-bottom-[calc(theme(spacing.5)/4_-_1.5px)]",
"data-[placement=top]:before:left-1/2",
"data-[placement=top]:before:-translate-x-1/2",
"data-[placement=top-start]:before:-bottom-[calc(theme(spacing.5)/4_-_1.5px)]",
"data-[placement=top-start]:before:left-3",
"data-[placement=top-end]:before:-bottom-[calc(theme(spacing.5)/4_-_1.5px)]",
"data-[placement=top-end]:before:right-3",
"data-[placement=bottom]:before:-top-[calc(theme(spacing.5)/4_-_1.5px)]",
"data-[placement=bottom]:before:left-1/2",
"data-[placement=bottom]:before:-translate-x-1/2",
"data-[placement=bottom-start]:before:-top-[calc(theme(spacing.5)/4_-_1.5px)]",
"data-[placement=bottom-start]:before:left-3",
"data-[placement=bottom-end]:before:-top-[calc(theme(spacing.5)/4_-_1.5px)]",
"data-[placement=bottom-end]:before:right-3",
"data-[placement=left]:before:-right-[calc(theme(spacing.5)/4_-_2px)]",
"data-[placement=left]:before:top-1/2",
"data-[placement=left]:before:-translate-y-1/2",
"data-[placement=left-start]:before:-right-[calc(theme(spacing.5)/4_-_3px)]",
"data-[placement=left-start]:before:top-1/4",
"data-[placement=left-end]:before:-right-[calc(theme(spacing.5)/4_-_3px)]",
"data-[placement=left-end]:before:bottom-1/4",
"data-[placement=right]:before:-left-[calc(theme(spacing.5)/4_-_2px)]",
"data-[placement=right]:before:top-1/2",
"data-[placement=right]:before:-translate-y-1/2",
"data-[placement=right-start]:before:-left-[calc(theme(spacing.5)/4_-_3px)]",
"data-[placement=right-start]:before:top-1/4",
"data-[placement=right-end]:before:-left-[calc(theme(spacing.5)/4_-_3px)]",
"data-[placement=right-end]:before:bottom-1/4",
...dataFocusVisibleClasses
],
content: [
"z-10",
"px-2.5",
"py-1",
"w-full",
"inline-flex",
"flex-col",
"items-center",
"justify-center",
"box-border",
"subpixel-antialiased",
"outline-none",
"box-border"
],
trigger: ["z-10"],
backdrop: ["hidden"],
arrow: []
},
variants: {
size: {
sm: { content: "text-tiny" },
md: { content: "text-small" },
lg: { content: "text-medium" }
},
color: {
default: {
base: "before:bg-content1 before:shadow-small",
content: "bg-content1"
},
foreground: {
base: "before:bg-foreground",
content: colorVariants.solid.foreground
},
primary: {
base: "before:bg-primary",
content: colorVariants.solid.primary
},
secondary: {
base: "before:bg-secondary",
content: colorVariants.solid.secondary
},
success: {
base: "before:bg-success",
content: colorVariants.solid.success
},
warning: {
base: "before:bg-warning",
content: colorVariants.solid.warning
},
danger: {
base: "before:bg-danger",
content: colorVariants.solid.danger
}
},
radius: {
none: { content: "rounded-none" },
sm: { content: "rounded-small" },
md: { content: "rounded-medium" },
lg: { content: "rounded-large" },
full: { content: "rounded-full" }
},
shadow: {
sm: {
content: "shadow-small"
},
md: {
content: "shadow-medium"
},
lg: {
content: "shadow-large"
}
},
backdrop: {
transparent: {},
opaque: {
backdrop: "bg-overlay/50 backdrop-opacity-disabled"
},
blur: {
backdrop: "backdrop-blur-sm backdrop-saturate-150 bg-overlay/30"
}
},
triggerScaleOnOpen: {
true: {
trigger: ["aria-expanded:scale-[0.97]", "aria-expanded:opacity-70", "subpixel-antialiased"]
},
false: {}
},
disableAnimation: {
true: {
base: "animate-none"
}
},
isTriggerDisabled: {
true: {
trigger: "opacity-disabled pointer-events-none"
},
false: {}
}
},
defaultVariants: {
color: "default",
radius: "lg",
size: "md",
shadow: "md",
backdrop: "transparent",
triggerScaleOnOpen: true
},
compoundVariants: [
{
backdrop: ["opaque", "blur"],
class: {
backdrop: "block w-full h-full fixed inset-0 -z-30"
}
}
]
});
// src/components/snippet.ts
var snippet = tv({
slots: {
base: "inline-flex items-center justify-between h-fit rounded-large gap-2",
pre: "bg-transparent text-inherit font-mono font-normal inline-block whitespace-nowrap",
content: "flex flex-col",
symbol: "select-none",
copyButton: [
"group",
"relative",
"z-10",
"text-large",
"text-inherit",
"data-[hover=true]:bg-transparent"
],
copyIcon: [
"absolute text-inherit opacity-100 scale-100 group-data-[copied=true]:opacity-0 group-data-[copied=true]:scale-50"
],
checkIcon: [
"absolute text-inherit opacity-0 scale-50 group-data-[copied=true]:opacity-100 group-data-[copied=true]:scale-100"
]
},
variants: {
variant: {
flat: "",
solid: "",
bordered: "border-medium bg-transparent",
shadow: ""
},
color: {
default: {},
primary: {},
secondary: {},
success: {},
warning: {},
danger: {}
},
size: {
sm: {
base: "px-1.5 py-0.5 text-tiny rounded-small"
},
md: {
base: "px-3 py-1.5 text-small rounded-medium"
},
lg: {
base: "px-4 py-2 text-medium rounded-large"
}
},
radius: {
none: {
base: "rounded-none"
},
sm: {
base: "rounded-small"
},
md: {
base: "rounded-medium"
},
lg: {
base: "rounded-large"
}
},
fullWidth: {
true: {
base: "w-full"
}
},
disableAnimation: {
true: {},
false: {
copyIcon: "transition-transform-opacity",
checkIcon: "transition-transform-opacity"
}
}
},
defaultVariants: {
color: "default",
variant: "flat",
size: "md",
fullWidth: false
},
compoundVariants: [
{
variant: ["solid", "shadow"],
color: "default",
class: {
copyButton: "data-[focus-visible]:outline-default-foreground"
}
},
{
variant: ["solid", "shadow"],
color: "primary",
class: {
copyButton: "data-[focus-visible]:outline-primary-foreground"
}
},
{
variant: ["solid", "shadow"],
color: "secondary",
class: {
copyButton: "data-[focus-visible]:outline-secondary-foreground"
}
},
{
variant: ["solid", "shadow"],
color: "success",
class: {
copyButton: "data-[focus-visible]:outline-success-foreground"
}
},
{
variant: ["solid", "shadow"],
color: "warning",
class: {
copyButton: "data-[focus-visible]:outline-warning-foreground"
}
},
{
variant: ["solid", "shadow"],
color: "danger",
class: {
copyButton: "data-[focus-visible]:outline-danger-foreground"
}
},
{
variant: "flat",
color: "default",
class: {
base: colorVariants.flat.default
}
},
{
variant: "flat",
color: "primary",
class: {
base: colorVariants.flat.primary
}
},
{
variant: "flat",
color: "secondary",
class: {
base: colorVariants.flat.secondary
}
},
{
variant: "flat",
color: "success",
class: {
base: colorVariants.flat.success
}
},
{
variant: "flat",
color: "warning",
class: {
base: colorVariants.flat.warning
}
},
{
variant: "flat",
color: "danger",
class: {
base: colorVariants.flat.danger
}
},
{
variant: "solid",
color: "default",
class: {
base: colorVariants.solid.default
}
},
{
variant: "solid",
color: "primary",
class: {
base: colorVariants.solid.primary
}
},
{
variant: "solid",
color: "secondary",
class: {
base: colorVariants.solid.secondary
}
},
{
variant: "solid",
color: "success",
class: {
base: colorVariants.solid.success
}
},
{
variant: "solid",
color: "warning",
class: {
base: colorVariants.solid.warning
}
},
{
variant: "solid",
color: "danger",
class: {
base: colorVariants.solid.danger
}
},
{
variant: "shadow",
color: "default",
class: {
base: colorVariants.shadow.default
}
},
{
variant: "shadow",
color: "primary",
class: {
base: colorVariants.shadow.primary
}
},
{
variant: "shadow",
color: "secondary",
class: {
base: colorVariants.shadow.secondary
}
},
{
variant: "shadow",
color: "success",
class: {
base: colorVariants.shadow.success
}
},
{
variant: "shadow",
color: "warning",
class: {
base: colorVariants.shadow.warning
}
},
{
variant: "shadow",
color: "danger",
class: {
base: colorVariants.shadow.danger
}
},
{
variant: "bordered",
color: "default",
class: {
base: colorVariants.bordered.default
}
},
{
variant: "bordered",
color: "primary",
class: {
base: colorVariants.bordered.primary
}
},
{
variant: "bordered",
color: "secondary",
class: {
base: colorVariants.bordered.secondary
}
},
{
variant: "bordered",
color: "success",
class: {
base: colorVariants.bordered.success
}
},
{
variant: "bordered",
color: "warning",
class: {
base: colorVariants.bordered.warning
}
},
{
variant: "bordered",
color: "danger",
class: {
base: colorVariants.bordered.danger
}
}
]
});
// src/components/chip.ts
var chip = tv({
slots: {
base: [
"relative",
"max-w-fit",
"min-w-min",
"inline-flex",
"items-center",
"justify-between",
"box-border",
"whitespace-nowrap"
],
content: "flex-1 text-inherit font-normal",
dot: ["w-2", "h-2", "ml-1", "rounded-full"],
avatar: "flex-shrink-0",
closeButton: [
"z-10",
"appearance-none",
"outline-none",
"select-none",
"transition-opacity",
"opacity-70",
"hover:opacity-100",
"cursor-pointer",
"active:opacity-disabled",
"tap-highlight-transparent"
]
},
variants: {
variant: {
solid: {},
bordered: {
base: "border-medium bg-transparent"
},
light: {
base: "bg-transparent"
},
flat: {},
faded: {
base: "border-medium"
},
shadow: {},
dot: {
base: "border-medium border-default text-foreground bg-transparent"
}
},
color: {
default: {
dot: "bg-default-400"
},
primary: {
dot: "bg-primary"
},
secondary: {
dot: "bg-secondary"
},
success: {
dot: "bg-success"
},
warning: {
dot: "bg-warning"
},
danger: {
dot: "bg-danger"
}
},
size: {
sm: {
base: "px-1 h-6 text-tiny",
content: "px-1",
closeButton: "text-medium",
avatar: "w-4 h-4"
},
md: {
base: "px-1 h-7 text-small",
content: "px-2",
closeButton: "text-large",
avatar: "w-5 h-5"
},
lg: {
base: "px-2 h-8 text-medium",
content: "px-2",
closeButton: "text-xl",
avatar: "w-6 h-6"
}
},
radius: {
none: {
base: "rounded-none"
},
sm: {
base: "rounded-small"
},
md: {
base: "rounded-medium"
},
lg: {
base: "rounded-large"
},
full: {
base: "rounded-full"
}
},
isOneChar: {
true: {},
false: {}
},
isCloseable: {
true: {},
false: {}
},
hasStartContent: {
true: {}
},
hasEndContent: {
true: {}
},
isDisabled: {
true: { base: "opacity-disabled pointer-events-none" }
},
isCloseButtonFocusVisible: {
true: {
closeButton: [...ringClasses, "ring-1", "rounded-full"]
}
}
},
defaultVariants: {
variant: "solid",
color: "default",
size: "md",
radius: "full",
isDisabled: false
},
compoundVariants: [
{
variant: "solid",
color: "default",
class: {
base: colorVariants.solid.default
}
},
{
variant: "solid",
color: "primary",
class: {
base: colorVariants.solid.primary
}
},
{
variant: "solid",
color: "secondary",
class: {
base: colorVariants.solid.secondary
}
},
{
variant: "solid",
color: "success",
class: {
base: colorVariants.solid.success
}
},
{
variant: "solid",
color: "warning",
class: {
base: colorVariants.solid.warning
}
},
{
variant: "solid",
color: "danger",
class: {
base: colorVariants.solid.danger
}
},
{
variant: "shadow",
color: "default",
class: {
base: colorVariants.shadow.default
}
},
{
variant: "shadow",
color: "primary",
class: {
base: colorVariants.shadow.primary
}
},
{
variant: "shadow",
color: "secondary",
class: {
base: colorVariants.shadow.secondary
}
},
{
variant: "shadow",
color: "success",
class: {
base: colorVariants.shadow.success
}
},
{
variant: "shadow",
color: "warning",
class: {
base: colorVariants.shadow.warning
}
},
{
variant: "shadow",
color: "danger",
class: {
base: colorVariants.shadow.danger
}
},
{
variant: "bordered",
color: "default",
class: {
base: colorVariants.bordered.default
}
},
{
variant: "bordered",
color: "primary",
class: {
base: colorVariants.bordered.primary
}
},
{
variant: "bordered",
color: "secondary",
class: {
base: colorVariants.bordered.secondary
}
},
{
variant: "bordered",
color: "success",
class: {
base: colorVariants.bordered.success
}
},
{
variant: "bordered",
color: "warning",
class: {
base: colorVariants.bordered.warning
}
},
{
variant: "bordered",
color: "danger",
class: {
base: colorVariants.bordered.danger
}
},
{
variant: "flat",
color: "default",
class: {
base: colorVariants.flat.default
}
},
{
variant: "flat",
color: "primary",
class: {
base: colorVariants.flat.primary
}
},
{
variant: "flat",
color: "secondary",
class: {
base: colorVariants.flat.secondary
}
},
{
variant: "flat",
color: "success",
class: {
base: colorVariants.flat.success
}
},
{
variant: "flat",
color: "warning",
class: {
base: colorVariants.flat.warning
}
},
{
variant: "flat",
color: "danger",
class: {
base: colorVariants.flat.danger
}
},
{
variant: "faded",
color: "default",
class: {
base: colorVariants.faded.default
}
},
{
variant: "faded",
color: "primary",
class: {
base: colorVariants.faded.primary
}
},
{
variant: "faded",
color: "secondary",
class: {
base: colorVariants.faded.secondary
}
},
{
variant: "faded",
color: "success",
class: {
base: colorVariants.faded.success
}
},
{
variant: "faded",
color: "warning",
class: {
base