UNPKG

@nextui-org/theme

Version:

The default theme for NextUI components

261 lines (254 loc) • 6.24 kB
"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/modal.ts var modal_exports = {}; __export(modal_exports, { modal: () => modal }); module.exports = __toCommonJS(modal_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/modal.ts var modal = tv({ slots: { wrapper: [ "flex", "w-screen", "h-[100dvh]", "fixed", "inset-0", "z-50", "overflow-x-auto", "justify-center", "h-[--visual-viewport-height]" ], base: [ "flex", "flex-col", "relative", "bg-white", "z-50", "w-full", "box-border", "bg-content1", "outline-none", "mx-1", "my-1", "sm:mx-6", "sm:my-16" ], backdrop: "z-50", header: "flex py-4 px-6 flex-initial text-large font-semibold", body: "flex flex-1 flex-col gap-3 px-6 py-2", footer: "flex flex-row gap-2 px-6 py-4 justify-end", closeButton: [ "absolute", "appearance-none", "outline-none", "select-none", "top-1", "end-1", "p-2", "text-foreground-500", "rounded-full", "hover:bg-default-100", "active:bg-default-200", "tap-highlight-transparent", ...dataFocusVisibleClasses ] }, variants: { size: { xs: { base: "max-w-xs" }, sm: { base: "max-w-sm" }, md: { base: "max-w-md" }, lg: { base: "max-w-lg" }, xl: { base: "max-w-xl" }, "2xl": { base: "max-w-2xl" }, "3xl": { base: "max-w-3xl" }, "4xl": { base: "max-w-4xl" }, "5xl": { base: "max-w-5xl" }, full: { base: "my-0 mx-0 sm:mx-0 sm:my-0 max-w-full h-[100dvh] min-h-[100dvh] !rounded-none" } }, radius: { none: { base: "rounded-none" }, sm: { base: "rounded-small" }, md: { base: "rounded-medium" }, lg: { base: "rounded-large" } }, placement: { auto: { wrapper: "items-end sm:items-center" }, center: { wrapper: "items-center sm:items-center" }, top: { wrapper: "items-start sm:items-start" }, "top-center": { wrapper: "items-start sm:items-center" }, bottom: { wrapper: "items-end sm:items-end" }, "bottom-center": { wrapper: "items-end sm:items-center" } }, shadow: { sm: { base: "shadow-small" }, md: { base: "shadow-medium" }, lg: { base: "shadow-large" } }, backdrop: { transparent: { backdrop: "hidden" }, opaque: { backdrop: "bg-overlay/50 backdrop-opacity-disabled" }, blur: { backdrop: "backdrop-blur-md backdrop-saturate-150 bg-overlay/30" } }, scrollBehavior: { normal: { base: "overflow-y-hidden" }, inside: { base: "max-h-[calc(100%_-_8rem)]", body: "overflow-y-auto" }, outside: { wrapper: "items-start sm:items-start overflow-y-auto", base: "my-16" } }, disableAnimation: { false: { wrapper: [ "[--scale-enter:100%]", "[--scale-exit:100%]", "[--slide-enter:0px]", "[--slide-exit:80px]", "sm:[--scale-enter:100%]", "sm:[--scale-exit:103%]", "sm:[--slide-enter:0px]", "sm:[--slide-exit:0px]" ] } } }, defaultVariants: { size: "md", radius: "lg", shadow: "sm", placement: "auto", backdrop: "opaque", scrollBehavior: "normal" }, compoundVariants: [ { backdrop: ["opaque", "blur"], class: { backdrop: "w-screen h-screen fixed inset-0" } } ] }); // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { modal });