UNPKG

@nextui-org/theme

Version:

The default theme for NextUI components

631 lines (623 loc) • 14.2 kB
"use strict"; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; 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 __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); // src/components/chip.ts var chip_exports = {}; __export(chip_exports, { chip: () => chip }); module.exports = __toCommonJS(chip_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 ringClasses = [ "outline-none", "ring-2", "ring-focus", "ring-offset-2", "ring-offset-background" ]; // 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/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: colorVariants.faded.warning } }, { variant: "faded", color: "danger", class: { base: colorVariants.faded.danger } }, { variant: "light", color: "default", class: { base: colorVariants.light.default } }, { variant: "light", color: "primary", class: { base: colorVariants.light.primary } }, { variant: "light", color: "secondary", class: { base: colorVariants.light.secondary } }, { variant: "light", color: "success", class: { base: colorVariants.light.success } }, { variant: "light", color: "warning", class: { base: colorVariants.light.warning } }, { variant: "light", color: "danger", class: { base: colorVariants.light.danger } }, { isOneChar: true, hasStartContent: false, hasEndContent: false, size: "sm", class: { base: "w-5 h-5 min-w-5 min-h-5" } }, { isOneChar: true, hasStartContent: false, hasEndContent: false, size: "md", class: { base: "w-6 h-6 min-w-6 min-h-6" } }, { isOneChar: true, hasStartContent: false, hasEndContent: false, size: "lg", class: { base: "w-7 h-7 min-w-7 min-h-7" } }, { isOneChar: true, isCloseable: false, hasStartContent: false, hasEndContent: false, class: { base: "px-0 justify-center", content: "px-0 flex-none" } }, { isOneChar: true, isCloseable: true, hasStartContent: false, hasEndContent: false, class: { base: "w-auto" } }, { isOneChar: true, variant: "dot", class: { base: "w-auto h-7 px-1 items-center", content: "px-2" } }, { hasStartContent: true, size: "sm", class: { content: "pl-0.5" } }, { hasStartContent: true, size: ["md", "lg"], class: { content: "pl-1" } }, { hasEndContent: true, size: "sm", class: { content: "pr-0.5" } }, { hasEndContent: true, size: ["md", "lg"], class: { content: "pr-1" } } ] }); // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { chip });