UNPKG

@nextui-org/theme

Version:

The default theme for NextUI components

2,126 lines (2,107 loc) 264 kB
"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