@nextui-org/theme
Version:
The default theme for NextUI components
560 lines (553 loc) • 15.5 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/listbox.ts
var listbox_exports = {};
__export(listbox_exports, {
listbox: () => menu,
listboxItem: () => menuItem,
listboxSection: () => menuSection
});
module.exports = __toCommonJS(listbox_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/components/menu.ts
var menu = tv({
slots: {
base: "w-full relative flex flex-col gap-1 p-1 overflow-clip",
list: "w-full flex flex-col gap-0.5 outline-none",
emptyContent: [
"h-10",
"px-2",
"py-1.5",
"w-full",
"h-full",
"text-foreground-400",
"text-start"
]
}
});
var menuItem = tv({
slots: {
base: [
"flex",
"group",
"gap-2",
"items-center",
"justify-between",
"relative",
"px-2",
"py-1.5",
"w-full",
"h-full",
"box-border",
"rounded-small",
"subpixel-antialiased",
"outline-none",
"cursor-pointer",
"tap-highlight-transparent",
...dataFocusVisibleClasses,
"data-[focus-visible=true]:dark:ring-offset-background-content1"
],
wrapper: "w-full flex flex-col items-start justify-center",
title: "flex-1 text-small font-normal",
description: ["w-full", "text-tiny", "text-foreground-500", "group-hover:text-current"],
selectedIcon: ["text-inherit", "w-3", "h-3", "flex-shrink-0"],
shortcut: [
"px-1",
"py-0.5",
"rounded",
"font-sans",
"text-foreground-500",
"text-tiny",
"border-small",
"border-default-300",
"group-hover:border-current"
]
},
variants: {
variant: {
solid: {
base: ""
},
bordered: {
base: "border-medium border-transparent bg-transparent"
},
light: {
base: "bg-transparent"
},
faded: {
base: [
"border-small border-transparent hover:border-default data-[hover=true]:bg-default-100",
"data-[selectable=true]:focus:border-default data-[selectable=true]:focus:bg-default-100"
]
},
flat: {
base: ""
},
shadow: {
base: "data-[hover=true]:shadow-lg"
}
},
color: {
default: {},
primary: {},
secondary: {},
success: {},
warning: {},
danger: {}
},
showDivider: {
true: {
base: [
"mb-1.5",
"after:content-['']",
"after:absolute",
"after:-bottom-1",
"after:left-0",
"after:right-0",
"after:h-divider",
"after:bg-divider"
]
},
false: {}
},
isDisabled: {
true: {
base: "opacity-disabled pointer-events-none"
}
},
disableAnimation: {
true: {},
false: {
base: "data-[hover=true]:transition-colors"
}
},
hasTitleTextChild: {
true: {
title: "truncate"
}
},
hasDescriptionTextChild: {
true: {
description: "truncate"
}
}
},
defaultVariants: {
variant: "solid",
color: "default",
showDivider: false
},
compoundVariants: [
{
variant: "solid",
color: "default",
class: {
base: [
"data-[hover=true]:bg-default",
"data-[hover=true]:text-default-foreground",
"data-[selectable=true]:focus:bg-default",
"data-[selectable=true]:focus:text-default-foreground"
]
}
},
{
variant: "solid",
color: "primary",
class: {
base: [
"data-[hover=true]:bg-primary data-[hover=true]:text-primary-foreground",
"data-[selectable=true]:focus:bg-primary data-[selectable=true]:focus:text-primary-foreground"
]
}
},
{
variant: "solid",
color: "secondary",
class: {
base: [
"data-[hover=true]:bg-secondary data-[hover=true]:text-secondary-foreground",
"data-[selectable=true]:focus:bg-secondary data-[selectable=true]:focus:text-secondary-foreground"
]
}
},
{
variant: "solid",
color: "success",
class: {
base: [
"data-[hover=true]:bg-success data-[hover=true]:text-success-foreground",
"data-[selectable=true]:focus:bg-success data-[selectable=true]:focus:text-success-foreground"
]
}
},
{
variant: "solid",
color: "warning",
class: {
base: [
"data-[hover=true]:bg-warning data-[hover=true]:text-warning-foreground",
"data-[selectable=true]:focus:bg-warning data-[selectable=true]:focus:text-warning-foreground"
]
}
},
{
variant: "solid",
color: "danger",
class: {
base: [
"data-[hover=true]:bg-danger data-[hover=true]:text-danger-foreground",
"data-[selectable=true]:focus:bg-danger data-[selectable=true]:focus:text-danger-foreground"
]
}
},
{
variant: "shadow",
color: "default",
class: {
base: [
"data-[hover=true]:shadow-default/50 data-[hover=true]:bg-default data-[hover=true]:text-default-foreground",
"data-[selectable=true]:focus:shadow-default/50 data-[selectable=true]:focus:bg-default data-[selectable=true]:focus:text-default-foreground"
]
}
},
{
variant: "shadow",
color: "primary",
class: {
base: [
"data-[hover=true]:shadow-primary/30 data-[hover=true]:bg-primary data-[hover=true]:text-primary-foreground",
"data-[selectable=true]:focus:shadow-primary/30 data-[selectable=true]:focus:bg-primary data-[selectable=true]:focus:text-primary-foreground"
]
}
},
{
variant: "shadow",
color: "secondary",
class: {
base: [
"data-[hover=true]:shadow-secondary/30 data-[hover=true]:bg-secondary data-[hover=true]:text-secondary-foreground",
"data-[selectable=true]:focus:shadow-secondary/30 data-[selectable=true]:focus:bg-secondary data-[selectable=true]:focus:text-secondary-foreground"
]
}
},
{
variant: "shadow",
color: "success",
class: {
base: [
"data-[hover=true]:shadow-success/30 data-[hover=true]:bg-success data-[hover=true]:text-success-foreground",
"data-[selectable=true]:focus:shadow-success/30 data-[selectable=true]:focus:bg-success data-[selectable=true]:focus:text-success-foreground"
]
}
},
{
variant: "shadow",
color: "warning",
class: {
base: [
"data-[hover=true]:shadow-warning/30 data-[hover=true]:bg-warning data-[hover=true]:text-warning-foreground",
"data-[selectable=true]:focus:shadow-warning/30 data-[selectable=true]:focus:bg-warning data-[selectable=true]:focus:text-warning-foreground"
]
}
},
{
variant: "shadow",
color: "danger",
class: {
base: [
"data-[hover=true]:shadow-danger/30 data-[hover=true]:bg-danger data-[hover=true]:text-danger-foreground",
"data-[selectable=true]:focus:shadow-danger/30 data-[selectable=true]:focus:bg-danger data-[selectable=true]:focus:text-danger-foreground"
]
}
},
{
variant: "bordered",
color: "default",
class: {
base: ["data-[hover=true]:border-default", "data-[selectable=true]:focus:border-default"]
}
},
{
variant: "bordered",
color: "primary",
class: {
base: [
"data-[hover=true]:border-primary data-[hover=true]:text-primary",
"data-[selectable=true]:focus:border-primary data-[selectable=true]:focus:text-primary"
]
}
},
{
variant: "bordered",
color: "secondary",
class: {
base: [
"data-[hover=true]:border-secondary data-[hover=true]:text-secondary",
"data-[selectable=true]:focus:border-secondary data-[selectable=true]:focus:text-secondary"
]
}
},
{
variant: "bordered",
color: "success",
class: {
base: [
"data-[hover=true]:border-success data-[hover=true]:text-success",
"data-[selectable=true]:focus:border-success data-[selectable=true]:focus:text-success"
]
}
},
{
variant: "bordered",
color: "warning",
class: {
base: [
"data-[hover=true]:border-warning data-[hover=true]:text-warning",
"data-[selectable=true]:focus:border-warning data-[selectable=true]:focus:text-warning"
]
}
},
{
variant: "bordered",
color: "danger",
class: {
base: [
"data-[hover=true]:border-danger data-[hover=true]:text-danger",
"data-[selectable=true]:focus:border-danger data-[selectable=true]:focus:text-danger"
]
}
},
{
variant: "flat",
color: "default",
class: {
base: [
"data-[hover=true]:bg-default/40",
"data-[hover=true]:text-default-foreground",
"data-[selectable=true]:focus:bg-default/40",
"data-[selectable=true]:focus:text-default-foreground"
]
}
},
{
variant: "flat",
color: "primary",
class: {
base: [
"data-[hover=true]:bg-primary/20 data-[hover=true]:text-primary",
"data-[selectable=true]:focus:bg-primary/20 data-[selectable=true]:focus:text-primary"
]
}
},
{
variant: "flat",
color: "secondary",
class: {
base: [
"data-[hover=true]:bg-secondary/20 data-[hover=true]:text-secondary",
"data-[selectable=true]:focus:bg-secondary/20 data-[selectable=true]:focus:text-secondary"
]
}
},
{
variant: "flat",
color: "success",
class: {
base: [
"data-[hover=true]:bg-success/20 data-[hover=true]:text-success",
"data-[selectable=true]:focus:bg-success/20 data-[selectable=true]:focus:text-success"
]
}
},
{
variant: "flat",
color: "warning",
class: {
base: [
"data-[hover=true]:bg-warning/20 data-[hover=true]:text-warning",
"data-[selectable=true]:focus:bg-warning/20 data-[selectable=true]:focus:text-warning"
]
}
},
{
variant: "flat",
color: "danger",
class: {
base: [
"data-[hover=true]:bg-danger/20 data-[hover=true]:text-danger",
"data-[selectable=true]:focus:bg-danger/20 data-[selectable=true]:focus:text-danger"
]
}
},
{
variant: "faded",
color: "default",
class: {
base: [
"data-[hover=true]:text-default-foreground",
"data-[selectable=true]:focus:text-default-foreground"
]
}
},
{
variant: "faded",
color: "primary",
class: {
base: ["data-[hover=true]:text-primary", "data-[selectable=true]:focus:text-primary"]
}
},
{
variant: "faded",
color: "secondary",
class: {
base: ["data-[hover=true]:text-secondary", "data-[selectable=true]:focus:text-secondary"]
}
},
{
variant: "faded",
color: "success",
class: {
base: ["data-[hover=true]:text-success", "data-[selectable=true]:focus:text-success"]
}
},
{
variant: "faded",
color: "warning",
class: {
base: ["data-[hover=true]:text-warning", "data-[selectable=true]:focus:text-warning"]
}
},
{
variant: "faded",
color: "danger",
class: {
base: ["data-[hover=true]:text-danger", "data-[selectable=true]:focus:text-danger"]
}
},
{
variant: "light",
color: "default",
class: {
base: [
"data-[hover=true]:text-default-500",
"data-[selectable=true]:focus:text-default-500"
]
}
},
{
variant: "light",
color: "primary",
class: {
base: ["data-[hover=true]:text-primary", "data-[selectable=true]:focus:text-primary"]
}
},
{
variant: "light",
color: "secondary",
class: {
base: ["data-[hover=true]:text-secondary", "data-[selectable=true]:focus:text-secondary"]
}
},
{
variant: "light",
color: "success",
class: {
base: ["data-[hover=true]:text-success", "data-[selectable=true]:focus:text-success"]
}
},
{
variant: "light",
color: "warning",
class: {
base: ["data-[hover=true]:text-warning", "data-[selectable=true]:focus:text-warning"]
}
},
{
variant: "light",
color: "danger",
class: {
base: ["data-[hover=true]:text-danger", "data-[selectable=true]:focus:text-danger"]
}
}
]
});
var menuSection = tv({
slots: {
base: "relative mb-2",
heading: "pl-1 text-tiny text-foreground-500",
group: "data-[has-title=true]:pt-1",
divider: "mt-2"
}
});
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
listbox,
listboxItem,
listboxSection
});