@nextui-org/theme
Version:
The default theme for NextUI components
591 lines (583 loc) • 16 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/button.ts
var button_exports = {};
__export(button_exports, {
button: () => button,
buttonGroup: () => buttonGroup
});
module.exports = __toCommonJS(button_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"
];
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)]"]
};
// 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/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
}
});
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
button,
buttonGroup
});