@nextui-org/theme
Version:
The default theme for NextUI components
464 lines (458 loc) • 11.1 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/slider.ts
var slider_exports = {};
__export(slider_exports, {
slider: () => slider
});
module.exports = __toCommonJS(slider_exports);
// 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/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 import_tailwind_variants = require("tailwind-variants");
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/slider.ts
var slider = tv({
slots: {
base: "flex flex-col w-full gap-1",
labelWrapper: "w-full flex justify-between items-center",
label: "",
value: "",
step: [
"h-1.5",
"w-1.5",
"absolute",
"rounded-full",
"bg-default-300/50",
"data-[in-range=true]:bg-background/50"
],
mark: [
"absolute",
"text-small",
"cursor-default",
"opacity-50",
"data-[in-range=true]:opacity-100"
],
trackWrapper: "relative flex gap-2",
track: ["flex", "w-full", "relative", "rounded-full", "bg-default-300/50"],
filler: "h-full absolute",
thumb: [
"flex",
"justify-center",
"items-center",
"before:absolute",
"before:w-11",
"before:h-11",
"before:rounded-full",
"after:shadow-small",
"after:shadow-small",
"after:bg-background",
"data-[focused=true]:z-10",
dataFocusVisibleClasses
],
startContent: [],
endContent: []
},
variants: {
size: {
sm: {
label: "text-small",
value: "text-small",
thumb: "w-5 h-5 after:w-4 after:h-4",
step: "data-[in-range=false]:bg-default-200"
},
md: {
thumb: "w-6 h-6 after:w-5 after:h-5",
label: "text-small",
value: "text-small"
},
lg: {
thumb: "h-7 w-7 after:w-5 after:h-5",
step: "w-2 h-2",
label: "text-medium",
value: "text-medium",
mark: "mt-2"
}
},
radius: {
none: {
thumb: "rounded-none after:rounded-none"
},
sm: {
thumb: "rounded-[calc(theme(borderRadius.small)/2)] after:rounded-[calc(theme(borderRadius.small)/3)]"
},
md: {
thumb: "rounded-[calc(theme(borderRadius.medium)/2)] after:rounded-[calc(theme(borderRadius.medium)/3)]"
},
lg: {
thumb: "rounded-[calc(theme(borderRadius.large)/1.5)] after:rounded-[calc(theme(borderRadius.large)/2)]"
},
full: {
thumb: "rounded-full after:rounded-full"
}
},
color: {
foreground: {
filler: "bg-foreground",
thumb: "bg-foreground"
},
primary: {
filler: "bg-primary",
thumb: "bg-primary"
},
secondary: {
filler: "bg-secondary",
thumb: "bg-secondary"
},
success: {
filler: "bg-success",
thumb: "bg-success"
},
warning: {
filler: "bg-warning",
thumb: "bg-warning"
},
danger: {
filler: "bg-danger",
thumb: "bg-danger"
}
},
isVertical: {
true: {
base: "w-auto h-full flex-col-reverse items-center",
trackWrapper: "flex-col h-full justify-center items-center",
filler: "w-full h-auto",
thumb: "left-1/2",
track: "h-full border-y-transparent",
labelWrapper: "flex-col justify-center items-center",
step: ["left-1/2", "-translate-x-1/2", "translate-y-1/2"],
mark: ["left-1/2", "ml-1", "translate-x-1/2", "translate-y-1/2"]
},
false: {
thumb: "top-1/2",
trackWrapper: "items-center",
track: "border-x-transparent",
step: ["top-1/2", "-translate-x-1/2", "-translate-y-1/2"],
mark: ["top-1/2", "mt-1", "-translate-x-1/2", "translate-y-1/2"]
}
},
isDisabled: {
false: {
thumb: ["cursor-grab", "data-[dragging=true]:cursor-grabbing"]
},
true: {
base: "opacity-disabled",
thumb: "cursor-default"
}
},
hasMarks: {
true: {
base: "mb-5",
mark: "cursor-pointer"
},
false: {}
},
showOutline: {
true: {
thumb: "ring-2 ring-background"
},
false: {
thumb: "ring-transparent border-0"
}
},
hideValue: {
true: {
value: "sr-only"
}
},
hideThumb: {
true: {
thumb: "sr-only",
track: "cursor-pointer"
}
},
hasSingleThumb: {
true: {},
false: {}
},
disableAnimation: {
true: {
thumb: "data-[dragging=true]:after:scale-100"
},
false: {
thumb: "after:transition-all motion-reduce:after:transition-none",
mark: "transition-opacity motion-reduce:transition-none"
}
},
disableThumbScale: {
true: {},
false: {
thumb: "data-[dragging=true]:after:scale-80"
}
}
},
compoundVariants: [
{
size: ["sm", "md"],
showOutline: false,
class: {
thumb: "shadow-small"
}
},
{
size: "sm",
color: "foreground",
class: {
step: "data-[in-range=true]:bg-foreground"
}
},
{
size: "sm",
color: "primary",
class: {
step: "data-[in-range=true]:bg-primary"
}
},
{
size: "sm",
color: "secondary",
class: {
step: "data-[in-range=true]:bg-secondary"
}
},
{
size: "sm",
color: "success",
class: {
step: "data-[in-range=true]:bg-success"
}
},
{
size: "sm",
color: "warning",
class: {
step: "data-[in-range=true]:bg-warning"
}
},
{
size: "sm",
color: "danger",
class: {
step: "data-[in-range=true]:bg-danger"
}
},
{
size: "sm",
isVertical: false,
class: {
track: "h-1 my-[calc((theme(spacing.5)-theme(spacing.1))/2)] border-x-[calc(theme(spacing.5)/2)]"
}
},
{
size: "md",
isVertical: false,
class: {
track: "h-3 my-[calc((theme(spacing.6)-theme(spacing.3))/2)] border-x-[calc(theme(spacing.6)/2)]"
}
},
{
size: "lg",
isVertical: false,
class: {
track: "h-7 my-[calc((theme(spacing.7)-theme(spacing.5))/2)] border-x-[calc(theme(spacing.7)/2)]"
}
},
{
size: "sm",
isVertical: true,
class: {
track: "w-1 mx-[calc((theme(spacing.5)-theme(spacing.1))/2)] border-y-[calc(theme(spacing.5)/2)]"
}
},
{
size: "md",
isVertical: true,
class: {
track: "w-3 mx-[calc((theme(spacing.6)-theme(spacing.3))/2)] border-y-[calc(theme(spacing.6)/2)]"
}
},
{
size: "lg",
isVertical: true,
class: {
track: "w-7 mx-[calc((theme(spacing.7)-theme(spacing.5))/2)] border-y-[calc(theme(spacing.7)/2)]"
}
},
{
color: "foreground",
isVertical: false,
hasSingleThumb: true,
class: {
track: "border-s-foreground"
}
},
{
color: "primary",
isVertical: false,
hasSingleThumb: true,
class: {
track: "border-s-primary"
}
},
{
color: "secondary",
isVertical: false,
hasSingleThumb: true,
class: {
track: "border-s-secondary"
}
},
{
color: "success",
isVertical: false,
hasSingleThumb: true,
class: {
track: "border-s-success"
}
},
{
color: "warning",
isVertical: false,
hasSingleThumb: true,
class: {
track: "border-s-warning"
}
},
{
color: "danger",
isVertical: false,
hasSingleThumb: true,
class: {
track: "border-s-danger"
}
},
{
color: "foreground",
isVertical: true,
hasSingleThumb: true,
class: {
track: "border-b-foreground"
}
},
{
color: "primary",
isVertical: true,
hasSingleThumb: true,
class: {
track: "border-b-primary"
}
},
{
color: "secondary",
isVertical: true,
hasSingleThumb: true,
class: {
track: "border-b-secondary"
}
},
{
color: "success",
isVertical: true,
hasSingleThumb: true,
class: {
track: "border-b-success"
}
},
{
color: "warning",
isVertical: true,
hasSingleThumb: true,
class: {
track: "border-b-warning"
}
},
{
color: "danger",
isVertical: true,
hasSingleThumb: true,
class: {
track: "border-b-danger"
}
}
],
defaultVariants: {
size: "md",
color: "primary",
radius: "full",
hideValue: false,
hideThumb: false,
isDisabled: false,
disableThumbScale: false,
showOutline: false
}
});
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
slider
});