@nextui-org/theme
Version:
The default theme for NextUI components
268 lines (261 loc) • 7.19 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/toggle.ts
var toggle_exports = {};
__export(toggle_exports, {
toggle: () => toggle
});
module.exports = __toCommonJS(toggle_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 groupDataFocusVisibleClasses = [
"outline-none",
"group-data-[focus-visible=true]:z-10",
"group-data-[focus-visible=true]:ring-2",
"group-data-[focus-visible=true]:ring-focus",
"group-data-[focus-visible=true]:ring-offset-2",
"group-data-[focus-visible=true]:ring-offset-background"
];
var hiddenInputClasses = [
"[--cursor-hit-x:8px]",
"font-inherit",
"text-[100%]",
"leading-[1.15]",
"m-0",
"p-0",
"overflow-visible",
"box-border",
"absolute",
"top-0",
"start-[calc(var(--cursor-hit-x)*-1)]",
"w-[calc(100%+var(--cursor-hit-x)*2)]",
"h-full",
"opacity-[0.0001]",
"z-[1]",
"cursor-pointer",
"disabled:cursor-default"
];
// src/components/toggle.ts
var toggle = tv({
slots: {
base: "group relative max-w-fit inline-flex items-center justify-start cursor-pointer touch-none tap-highlight-transparent select-none",
wrapper: [
"px-1",
"relative",
"inline-flex",
"items-center",
"justify-start",
"flex-shrink-0",
"overflow-hidden",
"bg-default-200",
"rounded-full",
...groupDataFocusVisibleClasses
],
thumb: [
"z-10",
"flex",
"items-center",
"justify-center",
"bg-white",
"shadow-small",
"rounded-full",
"origin-right",
"pointer-events-none"
],
hiddenInput: hiddenInputClasses,
startContent: "z-0 absolute start-1.5 text-current",
endContent: "z-0 absolute end-1.5 text-default-600",
thumbIcon: "text-black",
label: "relative text-foreground select-none ms-2"
},
variants: {
color: {
default: {
wrapper: [
"group-data-[selected=true]:bg-default-400",
"group-data-[selected=true]:text-default-foreground"
]
},
primary: {
wrapper: [
"group-data-[selected=true]:bg-primary",
"group-data-[selected=true]:text-primary-foreground"
]
},
secondary: {
wrapper: [
"group-data-[selected=true]:bg-secondary",
"group-data-[selected=true]:text-secondary-foreground"
]
},
success: {
wrapper: [
"group-data-[selected=true]:bg-success",
"group-data-[selected=true]:text-success-foreground"
]
},
warning: {
wrapper: [
"group-data-[selected=true]:bg-warning",
"group-data-[selected=true]:text-warning-foreground"
]
},
danger: {
wrapper: [
"group-data-[selected=true]:bg-danger",
"data-[selected=true]:text-danger-foreground"
]
}
},
size: {
sm: {
wrapper: "w-10 h-6",
thumb: [
"w-4 h-4 text-tiny",
"group-data-[selected=true]:ms-4"
],
endContent: "text-tiny",
startContent: "text-tiny",
label: "text-small"
},
md: {
wrapper: "w-12 h-7",
thumb: [
"w-5 h-5 text-small",
"group-data-[selected=true]:ms-5"
],
endContent: "text-small",
startContent: "text-small",
label: "text-medium"
},
lg: {
wrapper: "w-14 h-8",
thumb: [
"w-6 h-6 text-medium",
"group-data-[selected=true]:ms-6"
],
endContent: "text-medium",
startContent: "text-medium",
label: "text-large"
}
},
isDisabled: {
true: {
base: "opacity-disabled pointer-events-none"
}
},
disableAnimation: {
true: {
wrapper: "transition-none",
thumb: "transition-none"
},
false: {
wrapper: "transition-background",
thumb: "transition-all",
startContent: [
"opacity-0",
"scale-50",
"transition-transform-opacity",
"group-data-[selected=true]:scale-100",
"group-data-[selected=true]:opacity-100"
],
endContent: [
"opacity-100",
"transition-transform-opacity",
"group-data-[selected=true]:translate-x-3",
"group-data-[selected=true]:opacity-0"
]
}
}
},
defaultVariants: {
color: "primary",
size: "md",
isDisabled: false
},
compoundVariants: [
{
disableAnimation: false,
size: "sm",
class: {
thumb: ["group-data-[pressed=true]:w-5", "group-data-[selected]:group-data-[pressed]:ml-3"]
}
},
{
disableAnimation: false,
size: "md",
class: {
thumb: ["group-data-[pressed=true]:w-6", "group-data-[selected]:group-data-[pressed]:ml-4"]
}
},
{
disableAnimation: false,
size: "lg",
class: {
thumb: ["group-data-[pressed=true]:w-7", "group-data-[selected]:group-data-[pressed]:ml-5"]
}
}
]
});
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
toggle
});