@nextui-org/theme
Version:
The default theme for NextUI components
309 lines (303 loc) • 7.4 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/progress.ts
var progress_exports = {};
__export(progress_exports, {
circularProgress: () => circularProgress,
progress: () => progress
});
module.exports = __toCommonJS(progress_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/components/progress.ts
var progress = tv(
{
slots: {
base: "flex flex-col gap-2 w-full",
label: "",
labelWrapper: "flex justify-between",
value: "",
track: "z-0 relative bg-default-300/50 overflow-hidden",
indicator: "h-full"
},
variants: {
color: {
default: {
indicator: "bg-default-400"
},
primary: {
indicator: "bg-primary"
},
secondary: {
indicator: "bg-secondary"
},
success: {
indicator: "bg-success"
},
warning: {
indicator: "bg-warning"
},
danger: {
indicator: "bg-danger"
}
},
size: {
sm: {
label: "text-small",
value: "text-small",
track: "h-1"
},
md: {
label: "text-medium",
value: "text-medium",
track: "h-3"
},
lg: {
label: "text-large",
value: "text-large",
track: "h-5"
}
},
radius: {
none: {
track: "rounded-none",
indicator: "rounded-none"
},
sm: {
track: "rounded-small",
indicator: "rounded-small"
},
md: {
track: "rounded-medium",
indicator: "rounded-medium"
},
lg: {
track: "rounded-large",
indicator: "rounded-large"
},
full: {
track: "rounded-full",
indicator: "rounded-full"
}
},
isStriped: {
true: {
indicator: "bg-stripe-gradient-default bg-stripe-size"
}
},
isIndeterminate: {
true: {
indicator: ["absolute", "w-full", "origin-left", "animate-indeterminate-bar"]
}
},
isDisabled: {
true: {
base: "opacity-disabled cursor-not-allowed"
}
},
disableAnimation: {
true: {},
false: {
indicator: "transition-transform !duration-500"
}
}
},
defaultVariants: {
color: "primary",
size: "md",
radius: "full",
isStriped: false,
isIndeterminate: false,
isDisabled: false
},
compoundVariants: [
{
disableAnimation: true,
isIndeterminate: false,
class: {
indicator: "!transition-none motion-reduce:transition-none"
}
},
{
color: "primary",
isStriped: true,
class: {
indicator: "bg-stripe-gradient-primary bg-stripe-size"
}
},
{
color: "secondary",
isStriped: true,
class: {
indicator: "bg-stripe-gradient-secondary bg-stripe-size"
}
},
{
color: "success",
isStriped: true,
class: {
indicator: "bg-stripe-gradient-success bg-stripe-size"
}
},
{
color: "warning",
isStriped: true,
class: {
indicator: "bg-stripe-gradient-warning bg-stripe-size"
}
},
{
color: "danger",
isStriped: true,
class: {
indicator: "bg-stripe-gradient-danger bg-stripe-size"
}
}
]
},
{
twMerge: true
}
);
var circularProgress = tv({
slots: {
base: "flex flex-col justify-center gap-1 max-w-fit items-center",
label: "",
svgWrapper: "relative block",
svg: "z-0 relative overflow-hidden",
track: "h-full stroke-default-300/50",
indicator: "h-full stroke-current",
value: "absolute font-normal inset-0 flex items-center justify-center"
},
variants: {
color: {
default: {
svg: "text-default-400"
},
primary: {
svg: "text-primary"
},
secondary: {
svg: "text-secondary"
},
success: {
svg: "text-success"
},
warning: {
svg: "text-warning"
},
danger: {
svg: "text-danger"
}
},
size: {
sm: {
svg: "w-8 h-8",
label: "text-small",
value: "text-[0.5rem]"
},
md: {
svg: "w-10 h-10",
label: "text-small",
value: "text-[0.55rem]"
},
lg: {
svg: "w-12 h-12",
label: "text-medium",
value: "text-[0.6rem]"
}
},
isIndeterminate: {
true: {
svg: "animate-spinner-ease-spin"
}
},
isDisabled: {
true: {
base: "opacity-disabled cursor-not-allowed"
}
},
disableAnimation: {
true: {},
false: {
indicator: "transition-all !duration-500"
}
}
},
defaultVariants: {
color: "primary",
size: "md",
isDisabled: false
},
compoundVariants: [
{
disableAnimation: true,
isIndeterminate: false,
class: {
svg: "!transition-none motion-reduce:transition-none"
}
}
]
});
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
circularProgress,
progress
});