UNPKG

@nextui-org/theme

Version:

The default theme for NextUI components

542 lines (534 loc) • 14.6 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/tabs.ts var tabs_exports = {}; __export(tabs_exports, { tabs: () => tabs }); module.exports = __toCommonJS(tabs_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 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" ]; // 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/tabs.ts var tabs = tv({ slots: { base: "inline-flex", tabList: [ "flex", "p-1", "h-fit", "gap-2", "items-center", "flex-nowrap", "overflow-x-scroll", "scrollbar-hide", "bg-default-100" ], tab: [ "z-0", "w-full", "px-3", "py-1", "flex", "group", "relative", "justify-center", "items-center", "outline-none", "cursor-pointer", "transition-opacity", "tap-highlight-transparent", "data-[disabled=true]:cursor-not-allowed", "data-[disabled=true]:opacity-30", "data-[hover-unselected=true]:opacity-disabled", ...dataFocusVisibleClasses ], tabContent: [ "relative", "z-10", "text-inherit", "whitespace-nowrap", "transition-colors", "text-default-500", "group-data-[selected=true]:text-foreground" ], cursor: ["absolute", "z-0", "bg-white"], panel: [ "py-3", "px-1", "outline-none", "data-[inert=true]:hidden", ...dataFocusVisibleClasses ], wrapper: [] }, variants: { variant: { solid: { cursor: "inset-0" }, light: { tabList: "bg-transparent dark:bg-transparent", cursor: "inset-0" }, underlined: { tabList: "bg-transparent dark:bg-transparent", cursor: "h-[2px] w-[80%] bottom-0 shadow-[0_1px_0px_0_rgba(0,0,0,0.05)]" }, bordered: { tabList: "bg-transparent dark:bg-transparent border-medium border-default-200 shadow-sm", cursor: "inset-0" } }, color: { default: {}, primary: {}, secondary: {}, success: {}, warning: {}, danger: {} }, size: { sm: { tabList: "rounded-medium", tab: "h-7 text-tiny rounded-small", cursor: "rounded-small" }, md: { tabList: "rounded-medium", tab: "h-8 text-small rounded-small", cursor: "rounded-small" }, lg: { tabList: "rounded-large", tab: "h-9 text-medium rounded-medium", cursor: "rounded-medium" } }, radius: { none: { tabList: "rounded-none", tab: "rounded-none", cursor: "rounded-none" }, sm: { tabList: "rounded-medium", tab: "rounded-small", cursor: "rounded-small" }, md: { tabList: "rounded-medium", tab: "rounded-small", cursor: "rounded-small" }, lg: { tabList: "rounded-large", tab: "rounded-medium", cursor: "rounded-medium" }, full: { tabList: "rounded-full", tab: "rounded-full", cursor: "rounded-full" } }, fullWidth: { true: { base: "w-full", tabList: "w-full" } }, isDisabled: { true: { tabList: "opacity-disabled pointer-events-none" } }, disableAnimation: { true: { tab: "transition-none", tabContent: "transition-none" } }, placement: { top: {}, start: { tabList: "flex-col", panel: "py-0 px-3", wrapper: "flex" }, end: { tabList: "flex-col", panel: "py-0 px-3", wrapper: "flex flex-row-reverse" }, bottom: { wrapper: "flex flex-col-reverse" } } }, defaultVariants: { color: "default", variant: "solid", size: "md", fullWidth: false, isDisabled: false }, compoundVariants: [ { variant: ["solid", "bordered", "light"], color: "default", class: { cursor: ["bg-background", "dark:bg-default", "shadow-small"], tabContent: "group-data-[selected=true]:text-default-foreground" } }, { variant: ["solid", "bordered", "light"], color: "primary", class: { cursor: colorVariants.solid.primary, tabContent: "group-data-[selected=true]:text-primary-foreground" } }, { variant: ["solid", "bordered", "light"], color: "secondary", class: { cursor: colorVariants.solid.secondary, tabContent: "group-data-[selected=true]:text-secondary-foreground" } }, { variant: ["solid", "bordered", "light"], color: "success", class: { cursor: colorVariants.solid.success, tabContent: "group-data-[selected=true]:text-success-foreground" } }, { variant: ["solid", "bordered", "light"], color: "warning", class: { cursor: colorVariants.solid.warning, tabContent: "group-data-[selected=true]:text-warning-foreground" } }, { variant: ["solid", "bordered", "light"], color: "danger", class: { cursor: colorVariants.solid.danger, tabContent: "group-data-[selected=true]:text-danger-foreground" } }, { variant: "underlined", color: "default", class: { cursor: "bg-foreground", tabContent: "group-data-[selected=true]:text-foreground" } }, { variant: "underlined", color: "primary", class: { cursor: "bg-primary", tabContent: "group-data-[selected=true]:text-primary" } }, { variant: "underlined", color: "secondary", class: { cursor: "bg-secondary", tabContent: "group-data-[selected=true]:text-secondary" } }, { variant: "underlined", color: "success", class: { cursor: "bg-success", tabContent: "group-data-[selected=true]:text-success" } }, { variant: "underlined", color: "warning", class: { cursor: "bg-warning", tabContent: "group-data-[selected=true]:text-warning" } }, { variant: "underlined", color: "danger", class: { cursor: "bg-danger", tabContent: "group-data-[selected=true]:text-danger" } }, { disableAnimation: true, variant: "underlined", class: { tab: [ "after:content-['']", "after:absolute", "after:bottom-0", "after:h-[2px]", "after:w-[80%]", "after:opacity-0", "after:shadow-[0_1px_0px_0_rgba(0,0,0,0.05)]", "data-[selected=true]:after:opacity-100" ] } }, { disableAnimation: true, color: "default", variant: ["solid", "bordered", "light"], class: { tab: "data-[selected=true]:bg-default data-[selected=true]:text-default-foreground" } }, { disableAnimation: true, color: "primary", variant: ["solid", "bordered", "light"], class: { tab: "data-[selected=true]:bg-primary data-[selected=true]:text-primary-foreground" } }, { disableAnimation: true, color: "secondary", variant: ["solid", "bordered", "light"], class: { tab: "data-[selected=true]:bg-secondary data-[selected=true]:text-secondary-foreground" } }, { disableAnimation: true, color: "success", variant: ["solid", "bordered", "light"], class: { tab: "data-[selected=true]:bg-success data-[selected=true]:text-success-foreground" } }, { disableAnimation: true, color: "warning", variant: ["solid", "bordered", "light"], class: { tab: "data-[selected=true]:bg-warning data-[selected=true]:text-warning-foreground" } }, { disableAnimation: true, color: "danger", variant: ["solid", "bordered", "light"], class: { tab: "data-[selected=true]:bg-danger data-[selected=true]:text-danger-foreground" } }, { disableAnimation: true, color: "default", variant: "underlined", class: { tab: "data-[selected=true]:after:bg-foreground" } }, { disableAnimation: true, color: "primary", variant: "underlined", class: { tab: "data-[selected=true]:after:bg-primary" } }, { disableAnimation: true, color: "secondary", variant: "underlined", class: { tab: "data-[selected=true]:after:bg-secondary" } }, { disableAnimation: true, color: "success", variant: "underlined", class: { tab: "data-[selected=true]:after:bg-success" } }, { disableAnimation: true, color: "warning", variant: "underlined", class: { tab: "data-[selected=true]:after:bg-warning" } }, { disableAnimation: true, color: "danger", variant: "underlined", class: { tab: "data-[selected=true]:after:bg-danger" } } ], compoundSlots: [ { variant: "underlined", slots: ["tab", "tabList", "cursor"], class: ["rounded-none"] } ] }); // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { tabs });