UNPKG

@nextui-org/theme

Version:

The default theme for NextUI components

930 lines (923 loc) • 23.3 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/input.ts var input_exports = {}; __export(input_exports, { input: () => input }); module.exports = __toCommonJS(input_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 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" ]; // src/components/input.ts var input = tv({ slots: { base: "group flex flex-col data-[hidden=true]:hidden", label: [ "absolute", "z-10", "pointer-events-none", "origin-top-left", "flex-shrink-0", "rtl:origin-top-right", "subpixel-antialiased", "block", "text-small", "text-foreground-500" ], mainWrapper: "h-full", inputWrapper: "relative w-full inline-flex tap-highlight-transparent flex-row items-center shadow-sm px-3 gap-3", innerWrapper: "inline-flex w-full items-center h-full box-border", input: [ "w-full font-normal bg-transparent !outline-none placeholder:text-foreground-500 focus-visible:outline-none", "data-[has-start-content=true]:ps-1.5", "data-[has-end-content=true]:pe-1.5", "file:cursor-pointer file:bg-transparent file:border-0", "autofill:bg-transparent bg-clip-text" ], clearButton: [ "p-2", "-m-2", "z-10", "absolute", "end-3", "start-auto", "pointer-events-none", "appearance-none", "outline-none", "select-none", "opacity-0", "hover:!opacity-100", "cursor-pointer", "active:!opacity-70", "rounded-full", ...dataFocusVisibleClasses ], helperWrapper: "hidden group-data-[has-helper=true]:flex p-1 relative flex-col gap-1.5", description: "text-tiny text-foreground-400", errorMessage: "text-tiny text-danger" }, variants: { variant: { flat: { inputWrapper: [ "bg-default-100", "data-[hover=true]:bg-default-200", "group-data-[focus=true]:bg-default-100" ] }, faded: { inputWrapper: [ "bg-default-100", "border-medium", "border-default-200", "data-[hover=true]:border-default-400 focus-within:border-default-400" ], value: "group-data-[has-value=true]:text-default-foreground" }, bordered: { inputWrapper: [ "border-medium", "border-default-200", "data-[hover=true]:border-default-400", "group-data-[focus=true]:border-default-foreground" ] }, underlined: { inputWrapper: [ "!px-1", "!pb-0", "!gap-0", "relative", "box-border", "border-b-medium", "shadow-[0_1px_0px_0_rgba(0,0,0,0.05)]", "border-default-200", "!rounded-none", "hover:border-default-300", "after:content-['']", "after:w-0", "after:origin-center", "after:bg-default-foreground", "after:absolute", "after:left-1/2", "after:-translate-x-1/2", "after:-bottom-[2px]", "after:h-[2px]", "group-data-[focus=true]:after:w-full" ], innerWrapper: "pb-1", label: "group-data-[filled-within=true]:text-foreground" } }, color: { default: {}, primary: {}, secondary: {}, success: {}, warning: {}, danger: {} }, size: { sm: { label: "text-tiny", inputWrapper: "h-8 min-h-8 px-2 rounded-small", input: "text-small", clearButton: "text-medium" }, md: { inputWrapper: "h-10 min-h-10 rounded-medium", input: "text-small", clearButton: "text-large" }, lg: { label: "text-medium", inputWrapper: "h-12 min-h-12 rounded-large", input: "text-medium", clearButton: "text-large" } }, radius: { none: { inputWrapper: "rounded-none" }, sm: { inputWrapper: "rounded-small" }, md: { inputWrapper: "rounded-medium" }, lg: { inputWrapper: "rounded-large" }, full: { inputWrapper: "rounded-full" } }, labelPlacement: { outside: { mainWrapper: "flex flex-col" }, "outside-left": { base: "flex-row items-center flex-nowrap data-[has-helper=true]:items-start", inputWrapper: "flex-1", mainWrapper: "flex flex-col", label: "relative text-foreground pe-2 ps-2 pointer-events-auto" }, inside: { label: "cursor-text", inputWrapper: "flex-col items-start justify-center gap-0", innerWrapper: "group-data-[has-label=true]:items-end" } }, fullWidth: { true: { base: "w-full" }, false: {} }, isClearable: { true: { input: "peer pe-6 input-search-cancel-button-none", clearButton: [ "peer-data-[filled=true]:pointer-events-auto", "peer-data-[filled=true]:opacity-70 peer-data-[filled=true]:block", "peer-data-[filled=true]:scale-100" ] } }, isDisabled: { true: { base: "opacity-disabled pointer-events-none", inputWrapper: "pointer-events-none", label: "pointer-events-none" } }, isInvalid: { true: { label: "!text-danger", input: "!placeholder:text-danger !text-danger" } }, isRequired: { true: { label: "after:content-['*'] after:text-danger after:ms-0.5" } }, isMultiline: { true: { label: "relative", inputWrapper: "!h-auto", innerWrapper: "items-start group-data-[has-label=true]:items-start", input: "resize-none data-[hide-scroll=true]:scrollbar-hide", clearButton: "absolute top-2 right-2 rtl:right-auto rtl:left-2 z-10" } }, disableAnimation: { true: { input: "transition-none", inputWrapper: "transition-none", label: "transition-none" }, false: { inputWrapper: "transition-background motion-reduce:transition-none !duration-150", label: [ "will-change-auto", "!duration-200", "!ease-out", "motion-reduce:transition-none", "transition-[transform,color,left,opacity]" ], clearButton: [ "scale-90", "ease-out", "duration-150", "transition-[opacity,transform]", "motion-reduce:transition-none", "motion-reduce:scale-100" ] } } }, defaultVariants: { variant: "flat", color: "default", size: "md", fullWidth: true, labelPlacement: "inside", isDisabled: false, isMultiline: false }, compoundVariants: [ { variant: "flat", color: "default", class: { input: "group-data-[has-value=true]:text-default-foreground" } }, { variant: "flat", color: "primary", class: { inputWrapper: [ "bg-primary-100", "data-[hover=true]:bg-primary-50", "text-primary", "group-data-[focus=true]:bg-primary-50", "placeholder:text-primary" ], input: "placeholder:text-primary", label: "text-primary" } }, { variant: "flat", color: "secondary", class: { inputWrapper: [ "bg-secondary-100", "text-secondary", "data-[hover=true]:bg-secondary-50", "group-data-[focus=true]:bg-secondary-50", "placeholder:text-secondary" ], input: "placeholder:text-secondary", label: "text-secondary" } }, { variant: "flat", color: "success", class: { inputWrapper: [ "bg-success-100", "text-success-600", "dark:text-success", "placeholder:text-success-600", "dark:placeholder:text-success", "data-[hover=true]:bg-success-50", "group-data-[focus=true]:bg-success-50" ], input: "placeholder:text-success-600 dark:placeholder:text-success", label: "text-success-600 dark:text-success" } }, { variant: "flat", color: "warning", class: { inputWrapper: [ "bg-warning-100", "text-warning-600", "dark:text-warning", "placeholder:text-warning-600", "dark:placeholder:text-warning", "data-[hover=true]:bg-warning-50", "group-data-[focus=true]:bg-warning-50" ], input: "placeholder:text-warning-600 dark:placeholder:text-warning", label: "text-warning-600 dark:text-warning" } }, { variant: "flat", color: "danger", class: { inputWrapper: [ "bg-danger-100", "text-danger", "dark:text-danger-500", "placeholder:text-danger", "dark:placeholder:text-danger-500", "data-[hover=true]:bg-danger-50", "group-data-[focus=true]:bg-danger-50" ], input: "placeholder:text-danger dark:placeholder:text-danger-500", label: "text-danger dark:text-danger-500" } }, { variant: "faded", color: "primary", class: { label: "text-primary", inputWrapper: "data-[hover=true]:border-primary focus-within:border-primary" } }, { variant: "faded", color: "secondary", class: { label: "text-secondary", inputWrapper: "data-[hover=true]:border-secondary focus-within:border-secondary" } }, { variant: "faded", color: "success", class: { label: "text-success", inputWrapper: "data-[hover=true]:border-success focus-within:border-success" } }, { variant: "faded", color: "warning", class: { label: "text-warning", inputWrapper: "data-[hover=true]:border-warning focus-within:border-warning" } }, { variant: "faded", color: "danger", class: { label: "text-danger", inputWrapper: "data-[hover=true]:border-danger focus-within:border-danger" } }, { variant: "underlined", color: "default", class: { input: "group-data-[has-value=true]:text-foreground" } }, { variant: "underlined", color: "primary", class: { inputWrapper: "after:bg-primary", label: "text-primary" } }, { variant: "underlined", color: "secondary", class: { inputWrapper: "after:bg-secondary", label: "text-secondary" } }, { variant: "underlined", color: "success", class: { inputWrapper: "after:bg-success", label: "text-success" } }, { variant: "underlined", color: "warning", class: { inputWrapper: "after:bg-warning", label: "text-warning" } }, { variant: "underlined", color: "danger", class: { inputWrapper: "after:bg-danger", label: "text-danger" } }, { variant: "bordered", color: "primary", class: { inputWrapper: "group-data-[focus=true]:border-primary", label: "text-primary" } }, { variant: "bordered", color: "secondary", class: { inputWrapper: "group-data-[focus=true]:border-secondary", label: "text-secondary" } }, { variant: "bordered", color: "success", class: { inputWrapper: "group-data-[focus=true]:border-success", label: "text-success" } }, { variant: "bordered", color: "warning", class: { inputWrapper: "group-data-[focus=true]:border-warning", label: "text-warning" } }, { variant: "bordered", color: "danger", class: { inputWrapper: "group-data-[focus=true]:border-danger", label: "text-danger" } }, { labelPlacement: "inside", color: "default", class: { label: "group-data-[filled-within=true]:text-default-600" } }, { labelPlacement: "outside", color: "default", class: { label: "group-data-[filled-within=true]:text-foreground" } }, { radius: "full", size: ["sm"], class: { inputWrapper: "px-3" } }, { radius: "full", size: "md", class: { inputWrapper: "px-4" } }, { radius: "full", size: "lg", class: { inputWrapper: "px-5" } }, { disableAnimation: false, variant: ["faded", "bordered"], class: { inputWrapper: "transition-colors motion-reduce:transition-none" } }, { disableAnimation: false, variant: "underlined", class: { inputWrapper: "after:transition-width motion-reduce:after:transition-none" } }, { variant: ["flat", "faded"], class: { inputWrapper: [ ...groupDataFocusVisibleClasses ] } }, { isInvalid: true, variant: "flat", class: { inputWrapper: [ "!bg-danger-50", "data-[hover=true]:!bg-danger-100", "group-data-[focus=true]:!bg-danger-50" ] } }, { isInvalid: true, variant: "bordered", class: { inputWrapper: "!border-danger group-data-[focus=true]:!border-danger" } }, { isInvalid: true, variant: "underlined", class: { inputWrapper: "after:!bg-danger" } }, { labelPlacement: "inside", size: "sm", class: { inputWrapper: "h-12 py-1.5 px-3" } }, { labelPlacement: "inside", size: "md", class: { inputWrapper: "h-14 py-2" } }, { labelPlacement: "inside", size: "lg", class: { inputWrapper: "h-16 py-2.5 gap-0" } }, { labelPlacement: "inside", size: "sm", variant: ["bordered", "faded"], class: { inputWrapper: "py-1" } }, { labelPlacement: ["inside", "outside"], class: { label: ["group-data-[filled-within=true]:pointer-events-auto"] } }, { labelPlacement: "outside", isMultiline: false, class: { base: "relative justify-end", label: [ "pb-0", "z-20", "top-1/2", "-translate-y-1/2", "group-data-[filled-within=true]:start-0" ] } }, { labelPlacement: ["inside"], class: { label: ["group-data-[filled-within=true]:scale-85"] } }, { labelPlacement: ["inside"], variant: "flat", class: { innerWrapper: "pb-0.5" } }, { variant: "underlined", size: "sm", class: { innerWrapper: "pb-1" } }, { variant: "underlined", size: ["md", "lg"], class: { innerWrapper: "pb-1.5" } }, { labelPlacement: "inside", size: ["sm", "md"], class: { label: "text-small" } }, { labelPlacement: "inside", isMultiline: false, size: "sm", class: { label: [ "group-data-[filled-within=true]:-translate-y-[calc(50%_+_theme(fontSize.tiny)/2_-_8px)]" ] } }, { labelPlacement: "inside", isMultiline: false, size: "md", class: { label: [ "group-data-[filled-within=true]:-translate-y-[calc(50%_+_theme(fontSize.small)/2_-_6px)]" ] } }, { labelPlacement: "inside", isMultiline: false, size: "lg", class: { label: [ "text-medium", "group-data-[filled-within=true]:-translate-y-[calc(50%_+_theme(fontSize.small)/2_-_8px)]" ] } }, { labelPlacement: "inside", variant: ["faded", "bordered"], isMultiline: false, size: "sm", class: { label: [ "group-data-[filled-within=true]:-translate-y-[calc(50%_+_theme(fontSize.tiny)/2_-_8px_-_theme(borderWidth.medium))]" ] } }, { labelPlacement: "inside", variant: ["faded", "bordered"], isMultiline: false, size: "md", class: { label: [ "group-data-[filled-within=true]:-translate-y-[calc(50%_+_theme(fontSize.small)/2_-_6px_-_theme(borderWidth.medium))]" ] } }, { labelPlacement: "inside", variant: ["faded", "bordered"], isMultiline: false, size: "lg", class: { label: [ "text-medium", "group-data-[filled-within=true]:-translate-y-[calc(50%_+_theme(fontSize.small)/2_-_8px_-_theme(borderWidth.medium))]" ] } }, { labelPlacement: "inside", variant: "underlined", isMultiline: false, size: "sm", class: { label: [ "group-data-[filled-within=true]:-translate-y-[calc(50%_+_theme(fontSize.tiny)/2_-_5px)]" ] } }, { labelPlacement: "inside", variant: "underlined", isMultiline: false, size: "md", class: { label: [ "group-data-[filled-within=true]:-translate-y-[calc(50%_+_theme(fontSize.small)/2_-_3.5px)]" ] } }, { labelPlacement: "inside", variant: "underlined", size: "lg", isMultiline: false, class: { label: [ "text-medium", "group-data-[filled-within=true]:-translate-y-[calc(50%_+_theme(fontSize.small)/2_-_4px)]" ] } }, { labelPlacement: "outside", size: "sm", isMultiline: false, class: { label: [ "start-2", "text-tiny", "group-data-[filled-within=true]:-translate-y-[calc(100%_+_theme(fontSize.tiny)/2_+_16px)]" ], base: "data-[has-label=true]:mt-[calc(theme(fontSize.small)_+_8px)]" } }, { labelPlacement: "outside", size: "md", isMultiline: false, class: { label: [ "start-3", "end-auto", "text-small", "group-data-[filled-within=true]:-translate-y-[calc(100%_+_theme(fontSize.small)/2_+_20px)]" ], base: "data-[has-label=true]:mt-[calc(theme(fontSize.small)_+_10px)]" } }, { labelPlacement: "outside", size: "lg", isMultiline: false, class: { label: [ "start-3", "end-auto", "text-medium", "group-data-[filled-within=true]:-translate-y-[calc(100%_+_theme(fontSize.small)/2_+_24px)]" ], base: "data-[has-label=true]:mt-[calc(theme(fontSize.small)_+_12px)]" } }, { labelPlacement: "outside-left", size: "sm", class: { label: "group-data-[has-helper=true]:pt-2" } }, { labelPlacement: "outside-left", size: "md", class: { label: "group-data-[has-helper=true]:pt-3" } }, { labelPlacement: "outside-left", size: "lg", class: { label: "group-data-[has-helper=true]:pt-4" } }, { labelPlacement: ["outside", "outside-left"], isMultiline: true, class: { inputWrapper: "py-2" } }, { labelPlacement: "outside", isMultiline: true, class: { label: "pb-1.5" } }, { labelPlacement: "inside", isMultiline: true, class: { label: "pb-0.5", input: "pt-0" } }, { isMultiline: true, disableAnimation: false, class: { input: "transition-height !duration-100 motion-reduce:transition-none" } }, { labelPlacement: ["inside", "outside"], class: { label: ["pe-2", "max-w-full", "text-ellipsis", "overflow-hidden"] } }, { isMultiline: true, radius: "full", class: { inputWrapper: "data-[has-multiple-rows=true]:rounded-large" } }, { isClearable: true, isMultiline: true, class: { clearButton: [ "group-data-[has-value=true]:opacity-70 group-data-[has-value=true]:block", "group-data-[has-value=true]:scale-100", "group-data-[has-value=true]:pointer-events-auto" ] } } ] }); // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { input });