@nextui-org/theme
Version:
The default theme for NextUI components
542 lines (534 loc) • 14.6 kB
JavaScript
"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
});