@hua-labs/ui 1.1.0-alpha.0.1 → 1.1.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +12 -3
- package/dist/advanced-dashboard.js.map +1 -1
- package/dist/advanced-dashboard.mjs +1 -1
- package/dist/advanced.js.map +1 -1
- package/dist/advanced.mjs +1 -1
- package/dist/{chunk-VPOFRDYL.mjs → chunk-627HOIRV.mjs} +2 -2
- package/dist/{chunk-VPOFRDYL.mjs.map → chunk-627HOIRV.mjs.map} +1 -1
- package/dist/{chunk-SGCVGEDR.mjs → chunk-E5PN4LUS.mjs} +2 -2
- package/dist/{chunk-SGCVGEDR.mjs.map → chunk-E5PN4LUS.mjs.map} +1 -1
- package/dist/{chunk-ZQAAB3P4.mjs → chunk-MXGXBG63.mjs} +2 -2
- package/dist/{chunk-ZQAAB3P4.mjs.map → chunk-MXGXBG63.mjs.map} +1 -1
- package/dist/{chunk-YY6ZBUVJ.mjs → chunk-R5KCFRYV.mjs} +2 -2
- package/dist/{chunk-YY6ZBUVJ.mjs.map → chunk-R5KCFRYV.mjs.map} +1 -1
- package/dist/{chunk-DMYT7RZ4.mjs → chunk-UGSYQDR4.mjs} +2 -2
- package/dist/{chunk-DMYT7RZ4.mjs.map → chunk-UGSYQDR4.mjs.map} +1 -1
- package/dist/{chunk-QXBMXCML.mjs → chunk-VU264VFN.mjs} +2 -2
- package/dist/{chunk-QXBMXCML.mjs.map → chunk-VU264VFN.mjs.map} +1 -1
- package/dist/{chunk-6NXF6ATP.mjs → chunk-ZFS4B5QT.mjs} +2 -2
- package/dist/{chunk-6NXF6ATP.mjs.map → chunk-ZFS4B5QT.mjs.map} +1 -1
- package/dist/feedback.js +1 -1
- package/dist/feedback.js.map +1 -1
- package/dist/feedback.mjs +1 -1
- package/dist/form.js.map +1 -1
- package/dist/form.mjs +1 -1
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +1 -1
- package/dist/lib/icon-providers.d.ts +2 -3
- package/dist/lib/icon-providers.d.ts.map +1 -1
- package/dist/navigation.js.map +1 -1
- package/dist/navigation.mjs +1 -1
- package/package.json +9 -8
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/components/Input.tsx","../src/components/Popover.tsx","../src/components/Form.tsx","../src/components/Label.tsx","../src/components/Checkbox.tsx","../src/components/Radio.tsx","../src/components/Select.tsx","../src/components/Switch.tsx","../src/components/Slider.tsx","../src/components/Textarea.tsx","../src/components/DatePicker.tsx","../src/components/Upload.tsx","../src/components/Autocomplete.tsx"],"names":["Input","React","className","type","props","ref","ariaInvalid","isInvalid","jsx","merge","Popover","children","trigger","controlledOpen","onOpenChange","position","align","offset","disabled","internalOpen","setInternalOpen","triggerRef","popoverRef","isControlled","isOpen","handleOpenChange","newOpen","handleTriggerClick","handleClickOutside","event","getPositionClasses","baseClasses","getAlignmentClasses","getArrowClasses","jsxs","PopoverTrigger","PopoverContent","Form","onSubmit","variant","e","FormField","error","required","errorId","enhancedChildren","child","childProps","childType","isFormComponent","typeObj","displayName","name","isNativeFormElement","existingAriaDescribedBy","ariaDescribedBy","FormGroup","inline","Label","variantClasses","Checkbox","size","success","label","description","id","_a","checkboxId","labelId","descriptionId","sizeClasses","iconSizes","stateClasses","isChecked","Icon","Radio","radioId","dotSizes","Select","leftIcon","placeholder","ariaLabel","selectRef","combinedRef","node","isFocused","setIsFocused","SelectOption","Switch","switchId","thumbSizes","Slider","showValue","showLabel","min","max","step","value","onValueChange","orientation","isRange","currentValue","handleChange","newValue","index","newRange","thumbVariantClasses","thumbSizeClasses","orientationClasses","renderSlider","renderValue","val","_","Textarea","resize","resizeClasses","formatDate","date","format","locale","year","month","day","getDaysInMonth","getFirstDayOfMonth","DatePicker","onChange","minDate","maxDate","dateFormat","setIsOpen","currentMonth","setCurrentMonth","hoveredDate","setHoveredDate","displayDate","handleDateSelect","handlePrevMonth","handleNextMonth","handleToday","today","daysInMonth","firstDay","weekDays","isDateDisabled","isDateSelected","isToday","calendarDays","i","remainingDays","triggerButton","isCurrentMonth","isDisabled","isSelected","isTodayDate","isHovered","Button","formatFileSize","bytes","k","sizes","getFileIcon","Upload","files","onRemove","multiple","accept","maxSize","maxFiles","dragDrop","fileInputRef","isDragging","setIsDragging","handleFileSelect","selectedFiles","fileArray","validFiles","file","handleClick","handleDragOver","handleDragLeave","handleDrop","handleRemove","Fragment","Autocomplete","options","loading","maxHeight","clearable","filterable","onSearch","emptyText","inputValue","setInputValue","filteredOptions","setFilteredOptions","selectedIndex","setSelectedIndex","isSearching","setIsSearching","inputRef","dropdownRef","selectedOption","opt","result","filtered","option","handleInputChange","handleInputFocus","handleInputBlur","handleOptionSelect","handleClear","handleKeyDown","prev","isValueSelected"],"mappings":"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","file":"chunk-6NXF6ATP.mjs","sourcesContent":["\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Input 컴포넌트의 props / Input component props\n * HTML input 요소의 모든 표준 속성을 상속받습니다.\n * Inherits all standard attributes of HTML input element.\n * @typedef {Object} InputProps\n * @extends {React.InputHTMLAttributes<HTMLInputElement>}\n */\nexport interface InputProps extends React.InputHTMLAttributes<HTMLInputElement> {}\n\n/**\n * Input 컴포넌트 / Input component\n * \n * 표준 HTML input 요소를 래핑한 스타일링된 입력 필드 컴포넌트입니다.\n * 접근성 속성(aria-invalid)을 자동으로 처리합니다.\n * \n * Styled input field component wrapping standard HTML input element.\n * Automatically handles accessibility attributes (aria-invalid).\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Input type=\"text\" placeholder=\"이름을 입력하세요\" />\n * \n * @example\n * // 에러 상태 / Error state\n * <Input \n * type=\"email\" \n * placeholder=\"이메일\"\n * aria-invalid={true}\n * />\n * \n * @example\n * // ref 사용 / Using ref\n * const inputRef = useRef<HTMLInputElement>(null)\n * <Input ref={inputRef} type=\"text\" />\n * \n * @param {InputProps} props - Input 컴포넌트의 props / Input component props\n * @param {React.Ref<HTMLInputElement>} ref - input 요소 ref / input element ref\n * @returns {JSX.Element} Input 컴포넌트 / Input component\n */\nconst Input = React.forwardRef<HTMLInputElement, InputProps>(\n ({ className, type, ...props }, ref) => {\n // aria-invalid이 명시적으로 전달되지 않았고, error prop이 있으면 자동 설정\n const ariaInvalid = props[\"aria-invalid\" as keyof typeof props] as boolean | undefined;\n const isInvalid = ariaInvalid !== undefined ? ariaInvalid : false;\n \n return (\n <input\n type={type}\n className={merge(\n \"flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 transition-all duration-200 hover:border-blue-400 hover:shadow-sm\",\n isInvalid && \"border-red-500 focus-visible:ring-red-500\",\n className\n )}\n ref={ref}\n aria-invalid={isInvalid || undefined}\n {...props}\n />\n )\n }\n)\nInput.displayName = \"Input\"\n\nexport { Input } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Popover 컴포넌트의 props / Popover component props\n * @typedef {Object} PopoverProps\n * @property {React.ReactNode} children - Popover 내용 / Popover content\n * @property {React.ReactNode} trigger - Popover를 열기 위한 트리거 요소 / Trigger element to open popover\n * @property {boolean} [open] - 제어 모드에서 열림/닫힘 상태 / Open/close state in controlled mode\n * @property {(open: boolean) => void} [onOpenChange] - 상태 변경 콜백 / State change callback\n * @property {\"top\" | \"bottom\" | \"left\" | \"right\"} [position=\"bottom\"] - Popover 표시 위치 / Popover display position\n * @property {\"start\" | \"center\" | \"end\"} [align=\"center\"] - Popover 정렬 / Popover alignment\n * @property {number} [offset=8] - 트리거와 Popover 사이 간격 (px) / Spacing between trigger and popover (px)\n * @property {boolean} [disabled=false] - Popover 비활성화 여부 / Disable popover\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface PopoverProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n trigger: React.ReactNode\n open?: boolean\n onOpenChange?: (open: boolean) => void\n position?: \"top\" | \"bottom\" | \"left\" | \"right\"\n align?: \"start\" | \"center\" | \"end\"\n offset?: number\n disabled?: boolean\n}\n\n/**\n * Popover 컴포넌트 / Popover component\n * \n * 트리거 요소를 클릭하면 표시되는 팝오버 컴포넌트입니다.\n * 외부 클릭 시 자동으로 닫힙니다.\n * \n * Popover component that appears when the trigger element is clicked.\n * Automatically closes when clicking outside.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Popover trigger={<Button>열기</Button>}>\n * <div className=\"p-4\">Popover 내용</div>\n * </Popover>\n * \n * @example\n * // 제어 모드 / Controlled mode\n * const [open, setOpen] = useState(false)\n * <Popover \n * open={open}\n * onOpenChange={setOpen}\n * trigger={<Button>제어 모드</Button>}\n * position=\"top\"\n * >\n * <div className=\"p-4\">내용</div>\n * </Popover>\n * \n * @param {PopoverProps} props - Popover 컴포넌트의 props / Popover component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Popover 컴포넌트 / Popover component\n */\nconst Popover = React.forwardRef<HTMLDivElement, PopoverProps>(\n ({ \n className, \n children,\n trigger,\n open: controlledOpen,\n onOpenChange,\n position = \"bottom\",\n align = \"center\",\n offset = 8,\n disabled = false,\n ...props \n }, ref) => {\n const [internalOpen, setInternalOpen] = React.useState(false)\n const triggerRef = React.useRef<HTMLDivElement>(null)\n const popoverRef = React.useRef<HTMLDivElement>(null)\n const isControlled = controlledOpen !== undefined\n const isOpen = isControlled ? controlledOpen : internalOpen\n\n const handleOpenChange = (newOpen: boolean) => {\n if (disabled) return\n \n if (!isControlled) {\n setInternalOpen(newOpen)\n }\n onOpenChange?.(newOpen)\n }\n\n const handleTriggerClick = () => {\n handleOpenChange(!isOpen)\n }\n\n React.useEffect(() => {\n const handleClickOutside = (event: MouseEvent) => {\n if (\n triggerRef.current && \n popoverRef.current && \n !triggerRef.current.contains(event.target as Node) &&\n !popoverRef.current.contains(event.target as Node)\n ) {\n handleOpenChange(false)\n }\n }\n\n if (isOpen) {\n document.addEventListener('mousedown', handleClickOutside)\n return () => {\n document.removeEventListener('mousedown', handleClickOutside)\n }\n }\n }, [isOpen])\n\n const getPositionClasses = () => {\n const baseClasses = \"absolute z-50\"\n \n switch (position) {\n case \"top\":\n return merge(baseClasses, \"bottom-full left-0\", `mb-${Math.max(1, Math.floor(offset / 4))}`)\n case \"bottom\":\n return merge(baseClasses, \"top-full left-0\", `mt-${Math.max(1, Math.floor(offset / 4))}`)\n case \"left\":\n return merge(baseClasses, \"right-full top-0\", `mr-${Math.max(1, Math.floor(offset / 4))}`)\n case \"right\":\n return merge(baseClasses, \"left-full top-0\", `ml-${Math.max(1, Math.floor(offset / 4))}`)\n default:\n return merge(baseClasses, \"top-full left-0\", `mt-${Math.max(1, Math.floor(offset / 4))}`)\n }\n }\n\n const getAlignmentClasses = () => {\n switch (align) {\n case \"start\":\n if (position === \"top\" || position === \"bottom\") {\n return \"left-0\"\n } else {\n return \"top-0\"\n }\n case \"end\":\n if (position === \"top\" || position === \"bottom\") {\n return \"right-0\"\n } else {\n return \"bottom-0\"\n }\n case \"center\":\n default:\n if (position === \"top\" || position === \"bottom\") {\n return \"left-1/2 -translate-x-1/2\"\n } else {\n return \"top-1/2 -translate-y-1/2\"\n }\n }\n }\n\n const getArrowClasses = () => {\n const baseClasses = \"absolute w-0 h-0 border-4 border-transparent\"\n \n switch (position) {\n case \"top\":\n return `${baseClasses} top-full left-1/2 -translate-x-1/2 border-t-gray-200 dark:border-t-gray-700`\n case \"bottom\":\n return `${baseClasses} bottom-full left-1/2 -translate-x-1/2 border-b-gray-200 dark:border-b-gray-700`\n case \"left\":\n return `${baseClasses} left-full top-1/2 -translate-y-1/2 border-l-gray-200 dark:border-l-gray-700`\n case \"right\":\n return `${baseClasses} right-full top-1/2 -translate-y-1/2 border-r-gray-200 dark:border-r-gray-700`\n default:\n return `${baseClasses} bottom-full left-1/2 -translate-x-1/2 border-b-gray-200 dark:border-b-gray-700`\n }\n }\n\n return (\n <div ref={ref} className={merge(\"relative\", className)} {...props}>\n {/* 트리거 */}\n <div\n ref={triggerRef}\n onClick={handleTriggerClick}\n className=\"inline-block cursor-pointer\"\n >\n {trigger}\n </div>\n\n {/* 팝오버 */}\n {isOpen && (\n <div\n ref={popoverRef}\n className={merge(\n \"bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700 rounded-lg shadow-lg p-4 min-w-[200px]\",\n getPositionClasses(),\n getAlignmentClasses()\n )}\n >\n {/* 화살표 */}\n <div className={getArrowClasses()} />\n \n {/* 내용 */}\n <div className=\"relative z-10\">\n {children}\n </div>\n </div>\n )}\n </div>\n )\n }\n)\nPopover.displayName = \"Popover\"\n\n// 편의 컴포넌트들\nexport const PopoverTrigger = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"inline-block cursor-pointer\", className)}\n {...props}\n >\n {children}\n </div>\n )\n)\nPopoverTrigger.displayName = \"PopoverTrigger\"\n\nexport const PopoverContent = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700 rounded-lg shadow-lg p-4\", className)}\n {...props}\n >\n {children}\n </div>\n )\n)\nPopoverContent.displayName = \"PopoverContent\"\n\nexport { Popover } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Form 컴포넌트의 props / Form component props\n * @typedef {Object} FormProps\n * @property {(e: React.FormEvent<HTMLFormElement>) => void} [onSubmit] - 폼 제출 핸들러 / Form submit handler\n * @property {\"default\" | \"glass\"} [variant=\"default\"] - Form 스타일 변형 / Form style variant\n * @extends {React.FormHTMLAttributes<HTMLFormElement>}\n */\nexport interface FormProps extends React.FormHTMLAttributes<HTMLFormElement> {\n onSubmit?: (e: React.FormEvent<HTMLFormElement>) => void\n variant?: \"default\" | \"glass\"\n}\n\n/**\n * FormField 컴포넌트의 props / FormField component props\n * @typedef {Object} FormFieldProps\n * @property {string} [error] - 에러 메시지 / Error message\n * @property {boolean} [required=false] - 필수 필드 여부 / Required field\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface FormFieldProps extends React.HTMLAttributes<HTMLDivElement> {\n error?: string\n required?: boolean\n}\n\n/**\n * FormGroup 컴포넌트의 props / FormGroup component props\n * @typedef {Object} FormGroupProps\n * @property {boolean} [inline=false] - 인라인 레이아웃 여부 / Inline layout\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface FormGroupProps extends React.HTMLAttributes<HTMLDivElement> {\n inline?: boolean\n}\n\n/**\n * Form 컴포넌트 / Form component\n * \n * 폼 컨테이너 컴포넌트입니다.\n * FormField, FormGroup과 함께 사용하여 구조화된 폼을 구성합니다.\n * \n * Form container component.\n * Used with FormField and FormGroup to create structured forms.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Form onSubmit={(e) => { e.preventDefault(); console.log('제출') }}>\n * <FormField>\n * <Label>이름</Label>\n * <Input />\n * </FormField>\n * </Form>\n * \n * @example\n * // Glass 스타일 / Glass style\n * <Form variant=\"glass\" onSubmit={handleSubmit}>\n * <FormGroup>\n * <FormField>\n * <Label>이메일</Label>\n * <Input type=\"email\" />\n * </FormField>\n * </FormGroup>\n * </Form>\n * \n * @param {FormProps} props - Form 컴포넌트의 props / Form component props\n * @param {React.Ref<HTMLFormElement>} ref - form 요소 ref / form element ref\n * @returns {JSX.Element} Form 컴포넌트 / Form component\n */\nconst Form = React.forwardRef<HTMLFormElement, FormProps>(\n ({ \n className, \n children, \n onSubmit,\n variant = \"default\",\n ...props \n }, ref) => {\n const handleSubmit = (e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault()\n onSubmit?.(e)\n }\n\n const variantClasses = {\n default: \"space-y-6\",\n glass: \"space-y-6 bg-white/10 backdrop-blur-sm border border-white/20 rounded-xl p-6 shadow-xl dark:bg-slate-800/20 dark:border-slate-700/50\"\n }\n\n return (\n <form\n ref={ref}\n onSubmit={handleSubmit}\n className={merge(variantClasses[variant], className)}\n {...props}\n >\n {children}\n </form>\n )\n }\n)\nForm.displayName = \"Form\"\n\n/**\n * FormField 컴포넌트 / FormField component\n * \n * 폼 필드를 감싸는 컨테이너입니다.\n * 에러 메시지를 표시하고 필수 필드 표시를 지원합니다.\n * \n * Container that wraps a form field.\n * Displays error messages and supports required field indication.\n * \n * @component\n * @example\n * <FormField error=\"이 필드는 필수입니다\" required>\n * <Label>이름</Label>\n * <Input />\n * </FormField>\n * \n * @param {FormFieldProps} props - FormField 컴포넌트의 props / FormField component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} FormField 컴포넌트 / FormField component\n */\nconst FormField = React.forwardRef<HTMLDivElement, FormFieldProps>(\n ({ \n className, \n children, \n error,\n required,\n ...props \n }, ref) => {\n const errorId = React.useId()\n\n // 자식 요소에 aria-describedby와 aria-invalid 연결\n // Connect aria-describedby and aria-invalid to child elements\n const enhancedChildren = React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n const childProps = child.props as Record<string, unknown>\n const childType = child.type\n \n // Input, Select, Textarea 컴포넌트 확인\n // Check for Input, Select, Textarea components\n let isFormComponent = false\n if (typeof childType === 'object' && childType !== null) {\n const typeObj = childType as Record<string, unknown>\n const displayName = typeObj.displayName as string | undefined\n const name = typeObj.name as string | undefined\n isFormComponent = \n displayName === 'Input' || \n displayName === 'Select' || \n displayName === 'Textarea' ||\n name === 'Input' || \n name === 'Select' || \n name === 'Textarea'\n }\n \n // 네이티브 HTML 요소 확인\n // Check for native HTML elements\n const isNativeFormElement = \n typeof childType === 'string' &&\n ['input', 'select', 'textarea'].includes(childType.toLowerCase())\n \n if (isFormComponent || isNativeFormElement) {\n const existingAriaDescribedBy = childProps['aria-describedby'] as string | undefined\n const ariaDescribedBy = error \n ? existingAriaDescribedBy \n ? `${existingAriaDescribedBy} ${errorId}`\n : errorId\n : existingAriaDescribedBy\n \n return React.cloneElement(child, {\n 'aria-describedby': ariaDescribedBy,\n 'aria-invalid': error ? true : childProps['aria-invalid'],\n required: required || childProps.required,\n } as Record<string, unknown>)\n }\n }\n return child\n })\n\n return (\n <div\n ref={ref}\n className={merge(\"space-y-2\", className)}\n {...props}\n >\n {enhancedChildren}\n {error && (\n <p \n id={errorId}\n className=\"text-sm text-red-600 dark:text-red-400\"\n role=\"alert\"\n aria-live=\"polite\"\n >\n {error}\n </p>\n )}\n </div>\n )\n }\n)\nFormField.displayName = \"FormField\"\n\n/**\n * FormGroup 컴포넌트 / FormGroup component\n * \n * 여러 폼 필드를 그룹화하는 컨테이너입니다.\n * Container that groups multiple form fields.\n * \n * @component\n * @example\n * <FormGroup inline>\n * <FormField>\n * <Label>이름</Label>\n * <Input />\n * </FormField>\n * <FormField>\n * <Label>성</Label>\n * <Input />\n * </FormField>\n * </FormGroup>\n * \n * @param {FormGroupProps} props - FormGroup 컴포넌트의 props / FormGroup component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} FormGroup 컴포넌트 / FormGroup component\n */\nconst FormGroup = React.forwardRef<HTMLDivElement, FormGroupProps>(\n ({ \n className, \n children, \n inline = false,\n ...props \n }, ref) => {\n return (\n <div\n ref={ref}\n className={merge(\n inline ? \"flex gap-4\" : \"space-y-4\",\n className\n )}\n {...props}\n >\n {children}\n </div>\n )\n }\n)\nFormGroup.displayName = \"FormGroup\"\n\nexport { Form, FormField, FormGroup } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Label 컴포넌트의 props / Label component props\n * @typedef {Object} LabelProps\n * @property {boolean} [required=false] - 필수 필드 여부 / Required field indicator\n * @property {boolean} [error=false] - 에러 상태 표시 / Error state\n * @property {boolean} [disabled=false] - 비활성화 상태 / Disabled state\n * @property {\"default\" | \"glass\"} [variant=\"default\"] - Label 스타일 변형 / Label style variant\n * @extends {React.LabelHTMLAttributes<HTMLLabelElement>}\n */\nexport interface LabelProps extends React.LabelHTMLAttributes<HTMLLabelElement> {\n required?: boolean\n error?: boolean\n disabled?: boolean\n variant?: \"default\" | \"glass\"\n}\n\n/**\n * Label 컴포넌트 / Label component\n * \n * 폼 필드의 레이블을 표시하는 컴포넌트입니다.\n * 필수 필드 표시와 에러 상태를 지원합니다.\n * \n * Component for displaying form field labels.\n * Supports required field indicator and error state.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Label htmlFor=\"email\">이메일</Label>\n * <Input id=\"email\" />\n * \n * @example\n * // 필수 필드 / Required field\n * <Label required htmlFor=\"name\">이름</Label>\n * <Input id=\"name\" required />\n * \n * @example\n * // 에러 상태 / Error state\n * <Label error htmlFor=\"password\">비밀번호</Label>\n * <Input id=\"password\" aria-invalid />\n * \n * @param {LabelProps} props - Label 컴포넌트의 props / Label component props\n * @param {React.Ref<HTMLLabelElement>} ref - label 요소 ref / label element ref\n * @returns {JSX.Element} Label 컴포넌트 / Label component\n * \n * @todo 접근성 개선: required일 때 aria-required=\"true\" 추가 필요 / Accessibility improvement: add aria-required=\"true\" when required\n */\nconst Label = React.forwardRef<HTMLLabelElement, LabelProps>(\n ({ \n className, \n children, \n required = false,\n error = false,\n disabled = false,\n variant = \"default\",\n ...props \n }, ref) => {\n const variantClasses = {\n default: merge(\n \"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70\",\n error && \"text-red-600 dark:text-red-400\",\n disabled && \"text-slate-400 dark:text-slate-500\",\n !error && !disabled && \"text-slate-700 dark:text-slate-300\"\n ),\n glass: merge(\n \"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70\",\n error && \"text-red-400\",\n disabled && \"text-white/50\",\n !error && !disabled && \"text-white\"\n )\n }\n\n return (\n <label\n ref={ref}\n className={merge(variantClasses[variant], className)}\n aria-required={required ? true : undefined}\n {...props}\n >\n {children}\n {required && (\n <span className={variant === \"glass\" ? \"text-red-400 ml-1\" : \"text-red-500 ml-1\"} aria-label=\"필수 필드\">*</span>\n )}\n </label>\n )\n }\n)\nLabel.displayName = \"Label\"\n\nexport { Label } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\n\n/**\n * Checkbox 컴포넌트의 props / Checkbox component props\n * @typedef {Object} CheckboxProps\n * @property {\"default\" | \"outline\" | \"filled\" | \"glass\"} [variant=\"default\"] - Checkbox 스타일 변형 / Checkbox style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Checkbox 크기 / Checkbox size\n * @property {boolean} [error=false] - 에러 상태 표시 / Error state\n * @property {boolean} [success=false] - 성공 상태 표시 / Success state\n * @property {string} [label] - 체크박스 레이블 텍스트 / Checkbox label text\n * @property {string} [description] - 체크박스 설명 텍스트 / Checkbox description text\n * @extends {Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size'>}\n */\nexport interface CheckboxProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size'> {\n variant?: \"default\" | \"outline\" | \"filled\" | \"glass\"\n size?: \"sm\" | \"md\" | \"lg\"\n error?: boolean\n success?: boolean\n label?: string\n description?: string\n}\n\n/**\n * Checkbox 컴포넌트 / Checkbox component\n * \n * 체크박스 입력 필드를 제공하는 컴포넌트입니다.\n * ARIA 속성을 자동으로 설정하여 접근성을 지원합니다.\n * \n * Checkbox input field component.\n * Automatically sets ARIA attributes for accessibility support.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Checkbox label=\"이용약관에 동의합니다\" />\n * \n * @example\n * // 에러 상태와 설명 / Error state with description\n * <Checkbox \n * label=\"필수 항목\"\n * description=\"이 항목은 필수입니다\"\n * error\n * />\n * \n * @example\n * // 제어 컴포넌트 / Controlled component\n * const [checked, setChecked] = useState(false)\n * <Checkbox \n * checked={checked}\n * onChange={(e) => setChecked(e.target.checked)}\n * label=\"동의\"\n * />\n * \n * @param {CheckboxProps} props - Checkbox 컴포넌트의 props / Checkbox component props\n * @param {React.Ref<HTMLInputElement>} ref - input 요소 ref / input element ref\n * @returns {JSX.Element} Checkbox 컴포넌트 / Checkbox component\n */\nconst Checkbox = React.forwardRef<HTMLInputElement, CheckboxProps>(\n ({ \n className, \n variant = \"default\",\n size = \"md\",\n error = false,\n success = false,\n label,\n description,\n id,\n ...props \n }, ref) => {\n const checkboxId = id || React.useId()\n const labelId = label ? `${checkboxId}-label` : undefined\n const descriptionId = description ? `${checkboxId}-description` : undefined\n const sizeClasses = {\n sm: \"w-4 h-4\",\n md: \"w-5 h-5\",\n lg: \"w-6 h-6\"\n }\n\n const iconSizes = {\n sm: 12,\n md: 14,\n lg: 16\n }\n\n const variantClasses = {\n default: \"border-gray-300 bg-white text-blue-600 focus:ring-blue-500 dark:border-gray-600 dark:bg-gray-800 dark:focus:ring-blue-400\",\n outline: \"border-2 border-gray-200 bg-transparent text-blue-600 focus:ring-blue-500 dark:border-gray-700 dark:focus:ring-blue-400\",\n filled: \"border-transparent bg-gray-50 text-blue-600 focus:bg-white focus:ring-blue-500 dark:bg-gray-700 dark:focus:bg-gray-800 dark:focus:ring-blue-400\",\n glass: \"border-white/30 bg-white/10 backdrop-blur-sm text-white focus:ring-blue-400/50 focus:bg-white/20 dark:border-slate-600/50 dark:bg-slate-800/10 dark:focus:ring-blue-400/50 dark:focus:bg-slate-700/20\"\n }\n\n const stateClasses = error \n ? \"border-red-500 focus:ring-red-500 dark:border-red-400 dark:focus:ring-red-400\"\n : success\n ? \"border-green-500 focus:ring-green-500 dark:border-green-400 dark:focus:ring-green-400\"\n : \"\"\n\n const isChecked = props.checked ?? false;\n\n return (\n <div className=\"flex items-start space-x-3\">\n <div className=\"relative\">\n <input\n type=\"checkbox\"\n id={checkboxId}\n className={merge(\n \"peer absolute inset-0 w-full h-full opacity-0 cursor-pointer z-10\",\n className\n )}\n ref={ref}\n aria-checked={isChecked}\n aria-invalid={error}\n aria-label={!label ? props['aria-label'] : undefined}\n aria-labelledby={label ? labelId : undefined}\n aria-describedby={descriptionId}\n role=\"checkbox\"\n {...props}\n />\n <div\n className={merge(\n \"flex items-center justify-center rounded border transition-all duration-200 cursor-pointer relative\",\n \"peer-focus:outline-none peer-focus:ring-2 peer-focus:ring-offset-2\",\n \"peer-hover:border-blue-400 peer-hover:shadow-sm\",\n \"peer-disabled:cursor-not-allowed peer-disabled:opacity-50 peer-disabled:hover:border-gray-300\",\n sizeClasses[size],\n variantClasses[variant],\n stateClasses,\n isChecked && \"bg-blue-600 border-blue-600 dark:bg-blue-500 dark:border-blue-500 shadow-md shadow-blue-500/20\",\n !isChecked && \"bg-white dark:bg-gray-800\"\n )}\n >\n {/* 체크 아이콘으로 개선 */}\n <Icon \n name=\"check\" \n size={iconSizes[size]} \n className={merge(\n \"text-white transition-all duration-200\",\n isChecked ? \"opacity-100 scale-100\" : \"opacity-0 scale-0\"\n )}\n />\n </div>\n </div>\n {(label || description) && (\n <div className=\"flex flex-col\">\n {label && (\n <label htmlFor={checkboxId} id={labelId} className=\"text-sm font-medium text-gray-900 dark:text-white cursor-pointer\">\n {label}\n </label>\n )}\n {description && (\n <p id={descriptionId} className=\"text-sm text-gray-500 dark:text-gray-400\">\n {description}\n </p>\n )}\n </div>\n )}\n </div>\n )\n }\n)\nCheckbox.displayName = \"Checkbox\"\n\nexport { Checkbox } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Radio 컴포넌트의 props / Radio component props\n * @typedef {Object} RadioProps\n * @property {\"default\" | \"outline\" | \"filled\" | \"glass\"} [variant=\"default\"] - Radio 스타일 변형 / Radio style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Radio 크기 / Radio size\n * @property {boolean} [error=false] - 에러 상태 표시 / Error state\n * @property {boolean} [success=false] - 성공 상태 표시 / Success state\n * @property {string} [label] - 라디오 버튼 레이블 텍스트 / Radio button label text\n * @property {string} [description] - 라디오 버튼 설명 텍스트 / Radio button description text\n * @extends {Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size'>}\n */\nexport interface RadioProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size'> {\n variant?: \"default\" | \"outline\" | \"filled\" | \"glass\"\n size?: \"sm\" | \"md\" | \"lg\"\n error?: boolean\n success?: boolean\n label?: string\n description?: string\n}\n\n/**\n * Radio 컴포넌트 / Radio component\n * \n * 라디오 버튼 입력 필드를 제공하는 컴포넌트입니다.\n * 같은 name 속성을 가진 여러 Radio는 그룹으로 동작합니다.\n * ARIA 속성을 자동으로 설정하여 접근성을 지원합니다.\n * \n * Radio button input field component.\n * Multiple Radio components with the same name attribute work as a group.\n * Automatically sets ARIA attributes for accessibility support.\n * \n * @component\n * @example\n * // 기본 사용 (그룹) / Basic usage (group)\n * <Radio name=\"option\" value=\"1\" label=\"옵션 1\" />\n * <Radio name=\"option\" value=\"2\" label=\"옵션 2\" />\n * <Radio name=\"option\" value=\"3\" label=\"옵션 3\" />\n * \n * @example\n * // 에러 상태 / Error state\n * <Radio \n * name=\"gender\"\n * value=\"male\"\n * label=\"남성\"\n * error\n * />\n * \n * @param {RadioProps} props - Radio 컴포넌트의 props / Radio component props\n * @param {React.Ref<HTMLInputElement>} ref - input 요소 ref / input element ref\n * @returns {JSX.Element} Radio 컴포넌트 / Radio component\n */\nconst Radio = React.forwardRef<HTMLInputElement, RadioProps>(\n ({ \n className, \n variant = \"default\",\n size = \"md\",\n error = false,\n success = false,\n label,\n description,\n id,\n ...props \n }, ref) => {\n const radioId = id || React.useId()\n const labelId = label ? `${radioId}-label` : undefined\n const descriptionId = description ? `${radioId}-description` : undefined\n const sizeClasses = {\n sm: \"w-4 h-4\",\n md: \"w-5 h-5\",\n lg: \"w-6 h-6\"\n }\n\n const dotSizes = {\n sm: \"w-1.5 h-1.5\",\n md: \"w-2 h-2\",\n lg: \"w-2.5 h-2.5\"\n }\n\n const variantClasses = {\n default: \"border-gray-300 bg-white text-blue-600 focus:ring-blue-500 dark:border-gray-600 dark:bg-gray-800 dark:focus:ring-blue-400\",\n outline: \"border-2 border-gray-200 bg-transparent text-blue-600 focus:ring-blue-500 dark:border-gray-700 dark:focus:ring-blue-400\",\n filled: \"border-transparent bg-gray-50 text-blue-600 focus:bg-white focus:ring-blue-500 dark:bg-gray-700 dark:focus:bg-gray-800 dark:focus:ring-blue-400\",\n glass: \"border-white/30 bg-white/10 backdrop-blur-sm text-white focus:ring-blue-400/50 focus:bg-white/20 dark:border-slate-600/50 dark:bg-slate-800/10 dark:focus:ring-blue-400/50 dark:focus:bg-slate-700/20\"\n }\n\n const stateClasses = error \n ? \"border-red-500 focus:ring-red-500 dark:border-red-400 dark:focus:ring-red-400\"\n : success\n ? \"border-green-500 focus:ring-green-500 dark:border-green-400 dark:focus:ring-green-400\"\n : \"\"\n\n return (\n <div className=\"flex items-start space-x-3\">\n <div className=\"relative\">\n <input\n type=\"radio\"\n id={radioId}\n className={merge(\n \"peer sr-only\",\n className\n )}\n ref={ref}\n aria-checked={props.checked ?? false}\n aria-invalid={error}\n aria-label={!label ? props['aria-label'] : undefined}\n aria-labelledby={label ? labelId : undefined}\n aria-describedby={descriptionId}\n role=\"radio\"\n {...props}\n />\n <div\n className={merge(\n \"flex items-center justify-center rounded-full border transition-all duration-200 cursor-pointer\",\n \"peer-focus:outline-none peer-focus:ring-2 peer-focus:ring-offset-2\",\n \"peer-disabled:cursor-not-allowed peer-disabled:opacity-50\",\n sizeClasses[size],\n variantClasses[variant],\n stateClasses,\n \"peer-checked:border-blue-600 dark:peer-checked:border-blue-500\"\n )}\n >\n <div\n className={merge(\n \"rounded-full bg-blue-600 dark:bg-blue-500 opacity-0 peer-checked:opacity-100 transition-opacity duration-200\",\n dotSizes[size]\n )}\n />\n </div>\n </div>\n {(label || description) && (\n <div className=\"flex flex-col\">\n {label && (\n <label htmlFor={radioId} id={labelId} className=\"text-sm font-medium text-gray-900 dark:text-white cursor-pointer\">\n {label}\n </label>\n )}\n {description && (\n <p id={descriptionId} className=\"text-sm text-gray-500 dark:text-gray-400\">\n {description}\n </p>\n )}\n </div>\n )}\n </div>\n )\n }\n)\nRadio.displayName = \"Radio\"\n\nexport { Radio } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\n\n/**\n * Select 컴포넌트의 props / Select component props\n * @typedef {Object} SelectProps\n * @property {\"default\" | \"outline\" | \"filled\" | \"ghost\" | \"glass\"} [variant=\"default\"] - Select 스타일 변형 / Select style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Select 크기 / Select size\n * @property {boolean} [error=false] - 에러 상태 표시 / Error state\n * @property {boolean} [success=false] - 성공 상태 표시 / Success state\n * @property {React.ReactNode} [leftIcon] - 왼쪽 아이콘 / Left icon\n * @property {string} [placeholder] - 플레이스홀더 텍스트 / Placeholder text\n * @extends {Omit<React.SelectHTMLAttributes<HTMLSelectElement>, 'size'>}\n */\nexport interface SelectProps extends Omit<React.SelectHTMLAttributes<HTMLSelectElement>, 'size'> {\n variant?: \"default\" | \"outline\" | \"filled\" | \"ghost\" | \"glass\"\n size?: \"sm\" | \"md\" | \"lg\"\n error?: boolean\n success?: boolean\n leftIcon?: React.ReactNode\n placeholder?: string\n}\n\n/**\n * SelectOption 컴포넌트의 props / SelectOption component props\n * @typedef {Object} SelectOptionProps\n * @property {string} value - 옵션 값 / Option value\n * @property {React.ReactNode} children - 옵션 표시 텍스트 / Option display text\n * @extends {React.OptionHTMLAttributes<HTMLOptionElement>}\n */\nexport interface SelectOptionProps extends React.OptionHTMLAttributes<HTMLOptionElement> {\n value: string\n children: React.ReactNode\n}\n\n/**\n * Select 컴포넌트 / Select component\n * \n * 드롭다운 선택 메뉴를 제공하는 컴포넌트입니다.\n * 다양한 스타일 변형과 크기를 지원하며, 접근성 속성을 포함합니다.\n * \n * Dropdown selection menu component.\n * Supports various style variants and sizes, includes accessibility attributes.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Select>\n * <option value=\"option1\">옵션 1</option>\n * <option value=\"option2\">옵션 2</option>\n * </Select>\n * \n * @example\n * // 에러 상태와 아이콘 / Error state with icon\n * <Select \n * error \n * leftIcon={<Icon name=\"alert\" />}\n * aria-label=\"국가 선택\"\n * >\n * <option value=\"\">국가를 선택하세요</option>\n * <option value=\"kr\">한국</option>\n * <option value=\"us\">미국</option>\n * </Select>\n * \n * @example\n * // 다양한 변형 / Various variants\n * <Select variant=\"outline\" size=\"lg\">\n * <option value=\"1\">항목 1</option>\n * </Select>\n * \n * @param {SelectProps} props - Select 컴포넌트의 props / Select component props\n * @param {React.Ref<HTMLSelectElement>} ref - select 요소 ref / select element ref\n * @returns {JSX.Element} Select 컴포넌트 / Select component\n */\nconst Select = React.forwardRef<HTMLSelectElement, SelectProps>(\n ({ \n className, \n variant = \"default\",\n size = \"md\",\n error = false,\n success = false,\n leftIcon,\n placeholder,\n children,\n \"aria-label\": ariaLabel,\n \"aria-invalid\": ariaInvalid,\n ...props \n }, ref) => {\n const variantClasses = {\n default: \"border-gray-300 bg-white text-gray-900 focus:border-blue-500 focus:ring-blue-500 dark:border-gray-600 dark:bg-gray-800 dark:text-white dark:focus:border-blue-400 dark:focus:ring-blue-400\",\n outline: \"border-2 border-gray-200 bg-transparent text-gray-900 focus:border-blue-500 focus:ring-blue-500 dark:border-gray-700 dark:text-white dark:focus:border-blue-400 dark:focus:ring-blue-400\",\n filled: \"border-transparent bg-gray-50 text-gray-900 focus:bg-white focus:border-blue-500 focus:ring-blue-500 dark:bg-gray-700 dark:text-white dark:focus:bg-gray-800 dark:focus:border-blue-400 dark:focus:ring-blue-400\",\n ghost: \"border-transparent bg-transparent text-gray-900 focus:bg-gray-50 focus:border-gray-300 focus:ring-gray-500 dark:text-white dark:focus:bg-gray-800 dark:focus:border-gray-600 dark:focus:ring-gray-400\",\n glass: \"border-white/30 bg-white/10 backdrop-blur-sm text-white focus:border-blue-400/50 focus:ring-blue-400/20 focus:bg-white/20 dark:border-slate-600/50 dark:bg-slate-800/10 dark:text-slate-200 dark:focus:border-blue-400/50 dark:focus:ring-blue-400/20 dark:focus:bg-slate-700/20\"\n }\n\n const sizeClasses = {\n sm: \"h-8 px-3 text-sm\",\n md: \"h-10 px-4 text-base\",\n lg: \"h-12 px-4 text-lg\"\n }\n\n const stateClasses = error \n ? \"border-red-500 focus:border-red-500 focus:ring-red-500 dark:border-red-400 dark:focus:border-red-400 dark:focus:ring-red-400\"\n : success\n ? \"border-green-500 focus:border-green-500 focus:ring-green-500 dark:border-green-400 dark:focus:border-green-400 dark:focus:ring-green-400\"\n : \"\"\n\n const selectRef = React.useRef<HTMLSelectElement>(null)\n const combinedRef = React.useCallback((node: HTMLSelectElement | null) => {\n selectRef.current = node\n if (typeof ref === 'function') {\n ref(node)\n } else if (ref) {\n (ref as React.MutableRefObject<HTMLSelectElement | null>).current = node\n }\n }, [ref])\n \n const [isFocused, setIsFocused] = React.useState(false)\n\n return (\n <div className=\"relative\">\n {leftIcon && (\n <div className=\"absolute left-3 top-1/2 transform -translate-y-1/2 text-gray-400 dark:text-gray-500 pointer-events-none z-10\">\n {leftIcon}\n </div>\n )}\n <select\n ref={combinedRef}\n className={merge(\n \"flex w-full appearance-none rounded-md border transition-all duration-200\",\n \"focus:outline-none focus:ring-2 focus:ring-offset-2\",\n \"hover:border-blue-400 hover:shadow-sm\",\n \"disabled:cursor-not-allowed disabled:opacity-50 disabled:hover:border-gray-300\",\n variantClasses[variant],\n sizeClasses[size],\n stateClasses,\n leftIcon ? \"pl-10\" : \"\",\n \"pr-10\", // 화살표 아이콘을 위한 공간\n className\n )}\n aria-label={ariaLabel || (placeholder ? undefined : \"선택\")}\n aria-invalid={ariaInvalid !== undefined ? ariaInvalid : (error || undefined)}\n onFocus={(e) => {\n setIsFocused(true)\n props.onFocus?.(e)\n }}\n onBlur={(e) => {\n setIsFocused(false)\n props.onBlur?.(e)\n }}\n {...props}\n >\n {placeholder && (\n <option value=\"\" disabled>\n {placeholder}\n </option>\n )}\n {children}\n </select>\n <div className={merge(\n \"absolute right-3 top-1/2 transform -translate-y-1/2 text-gray-400 dark:text-gray-500 pointer-events-none transition-transform duration-200\",\n isFocused && \"rotate-180\"\n )}>\n <Icon name=\"chevronDown\" size={16} />\n </div>\n </div>\n )\n }\n)\nSelect.displayName = \"Select\"\n\nconst SelectOption = React.forwardRef<HTMLOptionElement, SelectOptionProps>(\n ({ className, ...props }, ref) => (\n <option\n className={className || \"\"}\n ref={ref}\n {...props}\n />\n )\n)\nSelectOption.displayName = \"SelectOption\"\n\nexport { Select, SelectOption } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Switch 컴포넌트의 props / Switch component props\n * @typedef {Object} SwitchProps\n * @property {\"default\" | \"outline\" | \"filled\" | \"glass\"} [variant=\"default\"] - Switch 스타일 변형 / Switch style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Switch 크기 / Switch size\n * @property {boolean} [error=false] - 에러 상태 표시 / Error state\n * @property {boolean} [success=false] - 성공 상태 표시 / Success state\n * @property {string} [label] - 스위치 레이블 텍스트 / Switch label text\n * @property {string} [description] - 스위치 설명 텍스트 / Switch description text\n * @extends {Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size'>}\n */\nexport interface SwitchProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size'> {\n variant?: \"default\" | \"outline\" | \"filled\" | \"glass\"\n size?: \"sm\" | \"md\" | \"lg\"\n error?: boolean\n success?: boolean\n label?: string\n description?: string\n}\n\n/**\n * Switch 컴포넌트 / Switch component\n * \n * 토글 스위치 입력 필드를 제공하는 컴포넌트입니다.\n * ARIA 속성을 자동으로 설정하여 접근성을 지원합니다.\n * \n * Toggle switch input field component.\n * Automatically sets ARIA attributes for accessibility support.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Switch label=\"알림 받기\" />\n * \n * @example\n * // 제어 컴포넌트 / Controlled component\n * const [enabled, setEnabled] = useState(false)\n * <Switch \n * checked={enabled}\n * onChange={(e) => setEnabled(e.target.checked)}\n * label=\"다크 모드\"\n * />\n * \n * @example\n * // 에러 상태 / Error state\n * <Switch \n * label=\"필수 설정\"\n * description=\"이 설정을 활성화해야 합니다\"\n * error\n * />\n * \n * @param {SwitchProps} props - Switch 컴포넌트의 props / Switch component props\n * @param {React.Ref<HTMLInputElement>} ref - input 요소 ref / input element ref\n * @returns {JSX.Element} Switch 컴포넌트 / Switch component\n */\nconst Switch = React.forwardRef<HTMLInputElement, SwitchProps>(\n ({ \n className, \n variant = \"default\",\n size = \"md\",\n error = false,\n success = false,\n label,\n description,\n id,\n ...props \n }, ref) => {\n const switchId = id || React.useId()\n const labelId = label ? `${switchId}-label` : undefined\n const descriptionId = description ? `${switchId}-description` : undefined\n const sizeClasses = {\n sm: \"w-8 h-4\",\n md: \"w-11 h-6\",\n lg: \"w-14 h-7\"\n }\n\n const thumbSizes = {\n sm: \"w-3 h-3\",\n md: \"w-5 h-5\",\n lg: \"w-6 h-6\"\n }\n\n const variantClasses = {\n default: \"bg-gray-200 peer-checked:bg-blue-600 dark:bg-gray-700 dark:peer-checked:bg-blue-500\",\n outline: \"bg-transparent border-2 border-gray-300 peer-checked:border-blue-600 peer-checked:bg-blue-600 dark:border-gray-600 dark:peer-checked:border-blue-500 dark:peer-checked:bg-blue-500\",\n filled: \"bg-gray-100 peer-checked:bg-blue-600 dark:bg-gray-800 dark:peer-checked:bg-blue-500\",\n glass: \"bg-white/20 backdrop-blur-sm border border-white/30 peer-checked:bg-blue-400/50 peer-checked:border-blue-300/50 dark:bg-slate-800/20 dark:border-slate-700/50 dark:peer-checked:bg-blue-400/50 dark:peer-checked:border-blue-300/50\"\n }\n\n const stateClasses = error \n ? \"bg-red-200 peer-checked:bg-red-600 dark:bg-red-800 dark:peer-checked:bg-red-500\"\n : success\n ? \"bg-green-200 peer-checked:bg-green-600 dark:bg-green-800 dark:peer-checked:bg-green-500\"\n : \"\"\n\n return (\n <div className=\"flex items-start space-x-3\">\n <div className=\"relative\">\n <input\n type=\"checkbox\"\n id={switchId}\n className={merge(\n \"peer sr-only\",\n className\n )}\n ref={ref}\n aria-checked={props.checked ?? false}\n aria-invalid={error}\n aria-label={!label ? props['aria-label'] : undefined}\n aria-labelledby={label ? labelId : undefined}\n aria-describedby={descriptionId}\n role=\"switch\"\n {...props}\n />\n <div\n className={merge(\n \"relative inline-flex cursor-pointer items-center rounded-full transition-colors duration-200 ease-in-out\",\n \"peer-focus:outline-none peer-focus:ring-2 peer-focus:ring-blue-500 peer-focus:ring-offset-2\",\n \"peer-disabled:cursor-not-allowed peer-disabled:opacity-50\",\n sizeClasses[size],\n variantClasses[variant],\n stateClasses\n )}\n >\n <div\n className={merge(\n \"pointer-events-none block rounded-full bg-white shadow-lg ring-0 transition-transform duration-200 ease-in-out\",\n \"peer-checked:translate-x-full\",\n thumbSizes[size],\n size === \"sm\" ? \"translate-x-0.5 peer-checked:translate-x-4.5\" : \"\",\n size === \"md\" ? \"translate-x-0.5 peer-checked:translate-x-5.5\" : \"\",\n size === \"lg\" ? \"translate-x-0.5 peer-checked:translate-x-7\" : \"\"\n )}\n />\n </div>\n </div>\n {(label || description) && (\n <div className=\"flex flex-col\">\n {label && (\n <label htmlFor={switchId} id={labelId} className=\"text-sm font-medium text-gray-900 dark:text-white cursor-pointer\">\n {label}\n </label>\n )}\n {description && (\n <p id={descriptionId} className=\"text-sm text-gray-500 dark:text-gray-400\">\n {description}\n </p>\n )}\n </div>\n )}\n </div>\n )\n }\n)\nSwitch.displayName = \"Switch\"\n\nexport { Switch } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Slider 컴포넌트의 props\n * @typedef {Object} SliderProps\n * @property {\"default\" | \"primary\" | \"success\" | \"warning\" | \"danger\"} [variant=\"default\"] - Slider 스타일 변형\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Slider 크기\n * @property {boolean} [showValue=false] - 현재 값 표시 여부\n * @property {boolean} [showLabel=false] - 라벨 표시 여부\n * @property {string} [label] - 라벨 텍스트\n * @property {number} [min=0] - 최소값\n * @property {number} [max=100] - 최대값\n * @property {number} [step=1] - 단계값\n * @property {number | number[]} [value=0] - 현재 값 (배열이면 범위 슬라이더)\n * @property {(value: number | number[]) => void} [onValueChange] - 값 변경 콜백\n * @property {\"horizontal\" | \"vertical\"} [orientation=\"horizontal\"] - Slider 방향\n * @property {boolean} [disabled=false] - 비활성화 여부\n * @property {string} [className] - 추가 CSS 클래스\n * @extends {Omit<React.InputHTMLAttributes<HTMLInputElement>, 'type' | 'value' | 'onChange' | 'size'>}\n */\nexport interface SliderProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'type' | 'value' | 'onChange' | 'size'> {\n variant?: \"default\" | \"primary\" | \"success\" | \"warning\" | \"danger\"\n size?: \"sm\" | \"md\" | \"lg\"\n showValue?: boolean\n showLabel?: boolean\n label?: string\n min?: number\n max?: number\n step?: number\n value?: number | number[]\n onValueChange?: (value: number | number[]) => void\n orientation?: \"horizontal\" | \"vertical\"\n disabled?: boolean\n className?: string\n}\n\n/**\n * Slider 컴포넌트 / Slider component\n * \n * 숫자 값을 선택하는 슬라이더 컴포넌트입니다.\n * 단일 값 또는 범위 값을 선택할 수 있습니다.\n * \n * Slider component for selecting numeric values.\n * Supports single value or range value selection.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * const [value, setValue] = useState(50)\n * <Slider value={value} onValueChange={setValue} />\n * \n * @example\n * // 범위 슬라이더 / Range slider\n * const [range, setRange] = useState([20, 80])\n * <Slider \n * value={range} \n * onValueChange={setRange}\n * showValue\n * label=\"가격 범위\"\n * />\n * \n * @example\n * // 세로 슬라이더 / Vertical slider\n * <Slider \n * orientation=\"vertical\"\n * variant=\"primary\"\n * size=\"lg\"\n * className=\"h-64\"\n * />\n * \n * @param {SliderProps} props - Slider 컴포넌트의 props / Slider component props\n * @param {React.Ref<HTMLInputElement>} ref - input 요소 ref / input element ref\n * @returns {JSX.Element} Slider 컴포넌트 / Slider component\n */\nconst Slider = React.forwardRef<HTMLInputElement, SliderProps>(\n ({ \n className,\n variant = \"default\",\n size = \"md\",\n showValue = false,\n showLabel = false,\n label,\n min = 0,\n max = 100,\n step = 1,\n value = 0,\n onValueChange,\n orientation = \"horizontal\",\n disabled = false,\n ...props \n }, ref) => {\n const isRange = Array.isArray(value)\n const currentValue = isRange ? value : [value]\n \n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const newValue = parseFloat(e.target.value)\n if (onValueChange) {\n if (isRange) {\n // 범위 슬라이더의 경우, 어떤 슬라이더가 변경되었는지 확인\n const index = parseInt(e.target.dataset.index || \"0\")\n const newRange = [...currentValue]\n newRange[index] = newValue\n onValueChange(newRange)\n } else {\n onValueChange(newValue)\n }\n }\n }\n\n const variantClasses = {\n default: \"bg-gray-200 dark:bg-gray-700\",\n primary: \"bg-blue-200 dark:bg-blue-700\",\n success: \"bg-green-200 dark:bg-green-700\",\n warning: \"bg-yellow-200 dark:bg-yellow-700\",\n danger: \"bg-red-200 dark:bg-red-700\"\n }\n\n const thumbVariantClasses = {\n default: \"bg-gray-400 hover:bg-gray-500 dark:bg-gray-500 dark:hover:bg-gray-400\",\n primary: \"bg-blue-500 hover:bg-blue-600 dark:bg-blue-400 dark:hover:bg-blue-500\",\n success: \"bg-green-500 hover:bg-green-600 dark:bg-green-400 dark:hover:bg-green-500\",\n warning: \"bg-yellow-500 hover:bg-yellow-600 dark:bg-yellow-400 dark:hover:bg-yellow-500\",\n danger: \"bg-red-500 hover:bg-red-600 dark:bg-red-400 dark:hover:bg-red-500\"\n }\n\n const sizeClasses = {\n sm: orientation === \"horizontal\" ? \"h-1\" : \"w-1\",\n md: orientation === \"horizontal\" ? \"h-2\" : \"w-2\",\n lg: orientation === \"horizontal\" ? \"h-3\" : \"w-3\"\n }\n\n const thumbSizeClasses = {\n sm: \"w-3 h-3\",\n md: \"w-4 h-4\",\n lg: \"w-6 h-6\"\n }\n\n const orientationClasses = orientation === \"vertical\" \n ? \"flex-col h-full\" \n : \"flex-row w-full\"\n\n const renderSlider = (index: number = 0) => (\n <input\n key={index}\n ref={index === 0 ? ref : undefined}\n type=\"range\"\n min={min}\n max={max}\n step={step}\n value={currentValue[index]}\n onChange={handleChange}\n data-index={index}\n disabled={disabled}\n className={merge(\n \"appearance-none cursor-pointer rounded-full transition-all duration-200 focus:outline-none focus:ring-2 focus:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50\",\n sizeClasses[size],\n variantClasses[variant],\n orientation === \"vertical\" ? \"writing-mode: bt-lr; -webkit-appearance: slider-vertical\" : \"\",\n className\n )}\n style={{\n ...(orientation === \"vertical\" && {\n writingMode: \"vertical-rl\" as const,\n WebkitAppearance: \"slider-vertical\"\n })\n }}\n {...props}\n />\n )\n\n const renderValue = () => {\n if (!showValue) return null\n \n if (isRange) {\n return (\n <div className=\"flex gap-2 text-sm text-gray-600 dark:text-gray-400\">\n {currentValue.map((val, index) => (\n <span key={index} className=\"font-mono\">\n {val}\n </span>\n ))}\n </div>\n )\n }\n \n return (\n <span className=\"text-sm font-mono text-gray-600 dark:text-gray-400\">\n {currentValue[0]}\n </span>\n )\n }\n\n return (\n <div className={merge(\"flex items-center gap-4\", orientationClasses)}>\n {showLabel && label && (\n <label className=\"text-sm font-medium text-gray-700 dark:text-gray-300 min-w-0\">\n {label}\n </label>\n )}\n \n <div className=\"flex-1 relative\">\n <div className={merge(\"relative\", orientation === \"vertical\" ? \"h-full\" : \"w-full\")}>\n {/* 배경 트랙 */}\n <div className={merge(\n \"absolute rounded-full\",\n sizeClasses[size],\n variantClasses[variant],\n orientation === \"vertical\" ? \"w-full bottom-0\" : \"h-full left-0\"\n )} />\n \n {/* 활성 트랙 (값에 따른 채워진 부분) */}\n {isRange ? (\n // 범위 슬라이더\n <div className={merge(\n \"absolute rounded-full bg-blue-500 dark:bg-blue-400\",\n sizeClasses[size],\n orientation === \"vertical\" \n ? \"w-full bottom-0\" \n : \"h-full left-0\"\n )} style={{\n ...(orientation === \"vertical\" \n ? {\n bottom: `${(currentValue[0] - min) / (max - min) * 100}%`,\n height: `${(currentValue[1] - currentValue[0]) / (max - min) * 100}%`\n }\n : {\n left: `${(currentValue[0] - min) / (max - min) * 100}%`,\n width: `${(currentValue[1] - currentValue[0]) / (max - min) * 100}%`\n }\n )\n }} />\n ) : (\n // 단일 슬라이더\n <div className={merge(\n \"absolute rounded-full bg-blue-500 dark:bg-blue-400\",\n sizeClasses[size],\n orientation === \"vertical\" \n ? \"w-full bottom-0\" \n : \"h-full left-0\"\n )} style={{\n ...(orientation === \"vertical\"\n ? { height: `${(currentValue[0] - min) / (max - min) * 100}%` }\n : { width: `${(currentValue[0] - min) / (max - min) * 100}%` }\n )\n }} />\n )}\n \n {/* 슬라이더 핸들들 */}\n {isRange ? (\n // 범위 슬라이더 핸들\n currentValue.map((_, index) => (\n <div\n key={index}\n className={merge(\n \"absolute rounded-full border-2 border-white shadow-lg transition-all duration-200 hover:scale-110\",\n thumbSizeClasses[size],\n thumbVariantClasses[variant],\n orientation === \"vertical\" \n ? \"left-1/2 transform -translate-x-1/2\" \n : \"top-1/2 transform -translate-y-1/2\"\n )}\n style={{\n ...(orientation === \"vertical\"\n ? { bottom: `${(currentValue[index] - min) / (max - min) * 100}%` }\n : { left: `${(currentValue[index] - min) / (max - min) * 100}%` }\n )\n }}\n />\n ))\n ) : (\n // 단일 슬라이더 핸들\n <div\n className={merge(\n \"absolute rounded-full border-2 border-white shadow-lg transition-all duration-200 hover:scale-110\",\n thumbSizeClasses[size],\n thumbVariantClasses[variant],\n orientation === \"vertical\" \n ? \"left-1/2 transform -translate-x-1/2\" \n : \"top-1/2 transform -translate-y-1/2\"\n )}\n style={{\n ...(orientation === \"vertical\"\n ? { bottom: `${(currentValue[0] - min) / (max - min) * 100}%` }\n : { left: `${(currentValue[0] - min) / (max - min) * 100}%` }\n )\n }}\n />\n )}\n </div>\n \n {/* 실제 input 요소들 (숨김) */}\n <div className=\"absolute inset-0 opacity-0\">\n {isRange ? (\n currentValue.map((_, index) => renderSlider(index))\n ) : (\n renderSlider()\n )}\n </div>\n </div>\n \n {renderValue()}\n </div>\n )\n }\n)\nSlider.displayName = \"Slider\"\n\nexport { Slider }\n","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Textarea 컴포넌트의 props / Textarea component props\n * @typedef {Object} TextareaProps\n * @property {\"default\" | \"outline\" | \"filled\" | \"ghost\" | \"glass\"} [variant=\"default\"] - Textarea 스타일 변형 / Textarea style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Textarea 크기 / Textarea size\n * @property {boolean} [error=false] - 에러 상태 표시 / Error state\n * @property {boolean} [success=false] - 성공 상태 표시 / Success state\n * @property {\"none\" | \"vertical\" | \"horizontal\" | \"both\"} [resize=\"vertical\"] - 크기 조절 방향 / Resize direction\n * @extends {React.TextareaHTMLAttributes<HTMLTextAreaElement>}\n */\nexport interface TextareaProps extends React.TextareaHTMLAttributes<HTMLTextAreaElement> {\n variant?: \"default\" | \"outline\" | \"filled\" | \"ghost\" | \"glass\"\n size?: \"sm\" | \"md\" | \"lg\"\n error?: boolean\n success?: boolean\n resize?: \"none\" | \"vertical\" | \"horizontal\" | \"both\"\n}\n\n/**\n * Textarea 컴포넌트 / Textarea component\n * \n * 여러 줄 텍스트 입력을 위한 텍스트 영역 컴포넌트입니다.\n * 다양한 스타일 변형과 크기를 지원하며, 접근성 속성을 포함합니다.\n * \n * Text area component for multi-line text input.\n * Supports various style variants and sizes, includes accessibility attributes.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Textarea placeholder=\"내용을 입력하세요\" />\n * \n * @example\n * // 에러 상태 / Error state\n * <Textarea \n * error\n * placeholder=\"에러가 발생했습니다\"\n * aria-label=\"설명 입력\"\n * />\n * \n * @example\n * // 크기 조절 비활성화 / Disable resize\n * <Textarea \n * resize=\"none\"\n * rows={5}\n * placeholder=\"고정 크기 텍스트 영역\"\n * />\n * \n * @param {TextareaProps} props - Textarea 컴포넌트의 props / Textarea component props\n * @param {React.Ref<HTMLTextAreaElement>} ref - textarea 요소 ref / textarea element ref\n * @returns {JSX.Element} Textarea 컴포넌트 / Textarea component\n * \n * @todo 접근성 개선: aria-invalid 속성 자동 추가 필요 / Accessibility improvement: auto-add aria-invalid attribute\n */\nconst Textarea = React.forwardRef<HTMLTextAreaElement, TextareaProps>(\n ({ \n className, \n variant = \"default\",\n size = \"md\",\n error = false,\n success = false,\n resize = \"vertical\",\n ...props \n }, ref) => {\n const variantClasses = {\n default: \"border-gray-300 bg-white text-gray-900 placeholder-gray-500 focus:border-blue-500 focus:ring-blue-500 dark:border-gray-600 dark:bg-gray-800 dark:text-white dark:placeholder-gray-400 dark:focus:border-blue-400 dark:focus:ring-blue-400 transition-all duration-200 hover:border-blue-400 hover:shadow-sm\",\n outline: \"border-2 border-gray-200 bg-transparent text-gray-900 placeholder-gray-500 focus:border-blue-500 focus:ring-blue-500 dark:border-gray-700 dark:text-white dark:placeholder-gray-400 dark:focus:border-blue-400 dark:focus:ring-blue-400 transition-all duration-200 hover:border-blue-400 hover:shadow-sm\",\n filled: \"border-transparent bg-gray-50 text-gray-900 placeholder-gray-500 focus:bg-white focus:border-blue-500 focus:ring-blue-500 dark:bg-gray-700 dark:text-white dark:placeholder-gray-400 dark:focus:bg-gray-800 dark:focus:border-blue-400 dark:focus:ring-blue-400 transition-all duration-200 hover:bg-gray-100 dark:hover:bg-gray-600\",\n ghost: \"border-transparent bg-transparent text-gray-900 placeholder-gray-500 focus:bg-gray-50 focus:border-gray-300 focus:ring-gray-500 dark:text-white dark:placeholder-gray-400 dark:focus:bg-gray-800 dark:focus:border-gray-600 dark:focus:ring-gray-400 transition-all duration-200 hover:bg-gray-50 dark:hover:bg-gray-800\",\n glass: \"border-white/30 bg-white/10 backdrop-blur-sm text-white placeholder-white/60 focus:border-blue-400/50 focus:ring-blue-400/20 focus:bg-white/20 dark:border-slate-600/50 dark:bg-slate-800/10 dark:text-slate-200 dark:placeholder-slate-400 dark:focus:border-blue-400/50 dark:focus:ring-blue-400/20 dark:focus:bg-slate-700/20 transition-all duration-200 hover:border-blue-400/40 hover:bg-white/15 dark:hover:bg-slate-700/15\"\n }\n\n const sizeClasses = {\n sm: \"px-3 py-2 text-sm min-h-[80px]\",\n md: \"px-4 py-3 text-base min-h-[100px]\",\n lg: \"px-4 py-3 text-lg min-h-[120px]\"\n }\n\n const resizeClasses = {\n none: \"resize-none\",\n vertical: \"resize-y\",\n horizontal: \"resize-x\",\n both: \"resize\"\n }\n\n const stateClasses = error \n ? \"border-red-500 focus:border-red-500 focus:ring-red-500 dark:border-red-400 dark:focus:border-red-400 dark:focus:ring-red-400\"\n : success\n ? \"border-green-500 focus:border-green-500 focus:ring-green-500 dark:border-green-400 dark:focus:border-green-400 dark:focus:ring-green-400\"\n : \"\"\n \n // aria-invalid 자동 설정\n // Auto-set aria-invalid\n const ariaInvalid = props['aria-invalid' as keyof typeof props] as boolean | undefined\n const isInvalid = error || (ariaInvalid !== undefined ? ariaInvalid : false)\n\n return (\n <textarea\n className={merge(\n \"flex w-full rounded-md border transition-colors duration-200 focus:outline-none focus:ring-2 focus:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50\",\n variantClasses[variant],\n sizeClasses[size],\n resizeClasses[resize],\n stateClasses,\n className\n )}\n ref={ref}\n aria-invalid={isInvalid || undefined}\n {...props}\n />\n )\n }\n)\nTextarea.displayName = \"Textarea\"\n\nexport { Textarea } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\nimport { Popover } from \"./Popover\"\nimport { Button } from \"./Button\"\n\n/**\n * DatePicker 컴포넌트의 props / DatePicker component props\n * @typedef {Object} DatePickerProps\n * @property {Date | null} [value] - 선택된 날짜 / Selected date\n * @property {(date: Date | null) => void} [onChange] - 날짜 변경 핸들러 / Date change handler\n * @property {Date} [minDate] - 최소 날짜 / Minimum date\n * @property {Date} [maxDate] - 최대 날짜 / Maximum date\n * @property {string} [placeholder=\"날짜를 선택하세요\"] - 플레이스홀더 / Placeholder\n * @property {boolean} [disabled=false] - 비활성화 상태 / Disabled state\n * @property {boolean} [error=false] - 에러 상태 / Error state\n * @property {string} [dateFormat=\"YYYY-MM-DD\"] - 날짜 포맷 / Date format\n * @property {string} [locale=\"ko-KR\"] - 로케일 / Locale\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - 크기 / Size\n * @property {string} [className] - 추가 클래스명 / Additional class name\n * @extends {Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'>}\n */\nexport interface DatePickerProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'> {\n value?: Date | null\n onChange?: (date: Date | null) => void\n minDate?: Date\n maxDate?: Date\n placeholder?: string\n disabled?: boolean\n error?: boolean\n dateFormat?: string\n locale?: string\n size?: \"sm\" | \"md\" | \"lg\"\n className?: string\n}\n\nconst sizeClasses = {\n sm: \"h-8 text-sm px-3\",\n md: \"h-10 text-sm px-4\",\n lg: \"h-12 text-base px-5\",\n}\n\nconst formatDate = (date: Date | null, format: string = \"YYYY-MM-DD\", locale: string = \"ko-KR\"): string => {\n if (!date) return \"\"\n \n const year = date.getFullYear()\n const month = String(date.getMonth() + 1).padStart(2, \"0\")\n const day = String(date.getDate()).padStart(2, \"0\")\n \n return format\n .replace(\"YYYY\", String(year))\n .replace(\"MM\", month)\n .replace(\"DD\", day)\n}\n\nconst getDaysInMonth = (year: number, month: number): number => {\n return new Date(year, month + 1, 0).getDate()\n}\n\nconst getFirstDayOfMonth = (year: number, month: number): number => {\n return new Date(year, month, 1).getDay()\n}\n\n/**\n * DatePicker 컴포넌트 / DatePicker component\n * \n * 날짜를 선택할 수 있는 컴포넌트입니다.\n * 캘린더 팝오버를 통해 직관적으로 날짜를 선택할 수 있습니다.\n * \n * Component for selecting dates.\n * Allows intuitive date selection through a calendar popover.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <DatePicker\n * value={selectedDate}\n * onChange={setSelectedDate}\n * />\n * \n * @example\n * // 날짜 범위 제한 / Date range restriction\n * <DatePicker\n * value={date}\n * onChange={setDate}\n * minDate={new Date(\"2024-01-01\")}\n * maxDate={new Date(\"2024-12-31\")}\n * placeholder=\"날짜 선택\"\n * />\n * \n * @param {DatePickerProps} props - DatePicker 컴포넌트의 props / DatePicker component props\n * @returns {JSX.Element} DatePicker 컴포넌트 / DatePicker component\n */\nexport const DatePicker = React.forwardRef<HTMLDivElement, DatePickerProps>(\n (\n {\n value,\n onChange,\n minDate,\n maxDate,\n placeholder = \"날짜를 선택하세요\",\n disabled = false,\n error = false,\n dateFormat = \"YYYY-MM-DD\",\n locale = \"ko-KR\",\n size = \"md\",\n className,\n ...props\n },\n ref\n ) => {\n const [isOpen, setIsOpen] = React.useState(false)\n const [currentMonth, setCurrentMonth] = React.useState(value ? new Date(value.getFullYear(), value.getMonth()) : new Date())\n const [hoveredDate, setHoveredDate] = React.useState<Date | null>(null)\n\n const displayDate = value ? formatDate(value, dateFormat, locale) : \"\"\n\n const handleDateSelect = (date: Date) => {\n if (minDate && date < minDate) return\n if (maxDate && date > maxDate) return\n onChange?.(date)\n setIsOpen(false)\n }\n\n const handlePrevMonth = () => {\n setCurrentMonth(new Date(currentMonth.getFullYear(), currentMonth.getMonth() - 1))\n }\n\n const handleNextMonth = () => {\n setCurrentMonth(new Date(currentMonth.getFullYear(), currentMonth.getMonth() + 1))\n }\n\n const handleToday = () => {\n const today = new Date()\n today.setHours(0, 0, 0, 0)\n handleDateSelect(today)\n }\n\n const year = currentMonth.getFullYear()\n const month = currentMonth.getMonth()\n const daysInMonth = getDaysInMonth(year, month)\n const firstDay = getFirstDayOfMonth(year, month)\n\n const weekDays = locale === \"ko-KR\" \n ? [\"일\", \"월\", \"화\", \"수\", \"목\", \"금\", \"토\"]\n : [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"]\n\n const isDateDisabled = (date: Date): boolean => {\n if (minDate && date < minDate) return true\n if (maxDate && date > maxDate) return true\n return false\n }\n\n const isDateSelected = (date: Date): boolean => {\n if (!value) return false\n return (\n date.getFullYear() === value.getFullYear() &&\n date.getMonth() === value.getMonth() &&\n date.getDate() === value.getDate()\n )\n }\n\n const isToday = (date: Date): boolean => {\n const today = new Date()\n return (\n date.getFullYear() === today.getFullYear() &&\n date.getMonth() === today.getMonth() &&\n date.getDate() === today.getDate()\n )\n }\n\n const calendarDays: (Date | null)[] = []\n \n // 이전 달의 마지막 날들\n for (let i = firstDay - 1; i >= 0; i--) {\n const date = new Date(year, month, -i)\n calendarDays.push(date)\n }\n \n // 현재 달의 날들\n for (let day = 1; day <= daysInMonth; day++) {\n calendarDays.push(new Date(year, month, day))\n }\n \n // 다음 달의 첫 날들 (캘린더를 6주로 채우기)\n const remainingDays = 42 - calendarDays.length\n for (let day = 1; day <= remainingDays; day++) {\n calendarDays.push(new Date(year, month + 1, day))\n }\n\n const triggerButton = (\n <button\n type=\"button\"\n disabled={disabled}\n className={merge(\n \"flex w-full items-center justify-between rounded-lg border bg-white px-4 py-2 text-left text-sm transition-colors\",\n \"hover:bg-gray-50 focus:outline-none focus:ring-2 focus:ring-blue-500 focus:ring-offset-2\",\n \"dark:bg-gray-800 dark:border-gray-700 dark:hover:bg-gray-700\",\n error && \"border-red-500 focus:ring-red-500\",\n disabled && \"cursor-not-allowed opacity-50\",\n sizeClasses[size]\n )}\n aria-label={displayDate || placeholder}\n >\n <span className={merge(\"flex-1\", !displayDate && \"text-gray-400 dark:text-gray-500\")}>\n {displayDate || placeholder}\n </span>\n <Icon \n name=\"calendar\" \n className={merge(\n \"ml-2 h-4 w-4 transition-transform\",\n isOpen && \"rotate-180\"\n )} \n />\n </button>\n )\n\n return (\n <div ref={ref} className={merge(\"relative\", className)} {...props}>\n <Popover \n open={isOpen} \n onOpenChange={setIsOpen}\n trigger={triggerButton}\n position=\"bottom\"\n align=\"start\"\n >\n <div className=\"w-auto p-0\">\n <div className=\"p-4\">\n {/* 헤더 */}\n <div className=\"flex items-center justify-between mb-4\">\n <button\n type=\"button\"\n onClick={handlePrevMonth}\n className=\"rounded-lg p-2 hover:bg-gray-100 dark:hover:bg-gray-700 transition-colors\"\n aria-label=\"이전 달\"\n >\n <Icon name=\"chevronLeft\" className=\"h-4 w-4\" />\n </button>\n <div className=\"text-lg font-semibold text-gray-900 dark:text-white\">\n {year}년 {month + 1}월\n </div>\n <button\n type=\"button\"\n onClick={handleNextMonth}\n className=\"rounded-lg p-2 hover:bg-gray-100 dark:hover:bg-gray-700 transition-colors\"\n aria-label=\"다음 달\"\n >\n <Icon name=\"chevronRight\" className=\"h-4 w-4\" />\n </button>\n </div>\n\n {/* 요일 헤더 */}\n <div className=\"grid grid-cols-7 gap-1 mb-2\">\n {weekDays.map((day, index) => (\n <div\n key={index}\n className={merge(\n \"text-center text-xs font-medium py-2\",\n index === 0 && \"text-red-500 dark:text-red-400\",\n index === 6 && \"text-blue-500 dark:text-blue-400\"\n )}\n >\n {day}\n </div>\n ))}\n </div>\n\n {/* 캘린더 그리드 */}\n <div className=\"grid grid-cols-7 gap-1\">\n {calendarDays.map((date, index) => {\n if (!date) return <div key={index} />\n \n const isCurrentMonth = date.getMonth() === month\n const isDisabled = isDateDisabled(date)\n const isSelected = isDateSelected(date)\n const isTodayDate = isToday(date)\n const isHovered = hoveredDate && \n date.getFullYear() === hoveredDate.getFullYear() &&\n date.getMonth() === hoveredDate.getMonth() &&\n date.getDate() === hoveredDate.getDate()\n\n return (\n <button\n key={index}\n type=\"button\"\n disabled={isDisabled}\n onClick={() => handleDateSelect(date)}\n onMouseEnter={() => setHoveredDate(date)}\n onMouseLeave={() => setHoveredDate(null)}\n className={merge(\n \"relative h-9 w-9 rounded-lg text-sm font-medium transition-all\",\n \"hover:bg-blue-50 dark:hover:bg-blue-900/20\",\n \"focus:outline-none focus:ring-2 focus:ring-blue-500 focus:ring-offset-1\",\n !isCurrentMonth && \"text-gray-400 dark:text-gray-500\",\n isDisabled && \"cursor-not-allowed opacity-30\",\n isSelected && \"bg-blue-600 text-white hover:bg-blue-700 shadow-md\",\n isTodayDate && !isSelected && \"ring-2 ring-blue-500\",\n isHovered && !isSelected && \"bg-blue-100 dark:bg-blue-900/30\"\n )}\n aria-label={`${year}년 ${month + 1}월 ${date.getDate()}일`}\n >\n {date.getDate()}\n </button>\n )\n })}\n </div>\n\n {/* 오늘 버튼 */}\n <div className=\"mt-4 pt-4 border-t border-gray-200 dark:border-gray-700\">\n <Button\n variant=\"outline\"\n size=\"sm\"\n onClick={handleToday}\n className=\"w-full\"\n >\n 오늘\n </Button>\n </div>\n </div>\n </div>\n </Popover>\n </div>\n )\n }\n)\n\nDatePicker.displayName = \"DatePicker\"\n\n\n","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\nimport { Button } from \"./Button\"\nimport type { IconName } from \"../lib/icons\"\n\n/**\n * 업로드된 파일 정보 인터페이스 / Uploaded file information interface\n * @typedef {Object} UploadedFile\n * @property {string} id - 파일 고유 ID / File unique ID\n * @property {File} file - 파일 객체 / File object\n * @property {string} name - 파일 이름 / File name\n * @property {number} size - 파일 크기 (bytes) / File size in bytes\n * @property {string} type - 파일 타입 / File type\n * @property {number} [progress] - 업로드 진행률 (0-100) / Upload progress (0-100)\n * @property {\"pending\" | \"uploading\" | \"success\" | \"error\"} [status] - 업로드 상태 / Upload status\n * @property {string} [url] - 업로드된 파일 URL / Uploaded file URL\n * @property {string} [error] - 에러 메시지 / Error message\n */\nexport interface UploadedFile {\n id: string\n file: File\n name: string\n size: number\n type: string\n progress?: number\n status?: \"pending\" | \"uploading\" | \"success\" | \"error\"\n url?: string\n error?: string\n}\n\n/**\n * Upload 컴포넌트의 props / Upload component props\n * @typedef {Object} UploadProps\n * @property {UploadedFile[]} [files] - 업로드된 파일 목록 / Uploaded files list\n * @property {(files: File[]) => void} [onChange] - 파일 선택 핸들러 / File selection handler\n * @property {(file: UploadedFile) => void} [onRemove] - 파일 제거 핸들러 / File removal handler\n * @property {boolean} [multiple=false] - 다중 파일 선택 허용 / Allow multiple file selection\n * @property {string} [accept] - 허용할 파일 타입 (예: \"image/*\", \".pdf\") / Accepted file types\n * @property {number} [maxSize] - 최대 파일 크기 (bytes) / Maximum file size in bytes\n * @property {number} [maxFiles] - 최대 파일 개수 / Maximum number of files\n * @property {boolean} [disabled=false] - 비활성화 상태 / Disabled state\n * @property {boolean} [dragDrop=true] - 드래그 앤 드롭 활성화 / Enable drag and drop\n * @property {string} [placeholder=\"파일을 선택하거나 여기에 드래그하세요\"] - 플레이스홀더 / Placeholder\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - 크기 / Size\n * @property {string} [className] - 추가 클래스명 / Additional class name\n */\nexport interface UploadProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'> {\n files?: UploadedFile[]\n onChange?: (files: File[]) => void\n onRemove?: (file: UploadedFile) => void\n multiple?: boolean\n accept?: string\n maxSize?: number\n maxFiles?: number\n disabled?: boolean\n dragDrop?: boolean\n placeholder?: string\n size?: \"sm\" | \"md\" | \"lg\"\n className?: string\n}\n\nconst formatFileSize = (bytes: number): string => {\n if (bytes === 0) return \"0 Bytes\"\n const k = 1024\n const sizes = [\"Bytes\", \"KB\", \"MB\", \"GB\"]\n const i = Math.floor(Math.log(bytes) / Math.log(k))\n return Math.round(bytes / Math.pow(k, i) * 100) / 100 + \" \" + sizes[i]\n}\n\nconst getFileIcon = (type: string): IconName => {\n if (type.startsWith(\"image/\")) return \"image\"\n if (type.startsWith(\"video/\")) return \"video\"\n if (type.includes(\"pdf\")) return \"fileText\"\n if (type.includes(\"word\") || type.includes(\"document\")) return \"fileText\"\n if (type.includes(\"excel\") || type.includes(\"spreadsheet\")) return \"fileText\"\n return \"file\"\n}\n\n/**\n * Upload 컴포넌트 / Upload component\n * \n * 파일을 업로드할 수 있는 컴포넌트입니다.\n * 드래그 앤 드롭, 다중 파일 선택, 파일 크기 제한 등을 지원합니다.\n * \n * Component for uploading files.\n * Supports drag and drop, multiple file selection, file size limits, and more.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Upload\n * onChange={(files) => console.log(files)}\n * />\n * \n * @example\n * // 이미지만, 다중 선택 / Images only, multiple selection\n * <Upload\n * accept=\"image/*\"\n * multiple\n * maxSize={5 * 1024 * 1024} // 5MB\n * maxFiles={5}\n * files={uploadedFiles}\n * onRemove={(file) => handleRemove(file)}\n * />\n * \n * @param {UploadProps} props - Upload 컴포넌트의 props / Upload component props\n * @returns {JSX.Element} Upload 컴포넌트 / Upload component\n */\nexport const Upload = React.forwardRef<HTMLDivElement, UploadProps>(\n (\n {\n files = [],\n onChange,\n onRemove,\n multiple = false,\n accept,\n maxSize,\n maxFiles,\n disabled = false,\n dragDrop = true,\n placeholder = \"파일을 선택하거나 여기에 드래그하세요\",\n size = \"md\",\n className,\n ...props\n },\n ref\n ) => {\n const fileInputRef = React.useRef<HTMLInputElement>(null)\n const [isDragging, setIsDragging] = React.useState(false)\n\n const handleFileSelect = (selectedFiles: FileList | null) => {\n if (!selectedFiles || selectedFiles.length === 0) return\n\n const fileArray = Array.from(selectedFiles)\n \n // 파일 개수 체크\n if (maxFiles && files.length + fileArray.length > maxFiles) {\n alert(`최대 ${maxFiles}개의 파일만 업로드할 수 있습니다.`)\n return\n }\n\n // 파일 크기 체크\n const validFiles = fileArray.filter((file) => {\n if (maxSize && file.size > maxSize) {\n alert(`파일 크기는 ${formatFileSize(maxSize)}를 초과할 수 없습니다: ${file.name}`)\n return false\n }\n return true\n })\n\n if (validFiles.length > 0) {\n onChange?.(validFiles)\n }\n }\n\n const handleClick = () => {\n if (!disabled) {\n fileInputRef.current?.click()\n }\n }\n\n const handleDragOver = (e: React.DragEvent) => {\n e.preventDefault()\n if (!disabled && dragDrop) {\n setIsDragging(true)\n }\n }\n\n const handleDragLeave = (e: React.DragEvent) => {\n e.preventDefault()\n setIsDragging(false)\n }\n\n const handleDrop = (e: React.DragEvent) => {\n e.preventDefault()\n setIsDragging(false)\n if (!disabled && dragDrop) {\n handleFileSelect(e.dataTransfer.files)\n }\n }\n\n const handleRemove = (file: UploadedFile) => {\n onRemove?.(file)\n }\n\n const sizeClasses = {\n sm: \"p-4\",\n md: \"p-6\",\n lg: \"p-8\",\n }\n\n return (\n <div ref={ref} className={merge(\"w-full\", className)} {...props}>\n {/* 업로드 영역 */}\n <div\n onClick={handleClick}\n onDragOver={handleDragOver}\n onDragLeave={handleDragLeave}\n onDrop={handleDrop}\n className={merge(\n \"relative border-2 border-dashed rounded-xl transition-all cursor-pointer\",\n \"bg-gray-50 dark:bg-gray-900/50\",\n \"border-gray-300 dark:border-gray-700\",\n isDragging && \"border-blue-500 bg-blue-50 dark:bg-blue-900/20\",\n disabled && \"cursor-not-allowed opacity-50\",\n sizeClasses[size]\n )}\n >\n <input\n ref={fileInputRef}\n type=\"file\"\n multiple={multiple}\n accept={accept}\n disabled={disabled}\n onChange={(e) => handleFileSelect(e.target.files)}\n className=\"hidden\"\n aria-label=\"파일 선택\"\n />\n \n <div className=\"flex flex-col items-center justify-center text-center\">\n <div className={merge(\n \"rounded-full bg-blue-100 dark:bg-blue-900/30 p-4 mb-4\",\n isDragging && \"bg-blue-200 dark:bg-blue-900/50\"\n )}>\n <Icon \n name=\"upload\" \n className={merge(\n \"h-8 w-8 text-blue-600 dark:text-blue-400\",\n isDragging && \"scale-110\"\n )} \n />\n </div>\n <p className=\"text-sm font-medium text-gray-700 dark:text-gray-300 mb-1\">\n {placeholder}\n </p>\n <p className=\"text-xs text-gray-500 dark:text-gray-400\">\n {accept && `지원 형식: ${accept}`}\n {maxSize && ` • 최대 크기: ${formatFileSize(maxSize)}`}\n {maxFiles && ` • 최대 ${maxFiles}개`}\n </p>\n </div>\n </div>\n\n {/* 파일 목록 */}\n {files.length > 0 && (\n <div className=\"mt-4 space-y-2\">\n {files.map((file) => (\n <div\n key={file.id}\n className={merge(\n \"flex items-center gap-3 p-3 rounded-lg border\",\n \"bg-white dark:bg-gray-800\",\n \"border-gray-200 dark:border-gray-700\",\n file.status === \"error\" && \"border-red-300 dark:border-red-700 bg-red-50 dark:bg-red-900/20\"\n )}\n >\n <div className=\"flex-shrink-0\">\n <div className=\"rounded-lg bg-gray-100 dark:bg-gray-700 p-2\">\n <Icon \n name={getFileIcon(file.type)} \n className=\"h-5 w-5 text-gray-600 dark:text-gray-400\" \n />\n </div>\n </div>\n \n <div className=\"flex-1 min-w-0\">\n <p className=\"text-sm font-medium text-gray-900 dark:text-white truncate\">\n {file.name}\n </p>\n <div className=\"flex items-center gap-2 mt-1\">\n <p className=\"text-xs text-gray-500 dark:text-gray-400\">\n {formatFileSize(file.size)}\n </p>\n {file.status === \"uploading\" && file.progress !== undefined && (\n <>\n <div className=\"flex-1 h-1.5 bg-gray-200 dark:bg-gray-700 rounded-full overflow-hidden\">\n <div\n className=\"h-full bg-blue-600 transition-all duration-300\"\n style={{ width: `${file.progress}%` }}\n />\n </div>\n <span className=\"text-xs text-gray-500 dark:text-gray-400\">\n {file.progress}%\n </span>\n </>\n )}\n {file.status === \"success\" && (\n <span className=\"text-xs text-green-600 dark:text-green-400 flex items-center gap-1\">\n <Icon name=\"check\" className=\"h-3 w-3\" />\n 완료\n </span>\n )}\n {file.status === \"error\" && (\n <span className=\"text-xs text-red-600 dark:text-red-400\">\n {file.error || \"업로드 실패\"}\n </span>\n )}\n </div>\n </div>\n\n {onRemove && (\n <button\n type=\"button\"\n onClick={() => handleRemove(file)}\n className=\"flex-shrink-0 rounded-lg p-1.5 hover:bg-gray-100 dark:hover:bg-gray-700 transition-colors\"\n aria-label=\"파일 제거\"\n >\n <Icon name=\"close\" className=\"h-4 w-4 text-gray-500 dark:text-gray-400\" />\n </button>\n )}\n </div>\n ))}\n </div>\n )}\n </div>\n )\n }\n)\n\nUpload.displayName = \"Upload\"\n\n\n","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\nimport { Input } from \"./Input\"\n\n/**\n * Autocomplete 옵션 인터페이스 / Autocomplete option interface\n * @typedef {Object} AutocompleteOption\n * @property {string} value - 옵션 값 / Option value\n * @property {string} label - 옵션 라벨 / Option label\n * @property {string} [description] - 옵션 설명 / Option description\n * @property {React.ReactNode} [icon] - 옵션 아이콘 / Option icon\n * @property {Record<string, unknown>} [data] - 추가 데이터 / Additional data\n */\nexport interface AutocompleteOption {\n value: string\n label: string\n description?: string\n icon?: React.ReactNode\n data?: Record<string, unknown>\n}\n\n/**\n * Autocomplete 컴포넌트의 props / Autocomplete component props\n * @typedef {Object} AutocompleteProps\n * @property {AutocompleteOption[]} options - 옵션 목록 / Options list\n * @property {string} [value] - 선택된 값 / Selected value\n * @property {(value: string, option?: AutocompleteOption) => void} [onChange] - 값 변경 핸들러 / Value change handler\n * @property {string} [placeholder=\"검색하거나 선택하세요\"] - 플레이스홀더 / Placeholder\n * @property {boolean} [disabled=false] - 비활성화 상태 / Disabled state\n * @property {boolean} [error=false] - 에러 상태 / Error state\n * @property {boolean} [loading=false] - 로딩 상태 / Loading state\n * @property {number} [maxHeight=300] - 드롭다운 최대 높이 (px) / Dropdown max height in px\n * @property {boolean} [clearable=true] - 지우기 버튼 표시 / Show clear button\n * @property {boolean} [filterable=true] - 필터링 활성화 / Enable filtering\n * @property {(query: string) => AutocompleteOption[] | Promise<AutocompleteOption[]>} [onSearch] - 검색 핸들러 (비동기 지원) / Search handler (async support)\n * @property {React.ReactNode} [emptyText=\"결과가 없습니다\"] - 빈 결과 텍스트 / Empty result text\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - 크기 / Size\n * @property {string} [className] - 추가 클래스명 / Additional class name\n * @extends {Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'>}\n */\nexport interface AutocompleteProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'> {\n options: AutocompleteOption[]\n value?: string\n onChange?: (value: string, option?: AutocompleteOption) => void\n placeholder?: string\n disabled?: boolean\n error?: boolean\n loading?: boolean\n maxHeight?: number\n clearable?: boolean\n filterable?: boolean\n onSearch?: (query: string) => AutocompleteOption[] | Promise<AutocompleteOption[]>\n emptyText?: string\n size?: \"sm\" | \"md\" | \"lg\"\n className?: string\n}\n\nconst sizeClasses = {\n sm: \"h-8 text-sm\",\n md: \"h-10 text-sm\",\n lg: \"h-12 text-base\",\n}\n\n/**\n * Autocomplete 컴포넌트 / Autocomplete component\n * \n * 자동완성 입력 컴포넌트입니다.\n * 입력하면서 옵션을 필터링하고 선택할 수 있습니다.\n * \n * Autocomplete input component.\n * Filters and selects options as you type.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Autocomplete\n * options={[\n * { value: \"1\", label: \"옵션 1\" },\n * { value: \"2\", label: \"옵션 2\" }\n * ]}\n * onChange={(value) => console.log(value)}\n * />\n * \n * @example\n * // 비동기 검색 / Async search\n * <Autocomplete\n * options={options}\n * onSearch={async (query) => {\n * const results = await searchAPI(query)\n * return results\n * }}\n * loading={isLoading}\n * />\n * \n * @param {AutocompleteProps} props - Autocomplete 컴포넌트의 props / Autocomplete component props\n * @returns {JSX.Element} Autocomplete 컴포넌트 / Autocomplete component\n */\nexport const Autocomplete = React.forwardRef<HTMLDivElement, AutocompleteProps>(\n (\n {\n options,\n value,\n onChange,\n placeholder = \"검색하거나 선택하세요\",\n disabled = false,\n error = false,\n loading = false,\n maxHeight = 300,\n clearable = true,\n filterable = true,\n onSearch,\n emptyText = \"결과가 없습니다\",\n size = \"md\",\n className,\n ...props\n },\n ref\n ) => {\n const [isOpen, setIsOpen] = React.useState(false)\n const [inputValue, setInputValue] = React.useState(\"\")\n const [filteredOptions, setFilteredOptions] = React.useState<AutocompleteOption[]>(options)\n const [selectedIndex, setSelectedIndex] = React.useState(-1)\n const [isSearching, setIsSearching] = React.useState(false)\n \n const inputRef = React.useRef<HTMLInputElement>(null)\n const dropdownRef = React.useRef<HTMLDivElement>(null)\n\n const selectedOption = React.useMemo(() => {\n return options.find((opt) => opt.value === value)\n }, [options, value])\n\n // 초기 입력값 설정\n React.useEffect(() => {\n if (selectedOption) {\n setInputValue(selectedOption.label)\n } else if (!value) {\n setInputValue(\"\")\n }\n }, [selectedOption, value])\n\n // 옵션 필터링\n React.useEffect(() => {\n if (onSearch) {\n setIsSearching(true)\n const result = onSearch(inputValue)\n if (result instanceof Promise) {\n result.then((filtered) => {\n setFilteredOptions(filtered)\n setIsSearching(false)\n })\n } else {\n setFilteredOptions(result)\n setIsSearching(false)\n }\n } else if (filterable) {\n if (!inputValue.trim()) {\n setFilteredOptions(options)\n } else {\n const filtered = options.filter((option) =>\n option.label.toLowerCase().includes(inputValue.toLowerCase()) ||\n option.value.toLowerCase().includes(inputValue.toLowerCase()) ||\n option.description?.toLowerCase().includes(inputValue.toLowerCase())\n )\n setFilteredOptions(filtered)\n }\n } else {\n setFilteredOptions(options)\n }\n }, [inputValue, options, filterable, onSearch])\n\n const handleInputChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const newValue = e.target.value\n setInputValue(newValue)\n setIsOpen(true)\n setSelectedIndex(-1)\n \n if (!newValue && clearable) {\n onChange?.(\"\")\n }\n }\n\n const handleInputFocus = () => {\n setIsOpen(true)\n }\n\n const handleInputBlur = (e: React.FocusEvent) => {\n // 드롭다운 클릭 시에는 닫지 않음\n if (dropdownRef.current?.contains(e.relatedTarget as Node)) {\n return\n }\n setIsOpen(false)\n setSelectedIndex(-1)\n \n // 선택된 옵션이 있으면 그 라벨로 복원\n if (selectedOption) {\n setInputValue(selectedOption.label)\n }\n }\n\n const handleOptionSelect = (option: AutocompleteOption) => {\n setInputValue(option.label)\n onChange?.(option.value, option)\n setIsOpen(false)\n inputRef.current?.blur()\n }\n\n const handleClear = () => {\n setInputValue(\"\")\n onChange?.(\"\")\n inputRef.current?.focus()\n }\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (!isOpen || filteredOptions.length === 0) {\n if (e.key === \"ArrowDown\") {\n setIsOpen(true)\n }\n return\n }\n\n switch (e.key) {\n case \"ArrowDown\":\n e.preventDefault()\n setSelectedIndex((prev) => \n prev < filteredOptions.length - 1 ? prev + 1 : prev\n )\n break\n case \"ArrowUp\":\n e.preventDefault()\n setSelectedIndex((prev) => (prev > 0 ? prev - 1 : -1))\n break\n case \"Enter\":\n e.preventDefault()\n if (selectedIndex >= 0 && filteredOptions[selectedIndex]) {\n handleOptionSelect(filteredOptions[selectedIndex])\n }\n break\n case \"Escape\":\n setIsOpen(false)\n inputRef.current?.blur()\n break\n }\n }\n\n return (\n <div ref={ref} className={merge(\"relative w-full\", className)} {...props}>\n <div className=\"relative\">\n <Input\n ref={inputRef}\n type=\"text\"\n value={inputValue}\n onChange={handleInputChange}\n onFocus={handleInputFocus}\n onBlur={handleInputBlur}\n onKeyDown={handleKeyDown}\n placeholder={placeholder}\n disabled={disabled}\n aria-invalid={error}\n aria-autocomplete=\"list\"\n aria-expanded={isOpen}\n aria-controls=\"autocomplete-list\"\n className={merge(sizeClasses[size], \"pr-10\")}\n />\n \n <div className=\"absolute right-3 top-1/2 -translate-y-1/2 flex items-center gap-1\">\n {loading || isSearching ? (\n <Icon \n name=\"loader\"\n className=\"h-4 w-4 animate-spin text-gray-400\" \n />\n ) : clearable && inputValue ? (\n <button\n type=\"button\"\n onClick={handleClear}\n className=\"rounded p-1 hover:bg-gray-100 dark:hover:bg-gray-700 transition-colors\"\n aria-label=\"지우기\"\n >\n <Icon name=\"close\" className=\"h-4 w-4 text-gray-400\" />\n </button>\n ) : (\n <Icon name=\"chevronDown\" className=\"h-4 w-4 text-gray-400\" />\n )}\n </div>\n </div>\n\n {/* 드롭다운 */}\n {isOpen && (\n <div\n ref={dropdownRef}\n id=\"autocomplete-list\"\n role=\"listbox\"\n className={merge(\n \"absolute z-50 w-full mt-1 rounded-lg border shadow-lg\",\n \"bg-white dark:bg-gray-800\",\n \"border-gray-200 dark:border-gray-700\",\n \"overflow-hidden\"\n )}\n style={{ maxHeight: `${maxHeight}px` }}\n >\n <div className=\"overflow-y-auto\" style={{ maxHeight: `${maxHeight}px` }}>\n {filteredOptions.length === 0 ? (\n <div className=\"px-4 py-8 text-center text-sm text-gray-500 dark:text-gray-400\">\n {emptyText}\n </div>\n ) : (\n filteredOptions.map((option, index) => {\n const isSelected = selectedIndex === index\n const isValueSelected = value === option.value\n\n return (\n <div\n key={option.value}\n role=\"option\"\n aria-selected={isValueSelected}\n onClick={() => handleOptionSelect(option)}\n onMouseEnter={() => setSelectedIndex(index)}\n className={merge(\n \"px-4 py-3 cursor-pointer transition-colors\",\n \"hover:bg-gray-100 dark:hover:bg-gray-700\",\n isSelected && \"bg-blue-50 dark:bg-blue-900/20\",\n isValueSelected && \"bg-blue-100 dark:bg-blue-900/30\"\n )}\n >\n <div className=\"flex items-center gap-3\">\n {option.icon && (\n <div className=\"flex-shrink-0 text-gray-400\">\n {option.icon}\n </div>\n )}\n <div className=\"flex-1 min-w-0\">\n <div className=\"flex items-center gap-2\">\n <p className=\"text-sm font-medium text-gray-900 dark:text-white\">\n {option.label}\n </p>\n {isValueSelected && (\n <Icon \n name=\"check\" \n className=\"h-4 w-4 text-blue-600 dark:text-blue-400 flex-shrink-0\" \n />\n )}\n </div>\n {option.description && (\n <p className=\"text-xs text-gray-500 dark:text-gray-400 mt-0.5\">\n {option.description}\n </p>\n )}\n </div>\n </div>\n </div>\n )\n })\n )}\n </div>\n </div>\n )}\n </div>\n )\n }\n)\n\nAutocomplete.displayName = \"Autocomplete\"\n\n\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/components/Input.tsx","../src/components/Popover.tsx","../src/components/Form.tsx","../src/components/Label.tsx","../src/components/Checkbox.tsx","../src/components/Radio.tsx","../src/components/Select.tsx","../src/components/Switch.tsx","../src/components/Slider.tsx","../src/components/Textarea.tsx","../src/components/DatePicker.tsx","../src/components/Upload.tsx","../src/components/Autocomplete.tsx"],"names":["Input","React","className","type","props","ref","ariaInvalid","isInvalid","jsx","merge","Popover","children","trigger","controlledOpen","onOpenChange","position","align","offset","disabled","internalOpen","setInternalOpen","triggerRef","popoverRef","isControlled","isOpen","handleOpenChange","newOpen","handleTriggerClick","handleClickOutside","event","getPositionClasses","baseClasses","getAlignmentClasses","getArrowClasses","jsxs","PopoverTrigger","PopoverContent","Form","onSubmit","variant","e","FormField","error","required","errorId","enhancedChildren","child","childProps","childType","isFormComponent","typeObj","displayName","name","isNativeFormElement","existingAriaDescribedBy","ariaDescribedBy","FormGroup","inline","Label","variantClasses","Checkbox","size","success","label","description","id","_a","checkboxId","labelId","descriptionId","sizeClasses","iconSizes","stateClasses","isChecked","Icon","Radio","radioId","dotSizes","Select","leftIcon","placeholder","ariaLabel","selectRef","combinedRef","node","isFocused","setIsFocused","SelectOption","Switch","switchId","thumbSizes","Slider","showValue","showLabel","min","max","step","value","onValueChange","orientation","isRange","currentValue","handleChange","newValue","index","newRange","thumbVariantClasses","thumbSizeClasses","orientationClasses","renderSlider","renderValue","val","_","Textarea","resize","resizeClasses","formatDate","date","format","locale","year","month","day","getDaysInMonth","getFirstDayOfMonth","DatePicker","onChange","minDate","maxDate","dateFormat","setIsOpen","currentMonth","setCurrentMonth","hoveredDate","setHoveredDate","displayDate","handleDateSelect","handlePrevMonth","handleNextMonth","handleToday","today","daysInMonth","firstDay","weekDays","isDateDisabled","isDateSelected","isToday","calendarDays","i","remainingDays","triggerButton","isCurrentMonth","isDisabled","isSelected","isTodayDate","isHovered","Button","formatFileSize","bytes","k","sizes","getFileIcon","Upload","files","onRemove","multiple","accept","maxSize","maxFiles","dragDrop","fileInputRef","isDragging","setIsDragging","handleFileSelect","selectedFiles","fileArray","validFiles","file","handleClick","handleDragOver","handleDragLeave","handleDrop","handleRemove","Fragment","Autocomplete","options","loading","maxHeight","clearable","filterable","onSearch","emptyText","inputValue","setInputValue","filteredOptions","setFilteredOptions","selectedIndex","setSelectedIndex","isSearching","setIsSearching","inputRef","dropdownRef","selectedOption","opt","result","filtered","option","handleInputChange","handleInputFocus","handleInputBlur","handleOptionSelect","handleClear","handleKeyDown","prev","isValueSelected"],"mappings":"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","file":"chunk-ZFS4B5QT.mjs","sourcesContent":["\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Input 컴포넌트의 props / Input component props\n * HTML input 요소의 모든 표준 속성을 상속받습니다.\n * Inherits all standard attributes of HTML input element.\n * @typedef {Object} InputProps\n * @extends {React.InputHTMLAttributes<HTMLInputElement>}\n */\nexport interface InputProps extends React.InputHTMLAttributes<HTMLInputElement> {}\n\n/**\n * Input 컴포넌트 / Input component\n * \n * 표준 HTML input 요소를 래핑한 스타일링된 입력 필드 컴포넌트입니다.\n * 접근성 속성(aria-invalid)을 자동으로 처리합니다.\n * \n * Styled input field component wrapping standard HTML input element.\n * Automatically handles accessibility attributes (aria-invalid).\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Input type=\"text\" placeholder=\"이름을 입력하세요\" />\n * \n * @example\n * // 에러 상태 / Error state\n * <Input \n * type=\"email\" \n * placeholder=\"이메일\"\n * aria-invalid={true}\n * />\n * \n * @example\n * // ref 사용 / Using ref\n * const inputRef = useRef<HTMLInputElement>(null)\n * <Input ref={inputRef} type=\"text\" />\n * \n * @param {InputProps} props - Input 컴포넌트의 props / Input component props\n * @param {React.Ref<HTMLInputElement>} ref - input 요소 ref / input element ref\n * @returns {JSX.Element} Input 컴포넌트 / Input component\n */\nconst Input = React.forwardRef<HTMLInputElement, InputProps>(\n ({ className, type, ...props }, ref) => {\n // aria-invalid이 명시적으로 전달되지 않았고, error prop이 있으면 자동 설정\n const ariaInvalid = props[\"aria-invalid\" as keyof typeof props] as boolean | undefined;\n const isInvalid = ariaInvalid !== undefined ? ariaInvalid : false;\n \n return (\n <input\n type={type}\n className={merge(\n \"flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 transition-all duration-200 hover:border-blue-400 hover:shadow-sm\",\n isInvalid && \"border-red-500 focus-visible:ring-red-500\",\n className\n )}\n ref={ref}\n aria-invalid={isInvalid || undefined}\n {...props}\n />\n )\n }\n)\nInput.displayName = \"Input\"\n\nexport { Input } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Popover 컴포넌트의 props / Popover component props\n * @typedef {Object} PopoverProps\n * @property {React.ReactNode} children - Popover 내용 / Popover content\n * @property {React.ReactNode} trigger - Popover를 열기 위한 트리거 요소 / Trigger element to open popover\n * @property {boolean} [open] - 제어 모드에서 열림/닫힘 상태 / Open/close state in controlled mode\n * @property {(open: boolean) => void} [onOpenChange] - 상태 변경 콜백 / State change callback\n * @property {\"top\" | \"bottom\" | \"left\" | \"right\"} [position=\"bottom\"] - Popover 표시 위치 / Popover display position\n * @property {\"start\" | \"center\" | \"end\"} [align=\"center\"] - Popover 정렬 / Popover alignment\n * @property {number} [offset=8] - 트리거와 Popover 사이 간격 (px) / Spacing between trigger and popover (px)\n * @property {boolean} [disabled=false] - Popover 비활성화 여부 / Disable popover\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface PopoverProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n trigger: React.ReactNode\n open?: boolean\n onOpenChange?: (open: boolean) => void\n position?: \"top\" | \"bottom\" | \"left\" | \"right\"\n align?: \"start\" | \"center\" | \"end\"\n offset?: number\n disabled?: boolean\n}\n\n/**\n * Popover 컴포넌트 / Popover component\n * \n * 트리거 요소를 클릭하면 표시되는 팝오버 컴포넌트입니다.\n * 외부 클릭 시 자동으로 닫힙니다.\n * \n * Popover component that appears when the trigger element is clicked.\n * Automatically closes when clicking outside.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Popover trigger={<Button>열기</Button>}>\n * <div className=\"p-4\">Popover 내용</div>\n * </Popover>\n * \n * @example\n * // 제어 모드 / Controlled mode\n * const [open, setOpen] = useState(false)\n * <Popover \n * open={open}\n * onOpenChange={setOpen}\n * trigger={<Button>제어 모드</Button>}\n * position=\"top\"\n * >\n * <div className=\"p-4\">내용</div>\n * </Popover>\n * \n * @param {PopoverProps} props - Popover 컴포넌트의 props / Popover component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Popover 컴포넌트 / Popover component\n */\nconst Popover = React.forwardRef<HTMLDivElement, PopoverProps>(\n ({ \n className, \n children,\n trigger,\n open: controlledOpen,\n onOpenChange,\n position = \"bottom\",\n align = \"center\",\n offset = 8,\n disabled = false,\n ...props \n }, ref) => {\n const [internalOpen, setInternalOpen] = React.useState(false)\n const triggerRef = React.useRef<HTMLDivElement>(null)\n const popoverRef = React.useRef<HTMLDivElement>(null)\n const isControlled = controlledOpen !== undefined\n const isOpen = isControlled ? controlledOpen : internalOpen\n\n const handleOpenChange = (newOpen: boolean) => {\n if (disabled) return\n \n if (!isControlled) {\n setInternalOpen(newOpen)\n }\n onOpenChange?.(newOpen)\n }\n\n const handleTriggerClick = () => {\n handleOpenChange(!isOpen)\n }\n\n React.useEffect(() => {\n const handleClickOutside = (event: MouseEvent) => {\n if (\n triggerRef.current && \n popoverRef.current && \n !triggerRef.current.contains(event.target as Node) &&\n !popoverRef.current.contains(event.target as Node)\n ) {\n handleOpenChange(false)\n }\n }\n\n if (isOpen) {\n document.addEventListener('mousedown', handleClickOutside)\n return () => {\n document.removeEventListener('mousedown', handleClickOutside)\n }\n }\n }, [isOpen])\n\n const getPositionClasses = () => {\n const baseClasses = \"absolute z-50\"\n \n switch (position) {\n case \"top\":\n return merge(baseClasses, \"bottom-full left-0\", `mb-${Math.max(1, Math.floor(offset / 4))}`)\n case \"bottom\":\n return merge(baseClasses, \"top-full left-0\", `mt-${Math.max(1, Math.floor(offset / 4))}`)\n case \"left\":\n return merge(baseClasses, \"right-full top-0\", `mr-${Math.max(1, Math.floor(offset / 4))}`)\n case \"right\":\n return merge(baseClasses, \"left-full top-0\", `ml-${Math.max(1, Math.floor(offset / 4))}`)\n default:\n return merge(baseClasses, \"top-full left-0\", `mt-${Math.max(1, Math.floor(offset / 4))}`)\n }\n }\n\n const getAlignmentClasses = () => {\n switch (align) {\n case \"start\":\n if (position === \"top\" || position === \"bottom\") {\n return \"left-0\"\n } else {\n return \"top-0\"\n }\n case \"end\":\n if (position === \"top\" || position === \"bottom\") {\n return \"right-0\"\n } else {\n return \"bottom-0\"\n }\n case \"center\":\n default:\n if (position === \"top\" || position === \"bottom\") {\n return \"left-1/2 -translate-x-1/2\"\n } else {\n return \"top-1/2 -translate-y-1/2\"\n }\n }\n }\n\n const getArrowClasses = () => {\n const baseClasses = \"absolute w-0 h-0 border-4 border-transparent\"\n \n switch (position) {\n case \"top\":\n return `${baseClasses} top-full left-1/2 -translate-x-1/2 border-t-gray-200 dark:border-t-gray-700`\n case \"bottom\":\n return `${baseClasses} bottom-full left-1/2 -translate-x-1/2 border-b-gray-200 dark:border-b-gray-700`\n case \"left\":\n return `${baseClasses} left-full top-1/2 -translate-y-1/2 border-l-gray-200 dark:border-l-gray-700`\n case \"right\":\n return `${baseClasses} right-full top-1/2 -translate-y-1/2 border-r-gray-200 dark:border-r-gray-700`\n default:\n return `${baseClasses} bottom-full left-1/2 -translate-x-1/2 border-b-gray-200 dark:border-b-gray-700`\n }\n }\n\n return (\n <div ref={ref} className={merge(\"relative\", className)} {...props}>\n {/* 트리거 */}\n <div\n ref={triggerRef}\n onClick={handleTriggerClick}\n className=\"inline-block cursor-pointer\"\n >\n {trigger}\n </div>\n\n {/* 팝오버 */}\n {isOpen && (\n <div\n ref={popoverRef}\n className={merge(\n \"bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700 rounded-lg shadow-lg p-4 min-w-[200px]\",\n getPositionClasses(),\n getAlignmentClasses()\n )}\n >\n {/* 화살표 */}\n <div className={getArrowClasses()} />\n \n {/* 내용 */}\n <div className=\"relative z-10\">\n {children}\n </div>\n </div>\n )}\n </div>\n )\n }\n)\nPopover.displayName = \"Popover\"\n\n// 편의 컴포넌트들\nexport const PopoverTrigger = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"inline-block cursor-pointer\", className)}\n {...props}\n >\n {children}\n </div>\n )\n)\nPopoverTrigger.displayName = \"PopoverTrigger\"\n\nexport const PopoverContent = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700 rounded-lg shadow-lg p-4\", className)}\n {...props}\n >\n {children}\n </div>\n )\n)\nPopoverContent.displayName = \"PopoverContent\"\n\nexport { Popover } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Form 컴포넌트의 props / Form component props\n * @typedef {Object} FormProps\n * @property {(e: React.FormEvent<HTMLFormElement>) => void} [onSubmit] - 폼 제출 핸들러 / Form submit handler\n * @property {\"default\" | \"glass\"} [variant=\"default\"] - Form 스타일 변형 / Form style variant\n * @extends {React.FormHTMLAttributes<HTMLFormElement>}\n */\nexport interface FormProps extends React.FormHTMLAttributes<HTMLFormElement> {\n onSubmit?: (e: React.FormEvent<HTMLFormElement>) => void\n variant?: \"default\" | \"glass\"\n}\n\n/**\n * FormField 컴포넌트의 props / FormField component props\n * @typedef {Object} FormFieldProps\n * @property {string} [error] - 에러 메시지 / Error message\n * @property {boolean} [required=false] - 필수 필드 여부 / Required field\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface FormFieldProps extends React.HTMLAttributes<HTMLDivElement> {\n error?: string\n required?: boolean\n}\n\n/**\n * FormGroup 컴포넌트의 props / FormGroup component props\n * @typedef {Object} FormGroupProps\n * @property {boolean} [inline=false] - 인라인 레이아웃 여부 / Inline layout\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface FormGroupProps extends React.HTMLAttributes<HTMLDivElement> {\n inline?: boolean\n}\n\n/**\n * Form 컴포넌트 / Form component\n * \n * 폼 컨테이너 컴포넌트입니다.\n * FormField, FormGroup과 함께 사용하여 구조화된 폼을 구성합니다.\n * \n * Form container component.\n * Used with FormField and FormGroup to create structured forms.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Form onSubmit={(e) => { e.preventDefault(); console.log('제출') }}>\n * <FormField>\n * <Label>이름</Label>\n * <Input />\n * </FormField>\n * </Form>\n * \n * @example\n * // Glass 스타일 / Glass style\n * <Form variant=\"glass\" onSubmit={handleSubmit}>\n * <FormGroup>\n * <FormField>\n * <Label>이메일</Label>\n * <Input type=\"email\" />\n * </FormField>\n * </FormGroup>\n * </Form>\n * \n * @param {FormProps} props - Form 컴포넌트의 props / Form component props\n * @param {React.Ref<HTMLFormElement>} ref - form 요소 ref / form element ref\n * @returns {JSX.Element} Form 컴포넌트 / Form component\n */\nconst Form = React.forwardRef<HTMLFormElement, FormProps>(\n ({ \n className, \n children, \n onSubmit,\n variant = \"default\",\n ...props \n }, ref) => {\n const handleSubmit = (e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault()\n onSubmit?.(e)\n }\n\n const variantClasses = {\n default: \"space-y-6\",\n glass: \"space-y-6 bg-white/10 backdrop-blur-sm border border-white/20 rounded-xl p-6 shadow-xl dark:bg-slate-800/20 dark:border-slate-700/50\"\n }\n\n return (\n <form\n ref={ref}\n onSubmit={handleSubmit}\n className={merge(variantClasses[variant], className)}\n {...props}\n >\n {children}\n </form>\n )\n }\n)\nForm.displayName = \"Form\"\n\n/**\n * FormField 컴포넌트 / FormField component\n * \n * 폼 필드를 감싸는 컨테이너입니다.\n * 에러 메시지를 표시하고 필수 필드 표시를 지원합니다.\n * \n * Container that wraps a form field.\n * Displays error messages and supports required field indication.\n * \n * @component\n * @example\n * <FormField error=\"이 필드는 필수입니다\" required>\n * <Label>이름</Label>\n * <Input />\n * </FormField>\n * \n * @param {FormFieldProps} props - FormField 컴포넌트의 props / FormField component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} FormField 컴포넌트 / FormField component\n */\nconst FormField = React.forwardRef<HTMLDivElement, FormFieldProps>(\n ({ \n className, \n children, \n error,\n required,\n ...props \n }, ref) => {\n const errorId = React.useId()\n\n // 자식 요소에 aria-describedby와 aria-invalid 연결\n // Connect aria-describedby and aria-invalid to child elements\n const enhancedChildren = React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n const childProps = child.props as Record<string, unknown>\n const childType = child.type\n \n // Input, Select, Textarea 컴포넌트 확인\n // Check for Input, Select, Textarea components\n let isFormComponent = false\n if (typeof childType === 'object' && childType !== null) {\n const typeObj = childType as Record<string, unknown>\n const displayName = typeObj.displayName as string | undefined\n const name = typeObj.name as string | undefined\n isFormComponent = \n displayName === 'Input' || \n displayName === 'Select' || \n displayName === 'Textarea' ||\n name === 'Input' || \n name === 'Select' || \n name === 'Textarea'\n }\n \n // 네이티브 HTML 요소 확인\n // Check for native HTML elements\n const isNativeFormElement = \n typeof childType === 'string' &&\n ['input', 'select', 'textarea'].includes(childType.toLowerCase())\n \n if (isFormComponent || isNativeFormElement) {\n const existingAriaDescribedBy = childProps['aria-describedby'] as string | undefined\n const ariaDescribedBy = error \n ? existingAriaDescribedBy \n ? `${existingAriaDescribedBy} ${errorId}`\n : errorId\n : existingAriaDescribedBy\n \n return React.cloneElement(child, {\n 'aria-describedby': ariaDescribedBy,\n 'aria-invalid': error ? true : childProps['aria-invalid'],\n required: required || childProps.required,\n } as Record<string, unknown>)\n }\n }\n return child\n })\n\n return (\n <div\n ref={ref}\n className={merge(\"space-y-2\", className)}\n {...props}\n >\n {enhancedChildren}\n {error && (\n <p \n id={errorId}\n className=\"text-sm text-red-600 dark:text-red-400\"\n role=\"alert\"\n aria-live=\"polite\"\n >\n {error}\n </p>\n )}\n </div>\n )\n }\n)\nFormField.displayName = \"FormField\"\n\n/**\n * FormGroup 컴포넌트 / FormGroup component\n * \n * 여러 폼 필드를 그룹화하는 컨테이너입니다.\n * Container that groups multiple form fields.\n * \n * @component\n * @example\n * <FormGroup inline>\n * <FormField>\n * <Label>이름</Label>\n * <Input />\n * </FormField>\n * <FormField>\n * <Label>성</Label>\n * <Input />\n * </FormField>\n * </FormGroup>\n * \n * @param {FormGroupProps} props - FormGroup 컴포넌트의 props / FormGroup component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} FormGroup 컴포넌트 / FormGroup component\n */\nconst FormGroup = React.forwardRef<HTMLDivElement, FormGroupProps>(\n ({ \n className, \n children, \n inline = false,\n ...props \n }, ref) => {\n return (\n <div\n ref={ref}\n className={merge(\n inline ? \"flex gap-4\" : \"space-y-4\",\n className\n )}\n {...props}\n >\n {children}\n </div>\n )\n }\n)\nFormGroup.displayName = \"FormGroup\"\n\nexport { Form, FormField, FormGroup } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Label 컴포넌트의 props / Label component props\n * @typedef {Object} LabelProps\n * @property {boolean} [required=false] - 필수 필드 여부 / Required field indicator\n * @property {boolean} [error=false] - 에러 상태 표시 / Error state\n * @property {boolean} [disabled=false] - 비활성화 상태 / Disabled state\n * @property {\"default\" | \"glass\"} [variant=\"default\"] - Label 스타일 변형 / Label style variant\n * @extends {React.LabelHTMLAttributes<HTMLLabelElement>}\n */\nexport interface LabelProps extends React.LabelHTMLAttributes<HTMLLabelElement> {\n required?: boolean\n error?: boolean\n disabled?: boolean\n variant?: \"default\" | \"glass\"\n}\n\n/**\n * Label 컴포넌트 / Label component\n * \n * 폼 필드의 레이블을 표시하는 컴포넌트입니다.\n * 필수 필드 표시와 에러 상태를 지원합니다.\n * \n * Component for displaying form field labels.\n * Supports required field indicator and error state.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Label htmlFor=\"email\">이메일</Label>\n * <Input id=\"email\" />\n * \n * @example\n * // 필수 필드 / Required field\n * <Label required htmlFor=\"name\">이름</Label>\n * <Input id=\"name\" required />\n * \n * @example\n * // 에러 상태 / Error state\n * <Label error htmlFor=\"password\">비밀번호</Label>\n * <Input id=\"password\" aria-invalid />\n * \n * @param {LabelProps} props - Label 컴포넌트의 props / Label component props\n * @param {React.Ref<HTMLLabelElement>} ref - label 요소 ref / label element ref\n * @returns {JSX.Element} Label 컴포넌트 / Label component\n * \n * @todo 접근성 개선: required일 때 aria-required=\"true\" 추가 필요 / Accessibility improvement: add aria-required=\"true\" when required\n */\nconst Label = React.forwardRef<HTMLLabelElement, LabelProps>(\n ({ \n className, \n children, \n required = false,\n error = false,\n disabled = false,\n variant = \"default\",\n ...props \n }, ref) => {\n const variantClasses = {\n default: merge(\n \"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70\",\n error && \"text-red-600 dark:text-red-400\",\n disabled && \"text-slate-400 dark:text-slate-500\",\n !error && !disabled && \"text-slate-700 dark:text-slate-300\"\n ),\n glass: merge(\n \"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70\",\n error && \"text-red-400\",\n disabled && \"text-white/50\",\n !error && !disabled && \"text-white\"\n )\n }\n\n return (\n <label\n ref={ref}\n className={merge(variantClasses[variant], className)}\n aria-required={required ? true : undefined}\n {...props}\n >\n {children}\n {required && (\n <span className={variant === \"glass\" ? \"text-red-400 ml-1\" : \"text-red-500 ml-1\"} aria-label=\"필수 필드\">*</span>\n )}\n </label>\n )\n }\n)\nLabel.displayName = \"Label\"\n\nexport { Label } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\n\n/**\n * Checkbox 컴포넌트의 props / Checkbox component props\n * @typedef {Object} CheckboxProps\n * @property {\"default\" | \"outline\" | \"filled\" | \"glass\"} [variant=\"default\"] - Checkbox 스타일 변형 / Checkbox style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Checkbox 크기 / Checkbox size\n * @property {boolean} [error=false] - 에러 상태 표시 / Error state\n * @property {boolean} [success=false] - 성공 상태 표시 / Success state\n * @property {string} [label] - 체크박스 레이블 텍스트 / Checkbox label text\n * @property {string} [description] - 체크박스 설명 텍스트 / Checkbox description text\n * @extends {Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size'>}\n */\nexport interface CheckboxProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size'> {\n variant?: \"default\" | \"outline\" | \"filled\" | \"glass\"\n size?: \"sm\" | \"md\" | \"lg\"\n error?: boolean\n success?: boolean\n label?: string\n description?: string\n}\n\n/**\n * Checkbox 컴포넌트 / Checkbox component\n * \n * 체크박스 입력 필드를 제공하는 컴포넌트입니다.\n * ARIA 속성을 자동으로 설정하여 접근성을 지원합니다.\n * \n * Checkbox input field component.\n * Automatically sets ARIA attributes for accessibility support.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Checkbox label=\"이용약관에 동의합니다\" />\n * \n * @example\n * // 에러 상태와 설명 / Error state with description\n * <Checkbox \n * label=\"필수 항목\"\n * description=\"이 항목은 필수입니다\"\n * error\n * />\n * \n * @example\n * // 제어 컴포넌트 / Controlled component\n * const [checked, setChecked] = useState(false)\n * <Checkbox \n * checked={checked}\n * onChange={(e) => setChecked(e.target.checked)}\n * label=\"동의\"\n * />\n * \n * @param {CheckboxProps} props - Checkbox 컴포넌트의 props / Checkbox component props\n * @param {React.Ref<HTMLInputElement>} ref - input 요소 ref / input element ref\n * @returns {JSX.Element} Checkbox 컴포넌트 / Checkbox component\n */\nconst Checkbox = React.forwardRef<HTMLInputElement, CheckboxProps>(\n ({ \n className, \n variant = \"default\",\n size = \"md\",\n error = false,\n success = false,\n label,\n description,\n id,\n ...props \n }, ref) => {\n const checkboxId = id || React.useId()\n const labelId = label ? `${checkboxId}-label` : undefined\n const descriptionId = description ? `${checkboxId}-description` : undefined\n const sizeClasses = {\n sm: \"w-4 h-4\",\n md: \"w-5 h-5\",\n lg: \"w-6 h-6\"\n }\n\n const iconSizes = {\n sm: 12,\n md: 14,\n lg: 16\n }\n\n const variantClasses = {\n default: \"border-gray-300 bg-white text-blue-600 focus:ring-blue-500 dark:border-gray-600 dark:bg-gray-800 dark:focus:ring-blue-400\",\n outline: \"border-2 border-gray-200 bg-transparent text-blue-600 focus:ring-blue-500 dark:border-gray-700 dark:focus:ring-blue-400\",\n filled: \"border-transparent bg-gray-50 text-blue-600 focus:bg-white focus:ring-blue-500 dark:bg-gray-700 dark:focus:bg-gray-800 dark:focus:ring-blue-400\",\n glass: \"border-white/30 bg-white/10 backdrop-blur-sm text-white focus:ring-blue-400/50 focus:bg-white/20 dark:border-slate-600/50 dark:bg-slate-800/10 dark:focus:ring-blue-400/50 dark:focus:bg-slate-700/20\"\n }\n\n const stateClasses = error \n ? \"border-red-500 focus:ring-red-500 dark:border-red-400 dark:focus:ring-red-400\"\n : success\n ? \"border-green-500 focus:ring-green-500 dark:border-green-400 dark:focus:ring-green-400\"\n : \"\"\n\n const isChecked = props.checked ?? false;\n\n return (\n <div className=\"flex items-start space-x-3\">\n <div className=\"relative\">\n <input\n type=\"checkbox\"\n id={checkboxId}\n className={merge(\n \"peer absolute inset-0 w-full h-full opacity-0 cursor-pointer z-10\",\n className\n )}\n ref={ref}\n aria-checked={isChecked}\n aria-invalid={error}\n aria-label={!label ? props['aria-label'] : undefined}\n aria-labelledby={label ? labelId : undefined}\n aria-describedby={descriptionId}\n role=\"checkbox\"\n {...props}\n />\n <div\n className={merge(\n \"flex items-center justify-center rounded border transition-all duration-200 cursor-pointer relative\",\n \"peer-focus:outline-none peer-focus:ring-2 peer-focus:ring-offset-2\",\n \"peer-hover:border-blue-400 peer-hover:shadow-sm\",\n \"peer-disabled:cursor-not-allowed peer-disabled:opacity-50 peer-disabled:hover:border-gray-300\",\n sizeClasses[size],\n variantClasses[variant],\n stateClasses,\n isChecked && \"bg-blue-600 border-blue-600 dark:bg-blue-500 dark:border-blue-500 shadow-md shadow-blue-500/20\",\n !isChecked && \"bg-white dark:bg-gray-800\"\n )}\n >\n {/* 체크 아이콘으로 개선 */}\n <Icon \n name=\"check\" \n size={iconSizes[size]} \n className={merge(\n \"text-white transition-all duration-200\",\n isChecked ? \"opacity-100 scale-100\" : \"opacity-0 scale-0\"\n )}\n />\n </div>\n </div>\n {(label || description) && (\n <div className=\"flex flex-col\">\n {label && (\n <label htmlFor={checkboxId} id={labelId} className=\"text-sm font-medium text-gray-900 dark:text-white cursor-pointer\">\n {label}\n </label>\n )}\n {description && (\n <p id={descriptionId} className=\"text-sm text-gray-500 dark:text-gray-400\">\n {description}\n </p>\n )}\n </div>\n )}\n </div>\n )\n }\n)\nCheckbox.displayName = \"Checkbox\"\n\nexport { Checkbox } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Radio 컴포넌트의 props / Radio component props\n * @typedef {Object} RadioProps\n * @property {\"default\" | \"outline\" | \"filled\" | \"glass\"} [variant=\"default\"] - Radio 스타일 변형 / Radio style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Radio 크기 / Radio size\n * @property {boolean} [error=false] - 에러 상태 표시 / Error state\n * @property {boolean} [success=false] - 성공 상태 표시 / Success state\n * @property {string} [label] - 라디오 버튼 레이블 텍스트 / Radio button label text\n * @property {string} [description] - 라디오 버튼 설명 텍스트 / Radio button description text\n * @extends {Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size'>}\n */\nexport interface RadioProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size'> {\n variant?: \"default\" | \"outline\" | \"filled\" | \"glass\"\n size?: \"sm\" | \"md\" | \"lg\"\n error?: boolean\n success?: boolean\n label?: string\n description?: string\n}\n\n/**\n * Radio 컴포넌트 / Radio component\n * \n * 라디오 버튼 입력 필드를 제공하는 컴포넌트입니다.\n * 같은 name 속성을 가진 여러 Radio는 그룹으로 동작합니다.\n * ARIA 속성을 자동으로 설정하여 접근성을 지원합니다.\n * \n * Radio button input field component.\n * Multiple Radio components with the same name attribute work as a group.\n * Automatically sets ARIA attributes for accessibility support.\n * \n * @component\n * @example\n * // 기본 사용 (그룹) / Basic usage (group)\n * <Radio name=\"option\" value=\"1\" label=\"옵션 1\" />\n * <Radio name=\"option\" value=\"2\" label=\"옵션 2\" />\n * <Radio name=\"option\" value=\"3\" label=\"옵션 3\" />\n * \n * @example\n * // 에러 상태 / Error state\n * <Radio \n * name=\"gender\"\n * value=\"male\"\n * label=\"남성\"\n * error\n * />\n * \n * @param {RadioProps} props - Radio 컴포넌트의 props / Radio component props\n * @param {React.Ref<HTMLInputElement>} ref - input 요소 ref / input element ref\n * @returns {JSX.Element} Radio 컴포넌트 / Radio component\n */\nconst Radio = React.forwardRef<HTMLInputElement, RadioProps>(\n ({ \n className, \n variant = \"default\",\n size = \"md\",\n error = false,\n success = false,\n label,\n description,\n id,\n ...props \n }, ref) => {\n const radioId = id || React.useId()\n const labelId = label ? `${radioId}-label` : undefined\n const descriptionId = description ? `${radioId}-description` : undefined\n const sizeClasses = {\n sm: \"w-4 h-4\",\n md: \"w-5 h-5\",\n lg: \"w-6 h-6\"\n }\n\n const dotSizes = {\n sm: \"w-1.5 h-1.5\",\n md: \"w-2 h-2\",\n lg: \"w-2.5 h-2.5\"\n }\n\n const variantClasses = {\n default: \"border-gray-300 bg-white text-blue-600 focus:ring-blue-500 dark:border-gray-600 dark:bg-gray-800 dark:focus:ring-blue-400\",\n outline: \"border-2 border-gray-200 bg-transparent text-blue-600 focus:ring-blue-500 dark:border-gray-700 dark:focus:ring-blue-400\",\n filled: \"border-transparent bg-gray-50 text-blue-600 focus:bg-white focus:ring-blue-500 dark:bg-gray-700 dark:focus:bg-gray-800 dark:focus:ring-blue-400\",\n glass: \"border-white/30 bg-white/10 backdrop-blur-sm text-white focus:ring-blue-400/50 focus:bg-white/20 dark:border-slate-600/50 dark:bg-slate-800/10 dark:focus:ring-blue-400/50 dark:focus:bg-slate-700/20\"\n }\n\n const stateClasses = error \n ? \"border-red-500 focus:ring-red-500 dark:border-red-400 dark:focus:ring-red-400\"\n : success\n ? \"border-green-500 focus:ring-green-500 dark:border-green-400 dark:focus:ring-green-400\"\n : \"\"\n\n return (\n <div className=\"flex items-start space-x-3\">\n <div className=\"relative\">\n <input\n type=\"radio\"\n id={radioId}\n className={merge(\n \"peer sr-only\",\n className\n )}\n ref={ref}\n aria-checked={props.checked ?? false}\n aria-invalid={error}\n aria-label={!label ? props['aria-label'] : undefined}\n aria-labelledby={label ? labelId : undefined}\n aria-describedby={descriptionId}\n role=\"radio\"\n {...props}\n />\n <div\n className={merge(\n \"flex items-center justify-center rounded-full border transition-all duration-200 cursor-pointer\",\n \"peer-focus:outline-none peer-focus:ring-2 peer-focus:ring-offset-2\",\n \"peer-disabled:cursor-not-allowed peer-disabled:opacity-50\",\n sizeClasses[size],\n variantClasses[variant],\n stateClasses,\n \"peer-checked:border-blue-600 dark:peer-checked:border-blue-500\"\n )}\n >\n <div\n className={merge(\n \"rounded-full bg-blue-600 dark:bg-blue-500 opacity-0 peer-checked:opacity-100 transition-opacity duration-200\",\n dotSizes[size]\n )}\n />\n </div>\n </div>\n {(label || description) && (\n <div className=\"flex flex-col\">\n {label && (\n <label htmlFor={radioId} id={labelId} className=\"text-sm font-medium text-gray-900 dark:text-white cursor-pointer\">\n {label}\n </label>\n )}\n {description && (\n <p id={descriptionId} className=\"text-sm text-gray-500 dark:text-gray-400\">\n {description}\n </p>\n )}\n </div>\n )}\n </div>\n )\n }\n)\nRadio.displayName = \"Radio\"\n\nexport { Radio } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\n\n/**\n * Select 컴포넌트의 props / Select component props\n * @typedef {Object} SelectProps\n * @property {\"default\" | \"outline\" | \"filled\" | \"ghost\" | \"glass\"} [variant=\"default\"] - Select 스타일 변형 / Select style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Select 크기 / Select size\n * @property {boolean} [error=false] - 에러 상태 표시 / Error state\n * @property {boolean} [success=false] - 성공 상태 표시 / Success state\n * @property {React.ReactNode} [leftIcon] - 왼쪽 아이콘 / Left icon\n * @property {string} [placeholder] - 플레이스홀더 텍스트 / Placeholder text\n * @extends {Omit<React.SelectHTMLAttributes<HTMLSelectElement>, 'size'>}\n */\nexport interface SelectProps extends Omit<React.SelectHTMLAttributes<HTMLSelectElement>, 'size'> {\n variant?: \"default\" | \"outline\" | \"filled\" | \"ghost\" | \"glass\"\n size?: \"sm\" | \"md\" | \"lg\"\n error?: boolean\n success?: boolean\n leftIcon?: React.ReactNode\n placeholder?: string\n}\n\n/**\n * SelectOption 컴포넌트의 props / SelectOption component props\n * @typedef {Object} SelectOptionProps\n * @property {string} value - 옵션 값 / Option value\n * @property {React.ReactNode} children - 옵션 표시 텍스트 / Option display text\n * @extends {React.OptionHTMLAttributes<HTMLOptionElement>}\n */\nexport interface SelectOptionProps extends React.OptionHTMLAttributes<HTMLOptionElement> {\n value: string\n children: React.ReactNode\n}\n\n/**\n * Select 컴포넌트 / Select component\n * \n * 드롭다운 선택 메뉴를 제공하는 컴포넌트입니다.\n * 다양한 스타일 변형과 크기를 지원하며, 접근성 속성을 포함합니다.\n * \n * Dropdown selection menu component.\n * Supports various style variants and sizes, includes accessibility attributes.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Select>\n * <option value=\"option1\">옵션 1</option>\n * <option value=\"option2\">옵션 2</option>\n * </Select>\n * \n * @example\n * // 에러 상태와 아이콘 / Error state with icon\n * <Select \n * error \n * leftIcon={<Icon name=\"alert\" />}\n * aria-label=\"국가 선택\"\n * >\n * <option value=\"\">국가를 선택하세요</option>\n * <option value=\"kr\">한국</option>\n * <option value=\"us\">미국</option>\n * </Select>\n * \n * @example\n * // 다양한 변형 / Various variants\n * <Select variant=\"outline\" size=\"lg\">\n * <option value=\"1\">항목 1</option>\n * </Select>\n * \n * @param {SelectProps} props - Select 컴포넌트의 props / Select component props\n * @param {React.Ref<HTMLSelectElement>} ref - select 요소 ref / select element ref\n * @returns {JSX.Element} Select 컴포넌트 / Select component\n */\nconst Select = React.forwardRef<HTMLSelectElement, SelectProps>(\n ({ \n className, \n variant = \"default\",\n size = \"md\",\n error = false,\n success = false,\n leftIcon,\n placeholder,\n children,\n \"aria-label\": ariaLabel,\n \"aria-invalid\": ariaInvalid,\n ...props \n }, ref) => {\n const variantClasses = {\n default: \"border-gray-300 bg-white text-gray-900 focus:border-blue-500 focus:ring-blue-500 dark:border-gray-600 dark:bg-gray-800 dark:text-white dark:focus:border-blue-400 dark:focus:ring-blue-400\",\n outline: \"border-2 border-gray-200 bg-transparent text-gray-900 focus:border-blue-500 focus:ring-blue-500 dark:border-gray-700 dark:text-white dark:focus:border-blue-400 dark:focus:ring-blue-400\",\n filled: \"border-transparent bg-gray-50 text-gray-900 focus:bg-white focus:border-blue-500 focus:ring-blue-500 dark:bg-gray-700 dark:text-white dark:focus:bg-gray-800 dark:focus:border-blue-400 dark:focus:ring-blue-400\",\n ghost: \"border-transparent bg-transparent text-gray-900 focus:bg-gray-50 focus:border-gray-300 focus:ring-gray-500 dark:text-white dark:focus:bg-gray-800 dark:focus:border-gray-600 dark:focus:ring-gray-400\",\n glass: \"border-white/30 bg-white/10 backdrop-blur-sm text-white focus:border-blue-400/50 focus:ring-blue-400/20 focus:bg-white/20 dark:border-slate-600/50 dark:bg-slate-800/10 dark:text-slate-200 dark:focus:border-blue-400/50 dark:focus:ring-blue-400/20 dark:focus:bg-slate-700/20\"\n }\n\n const sizeClasses = {\n sm: \"h-8 px-3 text-sm\",\n md: \"h-10 px-4 text-base\",\n lg: \"h-12 px-4 text-lg\"\n }\n\n const stateClasses = error \n ? \"border-red-500 focus:border-red-500 focus:ring-red-500 dark:border-red-400 dark:focus:border-red-400 dark:focus:ring-red-400\"\n : success\n ? \"border-green-500 focus:border-green-500 focus:ring-green-500 dark:border-green-400 dark:focus:border-green-400 dark:focus:ring-green-400\"\n : \"\"\n\n const selectRef = React.useRef<HTMLSelectElement>(null)\n const combinedRef = React.useCallback((node: HTMLSelectElement | null) => {\n selectRef.current = node\n if (typeof ref === 'function') {\n ref(node)\n } else if (ref) {\n (ref as React.MutableRefObject<HTMLSelectElement | null>).current = node\n }\n }, [ref])\n \n const [isFocused, setIsFocused] = React.useState(false)\n\n return (\n <div className=\"relative\">\n {leftIcon && (\n <div className=\"absolute left-3 top-1/2 transform -translate-y-1/2 text-gray-400 dark:text-gray-500 pointer-events-none z-10\">\n {leftIcon}\n </div>\n )}\n <select\n ref={combinedRef}\n className={merge(\n \"flex w-full appearance-none rounded-md border transition-all duration-200\",\n \"focus:outline-none focus:ring-2 focus:ring-offset-2\",\n \"hover:border-blue-400 hover:shadow-sm\",\n \"disabled:cursor-not-allowed disabled:opacity-50 disabled:hover:border-gray-300\",\n variantClasses[variant],\n sizeClasses[size],\n stateClasses,\n leftIcon ? \"pl-10\" : \"\",\n \"pr-10\", // 화살표 아이콘을 위한 공간\n className\n )}\n aria-label={ariaLabel || (placeholder ? undefined : \"선택\")}\n aria-invalid={ariaInvalid !== undefined ? ariaInvalid : (error || undefined)}\n onFocus={(e) => {\n setIsFocused(true)\n props.onFocus?.(e)\n }}\n onBlur={(e) => {\n setIsFocused(false)\n props.onBlur?.(e)\n }}\n {...props}\n >\n {placeholder && (\n <option value=\"\" disabled>\n {placeholder}\n </option>\n )}\n {children}\n </select>\n <div className={merge(\n \"absolute right-3 top-1/2 transform -translate-y-1/2 text-gray-400 dark:text-gray-500 pointer-events-none transition-transform duration-200\",\n isFocused && \"rotate-180\"\n )}>\n <Icon name=\"chevronDown\" size={16} />\n </div>\n </div>\n )\n }\n)\nSelect.displayName = \"Select\"\n\nconst SelectOption = React.forwardRef<HTMLOptionElement, SelectOptionProps>(\n ({ className, ...props }, ref) => (\n <option\n className={className || \"\"}\n ref={ref}\n {...props}\n />\n )\n)\nSelectOption.displayName = \"SelectOption\"\n\nexport { Select, SelectOption } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Switch 컴포넌트의 props / Switch component props\n * @typedef {Object} SwitchProps\n * @property {\"default\" | \"outline\" | \"filled\" | \"glass\"} [variant=\"default\"] - Switch 스타일 변형 / Switch style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Switch 크기 / Switch size\n * @property {boolean} [error=false] - 에러 상태 표시 / Error state\n * @property {boolean} [success=false] - 성공 상태 표시 / Success state\n * @property {string} [label] - 스위치 레이블 텍스트 / Switch label text\n * @property {string} [description] - 스위치 설명 텍스트 / Switch description text\n * @extends {Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size'>}\n */\nexport interface SwitchProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size'> {\n variant?: \"default\" | \"outline\" | \"filled\" | \"glass\"\n size?: \"sm\" | \"md\" | \"lg\"\n error?: boolean\n success?: boolean\n label?: string\n description?: string\n}\n\n/**\n * Switch 컴포넌트 / Switch component\n * \n * 토글 스위치 입력 필드를 제공하는 컴포넌트입니다.\n * ARIA 속성을 자동으로 설정하여 접근성을 지원합니다.\n * \n * Toggle switch input field component.\n * Automatically sets ARIA attributes for accessibility support.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Switch label=\"알림 받기\" />\n * \n * @example\n * // 제어 컴포넌트 / Controlled component\n * const [enabled, setEnabled] = useState(false)\n * <Switch \n * checked={enabled}\n * onChange={(e) => setEnabled(e.target.checked)}\n * label=\"다크 모드\"\n * />\n * \n * @example\n * // 에러 상태 / Error state\n * <Switch \n * label=\"필수 설정\"\n * description=\"이 설정을 활성화해야 합니다\"\n * error\n * />\n * \n * @param {SwitchProps} props - Switch 컴포넌트의 props / Switch component props\n * @param {React.Ref<HTMLInputElement>} ref - input 요소 ref / input element ref\n * @returns {JSX.Element} Switch 컴포넌트 / Switch component\n */\nconst Switch = React.forwardRef<HTMLInputElement, SwitchProps>(\n ({ \n className, \n variant = \"default\",\n size = \"md\",\n error = false,\n success = false,\n label,\n description,\n id,\n ...props \n }, ref) => {\n const switchId = id || React.useId()\n const labelId = label ? `${switchId}-label` : undefined\n const descriptionId = description ? `${switchId}-description` : undefined\n const sizeClasses = {\n sm: \"w-8 h-4\",\n md: \"w-11 h-6\",\n lg: \"w-14 h-7\"\n }\n\n const thumbSizes = {\n sm: \"w-3 h-3\",\n md: \"w-5 h-5\",\n lg: \"w-6 h-6\"\n }\n\n const variantClasses = {\n default: \"bg-gray-200 peer-checked:bg-blue-600 dark:bg-gray-700 dark:peer-checked:bg-blue-500\",\n outline: \"bg-transparent border-2 border-gray-300 peer-checked:border-blue-600 peer-checked:bg-blue-600 dark:border-gray-600 dark:peer-checked:border-blue-500 dark:peer-checked:bg-blue-500\",\n filled: \"bg-gray-100 peer-checked:bg-blue-600 dark:bg-gray-800 dark:peer-checked:bg-blue-500\",\n glass: \"bg-white/20 backdrop-blur-sm border border-white/30 peer-checked:bg-blue-400/50 peer-checked:border-blue-300/50 dark:bg-slate-800/20 dark:border-slate-700/50 dark:peer-checked:bg-blue-400/50 dark:peer-checked:border-blue-300/50\"\n }\n\n const stateClasses = error \n ? \"bg-red-200 peer-checked:bg-red-600 dark:bg-red-800 dark:peer-checked:bg-red-500\"\n : success\n ? \"bg-green-200 peer-checked:bg-green-600 dark:bg-green-800 dark:peer-checked:bg-green-500\"\n : \"\"\n\n return (\n <div className=\"flex items-start space-x-3\">\n <div className=\"relative\">\n <input\n type=\"checkbox\"\n id={switchId}\n className={merge(\n \"peer sr-only\",\n className\n )}\n ref={ref}\n aria-checked={props.checked ?? false}\n aria-invalid={error}\n aria-label={!label ? props['aria-label'] : undefined}\n aria-labelledby={label ? labelId : undefined}\n aria-describedby={descriptionId}\n role=\"switch\"\n {...props}\n />\n <div\n className={merge(\n \"relative inline-flex cursor-pointer items-center rounded-full transition-colors duration-200 ease-in-out\",\n \"peer-focus:outline-none peer-focus:ring-2 peer-focus:ring-blue-500 peer-focus:ring-offset-2\",\n \"peer-disabled:cursor-not-allowed peer-disabled:opacity-50\",\n sizeClasses[size],\n variantClasses[variant],\n stateClasses\n )}\n >\n <div\n className={merge(\n \"pointer-events-none block rounded-full bg-white shadow-lg ring-0 transition-transform duration-200 ease-in-out\",\n \"peer-checked:translate-x-full\",\n thumbSizes[size],\n size === \"sm\" ? \"translate-x-0.5 peer-checked:translate-x-4.5\" : \"\",\n size === \"md\" ? \"translate-x-0.5 peer-checked:translate-x-5.5\" : \"\",\n size === \"lg\" ? \"translate-x-0.5 peer-checked:translate-x-7\" : \"\"\n )}\n />\n </div>\n </div>\n {(label || description) && (\n <div className=\"flex flex-col\">\n {label && (\n <label htmlFor={switchId} id={labelId} className=\"text-sm font-medium text-gray-900 dark:text-white cursor-pointer\">\n {label}\n </label>\n )}\n {description && (\n <p id={descriptionId} className=\"text-sm text-gray-500 dark:text-gray-400\">\n {description}\n </p>\n )}\n </div>\n )}\n </div>\n )\n }\n)\nSwitch.displayName = \"Switch\"\n\nexport { Switch } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Slider 컴포넌트의 props\n * @typedef {Object} SliderProps\n * @property {\"default\" | \"primary\" | \"success\" | \"warning\" | \"danger\"} [variant=\"default\"] - Slider 스타일 변형\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Slider 크기\n * @property {boolean} [showValue=false] - 현재 값 표시 여부\n * @property {boolean} [showLabel=false] - 라벨 표시 여부\n * @property {string} [label] - 라벨 텍스트\n * @property {number} [min=0] - 최소값\n * @property {number} [max=100] - 최대값\n * @property {number} [step=1] - 단계값\n * @property {number | number[]} [value=0] - 현재 값 (배열이면 범위 슬라이더)\n * @property {(value: number | number[]) => void} [onValueChange] - 값 변경 콜백\n * @property {\"horizontal\" | \"vertical\"} [orientation=\"horizontal\"] - Slider 방향\n * @property {boolean} [disabled=false] - 비활성화 여부\n * @property {string} [className] - 추가 CSS 클래스\n * @extends {Omit<React.InputHTMLAttributes<HTMLInputElement>, 'type' | 'value' | 'onChange' | 'size'>}\n */\nexport interface SliderProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'type' | 'value' | 'onChange' | 'size'> {\n variant?: \"default\" | \"primary\" | \"success\" | \"warning\" | \"danger\"\n size?: \"sm\" | \"md\" | \"lg\"\n showValue?: boolean\n showLabel?: boolean\n label?: string\n min?: number\n max?: number\n step?: number\n value?: number | number[]\n onValueChange?: (value: number | number[]) => void\n orientation?: \"horizontal\" | \"vertical\"\n disabled?: boolean\n className?: string\n}\n\n/**\n * Slider 컴포넌트 / Slider component\n * \n * 숫자 값을 선택하는 슬라이더 컴포넌트입니다.\n * 단일 값 또는 범위 값을 선택할 수 있습니다.\n * \n * Slider component for selecting numeric values.\n * Supports single value or range value selection.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * const [value, setValue] = useState(50)\n * <Slider value={value} onValueChange={setValue} />\n * \n * @example\n * // 범위 슬라이더 / Range slider\n * const [range, setRange] = useState([20, 80])\n * <Slider \n * value={range} \n * onValueChange={setRange}\n * showValue\n * label=\"가격 범위\"\n * />\n * \n * @example\n * // 세로 슬라이더 / Vertical slider\n * <Slider \n * orientation=\"vertical\"\n * variant=\"primary\"\n * size=\"lg\"\n * className=\"h-64\"\n * />\n * \n * @param {SliderProps} props - Slider 컴포넌트의 props / Slider component props\n * @param {React.Ref<HTMLInputElement>} ref - input 요소 ref / input element ref\n * @returns {JSX.Element} Slider 컴포넌트 / Slider component\n */\nconst Slider = React.forwardRef<HTMLInputElement, SliderProps>(\n ({ \n className,\n variant = \"default\",\n size = \"md\",\n showValue = false,\n showLabel = false,\n label,\n min = 0,\n max = 100,\n step = 1,\n value = 0,\n onValueChange,\n orientation = \"horizontal\",\n disabled = false,\n ...props \n }, ref) => {\n const isRange = Array.isArray(value)\n const currentValue = isRange ? value : [value]\n \n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const newValue = parseFloat(e.target.value)\n if (onValueChange) {\n if (isRange) {\n // 범위 슬라이더의 경우, 어떤 슬라이더가 변경되었는지 확인\n const index = parseInt(e.target.dataset.index || \"0\")\n const newRange = [...currentValue]\n newRange[index] = newValue\n onValueChange(newRange)\n } else {\n onValueChange(newValue)\n }\n }\n }\n\n const variantClasses = {\n default: \"bg-gray-200 dark:bg-gray-700\",\n primary: \"bg-blue-200 dark:bg-blue-700\",\n success: \"bg-green-200 dark:bg-green-700\",\n warning: \"bg-yellow-200 dark:bg-yellow-700\",\n danger: \"bg-red-200 dark:bg-red-700\"\n }\n\n const thumbVariantClasses = {\n default: \"bg-gray-400 hover:bg-gray-500 dark:bg-gray-500 dark:hover:bg-gray-400\",\n primary: \"bg-blue-500 hover:bg-blue-600 dark:bg-blue-400 dark:hover:bg-blue-500\",\n success: \"bg-green-500 hover:bg-green-600 dark:bg-green-400 dark:hover:bg-green-500\",\n warning: \"bg-yellow-500 hover:bg-yellow-600 dark:bg-yellow-400 dark:hover:bg-yellow-500\",\n danger: \"bg-red-500 hover:bg-red-600 dark:bg-red-400 dark:hover:bg-red-500\"\n }\n\n const sizeClasses = {\n sm: orientation === \"horizontal\" ? \"h-1\" : \"w-1\",\n md: orientation === \"horizontal\" ? \"h-2\" : \"w-2\",\n lg: orientation === \"horizontal\" ? \"h-3\" : \"w-3\"\n }\n\n const thumbSizeClasses = {\n sm: \"w-3 h-3\",\n md: \"w-4 h-4\",\n lg: \"w-6 h-6\"\n }\n\n const orientationClasses = orientation === \"vertical\" \n ? \"flex-col h-full\" \n : \"flex-row w-full\"\n\n const renderSlider = (index: number = 0) => (\n <input\n key={index}\n ref={index === 0 ? ref : undefined}\n type=\"range\"\n min={min}\n max={max}\n step={step}\n value={currentValue[index]}\n onChange={handleChange}\n data-index={index}\n disabled={disabled}\n className={merge(\n \"appearance-none cursor-pointer rounded-full transition-all duration-200 focus:outline-none focus:ring-2 focus:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50\",\n sizeClasses[size],\n variantClasses[variant],\n orientation === \"vertical\" ? \"writing-mode: bt-lr; -webkit-appearance: slider-vertical\" : \"\",\n className\n )}\n style={{\n ...(orientation === \"vertical\" && {\n writingMode: \"vertical-rl\" as const,\n WebkitAppearance: \"slider-vertical\"\n })\n }}\n {...props}\n />\n )\n\n const renderValue = () => {\n if (!showValue) return null\n \n if (isRange) {\n return (\n <div className=\"flex gap-2 text-sm text-gray-600 dark:text-gray-400\">\n {currentValue.map((val, index) => (\n <span key={index} className=\"font-mono\">\n {val}\n </span>\n ))}\n </div>\n )\n }\n \n return (\n <span className=\"text-sm font-mono text-gray-600 dark:text-gray-400\">\n {currentValue[0]}\n </span>\n )\n }\n\n return (\n <div className={merge(\"flex items-center gap-4\", orientationClasses)}>\n {showLabel && label && (\n <label className=\"text-sm font-medium text-gray-700 dark:text-gray-300 min-w-0\">\n {label}\n </label>\n )}\n \n <div className=\"flex-1 relative\">\n <div className={merge(\"relative\", orientation === \"vertical\" ? \"h-full\" : \"w-full\")}>\n {/* 배경 트랙 */}\n <div className={merge(\n \"absolute rounded-full\",\n sizeClasses[size],\n variantClasses[variant],\n orientation === \"vertical\" ? \"w-full bottom-0\" : \"h-full left-0\"\n )} />\n \n {/* 활성 트랙 (값에 따른 채워진 부분) */}\n {isRange ? (\n // 범위 슬라이더\n <div className={merge(\n \"absolute rounded-full bg-blue-500 dark:bg-blue-400\",\n sizeClasses[size],\n orientation === \"vertical\" \n ? \"w-full bottom-0\" \n : \"h-full left-0\"\n )} style={{\n ...(orientation === \"vertical\" \n ? {\n bottom: `${(currentValue[0] - min) / (max - min) * 100}%`,\n height: `${(currentValue[1] - currentValue[0]) / (max - min) * 100}%`\n }\n : {\n left: `${(currentValue[0] - min) / (max - min) * 100}%`,\n width: `${(currentValue[1] - currentValue[0]) / (max - min) * 100}%`\n }\n )\n }} />\n ) : (\n // 단일 슬라이더\n <div className={merge(\n \"absolute rounded-full bg-blue-500 dark:bg-blue-400\",\n sizeClasses[size],\n orientation === \"vertical\" \n ? \"w-full bottom-0\" \n : \"h-full left-0\"\n )} style={{\n ...(orientation === \"vertical\"\n ? { height: `${(currentValue[0] - min) / (max - min) * 100}%` }\n : { width: `${(currentValue[0] - min) / (max - min) * 100}%` }\n )\n }} />\n )}\n \n {/* 슬라이더 핸들들 */}\n {isRange ? (\n // 범위 슬라이더 핸들\n currentValue.map((_, index) => (\n <div\n key={index}\n className={merge(\n \"absolute rounded-full border-2 border-white shadow-lg transition-all duration-200 hover:scale-110\",\n thumbSizeClasses[size],\n thumbVariantClasses[variant],\n orientation === \"vertical\" \n ? \"left-1/2 transform -translate-x-1/2\" \n : \"top-1/2 transform -translate-y-1/2\"\n )}\n style={{\n ...(orientation === \"vertical\"\n ? { bottom: `${(currentValue[index] - min) / (max - min) * 100}%` }\n : { left: `${(currentValue[index] - min) / (max - min) * 100}%` }\n )\n }}\n />\n ))\n ) : (\n // 단일 슬라이더 핸들\n <div\n className={merge(\n \"absolute rounded-full border-2 border-white shadow-lg transition-all duration-200 hover:scale-110\",\n thumbSizeClasses[size],\n thumbVariantClasses[variant],\n orientation === \"vertical\" \n ? \"left-1/2 transform -translate-x-1/2\" \n : \"top-1/2 transform -translate-y-1/2\"\n )}\n style={{\n ...(orientation === \"vertical\"\n ? { bottom: `${(currentValue[0] - min) / (max - min) * 100}%` }\n : { left: `${(currentValue[0] - min) / (max - min) * 100}%` }\n )\n }}\n />\n )}\n </div>\n \n {/* 실제 input 요소들 (숨김) */}\n <div className=\"absolute inset-0 opacity-0\">\n {isRange ? (\n currentValue.map((_, index) => renderSlider(index))\n ) : (\n renderSlider()\n )}\n </div>\n </div>\n \n {renderValue()}\n </div>\n )\n }\n)\nSlider.displayName = \"Slider\"\n\nexport { Slider }\n","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Textarea 컴포넌트의 props / Textarea component props\n * @typedef {Object} TextareaProps\n * @property {\"default\" | \"outline\" | \"filled\" | \"ghost\" | \"glass\"} [variant=\"default\"] - Textarea 스타일 변형 / Textarea style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Textarea 크기 / Textarea size\n * @property {boolean} [error=false] - 에러 상태 표시 / Error state\n * @property {boolean} [success=false] - 성공 상태 표시 / Success state\n * @property {\"none\" | \"vertical\" | \"horizontal\" | \"both\"} [resize=\"vertical\"] - 크기 조절 방향 / Resize direction\n * @extends {React.TextareaHTMLAttributes<HTMLTextAreaElement>}\n */\nexport interface TextareaProps extends React.TextareaHTMLAttributes<HTMLTextAreaElement> {\n variant?: \"default\" | \"outline\" | \"filled\" | \"ghost\" | \"glass\"\n size?: \"sm\" | \"md\" | \"lg\"\n error?: boolean\n success?: boolean\n resize?: \"none\" | \"vertical\" | \"horizontal\" | \"both\"\n}\n\n/**\n * Textarea 컴포넌트 / Textarea component\n * \n * 여러 줄 텍스트 입력을 위한 텍스트 영역 컴포넌트입니다.\n * 다양한 스타일 변형과 크기를 지원하며, 접근성 속성을 포함합니다.\n * \n * Text area component for multi-line text input.\n * Supports various style variants and sizes, includes accessibility attributes.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Textarea placeholder=\"내용을 입력하세요\" />\n * \n * @example\n * // 에러 상태 / Error state\n * <Textarea \n * error\n * placeholder=\"에러가 발생했습니다\"\n * aria-label=\"설명 입력\"\n * />\n * \n * @example\n * // 크기 조절 비활성화 / Disable resize\n * <Textarea \n * resize=\"none\"\n * rows={5}\n * placeholder=\"고정 크기 텍스트 영역\"\n * />\n * \n * @param {TextareaProps} props - Textarea 컴포넌트의 props / Textarea component props\n * @param {React.Ref<HTMLTextAreaElement>} ref - textarea 요소 ref / textarea element ref\n * @returns {JSX.Element} Textarea 컴포넌트 / Textarea component\n * \n * @todo 접근성 개선: aria-invalid 속성 자동 추가 필요 / Accessibility improvement: auto-add aria-invalid attribute\n */\nconst Textarea = React.forwardRef<HTMLTextAreaElement, TextareaProps>(\n ({ \n className, \n variant = \"default\",\n size = \"md\",\n error = false,\n success = false,\n resize = \"vertical\",\n ...props \n }, ref) => {\n const variantClasses = {\n default: \"border-gray-300 bg-white text-gray-900 placeholder-gray-500 focus:border-blue-500 focus:ring-blue-500 dark:border-gray-600 dark:bg-gray-800 dark:text-white dark:placeholder-gray-400 dark:focus:border-blue-400 dark:focus:ring-blue-400 transition-all duration-200 hover:border-blue-400 hover:shadow-sm\",\n outline: \"border-2 border-gray-200 bg-transparent text-gray-900 placeholder-gray-500 focus:border-blue-500 focus:ring-blue-500 dark:border-gray-700 dark:text-white dark:placeholder-gray-400 dark:focus:border-blue-400 dark:focus:ring-blue-400 transition-all duration-200 hover:border-blue-400 hover:shadow-sm\",\n filled: \"border-transparent bg-gray-50 text-gray-900 placeholder-gray-500 focus:bg-white focus:border-blue-500 focus:ring-blue-500 dark:bg-gray-700 dark:text-white dark:placeholder-gray-400 dark:focus:bg-gray-800 dark:focus:border-blue-400 dark:focus:ring-blue-400 transition-all duration-200 hover:bg-gray-100 dark:hover:bg-gray-600\",\n ghost: \"border-transparent bg-transparent text-gray-900 placeholder-gray-500 focus:bg-gray-50 focus:border-gray-300 focus:ring-gray-500 dark:text-white dark:placeholder-gray-400 dark:focus:bg-gray-800 dark:focus:border-gray-600 dark:focus:ring-gray-400 transition-all duration-200 hover:bg-gray-50 dark:hover:bg-gray-800\",\n glass: \"border-white/30 bg-white/10 backdrop-blur-sm text-white placeholder-white/60 focus:border-blue-400/50 focus:ring-blue-400/20 focus:bg-white/20 dark:border-slate-600/50 dark:bg-slate-800/10 dark:text-slate-200 dark:placeholder-slate-400 dark:focus:border-blue-400/50 dark:focus:ring-blue-400/20 dark:focus:bg-slate-700/20 transition-all duration-200 hover:border-blue-400/40 hover:bg-white/15 dark:hover:bg-slate-700/15\"\n }\n\n const sizeClasses = {\n sm: \"px-3 py-2 text-sm min-h-[80px]\",\n md: \"px-4 py-3 text-base min-h-[100px]\",\n lg: \"px-4 py-3 text-lg min-h-[120px]\"\n }\n\n const resizeClasses = {\n none: \"resize-none\",\n vertical: \"resize-y\",\n horizontal: \"resize-x\",\n both: \"resize\"\n }\n\n const stateClasses = error \n ? \"border-red-500 focus:border-red-500 focus:ring-red-500 dark:border-red-400 dark:focus:border-red-400 dark:focus:ring-red-400\"\n : success\n ? \"border-green-500 focus:border-green-500 focus:ring-green-500 dark:border-green-400 dark:focus:border-green-400 dark:focus:ring-green-400\"\n : \"\"\n \n // aria-invalid 자동 설정\n // Auto-set aria-invalid\n const ariaInvalid = props['aria-invalid' as keyof typeof props] as boolean | undefined\n const isInvalid = error || (ariaInvalid !== undefined ? ariaInvalid : false)\n\n return (\n <textarea\n className={merge(\n \"flex w-full rounded-md border transition-colors duration-200 focus:outline-none focus:ring-2 focus:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50\",\n variantClasses[variant],\n sizeClasses[size],\n resizeClasses[resize],\n stateClasses,\n className\n )}\n ref={ref}\n aria-invalid={isInvalid || undefined}\n {...props}\n />\n )\n }\n)\nTextarea.displayName = \"Textarea\"\n\nexport { Textarea } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\nimport { Popover } from \"./Popover\"\nimport { Button } from \"./Button\"\n\n/**\n * DatePicker 컴포넌트의 props / DatePicker component props\n * @typedef {Object} DatePickerProps\n * @property {Date | null} [value] - 선택된 날짜 / Selected date\n * @property {(date: Date | null) => void} [onChange] - 날짜 변경 핸들러 / Date change handler\n * @property {Date} [minDate] - 최소 날짜 / Minimum date\n * @property {Date} [maxDate] - 최대 날짜 / Maximum date\n * @property {string} [placeholder=\"날짜를 선택하세요\"] - 플레이스홀더 / Placeholder\n * @property {boolean} [disabled=false] - 비활성화 상태 / Disabled state\n * @property {boolean} [error=false] - 에러 상태 / Error state\n * @property {string} [dateFormat=\"YYYY-MM-DD\"] - 날짜 포맷 / Date format\n * @property {string} [locale=\"ko-KR\"] - 로케일 / Locale\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - 크기 / Size\n * @property {string} [className] - 추가 클래스명 / Additional class name\n * @extends {Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'>}\n */\nexport interface DatePickerProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'> {\n value?: Date | null\n onChange?: (date: Date | null) => void\n minDate?: Date\n maxDate?: Date\n placeholder?: string\n disabled?: boolean\n error?: boolean\n dateFormat?: string\n locale?: string\n size?: \"sm\" | \"md\" | \"lg\"\n className?: string\n}\n\nconst sizeClasses = {\n sm: \"h-8 text-sm px-3\",\n md: \"h-10 text-sm px-4\",\n lg: \"h-12 text-base px-5\",\n}\n\nconst formatDate = (date: Date | null, format: string = \"YYYY-MM-DD\", locale: string = \"ko-KR\"): string => {\n if (!date) return \"\"\n \n const year = date.getFullYear()\n const month = String(date.getMonth() + 1).padStart(2, \"0\")\n const day = String(date.getDate()).padStart(2, \"0\")\n \n return format\n .replace(\"YYYY\", String(year))\n .replace(\"MM\", month)\n .replace(\"DD\", day)\n}\n\nconst getDaysInMonth = (year: number, month: number): number => {\n return new Date(year, month + 1, 0).getDate()\n}\n\nconst getFirstDayOfMonth = (year: number, month: number): number => {\n return new Date(year, month, 1).getDay()\n}\n\n/**\n * DatePicker 컴포넌트 / DatePicker component\n * \n * 날짜를 선택할 수 있는 컴포넌트입니다.\n * 캘린더 팝오버를 통해 직관적으로 날짜를 선택할 수 있습니다.\n * \n * Component for selecting dates.\n * Allows intuitive date selection through a calendar popover.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <DatePicker\n * value={selectedDate}\n * onChange={setSelectedDate}\n * />\n * \n * @example\n * // 날짜 범위 제한 / Date range restriction\n * <DatePicker\n * value={date}\n * onChange={setDate}\n * minDate={new Date(\"2024-01-01\")}\n * maxDate={new Date(\"2024-12-31\")}\n * placeholder=\"날짜 선택\"\n * />\n * \n * @param {DatePickerProps} props - DatePicker 컴포넌트의 props / DatePicker component props\n * @returns {JSX.Element} DatePicker 컴포넌트 / DatePicker component\n */\nexport const DatePicker = React.forwardRef<HTMLDivElement, DatePickerProps>(\n (\n {\n value,\n onChange,\n minDate,\n maxDate,\n placeholder = \"날짜를 선택하세요\",\n disabled = false,\n error = false,\n dateFormat = \"YYYY-MM-DD\",\n locale = \"ko-KR\",\n size = \"md\",\n className,\n ...props\n },\n ref\n ) => {\n const [isOpen, setIsOpen] = React.useState(false)\n const [currentMonth, setCurrentMonth] = React.useState(value ? new Date(value.getFullYear(), value.getMonth()) : new Date())\n const [hoveredDate, setHoveredDate] = React.useState<Date | null>(null)\n\n const displayDate = value ? formatDate(value, dateFormat, locale) : \"\"\n\n const handleDateSelect = (date: Date) => {\n if (minDate && date < minDate) return\n if (maxDate && date > maxDate) return\n onChange?.(date)\n setIsOpen(false)\n }\n\n const handlePrevMonth = () => {\n setCurrentMonth(new Date(currentMonth.getFullYear(), currentMonth.getMonth() - 1))\n }\n\n const handleNextMonth = () => {\n setCurrentMonth(new Date(currentMonth.getFullYear(), currentMonth.getMonth() + 1))\n }\n\n const handleToday = () => {\n const today = new Date()\n today.setHours(0, 0, 0, 0)\n handleDateSelect(today)\n }\n\n const year = currentMonth.getFullYear()\n const month = currentMonth.getMonth()\n const daysInMonth = getDaysInMonth(year, month)\n const firstDay = getFirstDayOfMonth(year, month)\n\n const weekDays = locale === \"ko-KR\" \n ? [\"일\", \"월\", \"화\", \"수\", \"목\", \"금\", \"토\"]\n : [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"]\n\n const isDateDisabled = (date: Date): boolean => {\n if (minDate && date < minDate) return true\n if (maxDate && date > maxDate) return true\n return false\n }\n\n const isDateSelected = (date: Date): boolean => {\n if (!value) return false\n return (\n date.getFullYear() === value.getFullYear() &&\n date.getMonth() === value.getMonth() &&\n date.getDate() === value.getDate()\n )\n }\n\n const isToday = (date: Date): boolean => {\n const today = new Date()\n return (\n date.getFullYear() === today.getFullYear() &&\n date.getMonth() === today.getMonth() &&\n date.getDate() === today.getDate()\n )\n }\n\n const calendarDays: (Date | null)[] = []\n \n // 이전 달의 마지막 날들\n for (let i = firstDay - 1; i >= 0; i--) {\n const date = new Date(year, month, -i)\n calendarDays.push(date)\n }\n \n // 현재 달의 날들\n for (let day = 1; day <= daysInMonth; day++) {\n calendarDays.push(new Date(year, month, day))\n }\n \n // 다음 달의 첫 날들 (캘린더를 6주로 채우기)\n const remainingDays = 42 - calendarDays.length\n for (let day = 1; day <= remainingDays; day++) {\n calendarDays.push(new Date(year, month + 1, day))\n }\n\n const triggerButton = (\n <button\n type=\"button\"\n disabled={disabled}\n className={merge(\n \"flex w-full items-center justify-between rounded-lg border bg-white px-4 py-2 text-left text-sm transition-colors\",\n \"hover:bg-gray-50 focus:outline-none focus:ring-2 focus:ring-blue-500 focus:ring-offset-2\",\n \"dark:bg-gray-800 dark:border-gray-700 dark:hover:bg-gray-700\",\n error && \"border-red-500 focus:ring-red-500\",\n disabled && \"cursor-not-allowed opacity-50\",\n sizeClasses[size]\n )}\n aria-label={displayDate || placeholder}\n >\n <span className={merge(\"flex-1\", !displayDate && \"text-gray-400 dark:text-gray-500\")}>\n {displayDate || placeholder}\n </span>\n <Icon \n name=\"calendar\" \n className={merge(\n \"ml-2 h-4 w-4 transition-transform\",\n isOpen && \"rotate-180\"\n )} \n />\n </button>\n )\n\n return (\n <div ref={ref} className={merge(\"relative\", className)} {...props}>\n <Popover \n open={isOpen} \n onOpenChange={setIsOpen}\n trigger={triggerButton}\n position=\"bottom\"\n align=\"start\"\n >\n <div className=\"w-auto p-0\">\n <div className=\"p-4\">\n {/* 헤더 */}\n <div className=\"flex items-center justify-between mb-4\">\n <button\n type=\"button\"\n onClick={handlePrevMonth}\n className=\"rounded-lg p-2 hover:bg-gray-100 dark:hover:bg-gray-700 transition-colors\"\n aria-label=\"이전 달\"\n >\n <Icon name=\"chevronLeft\" className=\"h-4 w-4\" />\n </button>\n <div className=\"text-lg font-semibold text-gray-900 dark:text-white\">\n {year}년 {month + 1}월\n </div>\n <button\n type=\"button\"\n onClick={handleNextMonth}\n className=\"rounded-lg p-2 hover:bg-gray-100 dark:hover:bg-gray-700 transition-colors\"\n aria-label=\"다음 달\"\n >\n <Icon name=\"chevronRight\" className=\"h-4 w-4\" />\n </button>\n </div>\n\n {/* 요일 헤더 */}\n <div className=\"grid grid-cols-7 gap-1 mb-2\">\n {weekDays.map((day, index) => (\n <div\n key={index}\n className={merge(\n \"text-center text-xs font-medium py-2\",\n index === 0 && \"text-red-500 dark:text-red-400\",\n index === 6 && \"text-blue-500 dark:text-blue-400\"\n )}\n >\n {day}\n </div>\n ))}\n </div>\n\n {/* 캘린더 그리드 */}\n <div className=\"grid grid-cols-7 gap-1\">\n {calendarDays.map((date, index) => {\n if (!date) return <div key={index} />\n \n const isCurrentMonth = date.getMonth() === month\n const isDisabled = isDateDisabled(date)\n const isSelected = isDateSelected(date)\n const isTodayDate = isToday(date)\n const isHovered = hoveredDate && \n date.getFullYear() === hoveredDate.getFullYear() &&\n date.getMonth() === hoveredDate.getMonth() &&\n date.getDate() === hoveredDate.getDate()\n\n return (\n <button\n key={index}\n type=\"button\"\n disabled={isDisabled}\n onClick={() => handleDateSelect(date)}\n onMouseEnter={() => setHoveredDate(date)}\n onMouseLeave={() => setHoveredDate(null)}\n className={merge(\n \"relative h-9 w-9 rounded-lg text-sm font-medium transition-all\",\n \"hover:bg-blue-50 dark:hover:bg-blue-900/20\",\n \"focus:outline-none focus:ring-2 focus:ring-blue-500 focus:ring-offset-1\",\n !isCurrentMonth && \"text-gray-400 dark:text-gray-500\",\n isDisabled && \"cursor-not-allowed opacity-30\",\n isSelected && \"bg-blue-600 text-white hover:bg-blue-700 shadow-md\",\n isTodayDate && !isSelected && \"ring-2 ring-blue-500\",\n isHovered && !isSelected && \"bg-blue-100 dark:bg-blue-900/30\"\n )}\n aria-label={`${year}년 ${month + 1}월 ${date.getDate()}일`}\n >\n {date.getDate()}\n </button>\n )\n })}\n </div>\n\n {/* 오늘 버튼 */}\n <div className=\"mt-4 pt-4 border-t border-gray-200 dark:border-gray-700\">\n <Button\n variant=\"outline\"\n size=\"sm\"\n onClick={handleToday}\n className=\"w-full\"\n >\n 오늘\n </Button>\n </div>\n </div>\n </div>\n </Popover>\n </div>\n )\n }\n)\n\nDatePicker.displayName = \"DatePicker\"\n\n\n","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\nimport { Button } from \"./Button\"\nimport type { IconName } from \"../lib/icons\"\n\n/**\n * 업로드된 파일 정보 인터페이스 / Uploaded file information interface\n * @typedef {Object} UploadedFile\n * @property {string} id - 파일 고유 ID / File unique ID\n * @property {File} file - 파일 객체 / File object\n * @property {string} name - 파일 이름 / File name\n * @property {number} size - 파일 크기 (bytes) / File size in bytes\n * @property {string} type - 파일 타입 / File type\n * @property {number} [progress] - 업로드 진행률 (0-100) / Upload progress (0-100)\n * @property {\"pending\" | \"uploading\" | \"success\" | \"error\"} [status] - 업로드 상태 / Upload status\n * @property {string} [url] - 업로드된 파일 URL / Uploaded file URL\n * @property {string} [error] - 에러 메시지 / Error message\n */\nexport interface UploadedFile {\n id: string\n file: File\n name: string\n size: number\n type: string\n progress?: number\n status?: \"pending\" | \"uploading\" | \"success\" | \"error\"\n url?: string\n error?: string\n}\n\n/**\n * Upload 컴포넌트의 props / Upload component props\n * @typedef {Object} UploadProps\n * @property {UploadedFile[]} [files] - 업로드된 파일 목록 / Uploaded files list\n * @property {(files: File[]) => void} [onChange] - 파일 선택 핸들러 / File selection handler\n * @property {(file: UploadedFile) => void} [onRemove] - 파일 제거 핸들러 / File removal handler\n * @property {boolean} [multiple=false] - 다중 파일 선택 허용 / Allow multiple file selection\n * @property {string} [accept] - 허용할 파일 타입 (예: \"image/*\", \".pdf\") / Accepted file types\n * @property {number} [maxSize] - 최대 파일 크기 (bytes) / Maximum file size in bytes\n * @property {number} [maxFiles] - 최대 파일 개수 / Maximum number of files\n * @property {boolean} [disabled=false] - 비활성화 상태 / Disabled state\n * @property {boolean} [dragDrop=true] - 드래그 앤 드롭 활성화 / Enable drag and drop\n * @property {string} [placeholder=\"파일을 선택하거나 여기에 드래그하세요\"] - 플레이스홀더 / Placeholder\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - 크기 / Size\n * @property {string} [className] - 추가 클래스명 / Additional class name\n */\nexport interface UploadProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'> {\n files?: UploadedFile[]\n onChange?: (files: File[]) => void\n onRemove?: (file: UploadedFile) => void\n multiple?: boolean\n accept?: string\n maxSize?: number\n maxFiles?: number\n disabled?: boolean\n dragDrop?: boolean\n placeholder?: string\n size?: \"sm\" | \"md\" | \"lg\"\n className?: string\n}\n\nconst formatFileSize = (bytes: number): string => {\n if (bytes === 0) return \"0 Bytes\"\n const k = 1024\n const sizes = [\"Bytes\", \"KB\", \"MB\", \"GB\"]\n const i = Math.floor(Math.log(bytes) / Math.log(k))\n return Math.round(bytes / Math.pow(k, i) * 100) / 100 + \" \" + sizes[i]\n}\n\nconst getFileIcon = (type: string): IconName => {\n if (type.startsWith(\"image/\")) return \"image\"\n if (type.startsWith(\"video/\")) return \"video\"\n if (type.includes(\"pdf\")) return \"fileText\"\n if (type.includes(\"word\") || type.includes(\"document\")) return \"fileText\"\n if (type.includes(\"excel\") || type.includes(\"spreadsheet\")) return \"fileText\"\n return \"file\"\n}\n\n/**\n * Upload 컴포넌트 / Upload component\n * \n * 파일을 업로드할 수 있는 컴포넌트입니다.\n * 드래그 앤 드롭, 다중 파일 선택, 파일 크기 제한 등을 지원합니다.\n * \n * Component for uploading files.\n * Supports drag and drop, multiple file selection, file size limits, and more.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Upload\n * onChange={(files) => console.log(files)}\n * />\n * \n * @example\n * // 이미지만, 다중 선택 / Images only, multiple selection\n * <Upload\n * accept=\"image/*\"\n * multiple\n * maxSize={5 * 1024 * 1024} // 5MB\n * maxFiles={5}\n * files={uploadedFiles}\n * onRemove={(file) => handleRemove(file)}\n * />\n * \n * @param {UploadProps} props - Upload 컴포넌트의 props / Upload component props\n * @returns {JSX.Element} Upload 컴포넌트 / Upload component\n */\nexport const Upload = React.forwardRef<HTMLDivElement, UploadProps>(\n (\n {\n files = [],\n onChange,\n onRemove,\n multiple = false,\n accept,\n maxSize,\n maxFiles,\n disabled = false,\n dragDrop = true,\n placeholder = \"파일을 선택하거나 여기에 드래그하세요\",\n size = \"md\",\n className,\n ...props\n },\n ref\n ) => {\n const fileInputRef = React.useRef<HTMLInputElement>(null)\n const [isDragging, setIsDragging] = React.useState(false)\n\n const handleFileSelect = (selectedFiles: FileList | null) => {\n if (!selectedFiles || selectedFiles.length === 0) return\n\n const fileArray = Array.from(selectedFiles)\n \n // 파일 개수 체크\n if (maxFiles && files.length + fileArray.length > maxFiles) {\n alert(`최대 ${maxFiles}개의 파일만 업로드할 수 있습니다.`)\n return\n }\n\n // 파일 크기 체크\n const validFiles = fileArray.filter((file) => {\n if (maxSize && file.size > maxSize) {\n alert(`파일 크기는 ${formatFileSize(maxSize)}를 초과할 수 없습니다: ${file.name}`)\n return false\n }\n return true\n })\n\n if (validFiles.length > 0) {\n onChange?.(validFiles)\n }\n }\n\n const handleClick = () => {\n if (!disabled) {\n fileInputRef.current?.click()\n }\n }\n\n const handleDragOver = (e: React.DragEvent) => {\n e.preventDefault()\n if (!disabled && dragDrop) {\n setIsDragging(true)\n }\n }\n\n const handleDragLeave = (e: React.DragEvent) => {\n e.preventDefault()\n setIsDragging(false)\n }\n\n const handleDrop = (e: React.DragEvent) => {\n e.preventDefault()\n setIsDragging(false)\n if (!disabled && dragDrop) {\n handleFileSelect(e.dataTransfer.files)\n }\n }\n\n const handleRemove = (file: UploadedFile) => {\n onRemove?.(file)\n }\n\n const sizeClasses = {\n sm: \"p-4\",\n md: \"p-6\",\n lg: \"p-8\",\n }\n\n return (\n <div ref={ref} className={merge(\"w-full\", className)} {...props}>\n {/* 업로드 영역 */}\n <div\n onClick={handleClick}\n onDragOver={handleDragOver}\n onDragLeave={handleDragLeave}\n onDrop={handleDrop}\n className={merge(\n \"relative border-2 border-dashed rounded-xl transition-all cursor-pointer\",\n \"bg-gray-50 dark:bg-gray-900/50\",\n \"border-gray-300 dark:border-gray-700\",\n isDragging && \"border-blue-500 bg-blue-50 dark:bg-blue-900/20\",\n disabled && \"cursor-not-allowed opacity-50\",\n sizeClasses[size]\n )}\n >\n <input\n ref={fileInputRef}\n type=\"file\"\n multiple={multiple}\n accept={accept}\n disabled={disabled}\n onChange={(e) => handleFileSelect(e.target.files)}\n className=\"hidden\"\n aria-label=\"파일 선택\"\n />\n \n <div className=\"flex flex-col items-center justify-center text-center\">\n <div className={merge(\n \"rounded-full bg-blue-100 dark:bg-blue-900/30 p-4 mb-4\",\n isDragging && \"bg-blue-200 dark:bg-blue-900/50\"\n )}>\n <Icon \n name=\"upload\" \n className={merge(\n \"h-8 w-8 text-blue-600 dark:text-blue-400\",\n isDragging && \"scale-110\"\n )} \n />\n </div>\n <p className=\"text-sm font-medium text-gray-700 dark:text-gray-300 mb-1\">\n {placeholder}\n </p>\n <p className=\"text-xs text-gray-500 dark:text-gray-400\">\n {accept && `지원 형식: ${accept}`}\n {maxSize && ` • 최대 크기: ${formatFileSize(maxSize)}`}\n {maxFiles && ` • 최대 ${maxFiles}개`}\n </p>\n </div>\n </div>\n\n {/* 파일 목록 */}\n {files.length > 0 && (\n <div className=\"mt-4 space-y-2\">\n {files.map((file) => (\n <div\n key={file.id}\n className={merge(\n \"flex items-center gap-3 p-3 rounded-lg border\",\n \"bg-white dark:bg-gray-800\",\n \"border-gray-200 dark:border-gray-700\",\n file.status === \"error\" && \"border-red-300 dark:border-red-700 bg-red-50 dark:bg-red-900/20\"\n )}\n >\n <div className=\"flex-shrink-0\">\n <div className=\"rounded-lg bg-gray-100 dark:bg-gray-700 p-2\">\n <Icon \n name={getFileIcon(file.type)} \n className=\"h-5 w-5 text-gray-600 dark:text-gray-400\" \n />\n </div>\n </div>\n \n <div className=\"flex-1 min-w-0\">\n <p className=\"text-sm font-medium text-gray-900 dark:text-white truncate\">\n {file.name}\n </p>\n <div className=\"flex items-center gap-2 mt-1\">\n <p className=\"text-xs text-gray-500 dark:text-gray-400\">\n {formatFileSize(file.size)}\n </p>\n {file.status === \"uploading\" && file.progress !== undefined && (\n <>\n <div className=\"flex-1 h-1.5 bg-gray-200 dark:bg-gray-700 rounded-full overflow-hidden\">\n <div\n className=\"h-full bg-blue-600 transition-all duration-300\"\n style={{ width: `${file.progress}%` }}\n />\n </div>\n <span className=\"text-xs text-gray-500 dark:text-gray-400\">\n {file.progress}%\n </span>\n </>\n )}\n {file.status === \"success\" && (\n <span className=\"text-xs text-green-600 dark:text-green-400 flex items-center gap-1\">\n <Icon name=\"check\" className=\"h-3 w-3\" />\n 완료\n </span>\n )}\n {file.status === \"error\" && (\n <span className=\"text-xs text-red-600 dark:text-red-400\">\n {file.error || \"업로드 실패\"}\n </span>\n )}\n </div>\n </div>\n\n {onRemove && (\n <button\n type=\"button\"\n onClick={() => handleRemove(file)}\n className=\"flex-shrink-0 rounded-lg p-1.5 hover:bg-gray-100 dark:hover:bg-gray-700 transition-colors\"\n aria-label=\"파일 제거\"\n >\n <Icon name=\"close\" className=\"h-4 w-4 text-gray-500 dark:text-gray-400\" />\n </button>\n )}\n </div>\n ))}\n </div>\n )}\n </div>\n )\n }\n)\n\nUpload.displayName = \"Upload\"\n\n\n","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\nimport { Input } from \"./Input\"\n\n/**\n * Autocomplete 옵션 인터페이스 / Autocomplete option interface\n * @typedef {Object} AutocompleteOption\n * @property {string} value - 옵션 값 / Option value\n * @property {string} label - 옵션 라벨 / Option label\n * @property {string} [description] - 옵션 설명 / Option description\n * @property {React.ReactNode} [icon] - 옵션 아이콘 / Option icon\n * @property {Record<string, unknown>} [data] - 추가 데이터 / Additional data\n */\nexport interface AutocompleteOption {\n value: string\n label: string\n description?: string\n icon?: React.ReactNode\n data?: Record<string, unknown>\n}\n\n/**\n * Autocomplete 컴포넌트의 props / Autocomplete component props\n * @typedef {Object} AutocompleteProps\n * @property {AutocompleteOption[]} options - 옵션 목록 / Options list\n * @property {string} [value] - 선택된 값 / Selected value\n * @property {(value: string, option?: AutocompleteOption) => void} [onChange] - 값 변경 핸들러 / Value change handler\n * @property {string} [placeholder=\"검색하거나 선택하세요\"] - 플레이스홀더 / Placeholder\n * @property {boolean} [disabled=false] - 비활성화 상태 / Disabled state\n * @property {boolean} [error=false] - 에러 상태 / Error state\n * @property {boolean} [loading=false] - 로딩 상태 / Loading state\n * @property {number} [maxHeight=300] - 드롭다운 최대 높이 (px) / Dropdown max height in px\n * @property {boolean} [clearable=true] - 지우기 버튼 표시 / Show clear button\n * @property {boolean} [filterable=true] - 필터링 활성화 / Enable filtering\n * @property {(query: string) => AutocompleteOption[] | Promise<AutocompleteOption[]>} [onSearch] - 검색 핸들러 (비동기 지원) / Search handler (async support)\n * @property {React.ReactNode} [emptyText=\"결과가 없습니다\"] - 빈 결과 텍스트 / Empty result text\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - 크기 / Size\n * @property {string} [className] - 추가 클래스명 / Additional class name\n * @extends {Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'>}\n */\nexport interface AutocompleteProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'> {\n options: AutocompleteOption[]\n value?: string\n onChange?: (value: string, option?: AutocompleteOption) => void\n placeholder?: string\n disabled?: boolean\n error?: boolean\n loading?: boolean\n maxHeight?: number\n clearable?: boolean\n filterable?: boolean\n onSearch?: (query: string) => AutocompleteOption[] | Promise<AutocompleteOption[]>\n emptyText?: string\n size?: \"sm\" | \"md\" | \"lg\"\n className?: string\n}\n\nconst sizeClasses = {\n sm: \"h-8 text-sm\",\n md: \"h-10 text-sm\",\n lg: \"h-12 text-base\",\n}\n\n/**\n * Autocomplete 컴포넌트 / Autocomplete component\n * \n * 자동완성 입력 컴포넌트입니다.\n * 입력하면서 옵션을 필터링하고 선택할 수 있습니다.\n * \n * Autocomplete input component.\n * Filters and selects options as you type.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Autocomplete\n * options={[\n * { value: \"1\", label: \"옵션 1\" },\n * { value: \"2\", label: \"옵션 2\" }\n * ]}\n * onChange={(value) => console.log(value)}\n * />\n * \n * @example\n * // 비동기 검색 / Async search\n * <Autocomplete\n * options={options}\n * onSearch={async (query) => {\n * const results = await searchAPI(query)\n * return results\n * }}\n * loading={isLoading}\n * />\n * \n * @param {AutocompleteProps} props - Autocomplete 컴포넌트의 props / Autocomplete component props\n * @returns {JSX.Element} Autocomplete 컴포넌트 / Autocomplete component\n */\nexport const Autocomplete = React.forwardRef<HTMLDivElement, AutocompleteProps>(\n (\n {\n options,\n value,\n onChange,\n placeholder = \"검색하거나 선택하세요\",\n disabled = false,\n error = false,\n loading = false,\n maxHeight = 300,\n clearable = true,\n filterable = true,\n onSearch,\n emptyText = \"결과가 없습니다\",\n size = \"md\",\n className,\n ...props\n },\n ref\n ) => {\n const [isOpen, setIsOpen] = React.useState(false)\n const [inputValue, setInputValue] = React.useState(\"\")\n const [filteredOptions, setFilteredOptions] = React.useState<AutocompleteOption[]>(options)\n const [selectedIndex, setSelectedIndex] = React.useState(-1)\n const [isSearching, setIsSearching] = React.useState(false)\n \n const inputRef = React.useRef<HTMLInputElement>(null)\n const dropdownRef = React.useRef<HTMLDivElement>(null)\n\n const selectedOption = React.useMemo(() => {\n return options.find((opt) => opt.value === value)\n }, [options, value])\n\n // 초기 입력값 설정\n React.useEffect(() => {\n if (selectedOption) {\n setInputValue(selectedOption.label)\n } else if (!value) {\n setInputValue(\"\")\n }\n }, [selectedOption, value])\n\n // 옵션 필터링\n React.useEffect(() => {\n if (onSearch) {\n setIsSearching(true)\n const result = onSearch(inputValue)\n if (result instanceof Promise) {\n result.then((filtered) => {\n setFilteredOptions(filtered)\n setIsSearching(false)\n })\n } else {\n setFilteredOptions(result)\n setIsSearching(false)\n }\n } else if (filterable) {\n if (!inputValue.trim()) {\n setFilteredOptions(options)\n } else {\n const filtered = options.filter((option) =>\n option.label.toLowerCase().includes(inputValue.toLowerCase()) ||\n option.value.toLowerCase().includes(inputValue.toLowerCase()) ||\n option.description?.toLowerCase().includes(inputValue.toLowerCase())\n )\n setFilteredOptions(filtered)\n }\n } else {\n setFilteredOptions(options)\n }\n }, [inputValue, options, filterable, onSearch])\n\n const handleInputChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const newValue = e.target.value\n setInputValue(newValue)\n setIsOpen(true)\n setSelectedIndex(-1)\n \n if (!newValue && clearable) {\n onChange?.(\"\")\n }\n }\n\n const handleInputFocus = () => {\n setIsOpen(true)\n }\n\n const handleInputBlur = (e: React.FocusEvent) => {\n // 드롭다운 클릭 시에는 닫지 않음\n if (dropdownRef.current?.contains(e.relatedTarget as Node)) {\n return\n }\n setIsOpen(false)\n setSelectedIndex(-1)\n \n // 선택된 옵션이 있으면 그 라벨로 복원\n if (selectedOption) {\n setInputValue(selectedOption.label)\n }\n }\n\n const handleOptionSelect = (option: AutocompleteOption) => {\n setInputValue(option.label)\n onChange?.(option.value, option)\n setIsOpen(false)\n inputRef.current?.blur()\n }\n\n const handleClear = () => {\n setInputValue(\"\")\n onChange?.(\"\")\n inputRef.current?.focus()\n }\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (!isOpen || filteredOptions.length === 0) {\n if (e.key === \"ArrowDown\") {\n setIsOpen(true)\n }\n return\n }\n\n switch (e.key) {\n case \"ArrowDown\":\n e.preventDefault()\n setSelectedIndex((prev) => \n prev < filteredOptions.length - 1 ? prev + 1 : prev\n )\n break\n case \"ArrowUp\":\n e.preventDefault()\n setSelectedIndex((prev) => (prev > 0 ? prev - 1 : -1))\n break\n case \"Enter\":\n e.preventDefault()\n if (selectedIndex >= 0 && filteredOptions[selectedIndex]) {\n handleOptionSelect(filteredOptions[selectedIndex])\n }\n break\n case \"Escape\":\n setIsOpen(false)\n inputRef.current?.blur()\n break\n }\n }\n\n return (\n <div ref={ref} className={merge(\"relative w-full\", className)} {...props}>\n <div className=\"relative\">\n <Input\n ref={inputRef}\n type=\"text\"\n value={inputValue}\n onChange={handleInputChange}\n onFocus={handleInputFocus}\n onBlur={handleInputBlur}\n onKeyDown={handleKeyDown}\n placeholder={placeholder}\n disabled={disabled}\n aria-invalid={error}\n aria-autocomplete=\"list\"\n aria-expanded={isOpen}\n aria-controls=\"autocomplete-list\"\n className={merge(sizeClasses[size], \"pr-10\")}\n />\n \n <div className=\"absolute right-3 top-1/2 -translate-y-1/2 flex items-center gap-1\">\n {loading || isSearching ? (\n <Icon \n name=\"loader\"\n className=\"h-4 w-4 animate-spin text-gray-400\" \n />\n ) : clearable && inputValue ? (\n <button\n type=\"button\"\n onClick={handleClear}\n className=\"rounded p-1 hover:bg-gray-100 dark:hover:bg-gray-700 transition-colors\"\n aria-label=\"지우기\"\n >\n <Icon name=\"close\" className=\"h-4 w-4 text-gray-400\" />\n </button>\n ) : (\n <Icon name=\"chevronDown\" className=\"h-4 w-4 text-gray-400\" />\n )}\n </div>\n </div>\n\n {/* 드롭다운 */}\n {isOpen && (\n <div\n ref={dropdownRef}\n id=\"autocomplete-list\"\n role=\"listbox\"\n className={merge(\n \"absolute z-50 w-full mt-1 rounded-lg border shadow-lg\",\n \"bg-white dark:bg-gray-800\",\n \"border-gray-200 dark:border-gray-700\",\n \"overflow-hidden\"\n )}\n style={{ maxHeight: `${maxHeight}px` }}\n >\n <div className=\"overflow-y-auto\" style={{ maxHeight: `${maxHeight}px` }}>\n {filteredOptions.length === 0 ? (\n <div className=\"px-4 py-8 text-center text-sm text-gray-500 dark:text-gray-400\">\n {emptyText}\n </div>\n ) : (\n filteredOptions.map((option, index) => {\n const isSelected = selectedIndex === index\n const isValueSelected = value === option.value\n\n return (\n <div\n key={option.value}\n role=\"option\"\n aria-selected={isValueSelected}\n onClick={() => handleOptionSelect(option)}\n onMouseEnter={() => setSelectedIndex(index)}\n className={merge(\n \"px-4 py-3 cursor-pointer transition-colors\",\n \"hover:bg-gray-100 dark:hover:bg-gray-700\",\n isSelected && \"bg-blue-50 dark:bg-blue-900/20\",\n isValueSelected && \"bg-blue-100 dark:bg-blue-900/30\"\n )}\n >\n <div className=\"flex items-center gap-3\">\n {option.icon && (\n <div className=\"flex-shrink-0 text-gray-400\">\n {option.icon}\n </div>\n )}\n <div className=\"flex-1 min-w-0\">\n <div className=\"flex items-center gap-2\">\n <p className=\"text-sm font-medium text-gray-900 dark:text-white\">\n {option.label}\n </p>\n {isValueSelected && (\n <Icon \n name=\"check\" \n className=\"h-4 w-4 text-blue-600 dark:text-blue-400 flex-shrink-0\" \n />\n )}\n </div>\n {option.description && (\n <p className=\"text-xs text-gray-500 dark:text-gray-400 mt-0.5\">\n {option.description}\n </p>\n )}\n </div>\n </div>\n </div>\n )\n })\n )}\n </div>\n </div>\n )}\n </div>\n )\n }\n)\n\nAutocomplete.displayName = \"Autocomplete\"\n\n\n"]}
|