@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.
Files changed (31) hide show
  1. package/README.md +12 -3
  2. package/dist/advanced-dashboard.js.map +1 -1
  3. package/dist/advanced-dashboard.mjs +1 -1
  4. package/dist/advanced.js.map +1 -1
  5. package/dist/advanced.mjs +1 -1
  6. package/dist/{chunk-VPOFRDYL.mjs → chunk-627HOIRV.mjs} +2 -2
  7. package/dist/{chunk-VPOFRDYL.mjs.map → chunk-627HOIRV.mjs.map} +1 -1
  8. package/dist/{chunk-SGCVGEDR.mjs → chunk-E5PN4LUS.mjs} +2 -2
  9. package/dist/{chunk-SGCVGEDR.mjs.map → chunk-E5PN4LUS.mjs.map} +1 -1
  10. package/dist/{chunk-ZQAAB3P4.mjs → chunk-MXGXBG63.mjs} +2 -2
  11. package/dist/{chunk-ZQAAB3P4.mjs.map → chunk-MXGXBG63.mjs.map} +1 -1
  12. package/dist/{chunk-YY6ZBUVJ.mjs → chunk-R5KCFRYV.mjs} +2 -2
  13. package/dist/{chunk-YY6ZBUVJ.mjs.map → chunk-R5KCFRYV.mjs.map} +1 -1
  14. package/dist/{chunk-DMYT7RZ4.mjs → chunk-UGSYQDR4.mjs} +2 -2
  15. package/dist/{chunk-DMYT7RZ4.mjs.map → chunk-UGSYQDR4.mjs.map} +1 -1
  16. package/dist/{chunk-QXBMXCML.mjs → chunk-VU264VFN.mjs} +2 -2
  17. package/dist/{chunk-QXBMXCML.mjs.map → chunk-VU264VFN.mjs.map} +1 -1
  18. package/dist/{chunk-6NXF6ATP.mjs → chunk-ZFS4B5QT.mjs} +2 -2
  19. package/dist/{chunk-6NXF6ATP.mjs.map → chunk-ZFS4B5QT.mjs.map} +1 -1
  20. package/dist/feedback.js +1 -1
  21. package/dist/feedback.js.map +1 -1
  22. package/dist/feedback.mjs +1 -1
  23. package/dist/form.js.map +1 -1
  24. package/dist/form.mjs +1 -1
  25. package/dist/index.js.map +1 -1
  26. package/dist/index.mjs +1 -1
  27. package/dist/lib/icon-providers.d.ts +2 -3
  28. package/dist/lib/icon-providers.d.ts.map +1 -1
  29. package/dist/navigation.js.map +1 -1
  30. package/dist/navigation.mjs +1 -1
  31. package/package.json +9 -8
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/lib/utils.ts","../src/components/Button.tsx","../src/components/Action.tsx","../src/components/Input.tsx","../src/components/Link.tsx","../src/lib/icons.ts","../src/lib/icon-providers.ts","../src/lib/icon-aliases.ts","../src/components/Icon/icon-store.ts","../src/components/Icon/IconProvider.tsx","../src/components/Icon/Icon.tsx","../src/components/Avatar.tsx","../src/components/Modal.tsx","../src/components/Container.tsx","../src/components/Grid.tsx","../src/components/Stack.tsx","../src/components/Divider.tsx","../src/components/Card.tsx","../src/components/Panel.tsx","../src/components/ActionToolbar.tsx","../src/components/Breadcrumb.tsx","../src/components/ComponentLayout.tsx","../src/components/Navigation.tsx","../src/components/Pagination.tsx","../src/components/PageNavigation.tsx","../src/components/LoadingSpinner.tsx","../src/components/PageTransition.tsx","../src/components/Table.tsx","../src/components/Badge.tsx","../src/components/Progress.tsx","../src/components/Skeleton.tsx","../src/components/Alert.tsx","../src/components/Toast.tsx","../src/components/Tooltip.tsx","../src/components/Popover.tsx","../src/components/Dropdown.tsx","../src/components/Drawer.tsx","../src/components/BottomSheet.tsx","../src/components/ConfirmModal.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","../src/components/Accordion.tsx","../src/components/Tabs.tsx","../src/components/Menu.tsx","../src/components/ContextMenu.tsx","../src/components/Command.tsx","../src/components/ScrollArea.tsx","../src/hooks/useScrollToggle.ts","../src/components/ScrollToTop.tsx","../src/components/ThemeProvider.tsx","../src/components/ThemeToggle.tsx","../src/lib/icon-names.ts"],"names":["merge","inputs","twMerge","clsx","mergeIf","condition","trueClass","falseClass","formatRelativeTime","timestamp","locale","date","diff","minutes","hours","days","mergeMap","classMap","classes","className","cn","isBrowser","useReducedMotion","reduce","setReduce","React","_a","mq","onChange","ButtonInner","variant","size","loading","icon","iconPosition","gradient","customGradient","rounded","shadow","hover","fullWidth","iconOnly","children","disabled","rest","ref","reduced","variantClasses","getGradientClass","sizeClasses","roundedClasses","shadowClasses","hoverClasses","base","content","jsxs","Fragment","jsx","onClick","target","rel","href","ariaLabel","anchorClassName","anchorProps","isDisabled","handleAnchorClick","e","buttonClassName","btnProps","Button","g","Action","actionType","feedback","particleEffect","rippleEffect","soundEffect","hapticFeedback","transparency","blurIntensity","glowIntensity","glowColor","runEffects","event","AudioContextClass","audioContext","oscillator","gainNode","button","rect","x","y","ripple","style","i","particle","angle","velocity","vx","vy","styleVars","cls","anchorRest","btnRest","Input","type","props","ariaInvalid","isInvalid","Link","external","icons","Home","ArrowLeft","ArrowRight","ArrowUp","ArrowDown","Menu","X","Search","Settings","ExternalLink","ChevronLeft","ChevronRight","ChevronDown","ChevronUp","Edit","Trash2","Plus","Minus","Download","Upload","RefreshCw","Save","Copy","Loader2","CheckCircle","XCircle","AlertCircle","Info","Check","Circle","HelpCircle","User","Users","UserPlus","LogIn","LogOut","Eye","EyeOff","BarChart3","TrendingUp","Activity","Database","Zap","FileText","File","Folder","Book","BookOpen","Mail","MessageCircle","Phone","Image","Video","Camera","Smile","Frown","Meh","Lock","Unlock","Shield","Wallet","Key","Clock","Calendar","CalendarPlus","Bell","Heart","Star","Bookmark","Share","Monitor","Sun","Moon","Lightbulb","Brain","Flag","Square","emotionIcons","statusIcons","iconCategories","PhosphorIcons","PROJECT_ICONS","initPhosphorIcons","getIconFromProvider","iconName","provider","iconMapping","getIconDirect","mappedName","LucideIcons","lucideName","camelCaseName","match","p1","phosphorName1","phosphorName2","word","ICON_ALIASES","resolveIconAlias","getIconAliases","_","alias","defaultIconConfig","getDefaultStrokeWidth","set","IconContext","createContext","IconProvider","weight","color","strokeWidth","value","useIconContext","useContext","IconComponent","name","emotion","status","animated","pulse","spin","bounce","ariaHidden","config","iconSet","iconSize","iconWeight","iconColor","iconStrokeWidth","isClient","setIsClient","phosphorReady","setPhosphorReady","iconProps","animationClasses","accessibilityProps","MemoizedIcon","prevProps","nextProps","Icon","EmotionIcon","StatusIcon","LoadingIcon","SuccessIcon","ErrorIcon","Avatar","src","alt","AvatarImage","AvatarFallback","useCombinedRefs","refs","node","Modal","isOpen","onClose","showCloseButton","closeOnOverlayClick","title","description","showBackdrop","backdropClassName","centered","modalRef","combinedRef","handleEscape","scrollbarWidth","handleOverlayClick","titleId","descriptionId","Container","padding","fluid","paddingClasses","Grid","cols","gap","gapX","gapY","responsive","colsClasses","gapClasses","gapXClasses","gapYClasses","Stack","direction","spacing","align","justify","wrap","directionClasses","spacingClasses","alignClasses","justifyClasses","DividerComponent","orientation","orientationClasses","colorClasses","Divider","Card","CardHeader","CardTitle","CardDescription","CardContent","CardFooter","Panel","effect","borderOpacity","shadowOpacity","hoverEffect","animationEffect","customPadding","customRounded","background","gradientColors","patternType","backgroundImage","backgroundVideo","interactive","hoverScale","hoverRotate","hoverGlow","cardProps","styleClasses","baseClasses","effectClasses","patternBackground","backgroundStyles","styles","panelClasses","ActionToolbarComponent","isSelectMode","totalCount","selectedCount","actions","selectModeActions","onToggleSelectMode","onToggleSelectAll","onCancelSelect","getBadgeColor","useCallback","renderButton","action","key","index","ActionToolbar","Breadcrumb","items","maxItems","showHomeIcon","homeLabel","separator","variantStyles","renderedItems","displayItems","firstItem","lastItems","item","isCurrent","BreadcrumbItem","child","itemsCount","ComponentLayout","prevPage","nextPage","breadcrumbItems","Navigation","defaultValue","onValueChange","scale","activeTab","setActiveTab","isControlled","currentValue","NavigationList","getStyleClasses","getScaleClasses","NavigationItem","active","handleClick","NavigationContent","NavigationComponent","Pagination","currentPage","totalPages","onPageChange","showFirstLast","showPrevNext","maxVisiblePages","shape","getVisiblePages","pages","halfVisible","start","end","getSizeClasses","getShapeClasses","getVariantClasses","isActive","handlePageClick","page","visiblePages","PaginationOutlined","PaginationMinimal","PaginationWithInfo","totalItems","itemsPerPage","showInfo","startItem","endItem","PageNavigation","showOnMobile","LoadingSpinner","text","spinnerColors","renderSpinner","PageTransition","duration","loadingVariant","loadingText","showLoading","onTransitionStart","onTransitionEnd","isLoading","setIsLoading","useState","isVisible","setIsVisible","useEffect","timer","transitionClasses","FadeTransition","SlideTransition","ScaleTransition","FlipTransition","Table","TableHeader","TableBody","TableFooter","TableRow","TableHead","TableCell","TableCaption","Badge","Progress","max","showValue","striped","label","percentage","getStripedClasses","ProgressSuccess","ProgressWarning","ProgressError","ProgressInfo","ProgressWrapper","ProgressGroup","Skeleton","width","height","animation","getAnimationClasses","defaultDims","finalWidth","finalHeight","SkeletonText","SkeletonCircle","SkeletonRectangle","SkeletonRounded","SkeletonCard","SkeletonAvatar","SkeletonImage","SkeletonUserProfile","SkeletonList","SkeletonTable","Alert","closable","getIconClasses","getDefaultIcon","AlertSuccess","AlertWarning","AlertError","AlertInfo","ToastContext","useToast","context","ToastProvider","maxToasts","position","toasts","setToasts","removeToast","id","prev","toast","addToast","newToast","clearToasts","ToastContainer","positionClasses","ToastItem","onRemove","handleRemove","getToastStyles","getIconStyles","getToastIcon","Tooltip","delay","coords","setCoords","timeoutRef","tooltipRef","showTooltip","tooltipRect","hideTooltip","getArrowClasses","TooltipLight","TooltipDark","Popover","trigger","controlledOpen","onOpenChange","offset","internalOpen","setInternalOpen","triggerRef","popoverRef","handleOpenChange","newOpen","handleTriggerClick","handleClickOutside","getPositionClasses","getAlignmentClasses","PopoverTrigger","PopoverContent","Dropdown","placement","showArrow","dropdownRef","updatePosition","triggerRect","dropdownRect","viewportWidth","viewportHeight","getPlacementClasses","DropdownItem","DropdownSeparator","DropdownLabel","DropdownMenu","DropdownGroup","Drawer","open","side","closeOnBackdropClick","closeOnEscape","isAnimating","setIsAnimating","sideClasses","transformClasses","DrawerHeader","DrawerContent","DrawerFooter","BottomSheet","showDragHandle","snapPoints","defaultSnap","currentHeight","setCurrentHeight","isDragging","setIsDragging","startY","setStartY","currentY","setCurrentY","heightClasses","handleTouchStart","handleTouchMove","handleTouchEnd","deltaY","threshold","currentIndex","nextIndex","BottomSheetHeader","BottomSheetContent","ConfirmModal","onConfirm","message","warning","confirmText","cancelText","confirmButtonText","showInput","inputValue","onInputChange","inputPlaceholder","inputLabel","requiredInputValue","showCancel","Form","onSubmit","FormField","error","required","errorId","enhancedChildren","childProps","childType","isFormComponent","typeObj","displayName","isNativeFormElement","existingAriaDescribedBy","ariaDescribedBy","FormGroup","inline","Label","Checkbox","success","checkboxId","labelId","iconSizes","stateClasses","isChecked","Radio","radioId","dotSizes","Select","leftIcon","placeholder","selectRef","isFocused","setIsFocused","SelectOption","Switch","switchId","thumbSizes","Slider","showLabel","min","step","isRange","handleChange","newValue","newRange","thumbVariantClasses","thumbSizeClasses","renderSlider","renderValue","val","Textarea","resize","resizeClasses","formatDate","format","year","month","day","getDaysInMonth","getFirstDayOfMonth","DatePicker","minDate","maxDate","dateFormat","setIsOpen","currentMonth","setCurrentMonth","hoveredDate","setHoveredDate","displayDate","handleDateSelect","handlePrevMonth","handleNextMonth","handleToday","today","daysInMonth","firstDay","weekDays","isDateDisabled","isDateSelected","isToday","calendarDays","remainingDays","triggerButton","isCurrentMonth","isSelected","isTodayDate","isHovered","formatFileSize","bytes","k","sizes","getFileIcon","files","multiple","accept","maxSize","maxFiles","dragDrop","fileInputRef","handleFileSelect","selectedFiles","fileArray","validFiles","file","handleDragOver","handleDragLeave","handleDrop","Autocomplete","options","maxHeight","clearable","filterable","onSearch","emptyText","setInputValue","filteredOptions","setFilteredOptions","selectedIndex","setSelectedIndex","isSearching","setIsSearching","inputRef","selectedOption","opt","result","filtered","option","handleInputChange","handleInputFocus","handleInputBlur","handleOptionSelect","handleClear","handleKeyDown","isValueSelected","Accordion","collapsible","openItems","setOpenItems","handleItemToggle","itemValue","newOpenItems","itemValues","values","newIndex","triggerElement","AccordionItem","onToggle","AccordionTrigger","defaultIcon","contentId","triggerId","AccordionContent","dataValue","setHeight","contentRef","TabsContent","Tabs","handleTabChange","TabsList","listRef","tabValues","TabsTrigger","TabsPills","TabsUnderline","TabsCards","MenuItem","MenuSeparator","MenuLabel","MenuHorizontal","MenuVertical","MenuCompact","ContextMenu","menuRef","handleContextMenu","menuRect","ContextMenuItem","ContextMenuSeparator","ContextMenuLabel","ContextMenuGroup","Command","controlledSearchValue","onSearchChange","internalSearchValue","setInternalSearchValue","commandRef","searchValue","handleSearchChange","itemCount","selectedItem","_b","CommandInput","CommandList","CommandItem","selected","onSelect","CommandGroup","heading","CommandSeparator","CommandEmpty","CommandDialog","ScrollArea","scrollHideDelay","showScrollbar","setShowScrollbar","handleMouseEnter","handleMouseLeave","ScrollBar","useScrollToggle","showOnMount","smooth","mounted","setMounted","toggleVisibility","ScrollToTop","scrollToTop","initialState","ThemeProviderContext","ThemeProvider","defaultTheme","storageKey","enableSystem","enableTransition","theme","setTheme","resolvedTheme","setResolvedTheme","savedTheme","root","systemTheme","mediaQuery","useTheme","ThemeToggle","renderIcon","iconNames","iconProviderMapping","isValidIconName","getIconNameForProvider","mapping"],"mappings":"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","file":"index.js","sourcesContent":["import { type ClassValue, clsx } from \"clsx\"\nimport { twMerge } from \"tailwind-merge\"\n\n/**\n * HUA UI의 스마트 클래스 병합 유틸리티\n * clsx와 tailwind-merge를 결합하여 중복 클래스를 자동으로 해결합니다.\n * \n * @param inputs - 병합할 클래스 값들\n * @returns 병합된 클래스 문자열\n * \n * @example\n * ```tsx\n * merge(\"px-2 py-1\", \"px-4\") // \"py-1 px-4\"\n * merge(\"text-red-500\", \"text-blue-500\") // \"text-blue-500\"\n * merge(\"bg-white\", \"dark:bg-slate-900\") // \"bg-white dark:bg-slate-900\"\n * ```\n */\nexport function merge(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs))\n}\n\n/**\n * 조건부 클래스 병합 유틸리티\n * 조건에 따라 클래스를 선택적으로 병합합니다.\n * \n * @param condition - 클래스를 적용할 조건\n * @param trueClass - 조건이 true일 때 적용할 클래스\n * @param falseClass - 조건이 false일 때 적용할 클래스 (선택사항)\n * @returns 병합된 클래스 문자열\n * \n * @example\n * ```tsx\n * mergeIf(isActive, \"bg-blue-500\", \"bg-gray-200\")\n * mergeIf(isLoading, \"opacity-50 cursor-not-allowed\")\n * ```\n */\nexport function mergeIf(\n condition: boolean,\n trueClass: ClassValue,\n falseClass?: ClassValue\n) {\n return merge(condition ? trueClass : falseClass || \"\")\n}\n\n/**\n * 상대 시간 포맷팅 유틸리티\n * \n * 날짜를 상대 시간 형식으로 포맷팅합니다 (예: \"방금 전\", \"5분 전\", \"2시간 전\", \"3일 전\").\n * 7일 이상 경과한 경우 절대 날짜를 반환합니다.\n * \n * Formats a date as relative time (e.g., \"방금 전\", \"5분 전\", \"2시간 전\", \"3일 전\").\n * Returns absolute date for dates older than 7 days.\n * \n * @param timestamp - 포맷팅할 날짜 (Date 객체 또는 ISO 문자열) / Date to format (Date object or ISO string)\n * @param locale - 로케일 (기본값: \"ko-KR\") / Locale (default: \"ko-KR\")\n * @returns 포맷팅된 상대 시간 문자열 / Formatted relative time string\n * \n * @example\n * ```tsx\n * formatRelativeTime(new Date()) // \"방금 전\"\n * formatRelativeTime(new Date(Date.now() - 5 * 60000)) // \"5분 전\"\n * formatRelativeTime(new Date(Date.now() - 2 * 3600000)) // \"2시간 전\"\n * formatRelativeTime(new Date(Date.now() - 3 * 86400000)) // \"3일 전\"\n * formatRelativeTime(new Date(\"2024-01-01\")) // \"2024. 1. 1.\" (7일 이상 경과)\n * ```\n */\nexport function formatRelativeTime(timestamp: Date | string, locale = \"ko-KR\"): string {\n const date = typeof timestamp === \"string\" ? new Date(timestamp) : timestamp;\n const now = new Date();\n const diff = now.getTime() - date.getTime();\n const minutes = Math.floor(diff / 60000);\n const hours = Math.floor(diff / 3600000);\n const days = Math.floor(diff / 86400000);\n\n if (minutes < 1) return locale === \"ko-KR\" ? \"방금 전\" : \"just now\";\n if (minutes < 60) return locale === \"ko-KR\" ? `${minutes}분 전` : `${minutes}m ago`;\n if (hours < 24) return locale === \"ko-KR\" ? `${hours}시간 전` : `${hours}h ago`;\n if (days < 7) return locale === \"ko-KR\" ? `${days}일 전` : `${days}d ago`;\n return date.toLocaleDateString(locale);\n}\n\n/**\n * 객체 기반 클래스 병합 유틸리티\n * 객체의 키-값 쌍을 기반으로 조건부 클래스를 병합합니다.\n * \n * @param classMap - 클래스 맵 객체\n * @returns 병합된 클래스 문자열\n * \n * @example\n * ```tsx\n * mergeMap({\n * \"bg-blue-500\": isPrimary,\n * \"bg-gray-500\": !isPrimary,\n * \"text-white\": true,\n * \"opacity-50\": isDisabled\n * })\n * ```\n */\nexport function mergeMap(classMap: Record<string, boolean | undefined | null>) {\n const classes = Object.entries(classMap)\n .filter(([, condition]) => condition)\n .map(([className]) => className)\n \n return merge(...classes)\n}\n\n// 하위 호환성을 위해 cn도 export (점진적 마이그레이션 지원)\nexport const cn = merge ","\"use client\";\n\nimport React from \"react\";\nimport { merge } from \"../lib/utils\";\n\n/**\n * 버튼 스타일 변형 / Button style variant\n * @typedef {\"default\" | \"destructive\" | \"outline\" | \"secondary\" | \"ghost\" | \"link\" | \"gradient\" | \"neon\" | \"glass\"} Variant\n */\ntype Variant =\n | \"default\" | \"destructive\" | \"outline\" | \"secondary\"\n | \"ghost\" | \"link\" | \"gradient\" | \"neon\" | \"glass\";\n\n/**\n * 버튼 크기 / Button size\n * @typedef {\"sm\" | \"md\" | \"lg\" | \"xl\" | \"icon\"} Size\n */\ntype Size = \"sm\" | \"md\" | \"lg\" | \"xl\" | \"icon\";\n\n/**\n * 버튼 모서리 둥글기 / Button border radius\n * @typedef {\"sm\" | \"md\" | \"lg\" | \"full\"} Rounded\n */\ntype Rounded = \"sm\" | \"md\" | \"lg\" | \"full\";\n\n/**\n * 버튼 그림자 / Button shadow\n * @typedef {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"} Shadow\n */\ntype Shadow = \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\";\n\n/**\n * 버튼 호버 효과 / Button hover effect\n * @typedef {\"scale\" | \"glow\" | \"slide\" | \"none\"} Hover\n */\ntype Hover = \"scale\" | \"glow\" | \"slide\" | \"none\";\n\n/**\n * 그라디언트 색상 이름 / Gradient color name\n * @typedef {\"blue\" | \"purple\" | \"green\" | \"orange\" | \"pink\" | \"custom\"} GradientName\n */\ntype GradientName = \"blue\" | \"purple\" | \"green\" | \"orange\" | \"pink\" | \"custom\";\n\n/**\n * Button 컴포넌트의 공통 props / Common props for Button component\n * @typedef {Object} CommonProps\n * @property {Variant} [variant=\"default\"] - 버튼 스타일 변형 / Button style variant\n * @property {Size} [size=\"md\"] - 버튼 크기 / Button size\n * @property {boolean} [loading=false] - 로딩 상태 (스피너 표시) / Loading state (shows spinner)\n * @property {React.ReactNode} [icon] - 아이콘 요소 / Icon element\n * @property {\"left\" | \"right\"} [iconPosition=\"left\"] - 아이콘 위치 / Icon position\n * @property {GradientName} [gradient=\"blue\"] - 그라디언트 색상 (variant=\"gradient\"일 때) / Gradient color (when variant=\"gradient\")\n * @property {string} [customGradient] - 커스텀 그라디언트 클래스 (variant=\"gradient\"일 때) / Custom gradient class (when variant=\"gradient\")\n * @property {Rounded} [rounded=\"md\"] - 모서리 둥글기 / Border radius\n * @property {Shadow} [shadow=\"md\"] - 그림자 크기 / Shadow size\n * @property {Hover} [hover=\"scale\"] - 호버 효과 / Hover effect\n * @property {boolean} [fullWidth=false] - 전체 너비 사용 / Use full width\n * @property {boolean} [iconOnly=false] - 아이콘만 표시 (aria-label 필수) / Icon only (aria-label required)\n * @property {string} [aria-label] - 접근성을 위한 레이블 (iconOnly일 때 필수) / Accessibility label (required when iconOnly)\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {boolean} [disabled=false] - 비활성화 상태 / Disabled state\n */\ntype CommonProps = {\n variant?: Variant;\n size?: Size;\n loading?: boolean;\n icon?: React.ReactNode;\n iconPosition?: \"left\" | \"right\";\n gradient?: GradientName;\n customGradient?: string;\n rounded?: Rounded;\n shadow?: Shadow;\n hover?: Hover;\n fullWidth?: boolean;\n iconOnly?: boolean;\n \"aria-label\"?: string;\n className?: string;\n disabled?: boolean; // <-- 요놈 추가\n};\n\ntype AnchorProps = CommonProps &\n Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, \"className\"> & {\n href: string;\n };\n\ntype NativeButtonProps = CommonProps &\n Omit<React.ButtonHTMLAttributes<HTMLButtonElement>, \"className\" | \"type\"> & {\n href?: undefined;\n };\n\n/**\n * Button 컴포넌트의 props 타입 / Button component props type\n * href가 제공되면 앵커 태그로, 그렇지 않으면 버튼 태그로 렌더링됩니다.\n * Renders as anchor tag if href is provided, otherwise as button tag.\n * @typedef {AnchorProps | NativeButtonProps} ButtonProps\n */\nexport type ButtonProps = AnchorProps | NativeButtonProps;\n\ntype AnchorOrButton = HTMLAnchorElement | HTMLButtonElement;\n\nconst isBrowser = typeof window !== \"undefined\";\nfunction useReducedMotion() {\n const [reduce, setReduce] = React.useState(false);\n React.useEffect(() => {\n if (!isBrowser || !(\"matchMedia\" in window)) return;\n const mq = window.matchMedia(\"(prefers-reduced-motion: reduce)\");\n const onChange = () => setReduce(!!mq.matches);\n onChange();\n mq.addEventListener?.(\"change\", onChange);\n return () => mq.removeEventListener?.(\"change\", onChange);\n }, []);\n return reduce;\n}\n\n/**\n * Button 컴포넌트 / Button component\n * \n * 다양한 스타일과 크기를 지원하는 범용 버튼 컴포넌트입니다.\n * href prop을 제공하면 앵커 태그로, 그렇지 않으면 버튼 태그로 렌더링됩니다.\n * \n * Universal button component supporting various styles and sizes.\n * Renders as anchor tag if href prop is provided, otherwise as button tag.\n * \n * @component\n * @example\n * // 기본 버튼 / Basic button\n * <Button onClick={() => console.log('클릭')}>클릭하세요</Button>\n * \n * @example\n * // 다양한 변형 / Various variants\n * <Button variant=\"destructive\" size=\"lg\">삭제</Button>\n * <Button variant=\"outline\" size=\"sm\">취소</Button>\n * <Button variant=\"ghost\">보기</Button>\n * \n * @example\n * // 아이콘과 함께 사용 / With icon\n * <Button icon={<Icon name=\"download\" />} iconPosition=\"left\">\n * 다운로드\n * </Button>\n * \n * @example\n * // 로딩 상태 / Loading state\n * <Button loading disabled>저장 중...</Button>\n * \n * @example\n * // 링크 버튼 / Link button\n * <Button href=\"/about\" variant=\"link\">자세히 보기</Button>\n * \n * @example\n * // 아이콘만 표시 (aria-label 필수) / Icon only (aria-label required)\n * <Button iconOnly aria-label=\"닫기\" icon={<Icon name=\"close\" />} />\n * \n * @param {ButtonProps} props - Button 컴포넌트의 props / Button component props\n * @param {React.Ref<HTMLAnchorElement | HTMLButtonElement>} ref - ref 객체 / ref object\n * @returns {JSX.Element} Button 컴포넌트 / Button component\n */\nconst ButtonInner = React.forwardRef<AnchorOrButton, ButtonProps>(function ButtonInner(\n {\n variant = \"default\",\n size = \"md\",\n loading = false,\n icon,\n iconPosition = \"left\",\n gradient = \"blue\",\n customGradient,\n rounded = \"md\",\n shadow = \"md\",\n hover = \"scale\",\n fullWidth,\n iconOnly,\n className,\n children,\n disabled,\n ...rest\n },\n ref\n) {\n const reduced = useReducedMotion();\n\n const variantClasses: Record<Variant, string> = {\n default:\n \"bg-blue-600 text-white hover:bg-blue-700 dark:bg-blue-500 dark:hover:bg-blue-600\",\n destructive:\n \"bg-red-600 text-white hover:bg-red-700 dark:bg-red-500 dark:hover:bg-red-600\",\n outline:\n \"border-2 border-blue-600 bg-transparent text-blue-600 hover:bg-blue-50 dark:border-blue-400 dark:text-blue-400 dark:hover:bg-blue-900/20\",\n secondary:\n \"bg-gray-200 text-gray-900 hover:bg-gray-300 dark:bg-gray-700 dark:text-white dark:hover:bg-gray-600\",\n ghost:\n \"bg-transparent text-gray-700 hover:bg-gray-100 dark:text-gray-300 dark:hover:bg-gray-800\",\n link:\n \"bg-transparent text-blue-600 underline hover:text-blue-700 dark:text-blue-400 dark:hover:text-blue-300\",\n gradient: `bg-gradient-to-r ${customGradient || getGradientClass(gradient)} text-white hover:shadow-lg`,\n neon:\n \"bg-gray-900 text-cyan-400 border border-cyan-400/30 shadow-lg shadow-cyan-400/20 hover:shadow-cyan-400/40\",\n glass:\n \"bg-white/10 backdrop-blur-md border border-white/20 text-white hover:bg-white/20\",\n };\n\n const sizeClasses: Record<Size, string> = {\n sm: \"h-8 px-3 py-1 text-sm\",\n md: \"h-10 px-4 py-2 text-base\",\n lg: \"h-12 px-6 py-3 text-lg\",\n xl: \"h-14 px-8 py-4 text-xl\",\n icon: \"h-10 w-10 p-0\",\n };\n\n const roundedClasses: Record<Rounded, string> = {\n sm: \"rounded\",\n md: \"rounded-md\",\n lg: \"rounded-lg\",\n full: \"rounded-full\",\n };\n\n const shadowClasses: Record<Shadow, string> = {\n none: \"\",\n sm: \"shadow-sm\",\n md: \"shadow-md\",\n lg: \"shadow-lg\",\n xl: \"shadow-xl\",\n };\n\n const hoverClasses: Record<Hover, string> = {\n scale: reduced ? \"\" : \"hover:scale-105 transition-transform duration-200\",\n glow: reduced ? \"\" : \"hover:shadow-2xl hover:shadow-blue-500/25 dark:hover:shadow-cyan-400/25 transition-shadow duration-300\",\n slide: reduced ? \"\" : \"hover:-translate-y-1 transition-transform duration-200\",\n none: \"\",\n };\n\n // variant별 포커스 스타일\n const focusClasses: Record<Variant, string> = {\n default: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-blue-500 focus-visible:ring-offset-1\",\n destructive: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-red-500 focus-visible:ring-offset-1\",\n outline: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-blue-300 dark:focus-visible:ring-blue-600 focus-visible:ring-offset-0\",\n secondary: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-gray-400 focus-visible:ring-offset-1\",\n ghost: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-gray-300 dark:focus-visible:ring-gray-600 focus-visible:ring-offset-0\",\n link: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-blue-400 focus-visible:ring-offset-0\",\n gradient: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-blue-500 focus-visible:ring-offset-1\",\n neon: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-cyan-400 focus-visible:ring-offset-1\",\n glass: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-blue-400/50 focus-visible:ring-offset-0\",\n };\n\n const base = merge(\n \"inline-flex items-center justify-center whitespace-nowrap font-medium transition-all duration-200\",\n focusClasses[variant],\n \"disabled:pointer-events-none disabled:opacity-50 min-w-fit\",\n fullWidth && \"w-full\",\n variantClasses[variant],\n sizeClasses[size],\n roundedClasses[rounded],\n shadowClasses[shadow],\n hoverClasses[hover],\n className\n );\n\n const Spinner = (\n <span role=\"status\" aria-live=\"polite\" className=\"-ml-1 mr-2 inline-flex\">\n <svg className=\"animate-spin h-4 w-4\" viewBox=\"0 0 24 24\" fill=\"none\">\n <circle className=\"opacity-25\" cx=\"12\" cy=\"12\" r=\"10\" stroke=\"currentColor\" strokeWidth=\"4\" />\n <path className=\"opacity-75\" fill=\"currentColor\" d=\"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z\" />\n </svg>\n <span className=\"sr-only\">로딩 중</span>\n </span>\n );\n\n const content = (\n <>\n {loading && Spinner}\n {!loading && icon && iconPosition === \"left\" && <span className=\"mr-2\">{icon}</span>}\n {children}\n {!loading && icon && iconPosition === \"right\" && <span className=\"ml-2\">{icon}</span>}\n </>\n );\n\n if (iconOnly && !(\"aria-label\" in rest) && process.env.NODE_ENV !== \"production\") {\n // eslint-disable-next-line no-console\n console.warn(\"[Button] iconOnly 사용 시 aria-label을 제공하세요.\");\n }\n\n // 앵커 모드\n if (\"href\" in rest && rest.href) {\n const { onClick, target, rel, href, \"aria-label\": ariaLabel, className: anchorClassName, ...anchorProps } = rest as AnchorProps;\n const isDisabled = !!disabled || loading;\n\n const handleAnchorClick: React.MouseEventHandler<HTMLAnchorElement> = (e) => {\n if (isDisabled) { e.preventDefault(); e.stopPropagation(); return; }\n onClick?.(e);\n };\n\n return (\n <a\n ref={ref as React.Ref<HTMLAnchorElement>}\n href={href}\n className={merge(base, anchorClassName)}\n onClick={handleAnchorClick}\n aria-busy={loading || undefined}\n aria-disabled={isDisabled || undefined}\n tabIndex={isDisabled ? -1 : anchorProps.tabIndex}\n target={target}\n rel={target === \"_blank\" ? rel ?? \"noopener noreferrer\" : rel}\n {...anchorProps}\n >\n {content}\n </a>\n );\n }\n\n // 버튼 모드\n const { className: buttonClassName, ...btnProps } = rest as NativeButtonProps;\n const isDisabled = !!disabled || loading;\n return (\n <button\n ref={ref as React.Ref<HTMLButtonElement>}\n className={merge(base, buttonClassName)}\n type=\"button\" // 폼 기본 제출 방지\n disabled={isDisabled}\n aria-busy={loading || undefined}\n aria-disabled={isDisabled || undefined}\n {...btnProps}\n >\n {content}\n </button>\n );\n});\n\nButtonInner.displayName = \"Button\";\n\nexport const Button = ButtonInner;\n\nfunction getGradientClass(gradient: GradientName): string {\n const g: Record<Exclude<GradientName, \"custom\">, string> = {\n blue: \"from-blue-500 to-cyan-500\",\n purple: \"from-purple-500 to-pink-500\",\n green: \"from-green-500 to-emerald-500 dark:from-green-400 dark:to-emerald-400\",\n orange: \"from-orange-500 to-red-500 dark:from-orange-300 dark:to-red-300\",\n pink: \"from-pink-500 to-rose-500\",\n };\n return g[gradient as keyof typeof g] || g.blue;\n}\n","\"use client\";\n\nimport React from \"react\";\nimport { merge } from \"../lib/utils\";\nimport { Button, type ButtonProps } from \"./Button\";\n\n/** Action 전용 옵션(버튼 공통 옵션은 ButtonProps에서 상속) */\ntype ActionKind =\n | \"primary\" | \"secondary\" | \"tertiary\"\n | \"magical\" | \"cyberpunk\" | \"ninja\" | \"wizard\" | \"sniper\";\ntype FeedbackKind = \"ripple\" | \"particle\" | \"sound\" | \"haptic\" | \"glitch\" | \"sparkle\" | \"smoke\";\n\ntype ActionExtras = {\n actionType?: ActionKind;\n feedback?: FeedbackKind;\n\n particleEffect?: boolean;\n rippleEffect?: boolean;\n soundEffect?: boolean;\n hapticFeedback?: boolean;\n\n transparency?: number; // 0~1\n blurIntensity?: number; // px\n glowIntensity?: number; // px\n glowColor?: string; // css color\n};\n\n/**\n * Action 컴포넌트의 props / Action component props\n * @typedef {Object} ActionProps\n * @property {ActionKind} [actionType=\"primary\"] - Action 타입 / Action type\n * @property {FeedbackKind} [feedback=\"ripple\"] - 피드백 타입 / Feedback type\n * @property {boolean} [particleEffect=false] - 파티클 효과 활성화 / Enable particle effect\n * @property {boolean} [rippleEffect=false] - 리플 효과 활성화 / Enable ripple effect\n * @property {boolean} [soundEffect=false] - 사운드 효과 활성화 / Enable sound effect\n * @property {boolean} [hapticFeedback=false] - 햅틱 피드백 활성화 / Enable haptic feedback\n * @property {number} [transparency=1] - 투명도 (0-1) / Transparency (0-1)\n * @property {number} [blurIntensity=0] - blur 강도 (px) / Blur intensity (px)\n * @property {number} [glowIntensity=0] - 글로우 강도 (px) / Glow intensity (px)\n * @property {string} [glowColor=\"rgba(91,140,255,.8)\"] - 글로우 색상 / Glow color\n * @extends {ButtonProps}\n */\nexport type ActionProps = ButtonProps & ActionExtras;\n\ntype AnchorEl = HTMLAnchorElement;\ntype ButtonEl = HTMLButtonElement;\ntype AnchorOrButton = AnchorEl | ButtonEl;\n\nconst isBrowser = typeof window !== \"undefined\";\nfunction useReducedMotion() {\n const [reduce, setReduce] = React.useState(false);\n React.useEffect(() => {\n if (!isBrowser || !(\"matchMedia\" in window)) return;\n const mq = window.matchMedia(\"(prefers-reduced-motion: reduce)\");\n const onChange = () => setReduce(!!mq.matches);\n onChange();\n mq.addEventListener?.(\"change\", onChange);\n return () => mq.removeEventListener?.(\"change\", onChange);\n }, []);\n return reduce;\n}\n\n/**\n * Action 컴포넌트 / Action component\n * \n * 고급 효과를 가진 액션 버튼 컴포넌트입니다.\n * Button 컴포넌트를 기반으로 하며, 파티클, 리플, 사운드, 햅틱 피드백 등을 지원합니다.\n * \n * Action button component with advanced effects.\n * Based on Button component, supports particle, ripple, sound, haptic feedback, etc.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Action>클릭</Action>\n * \n * @example\n * // 고급 효과 / Advanced effects\n * <Action \n * actionType=\"magical\"\n * feedback=\"particle\"\n * particleEffect\n * rippleEffect\n * >\n * 마법 버튼\n * </Action>\n * \n * @param {ActionProps} props - Action 컴포넌트의 props / Action component props\n * @param {React.Ref<AnchorOrButton>} ref - button 또는 anchor 요소 ref / button or anchor element ref\n * @returns {JSX.Element} Action 컴포넌트 / Action component\n */\nexport const Action = React.forwardRef<AnchorOrButton, ActionProps>(\n (\n {\n className,\n children,\n actionType = \"primary\",\n feedback = \"ripple\",\n particleEffect = false,\n rippleEffect = false,\n soundEffect = false,\n hapticFeedback = false,\n transparency = 1,\n blurIntensity = 0,\n glowIntensity = 0,\n glowColor = \"rgba(91,140,255,.8)\",\n loading = false,\n iconOnly = false,\n disabled,\n ...rest\n },\n ref\n ) => {\n const reduced = useReducedMotion();\n\n const runEffects = React.useCallback((event: React.MouseEvent) => {\n if (hapticFeedback && isBrowser && \"vibrate\" in navigator && !reduced) {\n try { navigator.vibrate?.(30); } catch {}\n }\n \n if (soundEffect && !reduced && isBrowser) {\n // 간단한 클릭 사운드 효과 (선택적)\n try {\n const AudioContextClass = window.AudioContext || (window as typeof window & { webkitAudioContext?: typeof AudioContext }).webkitAudioContext;\n if (!AudioContextClass) return;\n const audioContext = new AudioContextClass();\n const oscillator = audioContext.createOscillator();\n const gainNode = audioContext.createGain();\n \n oscillator.connect(gainNode);\n gainNode.connect(audioContext.destination);\n \n oscillator.frequency.value = 800;\n oscillator.type = 'sine';\n gainNode.gain.setValueAtTime(0.1, audioContext.currentTime);\n gainNode.gain.exponentialRampToValueAtTime(0.01, audioContext.currentTime + 0.1);\n \n oscillator.start(audioContext.currentTime);\n oscillator.stop(audioContext.currentTime + 0.1);\n } catch (e) {\n // 오디오 컨텍스트를 지원하지 않는 환경에서는 무시\n }\n }\n \n if (rippleEffect && !reduced && event.currentTarget) {\n // Ripple 효과: 클릭 위치에 원형 애니메이션 생성\n const button = event.currentTarget as HTMLElement;\n const rect = button.getBoundingClientRect();\n const x = event.clientX - rect.left;\n const y = event.clientY - rect.top;\n const size = Math.max(rect.width, rect.height);\n \n const ripple = document.createElement('span');\n ripple.style.cssText = `\n position: absolute;\n border-radius: 50%;\n background: rgba(255, 255, 255, 0.6);\n width: ${size}px;\n height: ${size}px;\n left: ${x - size / 2}px;\n top: ${y - size / 2}px;\n pointer-events: none;\n animation: ripple-animation 0.6s ease-out;\n `;\n \n // CSS 애니메이션 정의 (한 번만)\n if (!document.getElementById('ripple-animation-style')) {\n const style = document.createElement('style');\n style.id = 'ripple-animation-style';\n style.textContent = `\n @keyframes ripple-animation {\n to {\n transform: scale(4);\n opacity: 0;\n }\n }\n `;\n document.head.appendChild(style);\n }\n \n button.style.position = 'relative';\n button.style.overflow = 'hidden';\n button.appendChild(ripple);\n \n setTimeout(() => {\n ripple.remove();\n }, 600);\n }\n \n if (particleEffect && !reduced && event.currentTarget) {\n // 간단한 파티클 효과: 클릭 위치에서 작은 원들이 퍼져나감\n const button = event.currentTarget as HTMLElement;\n const rect = button.getBoundingClientRect();\n const x = event.clientX - rect.left;\n const y = event.clientY - rect.top;\n \n for (let i = 0; i < 5; i++) {\n const particle = document.createElement('span');\n const angle = (Math.PI * 2 * i) / 5;\n const velocity = 30 + Math.random() * 20;\n const vx = Math.cos(angle) * velocity;\n const vy = Math.sin(angle) * velocity;\n \n particle.style.cssText = `\n position: absolute;\n width: 4px;\n height: 4px;\n background: ${glowColor || 'rgba(91,140,255,0.8)'};\n border-radius: 50%;\n left: ${x}px;\n top: ${y}px;\n pointer-events: none;\n animation: particle-animation-${i} 0.5s ease-out forwards;\n `;\n \n // CSS 애니메이션 정의\n if (!document.getElementById(`particle-animation-${i}`)) {\n const style = document.createElement('style');\n style.id = `particle-animation-${i}`;\n style.textContent = `\n @keyframes particle-animation-${i} {\n to {\n transform: translate(${vx}px, ${vy}px) scale(0);\n opacity: 0;\n }\n }\n `;\n document.head.appendChild(style);\n }\n \n button.style.position = 'relative';\n button.appendChild(particle);\n \n setTimeout(() => {\n particle.remove();\n }, 500);\n }\n }\n }, [hapticFeedback, soundEffect, rippleEffect, particleEffect, reduced, glowColor]);\n\n const styleVars = React.useMemo<React.CSSProperties>(() => ({\n \"--action-opacity\": String(transparency),\n \"--action-blur\": `${blurIntensity}px`,\n \"--action-glow-size\": `${glowIntensity}px`,\n \"--action-glow-color\": glowColor,\n }) as React.CSSProperties, [transparency, blurIntensity, glowIntensity, glowColor]);\n\n const cls = React.useMemo(\n () =>\n merge(\n \"hua-action relative inline-flex items-center rounded-xl px-4 py-2 font-medium\",\n \"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary/60\",\n loading && \"cursor-wait opacity-80\",\n iconOnly && \"justify-center\",\n className\n ),\n [className, loading, iconOnly]\n );\n\n /** 분기 1) href가 있으면 앵커 브랜치 */\n if (\"href\" in rest && rest.href) {\n const { onClick, href, ...anchorRest } = rest as Extract<ButtonProps, { href: string }>;\n\n const handleClick: React.MouseEventHandler<AnchorEl> = (e) => {\n if (disabled || loading) { e.preventDefault(); e.stopPropagation(); return; }\n runEffects(e);\n onClick?.(e);\n };\n\n return (\n <Button\n ref={ref as React.Ref<AnchorEl>}\n href={href}\n className={cls}\n style={styleVars}\n onClick={handleClick}\n aria-busy={loading || undefined}\n aria-label={iconOnly ? (anchorRest[\"aria-label\"] as string) : undefined}\n data-action={actionType}\n data-feedback={feedback}\n data-reduced-motion={reduced ? \"true\" : \"false\"}\n disabled={disabled}\n {...anchorRest}\n >\n {children}\n </Button>\n );\n }\n\n /** 분기 2) 기본 버튼 브랜치 */\n const { onClick, ...btnRest } = rest as Extract<ButtonProps, { href?: undefined }>;\n\n const handleClick: React.MouseEventHandler<ButtonEl> = (e) => {\n if (disabled || loading) return;\n runEffects(e);\n onClick?.(e);\n };\n\n return (\n <Button\n ref={ref as React.Ref<ButtonEl>}\n className={cls}\n style={styleVars}\n onClick={handleClick}\n disabled={disabled}\n aria-busy={loading || undefined}\n aria-label={iconOnly ? (btnRest[\"aria-label\"] as string) : undefined}\n data-action={actionType}\n data-feedback={feedback}\n data-reduced-motion={reduced ? \"true\" : \"false\"}\n {...btnRest}\n >\n {children}\n </Button>\n );\n }\n);\n\nAction.displayName = \"Action\";\n","\"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 * Link 컴포넌트의 props / Link component props\n * @typedef {Object} LinkProps\n * @property {string} href - 링크 URL / Link URL\n * @property {React.ReactNode} children - 링크 텍스트 또는 내용 / Link text or content\n * @property {\"default\" | \"primary\" | \"secondary\" | \"ghost\" | \"underline\"} [variant=\"default\"] - Link 스타일 변형 / Link style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Link 크기 / Link size\n * @property {boolean} [external=false] - 외부 링크 여부 (target=\"_blank\" 자동 설정) / External link (auto sets target=\"_blank\")\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {() => void} [onClick] - 클릭 이벤트 핸들러 / Click event handler\n */\nexport interface LinkProps {\n href: string\n children: React.ReactNode\n variant?: \"default\" | \"primary\" | \"secondary\" | \"ghost\" | \"underline\"\n size?: \"sm\" | \"md\" | \"lg\"\n external?: boolean\n className?: string\n onClick?: () => void\n}\n\n/**\n * Link 컴포넌트 / Link component\n * \n * 링크를 표시하는 컴포넌트입니다.\n * 외부 링크의 경우 자동으로 `target=\"_blank\"`와 `rel=\"noopener noreferrer\"`를 설정합니다.\n * \n * Link component for displaying links.\n * Automatically sets `target=\"_blank\"` and `rel=\"noopener noreferrer\"` for external links.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Link href=\"/about\">소개</Link>\n * \n * @example\n * // 외부 링크 / External link\n * <Link href=\"https://example.com\" external>\n * 외부 사이트\n * </Link>\n * \n * @example\n * // Primary 스타일 / Primary style\n * <Link href=\"/contact\" variant=\"primary\" size=\"lg\">\n * 문의하기\n * </Link>\n * \n * @param {LinkProps} props - Link 컴포넌트의 props / Link component props\n * @returns {JSX.Element} Link 컴포넌트 / Link component\n */\nexport function Link({ \n href,\n children,\n className,\n variant = \"default\",\n size = \"md\",\n external = false,\n onClick\n}: LinkProps) {\n const variantClasses = {\n default: \"text-gray-900 dark:text-white hover:text-gray-700 dark:hover:text-gray-300\",\n primary: \"text-blue-600 dark:text-blue-400 hover:text-blue-700 dark:hover:text-blue-300\",\n secondary: \"text-gray-600 dark:text-gray-400 hover:text-gray-800 dark:hover:text-gray-200\",\n ghost: \"text-gray-500 dark:text-gray-400 hover:text-gray-700 dark:hover:bg-gray-800\",\n underline: \"text-blue-600 dark:text-blue-400 hover:text-blue-700 dark:hover:text-blue-300 underline hover:no-underline\"\n }\n\n const sizeClasses = {\n sm: \"text-sm\",\n md: \"text-base\",\n lg: \"text-lg\"\n }\n\n return (\n <a\n href={href}\n className={merge(\n \"transition-colors duration-200\",\n variantClasses[variant],\n sizeClasses[size],\n className\n )}\n target={external ? \"_blank\" : undefined}\n rel={external ? \"noopener noreferrer\" : undefined}\n onClick={onClick}\n >\n {children}\n </a>\n )\n} ","/**\n * Core Icons\n * \n * 핵심 아이콘만 포함하여 번들 크기를 최적화합니다.\n * 나머지 아이콘은 동적 fallback으로 처리됩니다.\n * \n * 포함 기준:\n * 1. sum-diary에서 실제 사용 중인 아이콘\n * 2. UI 컴포넌트에서 자주 사용되는 아이콘\n * 3. 각 카테고리의 대표 아이콘\n * \n * 새로운 아이콘이 필요하면 동적 fallback이 자동으로 처리합니다.\n */\n\nimport {\n // Navigation\n Home,\n ArrowLeft,\n ArrowRight,\n ArrowUp,\n ArrowDown,\n Menu,\n X,\n Search,\n Settings,\n ExternalLink,\n ChevronLeft,\n ChevronRight,\n ChevronDown,\n ChevronUp,\n \n // Actions\n Edit,\n Trash2,\n Plus,\n Minus,\n Download,\n Upload,\n RefreshCw,\n Save,\n Copy,\n \n // Status & Feedback\n Loader2,\n CheckCircle,\n XCircle,\n AlertCircle,\n Info,\n Check,\n Circle,\n HelpCircle,\n \n // User & Auth\n User,\n Users,\n UserPlus,\n LogIn,\n LogOut,\n Eye,\n EyeOff,\n \n // Data & Analytics\n BarChart3,\n TrendingUp,\n Activity,\n Database,\n Zap,\n \n // Files & Content\n FileText,\n File,\n Folder,\n Book,\n BookOpen,\n \n // Communication\n Mail,\n MessageCircle,\n Phone,\n \n // Media\n Image,\n Video,\n Camera,\n \n // Emotions\n Smile,\n Frown,\n Meh,\n \n // Security\n Lock,\n Unlock,\n Shield,\n Wallet,\n Key,\n \n // Time & Date\n Clock,\n Calendar,\n CalendarPlus,\n \n // UI Elements\n Bell,\n Heart,\n Star,\n Bookmark,\n Share,\n \n // Theme\n Monitor,\n Sun,\n Moon,\n \n // Additional\n Lightbulb,\n Brain,\n Flag,\n Square,\n} from 'lucide-react'\n\n// 핵심 아이콘 객체\nexport const icons = {\n // Navigation\n home: Home,\n arrowLeft: ArrowLeft,\n arrowRight: ArrowRight,\n arrowUp: ArrowUp,\n arrowDown: ArrowDown,\n menu: Menu,\n close: X,\n search: Search,\n settings: Settings,\n externalLink: ExternalLink,\n chevronLeft: ChevronLeft,\n chevronRight: ChevronRight,\n chevronDown: ChevronDown,\n chevronUp: ChevronUp,\n \n // Actions\n edit: Edit,\n delete: Trash2,\n add: Plus,\n remove: Minus,\n download: Download,\n upload: Upload,\n refresh: RefreshCw,\n save: Save,\n copy: Copy,\n \n // Status & Feedback\n loader: Loader2,\n success: CheckCircle,\n error: XCircle,\n alertCircle: AlertCircle,\n warning: AlertCircle, // warning은 alertCircle과 동일\n info: Info,\n check: Check,\n circle: Circle,\n helpCircle: HelpCircle,\n \n // User & Auth\n user: User,\n users: Users,\n userPlus: UserPlus,\n logIn: LogIn,\n logOut: LogOut,\n eye: Eye,\n eyeOff: EyeOff,\n \n // Data & Analytics\n chart: BarChart3,\n barChart: BarChart3,\n trendingUp: TrendingUp,\n activity: Activity,\n database: Database,\n zap: Zap,\n \n // Files & Content\n fileText: FileText,\n file: File,\n folder: Folder,\n book: Book,\n bookOpen: BookOpen,\n \n // Communication\n mail: Mail,\n message: MessageCircle,\n phone: Phone,\n \n // Media\n image: Image,\n video: Video,\n camera: Camera,\n \n // Emotions\n smile: Smile,\n frown: Frown,\n meh: Meh,\n \n // Security\n lock: Lock,\n unlock: Unlock,\n shield: Shield,\n wallet: Wallet,\n key: Key,\n \n // Time & Date\n clock: Clock,\n calendar: Calendar,\n calendarPlus: CalendarPlus,\n \n // UI Elements\n bell: Bell,\n heart: Heart,\n star: Star,\n bookmark: Bookmark,\n share: Share,\n \n // Theme\n monitor: Monitor,\n sun: Sun,\n moon: Moon,\n \n // Additional\n lightbulb: Lightbulb,\n brain: Brain,\n flag: Flag,\n square: Square,\n} as const\n\n// 아이콘 이름 타입\nexport type IconName = keyof typeof icons\n\n// 감정별 아이콘 매핑\nexport const emotionIcons = {\n happy: 'smile',\n sad: 'frown',\n neutral: 'meh',\n excited: 'smile', // laugh 대신 smile 사용\n angry: 'frown', // angry 대신 frown 사용\n love: 'heart',\n like: 'heart', // thumbsUp 대신 heart 사용\n dislike: 'frown', // thumbsDown 대신 frown 사용\n} as const\n\n// 상태별 아이콘 매핑\nexport const statusIcons = {\n loading: 'loader',\n success: 'success',\n error: 'error',\n warning: 'warning',\n info: 'info',\n locked: 'lock',\n unlocked: 'unlock',\n visible: 'eye',\n hidden: 'eyeOff',\n} as const\n\n// 아이콘 카테고리별 그룹화 (참고용)\nexport const iconCategories = {\n navigation: ['home', 'arrowLeft', 'arrowRight', 'arrowUp', 'arrowDown', 'menu', 'close', 'search', 'settings', 'externalLink', 'chevronLeft', 'chevronRight', 'chevronDown', 'chevronUp'],\n actions: ['edit', 'delete', 'add', 'remove', 'download', 'upload', 'refresh', 'save', 'copy'],\n status: ['loader', 'success', 'error', 'alertCircle', 'warning', 'info', 'check', 'circle'],\n user: ['user', 'users', 'userPlus', 'logIn', 'logOut', 'eye', 'eyeOff'],\n data: ['chart', 'barChart', 'trendingUp', 'activity', 'database', 'zap'],\n files: ['fileText', 'file', 'folder', 'book'],\n communication: ['mail', 'message', 'phone'],\n media: ['image', 'video', 'camera'],\n emotions: ['smile', 'frown', 'meh'],\n security: ['lock', 'unlock', 'shield'],\n time: ['clock', 'calendar'],\n ui: ['bell', 'heart', 'star', 'bookmark', 'share'],\n theme: ['monitor', 'sun', 'moon'],\n} as const\n","/**\n * Icon Provider System\n * \n * Supports multiple icon libraries:\n * - Lucide Icons (default)\n * - Phosphor Icons\n * - Untitled Icons (SVG-based)\n * \n * Only imports icons that are actually used in the project for optimal bundle size.\n */\n\nimport * as LucideIcons from 'lucide-react'\nimport type { LucideIcon } from 'lucide-react'\n\n// Phosphor Icons - lazy loaded, tree-shakeable\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nlet PhosphorIcons: any = null\n\n// Icon Provider Type (deprecated: IconSet 사용 권장)\n// @deprecated Use IconSet from './components/Icon/icon-store' instead\nexport type IconProvider = 'lucide' | 'phosphor' | 'untitled'\n\n// Icon Provider Configuration\nexport interface IconProviderConfig {\n /** @deprecated Use IconSet from './components/Icon/icon-store' instead */\n provider: IconProvider\n prefix?: string\n}\n\n/**\n * Project-specific icon list\n * These are the icons actually used in SumUp project\n * Only these icons will be loaded for optimal bundle size\n */\nexport const PROJECT_ICONS = {\n // Navigation & Layout\n 'home': { lucide: 'Home', phosphor: 'House', untitled: 'home' },\n 'layout-dashboard': { lucide: 'LayoutDashboard', phosphor: 'SquaresFour', untitled: 'layout-dashboard' },\n 'folder': { lucide: 'Folder', phosphor: 'Folder', untitled: 'folder' },\n 'alert-circle': { lucide: 'AlertCircle', phosphor: 'WarningCircle', untitled: 'alert-circle' },\n 'alertCircle': { lucide: 'AlertCircle', phosphor: 'WarningCircle', untitled: 'alert-circle' },\n 'columns': { lucide: 'Columns', phosphor: 'Columns', untitled: 'columns' },\n 'users': { lucide: 'Users', phosphor: 'Users', untitled: 'users' },\n 'settings': { lucide: 'Settings', phosphor: 'Gear', untitled: 'settings' },\n 'menu': { lucide: 'Menu', phosphor: 'List', untitled: 'menu' },\n 'close': { lucide: 'X', phosphor: 'X', untitled: 'close' },\n 'chevronLeft': { lucide: 'ChevronLeft', phosphor: 'CaretLeft', untitled: 'chevron-left' },\n 'chevronRight': { lucide: 'ChevronRight', phosphor: 'CaretRight', untitled: 'chevron-right' },\n 'chevronDown': { lucide: 'ChevronDown', phosphor: 'CaretDown', untitled: 'chevron-down' },\n 'chevronUp': { lucide: 'ChevronUp', phosphor: 'CaretUp', untitled: 'chevron-up' },\n 'arrowLeft': { lucide: 'ArrowLeft', phosphor: 'ArrowLeft', untitled: 'arrow-left' },\n 'arrowRight': { lucide: 'ArrowRight', phosphor: 'ArrowRight', untitled: 'arrow-right' },\n 'arrowUp': { lucide: 'ArrowUp', phosphor: 'ArrowUp', untitled: 'arrow-up' },\n 'arrowDown': { lucide: 'ArrowDown', phosphor: 'ArrowDown', untitled: 'arrow-down' },\n \n // Actions\n 'add': { lucide: 'Plus', phosphor: 'Plus', untitled: 'add' },\n 'edit': { lucide: 'Edit', phosphor: 'Pencil', untitled: 'edit' },\n 'pencil': { lucide: 'Pencil', phosphor: 'Pencil', untitled: 'pencil' },\n 'delete': { lucide: 'Trash2', phosphor: 'Trash', untitled: 'trash' },\n 'trash': { lucide: 'Trash2', phosphor: 'Trash', untitled: 'trash' },\n 'upload': { lucide: 'Upload', phosphor: 'Upload', untitled: 'upload' },\n 'download': { lucide: 'Download', phosphor: 'Download', untitled: 'download' },\n 'x': { lucide: 'X', phosphor: 'X', untitled: 'close' },\n 'check': { lucide: 'Check', phosphor: 'Check', untitled: 'check' },\n 'search': { lucide: 'Search', phosphor: 'MagnifyingGlass', untitled: 'search' },\n 'share': { lucide: 'Share', phosphor: 'Share', untitled: 'share' },\n 'copy': { lucide: 'Copy', phosphor: 'Copy', untitled: 'copy' },\n 'save': { lucide: 'Save', phosphor: 'FloppyDisk', untitled: 'save' },\n \n // Status & Feedback\n 'loader': { lucide: 'Loader2', phosphor: 'Spinner', untitled: 'loader' },\n 'loader2': { lucide: 'Loader2', phosphor: 'Spinner', untitled: 'loader' },\n 'check-circle': { lucide: 'CheckCircle', phosphor: 'CheckCircle', untitled: 'check-circle' },\n 'checkCircle': { lucide: 'CheckCircle', phosphor: 'CheckCircle', untitled: 'check-circle' },\n 'success': { lucide: 'CheckCircle', phosphor: 'CheckCircle', untitled: 'check-circle' },\n 'error': { lucide: 'XCircle', phosphor: 'XCircle', untitled: 'error' },\n 'warning': { lucide: 'AlertCircle', phosphor: 'WarningCircle', untitled: 'warning' },\n 'info': { lucide: 'Info', phosphor: 'Info', untitled: 'info' },\n 'refresh': { lucide: 'RefreshCw', phosphor: 'ArrowClockwise', untitled: 'refresh' },\n 'refreshCw': { lucide: 'RefreshCw', phosphor: 'ArrowClockwise', untitled: 'refresh' },\n 'bell': { lucide: 'Bell', phosphor: 'Bell', untitled: 'bell' },\n 'heart': { lucide: 'Heart', phosphor: 'Heart', untitled: 'heart' },\n 'star': { lucide: 'Star', phosphor: 'Star', untitled: 'star' },\n 'bookmark': { lucide: 'Bookmark', phosphor: 'Bookmark', untitled: 'bookmark' },\n \n // User & Auth\n 'user': { lucide: 'User', phosphor: 'User', untitled: 'user' },\n 'userPlus': { lucide: 'UserPlus', phosphor: 'UserPlus', untitled: 'user-plus' },\n 'logIn': { lucide: 'LogIn', phosphor: 'SignIn', untitled: 'log-in' },\n 'logOut': { lucide: 'LogOut', phosphor: 'SignOut', untitled: 'log-out' },\n 'chrome': { lucide: 'Chrome', phosphor: 'ChromeLogo', untitled: 'chrome' },\n 'github': { lucide: 'Github', phosphor: 'GithubLogo', untitled: 'github' },\n 'message': { lucide: 'MessageCircle', phosphor: 'ChatCircle', untitled: 'message' },\n \n // Content\n 'messageSquare': { lucide: 'MessageSquare', phosphor: 'ChatSquare', untitled: 'message-square' },\n 'message-square': { lucide: 'MessageSquare', phosphor: 'ChatSquare', untitled: 'message-square' },\n 'inbox': { lucide: 'Inbox', phosphor: 'Inbox', untitled: 'inbox' },\n 'calendar': { lucide: 'Calendar', phosphor: 'Calendar', untitled: 'calendar' },\n 'calendarPlus': { lucide: 'CalendarPlus', phosphor: 'CalendarPlus', untitled: 'calendar-plus' },\n 'checkSquare': { lucide: 'CheckSquare', phosphor: 'CheckSquare', untitled: 'check-square' },\n 'clock': { lucide: 'Clock', phosphor: 'Clock', untitled: 'clock' },\n 'book': { lucide: 'Book', phosphor: 'Book', untitled: 'book' },\n 'bookOpen': { lucide: 'BookOpen', phosphor: 'BookOpen', untitled: 'book-open' },\n \n // Theme & UI\n 'monitor': { lucide: 'Monitor', phosphor: 'Monitor', untitled: 'monitor' },\n 'sun': { lucide: 'Sun', phosphor: 'Sun', untitled: 'sun' },\n 'moon': { lucide: 'Moon', phosphor: 'Moon', untitled: 'moon' },\n \n // AI & Features\n 'sparkles': { lucide: 'Sparkles', phosphor: 'Sparkle', untitled: 'sparkles' },\n 'lightbulb': { lucide: 'Lightbulb', phosphor: 'Lightbulb', untitled: 'lightbulb' },\n 'brain': { lucide: 'Brain', phosphor: 'Brain', untitled: 'brain' },\n 'zap': { lucide: 'Zap', phosphor: 'Lightning', untitled: 'zap' },\n \n // Data & Analytics\n 'chart': { lucide: 'BarChart3', phosphor: 'ChartBar', untitled: 'chart' },\n 'barChart': { lucide: 'BarChart', phosphor: 'ChartBar', untitled: 'bar-chart' },\n 'trendingUp': { lucide: 'TrendingUp', phosphor: 'TrendUp', untitled: 'trending-up' },\n 'trendingDown': { lucide: 'TrendingDown', phosphor: 'TrendDown', untitled: 'trending-down' },\n 'activity': { lucide: 'Activity', phosphor: 'Activity', untitled: 'activity' },\n 'database': { lucide: 'Database', phosphor: 'Database', untitled: 'database' },\n 'dollarSign': { lucide: 'DollarSign', phosphor: 'CurrencyDollar', untitled: 'dollar-sign' },\n 'dollar': { lucide: 'DollarSign', phosphor: 'CurrencyDollar', untitled: 'dollar-sign' },\n 'currency': { lucide: 'DollarSign', phosphor: 'CurrencyDollar', untitled: 'currency' },\n \n // Security\n 'lock': { lucide: 'Lock', phosphor: 'Lock', untitled: 'lock' },\n 'unlock': { lucide: 'Unlock', phosphor: 'LockOpen', untitled: 'unlock' },\n 'shield': { lucide: 'Shield', phosphor: 'Shield', untitled: 'shield' },\n 'key': { lucide: 'Key', phosphor: 'Key', untitled: 'key' },\n \n // Media\n 'play': { lucide: 'Play', phosphor: 'Play', untitled: 'play' },\n 'pause': { lucide: 'Pause', phosphor: 'Pause', untitled: 'pause' },\n 'image': { lucide: 'Image', phosphor: 'Image', untitled: 'image' },\n 'video': { lucide: 'Video', phosphor: 'Video', untitled: 'video' },\n 'camera': { lucide: 'Camera', phosphor: 'Camera', untitled: 'camera' },\n \n // Files\n 'fileText': { lucide: 'FileText', phosphor: 'FileText', untitled: 'file-text' },\n 'file': { lucide: 'File', phosphor: 'File', untitled: 'file' },\n \n // Navigation\n 'externalLink': { lucide: 'ExternalLink', phosphor: 'ArrowSquareOut', untitled: 'external-link' },\n 'link': { lucide: 'Link', phosphor: 'Link', untitled: 'link' },\n 'moreHorizontal': { lucide: 'MoreHorizontal', phosphor: 'DotsThreeOutline', untitled: 'more-horizontal' },\n 'moreVertical': { lucide: 'MoreVertical', phosphor: 'DotsThreeVertical', untitled: 'more-vertical' },\n \n // Priority\n 'remove': { lucide: 'Minus', phosphor: 'Minus', untitled: 'remove' },\n \n // Eye (password)\n 'eye': { lucide: 'Eye', phosphor: 'Eye', untitled: 'eye' },\n 'eyeOff': { lucide: 'EyeOff', phosphor: 'EyeSlash', untitled: 'eye-off' },\n \n // Emotions\n 'smile': { lucide: 'Smile', phosphor: 'Smiley', untitled: 'smile' },\n 'frown': { lucide: 'Frown', phosphor: 'SmileySad', untitled: 'frown' },\n 'meh': { lucide: 'Meh', phosphor: 'SmileyMeh', untitled: 'meh' },\n \n // Social\n 'mail': { lucide: 'Mail', phosphor: 'Envelope', untitled: 'mail' },\n 'phone': { lucide: 'Phone', phosphor: 'Phone', untitled: 'phone' },\n \n // Additional\n 'flag': { lucide: 'Flag', phosphor: 'Flag', untitled: 'flag' },\n} as const\n\n/**\n * Initialize Phosphor Icons (lazy load)\n * Only loads when Phosphor provider is used\n * Uses tree-shaking to only include used icons\n */\nexport async function initPhosphorIcons() {\n if (typeof window === 'undefined') return null\n \n if (!PhosphorIcons) {\n try {\n // Dynamic import with tree-shaking support\n // Only icons actually used will be included in bundle\n const phosphorModule = await import('@phosphor-icons/react')\n PhosphorIcons = phosphorModule\n } catch (error) {\n console.warn('Phosphor Icons not available. Install @phosphor-icons/react to use.')\n return null\n }\n }\n return PhosphorIcons\n}\n\n/**\n * Get icon from provider\n * Only resolves icons that are in PROJECT_ICONS for optimal bundle size\n * \n * @param iconName - 아이콘 이름 / Icon name\n * @param provider - 아이콘 프로바이더 (deprecated: IconSet 사용 권장) / Icon provider (deprecated: use IconSet instead)\n * @returns 아이콘 컴포넌트 또는 null / Icon component or null\n */\nexport function getIconFromProvider(\n iconName: string,\n provider: IconProvider | 'lucide' | 'phosphor' | 'untitled' = 'lucide'\n): LucideIcon | React.ComponentType<Record<string, unknown>> | null {\n // Check if icon is in project icon list\n const iconMapping = PROJECT_ICONS[iconName as keyof typeof PROJECT_ICONS]\n \n if (!iconMapping) {\n // Fallback to direct lookup for backward compatibility\n return getIconDirect(iconName, provider)\n }\n \n const mappedName = iconMapping[provider]\n \n switch (provider) {\n case 'lucide':\n return (LucideIcons as unknown as Record<string, LucideIcon>)[mappedName] || null\n \n case 'phosphor':\n if (!PhosphorIcons) {\n return null\n }\n return PhosphorIcons?.[mappedName] || null\n \n case 'untitled':\n // Untitled Icons are SVG-based, handled separately\n return null\n \n default:\n return null\n }\n}\n\n/**\n * Direct icon lookup (fallback for icons not in PROJECT_ICONS)\n * \n * 동적으로 Lucide 아이콘을 가져옵니다.\n * icons.ts에 없는 아이콘도 사용 가능하도록 합니다.\n * \n * Dynamically loads Lucide icons.\n * Allows using icons not in icons.ts.\n * \n * @param iconName - 아이콘 이름 / Icon name\n * @param provider - 아이콘 프로바이더 (deprecated: IconSet 사용 권장) / Icon provider (deprecated: use IconSet instead)\n * @returns 아이콘 컴포넌트 또는 null / Icon component or null\n */\nfunction getIconDirect(\n iconName: string,\n provider: IconProvider | 'lucide' | 'phosphor' | 'untitled'\n): LucideIcon | React.ComponentType<Record<string, unknown>> | null {\n switch (provider) {\n case 'lucide':\n // icons.ts에 없는 아이콘을 동적으로 찾기\n // PascalCase 변환 시도\n const lucideName = iconName.charAt(0).toUpperCase() + iconName.slice(1)\n // camelCase도 시도\n const camelCaseName = iconName.replace(/([A-Z])/g, (match, p1) => \n match === iconName[0] ? match.toLowerCase() : match\n )\n \n return (LucideIcons as unknown as Record<string, LucideIcon>)[lucideName] || \n (LucideIcons as unknown as Record<string, LucideIcon>)[iconName] || \n (LucideIcons as unknown as Record<string, LucideIcon>)[camelCaseName] || \n null\n \n case 'phosphor':\n if (!PhosphorIcons) {\n return null\n }\n const phosphorName1 = iconName.charAt(0).toUpperCase() + iconName.slice(1)\n const phosphorName2 = iconName\n .split(/(?=[A-Z])/)\n .map(word => word.charAt(0).toUpperCase() + word.slice(1))\n .join('')\n return PhosphorIcons?.[phosphorName1] || \n PhosphorIcons?.[phosphorName2] ||\n PhosphorIcons?.[iconName] ||\n null\n \n case 'untitled':\n return null\n \n default:\n return null\n }\n}\n\n/**\n * Get icon name for provider\n * \n * 프로바이더별 아이콘 이름을 가져옵니다.\n * Gets icon name for the specified provider.\n * \n * @param iconName - 아이콘 이름 / Icon name\n * @param provider - 아이콘 프로바이더 (deprecated: IconSet 사용 권장) / Icon provider (deprecated: use IconSet instead)\n * @returns 프로바이더별 아이콘 이름 / Icon name for provider\n */\nexport function getIconNameForProvider(\n iconName: string,\n provider: IconProvider | 'lucide' | 'phosphor' | 'untitled'\n): string {\n const iconMapping = PROJECT_ICONS[iconName as keyof typeof PROJECT_ICONS]\n if (iconMapping && iconMapping[provider]) {\n return iconMapping[provider]\n }\n return iconName\n}\n\n/**\n * Get all project icon names\n */\nexport function getProjectIconNames(): string[] {\n return Object.keys(PROJECT_ICONS)\n}\n","/**\n * Icon Aliases\n * \n * 여러 이름이 같은 아이콘을 가리키도록 하는 alias 시스템\n * DX 향상을 위해 직관적인 이름들을 지원합니다.\n */\n\nexport const ICON_ALIASES: Record<string, string> = {\n // Navigation aliases\n 'back': 'arrowLeft',\n 'prev': 'arrowLeft',\n 'previous': 'arrowLeft',\n 'forward': 'arrowRight',\n 'next': 'arrowRight',\n \n // Close aliases\n 'close': 'x',\n 'cancel': 'x',\n \n // Delete aliases\n 'remove': 'delete',\n 'trash': 'delete',\n \n // Add aliases\n 'plus': 'add',\n 'new': 'add',\n \n // Edit aliases\n 'pencil': 'edit',\n 'modify': 'edit',\n \n // Save aliases\n 'store': 'save',\n 'floppy': 'save',\n \n // Search aliases\n 'magnify': 'search',\n \n // User aliases\n 'person': 'user',\n 'account': 'user',\n 'profile': 'user',\n \n // Settings aliases\n 'gear': 'settings',\n 'config': 'settings',\n 'preferences': 'settings',\n \n // Home aliases\n 'house': 'home',\n 'main': 'home',\n \n // Check aliases\n 'done': 'check',\n 'complete': 'check',\n 'tick': 'check',\n \n // Info aliases\n 'information': 'info',\n 'help': 'info',\n \n // Warning aliases\n 'alert': 'warning',\n 'caution': 'warning',\n \n // Success aliases\n 'checkmark': 'success',\n 'checkCircle': 'success',\n \n // Error aliases\n 'fail': 'error',\n 'cross': 'error',\n 'xCircle': 'error',\n \n // Loading aliases\n 'spinner': 'loader',\n 'loading': 'loader',\n 'wait': 'loader',\n \n // Refresh aliases\n 'reload': 'refresh',\n 'update': 'refresh',\n 'sync': 'refresh',\n \n // Eye aliases\n 'show': 'eye',\n 'view': 'eye',\n 'hide': 'eyeOff',\n 'hidden': 'eyeOff',\n \n // Lock aliases\n 'secure': 'lock',\n 'locked': 'lock',\n 'unsecure': 'unlock',\n 'unlocked': 'unlock',\n \n // Download aliases\n 'get': 'download',\n 'fetch': 'download',\n \n // Upload aliases\n 'post': 'upload',\n \n // Share aliases\n 'send': 'share',\n 'export': 'share',\n \n // Copy aliases\n 'duplicate': 'copy',\n 'clone': 'copy',\n \n // Mail aliases\n 'email': 'mail',\n 'envelope': 'mail',\n \n // Message aliases\n 'chat': 'message',\n 'comment': 'message',\n 'talk': 'message',\n \n // Calendar aliases\n 'date': 'calendar',\n 'schedule': 'calendar',\n \n // Clock aliases\n 'time': 'clock',\n 'watch': 'clock',\n \n // File aliases\n 'document': 'fileText',\n 'doc': 'fileText',\n 'text': 'fileText',\n \n // Folder aliases\n 'directory': 'folder',\n 'dir': 'folder',\n \n // Image aliases\n 'picture': 'image',\n 'img': 'image',\n \n // Video aliases\n 'movie': 'video',\n 'film': 'video',\n \n // Camera aliases\n 'photo': 'camera',\n 'capture': 'camera',\n \n // Play aliases\n 'start': 'play',\n 'run': 'play',\n \n // Pause aliases\n 'stop': 'pause',\n 'halt': 'pause',\n \n // Heart aliases\n 'like': 'heart',\n 'love': 'heart',\n \n // Star aliases\n 'favorite': 'star',\n \n // Bookmark aliases\n 'saveBookmark': 'bookmark',\n \n // Bell aliases\n 'notification': 'bell',\n 'notify': 'bell',\n 'alarm': 'bell',\n \n // Settings aliases\n 'prefs': 'settings',\n \n // Search aliases (duplicate removed - see line 37)\n 'lookup': 'search',\n \n // More aliases\n 'dots': 'moreHorizontal',\n 'moreMenu': 'moreHorizontal',\n 'moreOptions': 'moreVertical',\n \n // External link aliases\n 'external': 'externalLink',\n 'outbound': 'externalLink',\n 'open': 'externalLink',\n \n // Link aliases\n 'url': 'link',\n 'hyperlink': 'link',\n \n // Chart aliases\n 'graph': 'barChart',\n 'stats': 'barChart',\n 'analytics': 'barChart',\n \n // Database aliases\n 'db': 'database',\n 'storage': 'database',\n \n // Activity aliases\n 'pulse': 'activity',\n 'monitor': 'activity',\n \n // Trending aliases\n 'up': 'trendingUp',\n 'down': 'trendingDown',\n \n // Zap aliases\n 'lightning': 'zap',\n 'bolt': 'zap',\n 'flash': 'zap',\n \n // Shield aliases\n 'security': 'shield',\n 'protect': 'shield',\n \n // Key aliases\n 'password': 'key',\n 'secret': 'key',\n \n // Log in aliases\n 'signin': 'logIn',\n 'login': 'logIn',\n 'enter': 'logIn',\n \n // Log out aliases\n 'signout': 'logOut',\n 'logout': 'logOut',\n 'exit': 'logOut',\n \n // Users aliases\n 'people': 'users',\n 'group': 'users',\n 'team': 'users',\n \n // User plus aliases\n 'addUser': 'userPlus',\n 'invite': 'userPlus',\n \n // Book aliases\n 'read': 'book',\n 'library': 'book',\n \n // Book open aliases\n 'reading': 'bookOpen',\n 'openBook': 'bookOpen',\n \n // Sun aliases\n 'light': 'sun',\n 'day': 'sun',\n \n // Moon aliases\n 'dark': 'moon',\n 'night': 'moon',\n \n // Monitor aliases\n 'screen': 'monitor',\n 'display': 'monitor',\n \n // Brain aliases\n 'ai': 'brain',\n 'intelligence': 'brain',\n 'think': 'brain',\n \n // Lightbulb aliases\n 'idea': 'lightbulb',\n 'bulb': 'lightbulb',\n 'inspiration': 'lightbulb',\n \n // Sparkles aliases\n 'magic': 'sparkles',\n 'stars': 'sparkles',\n 'glitter': 'sparkles',\n} as const\n\n/**\n * Resolve icon alias to actual icon name\n * \n * @param iconName - 아이콘 이름 또는 별칭 / Icon name or alias\n * @returns 실제 아이콘 이름 / Actual icon name\n * @throws {TypeError} iconName이 문자열이 아닌 경우\n */\nexport function resolveIconAlias(iconName: string): string {\n if (typeof iconName !== 'string') {\n throw new TypeError('iconName must be a string');\n }\n return ICON_ALIASES[iconName] || iconName;\n}\n\n/**\n * Get all aliases for an icon name\n * \n * @param iconName - 아이콘 이름 / Icon name\n * @returns 해당 아이콘의 모든 별칭 배열 / Array of all aliases for the icon\n * @throws {TypeError} iconName이 문자열이 아닌 경우\n */\nexport function getIconAliases(iconName: string): string[] {\n if (typeof iconName !== 'string') {\n throw new TypeError('iconName must be a string');\n }\n return Object.entries(ICON_ALIASES)\n .filter(([_, target]) => target === iconName)\n .map(([alias]) => alias);\n}\n\n\n","/**\n * Icon Config Types\n * \n * Icon 시스템의 설정 타입 정의\n * 상태관리는 서비스 레벨에서 관리 (Zustand 등)\n */\n\nexport type IconSet = 'lucide' | 'phosphor' | 'untitled'\n\nexport type PhosphorWeight = 'thin' | 'light' | 'regular' | 'bold' | 'duotone' | 'fill'\n\nexport interface IconConfig {\n set: IconSet\n weight: PhosphorWeight\n size: number\n color: string\n strokeWidth?: number // Lucide/Untitled용\n}\n\nexport const defaultIconConfig: IconConfig = {\n set: 'phosphor',\n weight: 'regular',\n size: 20,\n color: 'currentColor',\n strokeWidth: 1.25,\n}\n\n/**\n * 세트별 기본 strokeWidth\n */\nexport const getDefaultStrokeWidth = (set: IconSet): number => {\n switch (set) {\n case 'lucide':\n return 1.25\n case 'phosphor':\n return 1.25 // Phosphor는 weight 사용\n case 'untitled':\n return 1.5\n default:\n return 1.25\n }\n}\n","'use client'\n\n/**\n * IconProvider - Icon 시스템 전역 설정 Provider\n * \n * React Context를 사용하여 전역 아이콘 설정을 제공합니다.\n * 서비스 레벨에서 Zustand 등으로 상태관리 후 props로 전달 가능합니다.\n * \n * IconProvider - Global Icon Settings Provider\n * \n * Provides global icon settings using React Context API.\n * Can be integrated with state management (e.g., Zustand) at the service level.\n */\n\nimport React, { createContext, useContext } from 'react'\nimport { type IconConfig, type IconSet, type PhosphorWeight, defaultIconConfig } from './icon-store'\n\n/**\n * IconProvider 컴포넌트 Props\n * \n * IconProvider component props interface.\n * \n * @interface IconProviderProps\n */\nexport interface IconProviderProps {\n /** 아이콘 세트 (lucide, phosphor, untitled) / Icon set (lucide, phosphor, untitled) */\n set?: IconSet\n /** Phosphor 아이콘 weight (thin, light, regular, bold, duotone, fill) / Phosphor icon weight */\n weight?: PhosphorWeight\n /** 기본 아이콘 크기 / Default icon size */\n size?: number\n /** 기본 아이콘 색상 / Default icon color */\n color?: string\n /** Lucide/Untitled 아이콘 stroke width / Lucide/Untitled icon stroke width */\n strokeWidth?: number\n /** 자식 컴포넌트 / Child components */\n children: React.ReactNode\n}\n\ninterface IconContextValue extends IconConfig {}\n\nconst IconContext = createContext<IconContextValue>(defaultIconConfig)\n\n/**\n * IconProvider 컴포넌트\n * \n * 전역 아이콘 설정을 Context로 제공합니다.\n * 서비스에서 Zustand로 관리한 값을 props로 전달할 수 있습니다.\n * \n * IconProvider component\n * \n * Provides global icon settings through Context API.\n * Can receive values managed by Zustand at the service level.\n * \n * @component\n * @example\n * ```tsx\n * // 기본 사용 / Basic usage\n * <IconProvider set=\"phosphor\" weight=\"regular\" size={20}>\n * <App />\n * </IconProvider>\n * \n * // Zustand와 함께 사용 / With Zustand\n * const iconConfig = useIconStore(state => state.iconConfig)\n * <IconProvider {...iconConfig}>\n * <App />\n * </IconProvider>\n * \n * // Lucide 아이콘 사용 / Using Lucide icons\n * <IconProvider set=\"lucide\" size={24} strokeWidth={1.5}>\n * <App />\n * </IconProvider>\n * ```\n * \n * @param props - IconProvider 컴포넌트 props / IconProvider component props\n * @returns IconProvider 컴포넌트 / IconProvider component\n */\nexport function IconProvider({\n set = defaultIconConfig.set,\n weight = defaultIconConfig.weight,\n size = defaultIconConfig.size,\n color = defaultIconConfig.color,\n strokeWidth = defaultIconConfig.strokeWidth,\n children,\n}: IconProviderProps) {\n const value: IconContextValue = {\n set,\n weight,\n size,\n color,\n strokeWidth,\n }\n\n return (\n <IconContext.Provider value={value}>\n {children}\n </IconContext.Provider>\n )\n}\n\n/**\n * useIconContext Hook\n * \n * Icon Context를 사용하는 Hook입니다.\n * Icon 컴포넌트 내부에서 사용됩니다.\n * \n * Hook to use Icon Context.\n * Used internally by Icon component.\n * \n * @returns Icon 설정 값 / Icon configuration value\n * \n * @example\n * ```tsx\n * // Icon 컴포넌트 내부에서 사용 / Used inside Icon component\n * const config = useIconContext()\n * const iconSet = config.set\n * const iconSize = config.size\n * ```\n */\nexport function useIconContext(): IconContextValue {\n return useContext(IconContext)\n}\n\n// Re-export types for convenience\nexport type { IconSet, PhosphorWeight, IconConfig } from './icon-store'\nexport { defaultIconConfig, getDefaultStrokeWidth } from './icon-store'\n\n","import React from 'react'\nimport type { LucideProps } from 'lucide-react'\nimport { merge, mergeMap } from '../../lib/utils'\nimport { icons, IconName, emotionIcons, statusIcons } from '../../lib/icons'\nimport { getIconFromProvider, initPhosphorIcons } from '../../lib/icon-providers'\nimport { resolveIconAlias } from '../../lib/icon-aliases'\nimport { useIconContext, type IconSet } from './IconProvider'\nimport { type PhosphorWeight } from './icon-store'\nimport type { AllIconName } from '../../lib/icon-names'\n\n/**\n * Icon 컴포넌트 Props\n * \n * Icon component props interface.\n * \n * @interface IconProps\n */\nexport interface IconProps {\n /** 아이콘 이름 / Icon name */\n name: AllIconName\n /** 아이콘 크기 (숫자 또는 문자열) / Icon size (number or string) */\n size?: number | string\n /** 추가 CSS 클래스 / Additional CSS classes */\n className?: string\n /** 감정 아이콘 타입 / Emotion icon type */\n emotion?: keyof typeof emotionIcons\n /** 상태 아이콘 타입 / Status icon type */\n status?: keyof typeof statusIcons\n /** 아이콘 프로바이더 오버라이드 (전역 설정 무시) / Icon provider override (ignores global config) */\n provider?: IconSet\n /** 부드러운 애니메이션 효과 / Smooth animation effect */\n animated?: boolean\n /** 펄스 애니메이션 / Pulse animation */\n pulse?: boolean\n /** 회전 애니메이션 / Spin animation */\n spin?: boolean\n /** 바운스 애니메이션 / Bounce animation */\n bounce?: boolean\n /** 색상 변형 / Color variant */\n variant?: 'default' | 'primary' | 'secondary' | 'success' | 'warning' | 'error' | 'muted'\n /** Phosphor 아이콘 weight 오버라이드 / Phosphor icon weight override */\n weight?: PhosphorWeight\n /** 스크린 리더용 라벨 (의미 있는 아이콘인 경우) / Screen reader label (for meaningful icons) */\n 'aria-label'?: string\n /** 장식용 아이콘인 경우 true (스크린 리더에서 숨김) / Set to true for decorative icons (hidden from screen readers) */\n 'aria-hidden'?: boolean\n}\n\n/**\n * Icon 컴포넌트\n * \n * 다중 아이콘 라이브러리(Lucide, Phosphor, Untitled)를 지원하는 통합 아이콘 컴포넌트입니다.\n * IconProvider를 통해 전역 설정을 관리할 수 있으며, 개별 아이콘에서도 설정을 오버라이드할 수 있습니다.\n * \n * Icon component that supports multiple icon libraries (Lucide, Phosphor, Untitled).\n * Global settings can be managed through IconProvider, and individual icons can override settings.\n * \n * @component\n * @example\n * ```tsx\n * // 기본 사용 / Basic usage\n * <Icon name=\"heart\" />\n * \n * // 크기 지정 / Specify size\n * <Icon name=\"user\" size={24} />\n * \n * // 색상 변형 / Color variant\n * <Icon name=\"check\" variant=\"success\" />\n * \n * // 애니메이션 / Animation\n * <Icon name=\"loader\" spin />\n * <Icon name=\"heart\" pulse />\n * \n * // 접근성 / Accessibility\n * <Icon name=\"search\" aria-label=\"검색\" />\n * <Icon name=\"decorative-icon\" aria-hidden />\n * \n * // 감정 아이콘 / Emotion icon\n * <Icon emotion=\"happy\" />\n * \n * // 상태 아이콘 / Status icon\n * <Icon status=\"loading\" spin />\n * ```\n * \n * @param props - Icon 컴포넌트 props / Icon component props\n * @returns Icon 컴포넌트 / Icon component\n */\nconst IconComponent = React.forwardRef<HTMLSpanElement, IconProps>(({\n name,\n size,\n className,\n emotion,\n status,\n provider,\n weight,\n animated = false,\n pulse = false,\n spin = false,\n bounce = false,\n variant = 'default',\n 'aria-label': ariaLabel,\n 'aria-hidden': ariaHidden\n}, ref) => {\n // Context에서 전역 설정 가져오기\n const config = useIconContext()\n \n // prop으로 오버라이드 가능, 없으면 Context에서 가져옴\n const iconSet = provider || config.set\n const iconSize = size ?? config.size\n const iconWeight = weight || config.weight\n const iconColor = config.color\n const iconStrokeWidth = config.strokeWidth ?? 1.25\n \n // 클라이언트 사이드에서만 아이콘 렌더링 (hydration 오류 방지)\n const [isClient, setIsClient] = React.useState(false)\n const [phosphorReady, setPhosphorReady] = React.useState(false)\n \n React.useEffect(() => {\n setIsClient(true)\n \n // Phosphor Icons 초기화 (provider가 phosphor일 때만)\n if (iconSet === 'phosphor') {\n initPhosphorIcons().then(() => {\n setPhosphorReady(true)\n })\n } else {\n setPhosphorReady(true)\n }\n }, [iconSet])\n\n // 감정이나 상태가 지정되면 해당 아이콘으로 오버라이드\n let iconName = emotion ? emotionIcons[emotion] : \n status ? statusIcons[status] : \n name\n \n // Alias 해결 (back, prev → arrowLeft 등)\n iconName = resolveIconAlias(iconName) as AllIconName\n \n // 색상 변형 클래스 (먼저 선언 - fallback에서 사용)\n const variantClasses = mergeMap({\n 'text-gray-900 dark:text-white': variant === 'default',\n 'text-blue-600 dark:text-blue-400': variant === 'primary',\n 'text-gray-600 dark:text-gray-400': variant === 'secondary',\n 'text-green-600 dark:text-green-400': variant === 'success',\n 'text-yellow-600 dark:text-yellow-400': variant === 'warning',\n 'text-red-600 dark:text-red-400': variant === 'error',\n 'text-gray-500 dark:text-gray-500': variant === 'muted',\n })\n \n // 서버사이드에서는 빈 span 반환 (hydration 오류 방지)\n // Return empty span on server-side (prevent hydration errors)\n if (!isClient || (iconSet === 'phosphor' && !phosphorReady)) {\n return (\n <span\n style={{ width: iconSize, height: iconSize }}\n className={merge(variantClasses, className)}\n aria-hidden={ariaHidden !== undefined ? ariaHidden : true}\n aria-label={ariaLabel}\n />\n )\n }\n\n // Provider에 따라 아이콘 가져오기\n type IconComponentType = React.ComponentType<LucideProps | React.SVGProps<SVGSVGElement> | Record<string, unknown>>\n let IconComponent: IconComponentType | null = null\n \n if (iconSet === 'lucide') {\n // 1. icons.ts에서 먼저 찾기 (실제 사용되는 아이콘만 포함)\n // 타입 단언: AllIconName에는 있지만 icons 객체에 없는 경우를 위해\n IconComponent = (icons[iconName as IconName] || null) as IconComponentType | null\n \n // 2. 없으면 동적으로 Lucide에서 가져오기 (fallback)\n if (!IconComponent) {\n IconComponent = getIconFromProvider(iconName, iconSet) as IconComponentType | null\n }\n } else {\n // Phosphor나 다른 provider는 getIconFromProvider 사용\n // phosphorReady가 true일 때만 호출됨 (위에서 체크)\n IconComponent = getIconFromProvider(iconName, iconSet) as IconComponentType | null\n }\n \n if (!IconComponent) {\n console.warn(`Icon \"${iconName}\" not found for provider \"${iconSet}\"`)\n // Fallback: 빈 원형 아이콘 표시 (에러 표시)\n // Fallback: display empty circle icon (error indicator)\n return (\n <span\n ref={ref}\n className={merge(\n 'inline-flex items-center justify-center rounded-full border-2 border-dashed border-gray-300 dark:border-gray-600',\n variantClasses,\n className\n )}\n style={{ width: iconSize, height: iconSize }}\n aria-label={ariaLabel || `아이콘을 찾을 수 없음: ${iconName}`}\n title={`Icon not found: ${iconName}`}\n >\n <span className=\"text-xs text-gray-400 dark:text-gray-500\" aria-hidden=\"true\">\n ?\n </span>\n </span>\n )\n }\n \n // 세트별 props 준비\n type IconPropsType = LucideProps & {\n size?: number\n width?: number | string\n height?: number | string\n color?: string\n weight?: PhosphorWeight\n strokeWidth?: number\n }\n \n const iconProps: IconPropsType = {\n size: typeof iconSize === 'number' ? iconSize : undefined,\n width: typeof iconSize === 'string' ? iconSize : iconSize,\n height: typeof iconSize === 'string' ? iconSize : iconSize,\n color: iconColor,\n } as IconPropsType\n \n // Phosphor는 weight 사용\n if (iconSet === 'phosphor') {\n iconProps.weight = iconWeight\n } else {\n // Lucide/Untitled는 strokeWidth 사용\n iconProps.strokeWidth = iconStrokeWidth\n }\n\n // 애니메이션 클래스 생성\n const animationClasses = mergeMap({\n 'animate-pulse': pulse,\n 'animate-spin': spin,\n 'animate-bounce': bounce,\n 'transition-all duration-200 ease-in-out': animated,\n })\n\n // 접근성 속성 결정 / Determine accessibility attributes\n // aria-label이 제공되면 사용, 없으면 aria-hidden이 true인지 확인\n // If aria-label is provided, use it; otherwise check if aria-hidden is true\n const accessibilityProps: React.AriaAttributes = {}\n \n if (ariaLabel) {\n accessibilityProps['aria-label'] = ariaLabel\n accessibilityProps['aria-hidden'] = false\n } else if (ariaHidden !== undefined) {\n accessibilityProps['aria-hidden'] = ariaHidden\n } else {\n // 기본값: 장식용으로 간주 (의미 있는 아이콘은 명시적으로 aria-label 제공 필요)\n // Default: considered decorative (meaningful icons should explicitly provide aria-label)\n accessibilityProps['aria-hidden'] = true\n }\n\n return (\n <span\n ref={ref}\n className={merge(\n 'inline-flex items-center justify-center',\n animationClasses,\n variantClasses,\n className\n )}\n style={{ width: iconSize, height: iconSize }}\n {...accessibilityProps}\n >\n {IconComponent && React.createElement(IconComponent, { \n ...iconProps,\n className: variantClasses,\n 'aria-hidden': true // SVG 내부 요소는 항상 숨김 (외부 span이 접근성 담당)\n } as React.ComponentProps<typeof IconComponent>)}\n </span>\n )\n})\n\nIconComponent.displayName = 'Icon'\n\n// 성능 최적화: React.memo 적용\n// Performance optimization: Apply React.memo\n// forwardRef와 함께 사용할 때는 React.memo로 감싸기\n// When using with forwardRef, wrap with React.memo\nconst MemoizedIcon = React.memo(IconComponent, (prevProps, nextProps) => {\n // props 비교 함수: 변경된 props만 체크\n // Props comparison function: only check changed props\n return (\n prevProps.name === nextProps.name &&\n prevProps.size === nextProps.size &&\n prevProps.className === nextProps.className &&\n prevProps.emotion === nextProps.emotion &&\n prevProps.status === nextProps.status &&\n prevProps.provider === nextProps.provider &&\n prevProps.animated === nextProps.animated &&\n prevProps.pulse === nextProps.pulse &&\n prevProps.spin === nextProps.spin &&\n prevProps.bounce === nextProps.bounce &&\n prevProps.variant === nextProps.variant &&\n prevProps.weight === nextProps.weight &&\n prevProps['aria-label'] === nextProps['aria-label'] &&\n prevProps['aria-hidden'] === nextProps['aria-hidden']\n )\n})\n\n// 타입 안전성을 위해 export\n// Export for type safety\nexport const Icon = MemoizedIcon as typeof IconComponent\n\nIcon.displayName = 'Icon'\n\n/**\n * EmotionIcon 컴포넌트\n * \n * 감정을 표현하는 아이콘 컴포넌트입니다.\n * Icon component for expressing emotions.\n * \n * @component\n * @example\n * ```tsx\n * <EmotionIcon emotion=\"happy\" />\n * <EmotionIcon emotion=\"sad\" size={24} />\n * ```\n */\nexport const EmotionIcon = React.forwardRef<HTMLSpanElement, Omit<IconProps, 'name'> & { emotion: keyof typeof emotionIcons }>(\n (props, ref) => <Icon ref={ref} name=\"smile\" {...props} />\n)\n\nEmotionIcon.displayName = 'EmotionIcon'\n\n/**\n * StatusIcon 컴포넌트\n * \n * 상태를 표현하는 아이콘 컴포넌트입니다.\n * Icon component for expressing status.\n * \n * @component\n * @example\n * ```tsx\n * <StatusIcon status=\"loading\" spin />\n * <StatusIcon status=\"success\" variant=\"success\" />\n * ```\n */\nexport const StatusIcon = React.forwardRef<HTMLSpanElement, Omit<IconProps, 'name'> & { status: keyof typeof statusIcons }>(\n (props, ref) => <Icon ref={ref} name=\"info\" {...props} />\n)\n\nStatusIcon.displayName = 'StatusIcon'\n\n/**\n * LoadingIcon 컴포넌트\n * \n * 로딩 상태를 표시하는 전용 아이콘 컴포넌트입니다.\n * Dedicated icon component for displaying loading status.\n * \n * @component\n * @example\n * ```tsx\n * <LoadingIcon />\n * <LoadingIcon size={32} />\n * ```\n */\nexport const LoadingIcon = React.forwardRef<HTMLDivElement, Omit<IconProps, 'name' | 'status'>>(\n (props, ref) => (\n <Icon ref={ref} name=\"loader\" status=\"loading\" spin aria-label=\"로딩 중\" {...props} />\n )\n)\n\nLoadingIcon.displayName = 'LoadingIcon'\n\n/**\n * SuccessIcon 컴포넌트\n * \n * 성공 상태를 표시하는 전용 아이콘 컴포넌트입니다.\n * Dedicated icon component for displaying success status.\n * \n * @component\n * @example\n * ```tsx\n * <SuccessIcon />\n * <SuccessIcon size={24} />\n * ```\n */\nexport const SuccessIcon = React.forwardRef<HTMLDivElement, Omit<IconProps, 'name' | 'status'>>(\n (props, ref) => (\n <Icon ref={ref} name=\"check\" status=\"success\" variant=\"success\" aria-label=\"성공\" {...props} />\n )\n)\n\nSuccessIcon.displayName = 'SuccessIcon'\n\n/**\n * ErrorIcon 컴포넌트\n * \n * 에러 상태를 표시하는 전용 아이콘 컴포넌트입니다.\n * Dedicated icon component for displaying error status.\n * \n * @component\n * @example\n * ```tsx\n * <ErrorIcon />\n * <ErrorIcon size={24} />\n * ```\n */\nexport const ErrorIcon = React.forwardRef<HTMLDivElement, Omit<IconProps, 'name' | 'status'>>(\n (props, ref) => (\n <Icon ref={ref} name=\"alertCircle\" status=\"error\" variant=\"error\" aria-label=\"오류\" {...props} />\n )\n)\n\nErrorIcon.displayName = 'ErrorIcon'\n\n","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Avatar 컴포넌트의 props / Avatar component props\n * @typedef {Object} AvatarProps\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - 아바타 크기 / Avatar size\n * @property {\"default\" | \"glass\"} [variant=\"default\"] - 아바타 스타일 변형 / Avatar style variant\n * @property {string} [src] - 이미지 URL / Image URL\n * @property {string} [alt] - 이미지 대체 텍스트 / Image alt text\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface AvatarProps extends React.HTMLAttributes<HTMLDivElement> {\n size?: \"sm\" | \"md\" | \"lg\"\n variant?: \"default\" | \"glass\"\n src?: string\n alt?: string\n}\n\n/**\n * AvatarImage 컴포넌트의 props\n * @typedef {Object} AvatarImageProps\n * @extends {React.ImgHTMLAttributes<HTMLImageElement>}\n */\nexport interface AvatarImageProps extends React.ImgHTMLAttributes<HTMLImageElement> {}\n\n/**\n * AvatarFallback 컴포넌트의 props\n * @typedef {Object} AvatarFallbackProps\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface AvatarFallbackProps extends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Avatar 컴포넌트 / Avatar component\n * \n * 사용자 프로필 이미지를 표시하는 컴포넌트입니다.\n * 이미지가 없을 경우 대체 텍스트나 초기 문자를 표시합니다.\n * \n * Component for displaying user profile images.\n * Shows fallback text or initials when image is not available.\n * \n * @component\n * @example\n * // 기본 사용 (이미지) / Basic usage (with image)\n * <Avatar src=\"/user.jpg\" alt=\"사용자\" />\n * \n * @example\n * // 대체 텍스트 / Fallback text\n * <Avatar alt=\"홍길동\">홍</Avatar>\n * \n * @example\n * // Glass 스타일 / Glass style\n * <Avatar variant=\"glass\" size=\"lg\" src=\"/user.jpg\" alt=\"사용자\" />\n * \n * @param {AvatarProps} props - Avatar 컴포넌트의 props / Avatar component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Avatar 컴포넌트 / Avatar component\n */\nconst Avatar = React.forwardRef<HTMLDivElement, AvatarProps>(\n ({ className, size = \"md\", variant = \"default\", src, alt, children, ...props }, ref) => {\n const sizeClasses = {\n sm: \"w-8 h-8\",\n md: \"w-10 h-10\", \n lg: \"w-12 h-12\"\n }\n\n const variantClasses = {\n default: \"\",\n glass: \"ring-2 ring-white/30 backdrop-blur-sm\"\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n \"relative flex shrink-0 overflow-hidden rounded-full\",\n sizeClasses[size],\n variantClasses[variant],\n className\n )}\n {...props}\n >\n {src ? (\n <AvatarImage src={src} alt={alt || \"avatar\"} />\n ) : (\n <AvatarFallback>\n {children || (alt ? alt.charAt(0).toUpperCase() : \"U\")}\n </AvatarFallback>\n )}\n </div>\n )\n }\n)\nAvatar.displayName = \"Avatar\"\n\n/**\n * AvatarImage 컴포넌트 / AvatarImage component\n * \n * 아바타 이미지를 표시하는 컴포넌트입니다.\n * Displays the avatar image.\n * \n * @component\n * @param {AvatarImageProps} props - AvatarImage 컴포넌트의 props / AvatarImage component props\n * @param {React.Ref<HTMLImageElement>} ref - img 요소 ref / img element ref\n * @returns {JSX.Element} AvatarImage 컴포넌트 / AvatarImage component\n */\nconst AvatarImage = React.forwardRef<HTMLImageElement, AvatarImageProps>(\n ({ className, ...props }, ref) => (\n <img\n ref={ref}\n className={merge(\"aspect-square h-full w-full object-cover object-center\", className)}\n {...props}\n />\n )\n)\nAvatarImage.displayName = \"AvatarImage\"\n\n/**\n * AvatarFallback 컴포넌트 / AvatarFallback component\n * \n * 아바타 이미지가 없을 때 표시되는 대체 컴포넌트입니다.\n * Fallback component displayed when avatar image is not available.\n * \n * @component\n * @param {AvatarFallbackProps} props - AvatarFallback 컴포넌트의 props / AvatarFallback component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} AvatarFallback 컴포넌트 / AvatarFallback component\n */\nconst AvatarFallback = React.forwardRef<HTMLDivElement, AvatarFallbackProps>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\n \"flex h-full w-full items-center justify-center rounded-full bg-gray-100 dark:bg-gray-800 text-gray-600 dark:text-gray-400 font-medium\",\n className\n )}\n {...props}\n />\n )\n)\nAvatarFallback.displayName = \"AvatarFallback\"\n\nexport { Avatar, AvatarImage, AvatarFallback } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Modal 컴포넌트의 props / Modal component props\n * @typedef {Object} ModalProps\n * @property {boolean} isOpen - 모달 열림/닫힘 상태 / Modal open/close state\n * @property {() => void} onClose - 모달 닫기 콜백 함수 / Modal close callback function\n * @property {React.ReactNode} children - 모달 내용 / Modal content\n * @property {\"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\" | \"3xl\"} [size=\"md\"] - 모달 크기 / Modal size\n * @property {boolean} [showCloseButton=true] - 닫기 버튼 표시 여부 / Show close button\n * @property {boolean} [closeOnOverlayClick=true] - 오버레이 클릭 시 닫기 여부 / Close on overlay click\n * @property {string} [title] - 모달 제목 / Modal title\n * @property {string} [description] - 모달 설명 / Modal description\n * @property {boolean} [showBackdrop=true] - 배경 오버레이 표시 여부 / Show backdrop overlay\n * @property {string} [backdropClassName] - 배경 오버레이 추가 CSS 클래스 / Additional CSS class for backdrop\n * @property {boolean} [centered=true] - 모달을 화면 중앙에 배치할지 여부 / Center modal on screen\n * @property {string} [className] - 모달 컨테이너 추가 CSS 클래스 / Additional CSS class for modal container\n */\nexport interface ModalProps {\n isOpen: boolean\n onClose: () => void\n children: React.ReactNode\n size?: \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\" | \"3xl\"\n showCloseButton?: boolean\n closeOnOverlayClick?: boolean\n title?: string\n description?: string\n showBackdrop?: boolean\n backdropClassName?: string\n centered?: boolean\n className?: string\n}\n\n// Ref 병합 유틸리티\nfunction useCombinedRefs<T>(...refs: (React.Ref<T> | undefined)[]): React.RefCallback<T> {\n return React.useCallback(\n (node: T) => {\n refs.forEach((ref) => {\n if (!ref) return;\n if (typeof ref === \"function\") {\n ref(node);\n } else {\n (ref as React.MutableRefObject<T | null>).current = node;\n }\n });\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n refs\n );\n}\n\n/**\n * Modal 컴포넌트 / Modal component\n * \n * 오버레이와 함께 표시되는 모달 다이얼로그 컴포넌트입니다.\n * ESC 키로 닫기, 오버레이 클릭으로 닫기, 접근성 속성(ARIA)을 지원합니다.\n * \n * Modal dialog component displayed with overlay.\n * Supports closing with ESC key, overlay click, and ARIA accessibility attributes.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * const [isOpen, setIsOpen] = useState(false)\n * \n * <Modal isOpen={isOpen} onClose={() => setIsOpen(false)}>\n * <p>모달 내용</p>\n * </Modal>\n * \n * @example\n * // 제목과 설명 포함 / With title and description\n * <Modal\n * isOpen={isOpen}\n * onClose={() => setIsOpen(false)}\n * title=\"확인\"\n * description=\"이 작업을 계속하시겠습니까?\"\n * >\n * <Button onClick={handleConfirm}>확인</Button>\n * </Modal>\n * \n * @example\n * // 큰 크기 모달 / Large size modal\n * <Modal\n * isOpen={isOpen}\n * onClose={() => setIsOpen(false)}\n * size=\"xl\"\n * closeOnOverlayClick={false}\n * >\n * <div>큰 모달 내용</div>\n * </Modal>\n * \n * @param {ModalProps} props - Modal 컴포넌트의 props / Modal component props\n * @param {React.Ref<HTMLDivElement>} ref - 모달 컨테이너 ref / Modal container ref\n * @returns {JSX.Element} Modal 컴포넌트 / Modal component\n */\nexport const Modal = React.forwardRef<HTMLDivElement, ModalProps>(\n ({ \n className,\n isOpen,\n onClose,\n children,\n size = \"md\",\n showCloseButton = true,\n closeOnOverlayClick = true,\n title,\n description,\n showBackdrop = true,\n backdropClassName,\n centered = true\n }, ref) => {\n const modalRef = React.useRef<HTMLDivElement>(null)\n const combinedRef = useCombinedRefs(ref, modalRef)\n\n // ESC 키로 모달 닫기 및 스크롤 잠금 (화면 흔들림 방지)\n React.useEffect(() => {\n const handleEscape = (e: KeyboardEvent) => {\n if (e.key === \"Escape\") {\n onClose()\n }\n }\n\n if (isOpen) {\n document.addEventListener(\"keydown\", handleEscape)\n // 스크롤바 너비 계산하여 padding 추가 (화면 흔들림 방지)\n const scrollbarWidth = window.innerWidth - document.documentElement.clientWidth\n document.body.style.overflow = \"hidden\"\n document.body.style.paddingRight = `${scrollbarWidth}px`\n }\n\n return () => {\n document.removeEventListener(\"keydown\", handleEscape)\n document.body.style.overflow = \"unset\"\n document.body.style.paddingRight = \"unset\"\n }\n }, [isOpen, onClose])\n\n // 모달 외부 클릭으로 닫기\n const handleOverlayClick = (e: React.MouseEvent) => {\n if (closeOnOverlayClick && e.target === e.currentTarget) {\n onClose()\n }\n }\n\n // 모달 크기 클래스 (반응형 포함)\n const sizeClasses = {\n sm: \"md:w-80\", // 20rem = 320px\n md: \"md:w-96\", // 24rem = 384px\n lg: \"md:w-[32rem]\", // 32rem = 512px\n xl: \"md:w-[38rem]\", // 38rem = 608px\n \"2xl\": \"md:w-[50rem]\", // 50rem = 800px\n \"3xl\": \"md:w-[72rem]\" // 72rem = 1152px (더 넓게)\n }\n\n // 접근성을 위한 ID 생성\n const titleId = title ? `modal-title-${React.useId()}` : undefined;\n const descriptionId = description ? `modal-description-${React.useId()}` : undefined;\n\n if (!isOpen) return null\n\n return (\n <div\n className={merge(\n \"fixed top-0 left-0 right-0 bottom-0 z-50 flex justify-center p-4 overflow-hidden\", // PWA 호환성 개선\n centered ? \"items-center\" : \"items-start pt-16\", // 64px 상단 여백\n className\n )}\n style={{\n width: '100vw',\n height: '100vh',\n minHeight: '100vh'\n }}\n onClick={handleOverlayClick}\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby={titleId}\n aria-describedby={descriptionId}\n >\n {/* 배경 오버레이 */}\n {showBackdrop && (\n <div className={merge(\n \"absolute inset-0 bg-black/60 backdrop-blur-md transition-opacity duration-300\",\n backdropClassName\n )} />\n )}\n \n {/* 모달 컨테이너 */}\n <div\n ref={combinedRef}\n className={merge(\n \"relative bg-white dark:bg-gray-800 rounded-lg shadow-2xl border border-gray-200/50 dark:border-gray-700/50 transform transition-all duration-300 ease-out overflow-hidden\",\n // 반응형: 모바일 전체, 데스크톱 고정\n \"w-[calc(100vw-2rem)]\", // 모바일: 화면 너비 - 패딩\n sizeClasses[size], // 데스크톱: md:w-[72rem]\n \"max-w-[calc(100vw-2rem)] md:max-w-none\", // 모바일: 최대 너비 제한, 데스크톱: 제한 없음\n \"flex-none\" // flex 컨테이너에서 크기 유지\n )}\n style={{\n animation: \"modalSlideIn 0.3s cubic-bezier(0.16, 1, 0.3, 1)\",\n maxHeight: \"90vh\",\n marginTop: centered ? 'auto' : '0',\n marginBottom: centered ? 'auto' : '0'\n }}\n >\n \n {/* 헤더 */}\n {title && (\n <div className=\"relative z-10 px-6 pt-6 pb-4 border-b border-gray-200/50 dark:border-gray-700/50\">\n {/* 타이틀과 닫기 버튼 - 같은 줄, 양쪽 끝 */}\n <div className=\"flex items-center justify-between gap-4 mb-2\">\n <h2 id={titleId} className=\"text-xl font-semibold text-gray-900 dark:text-white flex-1 min-w-0\">{title}</h2>\n {/* 닫기 버튼 - 타이틀과 같은 계층의 오른쪽 끝 */}\n {showCloseButton && (\n <button\n onClick={onClose}\n className=\"flex-shrink-0 p-2 text-gray-400 hover:text-gray-600 dark:hover:text-gray-300 transition-all duration-200 rounded-full hover:bg-gray-100 dark:hover:bg-gray-700 hover:scale-110 z-20\"\n aria-label=\"닫기\"\n >\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n </button>\n )}\n </div>\n {/* 설명 - 아래 줄 */}\n {description && (\n <p id={descriptionId} className=\"text-sm text-gray-600 dark:text-gray-400\">{description}</p>\n )}\n </div>\n )}\n \n {/* 타이틀이 없을 때만 별도 닫기 버튼 */}\n {!title && showCloseButton && (\n <button\n onClick={onClose}\n className=\"absolute top-4 right-4 p-2 text-gray-400 hover:text-gray-600 dark:hover:text-gray-300 transition-all duration-200 rounded-full hover:bg-gray-100 dark:hover:bg-gray-700 hover:scale-110 z-20\"\n aria-label=\"닫기\"\n >\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n </button>\n )}\n \n {/* 모달 내용 */}\n <div className={`relative z-10 ${title ? 'px-6 mb-6' : 'p-6'}`}>\n {children}\n </div>\n </div>\n </div>\n )\n})\n\nModal.displayName = \"Modal\" ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Container 컴포넌트의 props\n * @typedef {Object} ContainerProps\n * @property {\"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\"} [size=\"lg\"] - 컨테이너 최대 너비\n * @property {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"} [padding=\"md\"] - 내부 패딩 크기\n * @property {boolean} [centered=true] - 컨테이너를 중앙 정렬할지 여부\n * @property {boolean} [fluid=false] - 최대 너비 제한 없이 전체 너비 사용\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface ContainerProps extends React.HTMLAttributes<HTMLDivElement> {\n size?: \"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\"\n padding?: \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"\n centered?: boolean\n fluid?: boolean\n}\n\n/**\n * Container 컴포넌트\n * \n * 콘텐츠를 감싸는 컨테이너 컴포넌트입니다.\n * 반응형 최대 너비와 패딩을 제공하여 일관된 레이아웃을 구성합니다.\n * \n * @component\n * @example\n * // 기본 사용\n * <Container>\n * <h1>제목</h1>\n * <p>내용</p>\n * </Container>\n * \n * @example\n * // 작은 크기, 패딩 없음\n * <Container size=\"sm\" padding=\"none\">\n * <div>콘텐츠</div>\n * </Container>\n * \n * @example\n * // 전체 너비 사용\n * <Container fluid padding=\"xl\">\n * <div>전체 너비 콘텐츠</div>\n * </Container>\n * \n * @param {ContainerProps} props - Container 컴포넌트의 props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref\n * @returns {JSX.Element} Container 컴포넌트\n */\nconst Container = React.forwardRef<HTMLDivElement, ContainerProps>(\n ({ \n className, \n size = \"lg\",\n padding = \"md\",\n centered = true,\n fluid = false,\n ...props \n }, ref) => {\n const sizeClasses = {\n sm: \"max-w-2xl\", // 672px\n md: \"max-w-4xl\", // 896px\n lg: \"max-w-6xl\", // 1152px\n xl: \"max-w-7xl\", // 1280px\n full: \"max-w-full\"\n }\n\n const paddingClasses = {\n none: \"\",\n sm: \"px-4 py-8\", // 16px 좌우, 32px 상하\n md: \"px-6 py-12\", // 24px 좌우, 48px 상하\n lg: \"px-8 py-16\", // 32px 좌우, 64px 상하\n xl: \"px-12 py-20\" // 48px 좌우, 80px 상하\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n \"w-full\",\n !fluid && sizeClasses[size],\n paddingClasses[padding],\n centered && \"mx-auto\",\n \"bg-white/5 backdrop-blur-sm rounded-xl shadow-xl\",\n \"dark:bg-slate-900/5\",\n className\n )}\n {...props}\n />\n )\n }\n)\nContainer.displayName = \"Container\"\n\nexport { Container } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Grid 컴포넌트의 props\n * @typedef {Object} GridProps\n * @property {1|2|3|4|5|6|7|8|9|10|11|12} [cols=1] - 그리드 열 개수\n * @property {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"} [gap=\"md\"] - 그리드 아이템 간 간격\n * @property {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"} [gapX] - 가로 간격 (gap보다 우선)\n * @property {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"} [gapY] - 세로 간격\n * @property {boolean} [responsive=true] - 반응형 그리드 활성화 (모바일: 1열, 태블릿: 2열, 데스크톱: 지정 열)\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface GridProps extends React.HTMLAttributes<HTMLDivElement> {\n cols?: 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12\n gap?: \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"\n gapX?: \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"\n gapY?: \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"\n responsive?: boolean\n}\n\n/**\n * Grid 컴포넌트\n * \n * CSS Grid를 사용한 그리드 레이아웃 컴포넌트입니다.\n * 반응형 그리드를 지원하여 모바일부터 데스크톱까지 최적화된 레이아웃을 제공합니다.\n * \n * @component\n * @example\n * // 기본 3열 그리드\n * <Grid cols={3} gap=\"md\">\n * <div>아이템 1</div>\n * <div>아이템 2</div>\n * <div>아이템 3</div>\n * </Grid>\n * \n * @example\n * // 가로/세로 간격 분리\n * <Grid cols={4} gapX=\"lg\" gapY=\"sm\">\n * {items.map(item => <div key={item.id}>{item.content}</div>)}\n * </Grid>\n * \n * @example\n * // 반응형 비활성화 (고정 그리드)\n * <Grid cols={6} responsive={false} gap=\"lg\">\n * <div>고정 6열</div>\n * </Grid>\n * \n * @param {GridProps} props - Grid 컴포넌트의 props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref\n * @returns {JSX.Element} Grid 컴포넌트\n */\nconst Grid = React.forwardRef<HTMLDivElement, GridProps>(\n ({ \n className, \n cols = 1,\n gap = \"md\",\n gapX,\n gapY,\n responsive = true,\n ...props \n }, ref) => {\n const colsClasses = {\n 1: \"grid-cols-1\",\n 2: \"grid-cols-1 sm:grid-cols-2\",\n 3: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-3\",\n 4: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-4\",\n 5: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-5\",\n 6: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-6\",\n 7: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-7\",\n 8: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-8\",\n 9: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-9\",\n 10: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-10\",\n 11: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-11\",\n 12: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-12\"\n }\n\n const gapClasses = {\n none: \"gap-0\",\n sm: \"gap-4\", // 16px\n md: \"gap-6\", // 24px\n lg: \"gap-8\", // 32px\n xl: \"gap-12\" // 48px\n }\n\n const gapXClasses = {\n none: \"gap-x-0\",\n sm: \"gap-x-4\", // 16px\n md: \"gap-x-6\", // 24px\n lg: \"gap-x-8\", // 32px\n xl: \"gap-x-12\" // 48px\n }\n\n const gapYClasses = {\n none: \"gap-y-0\",\n sm: \"gap-y-4\", // 16px\n md: \"gap-y-6\", // 24px\n lg: \"gap-y-8\", // 32px\n xl: \"gap-y-12\" // 48px\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n \"grid\",\n responsive ? colsClasses[cols] : `grid-cols-${cols}`,\n gapX ? gapXClasses[gapX] : gapClasses[gap],\n gapY && gapYClasses[gapY],\n className\n )}\n {...props}\n />\n )\n }\n)\nGrid.displayName = \"Grid\"\n\nexport { Grid } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Stack 컴포넌트의 props\n * @typedef {Object} StackProps\n * @property {\"vertical\" | \"horizontal\"} [direction=\"vertical\"] - 스택 방향\n * @property {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"} [spacing=\"md\"] - 아이템 간 간격\n * @property {\"start\" | \"center\" | \"end\" | \"stretch\"} [align=\"start\"] - 교차축 정렬\n * @property {\"start\" | \"center\" | \"end\" | \"between\" | \"around\" | \"evenly\"} [justify=\"start\"] - 주축 정렬\n * @property {boolean} [wrap=false] - 아이템 줄바꿈 허용\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface StackProps extends React.HTMLAttributes<HTMLDivElement> {\n direction?: \"vertical\" | \"horizontal\"\n spacing?: \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"\n align?: \"start\" | \"center\" | \"end\" | \"stretch\"\n justify?: \"start\" | \"center\" | \"end\" | \"between\" | \"around\" | \"evenly\"\n wrap?: boolean\n}\n\n/**\n * Stack 컴포넌트\n * \n * Flexbox를 사용한 스택 레이아웃 컴포넌트입니다.\n * 수직 또는 수평 방향으로 아이템을 배치하고 정렬할 수 있습니다.\n * \n * @component\n * @example\n * // 기본 수직 스택\n * <Stack spacing=\"md\">\n * <div>아이템 1</div>\n * <div>아이템 2</div>\n * </Stack>\n * \n * @example\n * // 수평 스택, 중앙 정렬\n * <Stack direction=\"horizontal\" spacing=\"lg\" align=\"center\" justify=\"between\">\n * <Button>왼쪽</Button>\n * <Button>오른쪽</Button>\n * </Stack>\n * \n * @example\n * // 줄바꿈 허용\n * <Stack direction=\"horizontal\" wrap spacing=\"sm\">\n * {tags.map(tag => <Badge key={tag}>{tag}</Badge>)}\n * </Stack>\n * \n * @param {StackProps} props - Stack 컴포넌트의 props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref\n * @returns {JSX.Element} Stack 컴포넌트\n */\nconst Stack = React.forwardRef<HTMLDivElement, StackProps>(\n ({ \n className, \n direction = \"vertical\",\n spacing = \"md\",\n align = \"start\",\n justify = \"start\",\n wrap = false,\n ...props \n }, ref) => {\n const directionClasses = {\n vertical: \"flex flex-col\",\n horizontal: \"flex flex-row\"\n }\n\n const spacingClasses = {\n none: \"\",\n sm: direction === \"vertical\" ? \"space-y-4\" : \"space-x-4\", // 16px\n md: direction === \"vertical\" ? \"space-y-6\" : \"space-x-6\", // 24px\n lg: direction === \"vertical\" ? \"space-y-8\" : \"space-x-8\", // 32px\n xl: direction === \"vertical\" ? \"space-y-12\" : \"space-x-12\" // 48px\n }\n\n const alignClasses = {\n start: \"items-start\",\n center: \"items-center\",\n end: \"items-end\",\n stretch: \"items-stretch\"\n }\n\n const justifyClasses = {\n start: \"justify-start\",\n center: \"justify-center\",\n end: \"justify-end\",\n between: \"justify-between\",\n around: \"justify-around\",\n evenly: \"justify-evenly\"\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n directionClasses[direction],\n spacingClasses[spacing],\n alignClasses[align],\n justifyClasses[justify],\n wrap && \"flex-wrap\",\n className\n )}\n {...props}\n />\n )\n }\n)\nStack.displayName = \"Stack\"\n\nexport { Stack } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Divider 컴포넌트의 props / Divider component props\n * @typedef {Object} DividerProps\n * @property {\"horizontal\" | \"vertical\"} [orientation=\"horizontal\"] - Divider 방향 / Divider orientation\n * @property {\"solid\" | \"dashed\" | \"dotted\" | \"gradient\" | \"glass\"} [variant=\"solid\"] - Divider 스타일 변형 / Divider style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Divider 크기 / Divider size\n * @property {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"} [spacing=\"md\"] - Divider 주변 여백 / Divider spacing\n * @property {\"default\" | \"muted\" | \"primary\" | \"secondary\"} [color=\"default\"] - Divider 색상 / Divider color\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface DividerProps extends React.HTMLAttributes<HTMLDivElement> {\n orientation?: \"horizontal\" | \"vertical\"\n variant?: \"solid\" | \"dashed\" | \"dotted\" | \"gradient\" | \"glass\"\n size?: \"sm\" | \"md\" | \"lg\"\n spacing?: \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"\n color?: \"default\" | \"muted\" | \"primary\" | \"secondary\"\n}\n\n/**\n * Divider 컴포넌트 / Divider component\n * \n * 콘텐츠를 구분하는 구분선 컴포넌트입니다.\n * 가로/세로 방향, 다양한 스타일과 색상을 지원합니다.\n * \n * Divider component for separating content.\n * Supports horizontal/vertical orientation, various styles and colors.\n * \n * @component\n * @example\n * // 기본 사용 (가로) / Basic usage (horizontal)\n * <Divider />\n * \n * @example\n * // 세로 구분선 / Vertical divider\n * <div className=\"flex\">\n * <div>왼쪽</div>\n * <Divider orientation=\"vertical\" />\n * <div>오른쪽</div>\n * </div>\n * \n * @example\n * // 다양한 스타일 / Various styles\n * <Divider variant=\"dashed\" spacing=\"lg\" />\n * <Divider variant=\"gradient\" color=\"primary\" />\n * \n * @param {DividerProps} props - Divider 컴포넌트의 props / Divider component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Divider 컴포넌트 / Divider component\n */\nconst DividerComponent = React.forwardRef<HTMLDivElement, DividerProps>(\n ({ \n className, \n orientation = \"horizontal\",\n variant = \"solid\",\n size = \"md\",\n spacing = \"md\",\n color = \"default\",\n ...props \n }, ref) => {\n const orientationClasses = React.useMemo(() => ({\n horizontal: \"w-full\",\n vertical: \"h-full w-px\"\n }), [])\n\n const sizeClasses = React.useMemo(() => ({\n sm: orientation === \"horizontal\" ? \"h-px\" : \"w-px\",\n md: orientation === \"horizontal\" ? \"h-0.5\" : \"w-0.5\", // 2px\n lg: orientation === \"horizontal\" ? \"h-1\" : \"w-1\" // 4px\n }), [orientation])\n\n const variantClasses = React.useMemo(() => ({\n solid: \"\",\n dashed: \"border-dashed\",\n dotted: \"border-dotted\",\n gradient: orientation === \"horizontal\" \n ? \"bg-gradient-to-r from-transparent via-gray-300 to-transparent dark:via-gray-600\"\n : \"bg-gradient-to-b from-transparent via-gray-300 to-transparent dark:via-gray-600\",\n glass: orientation === \"horizontal\"\n ? \"bg-gradient-to-r from-transparent via-white/30 to-transparent\"\n : \"bg-gradient-to-b from-transparent via-white/30 to-transparent\"\n }), [orientation])\n\n const colorClasses = React.useMemo(() => ({\n default: \"bg-gray-200 dark:bg-gray-700\",\n muted: \"bg-gray-100 dark:bg-gray-800\",\n primary: \"bg-blue-200 dark:bg-blue-700\",\n secondary: \"bg-gray-300 dark:bg-gray-600\"\n }), [])\n\n const spacingClasses = React.useMemo(() => ({\n none: \"\",\n sm: orientation === \"horizontal\" ? \"my-4\" : \"mx-4\", // 16px\n md: orientation === \"horizontal\" ? \"my-6\" : \"mx-6\", // 24px\n lg: orientation === \"horizontal\" ? \"my-8\" : \"mx-8\", // 32px\n xl: orientation === \"horizontal\" ? \"my-12\" : \"mx-12\" // 48px\n }), [orientation])\n\n return (\n <div\n ref={ref}\n className={merge(\n \"flex-shrink-0\",\n orientationClasses[orientation],\n sizeClasses[size],\n variant === \"gradient\" ? variantClasses[variant] : colorClasses[color],\n variant !== \"gradient\" && variantClasses[variant],\n spacingClasses[spacing],\n className\n )}\n {...props}\n />\n )\n }\n)\n\nDividerComponent.displayName = \"Divider\"\n\nconst Divider = React.memo(DividerComponent)\n\nexport { Divider } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Card 컴포넌트의 props / Card component props\n * @typedef {Object} CardProps\n * @property {\"default\" | \"outline\" | \"elevated\"} [variant=\"default\"] - 카드 스타일 변형 / Card style variant\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CardProps extends React.HTMLAttributes<HTMLDivElement> {\n variant?: \"default\" | \"outline\" | \"elevated\"\n}\n\n/**\n * Card 컴포넌트 / Card component\n * \n * 콘텐츠를 카드 형태로 표시하는 컴포넌트입니다.\n * CardHeader, CardTitle, CardDescription, CardContent, CardFooter와 함께 사용합니다.\n * \n * Component that displays content in card format.\n * Used with CardHeader, CardTitle, CardDescription, CardContent, and CardFooter.\n * \n * @component\n * @example\n * // 기본 카드 / Basic card\n * <Card>\n * <CardHeader>\n * <CardTitle>카드 제목</CardTitle>\n * <CardDescription>카드 설명</CardDescription>\n * </CardHeader>\n * <CardContent>\n * <p>카드 내용</p>\n * </CardContent>\n * <CardFooter>\n * <Button>액션</Button>\n * </CardFooter>\n * </Card>\n * \n * @example\n * // Elevated 스타일 / Elevated style\n * <Card variant=\"elevated\">\n * <CardContent>강조된 카드</CardContent>\n * </Card>\n * \n * @param {CardProps} props - Card 컴포넌트의 props / Card component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Card 컴포넌트 / Card component\n */\nconst Card = React.forwardRef<HTMLDivElement, CardProps>(\n ({ className, variant = \"default\", ...props }, ref) => {\n const variantClasses = {\n default: \"bg-white dark:bg-slate-800 border border-slate-200 dark:border-slate-700\",\n outline: \"bg-transparent border-2 border-slate-300 dark:border-slate-600\",\n elevated: \"bg-white dark:bg-slate-800 shadow-lg border border-slate-200 dark:border-slate-700\"\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n \"rounded-lg p-6\",\n variantClasses[variant],\n className\n )}\n {...props}\n />\n )\n }\n)\n\nCard.displayName = \"Card\"\n\n/**\n * CardHeader 컴포넌트의 props / CardHeader component props\n * @typedef {Object} CardHeaderProps\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CardHeaderProps extends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * CardHeader 컴포넌트 / CardHeader component\n * 카드의 헤더 영역을 표시합니다. CardTitle과 CardDescription을 포함합니다.\n * Displays the header area of a card. Contains CardTitle and CardDescription.\n * \n * @component\n * @param {CardHeaderProps} props - CardHeader 컴포넌트의 props / CardHeader component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} CardHeader 컴포넌트 / CardHeader component\n */\nconst CardHeader = React.forwardRef<HTMLDivElement, CardHeaderProps>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"flex flex-col space-y-1.5 p-6\", className)}\n {...props}\n />\n )\n)\n\nCardHeader.displayName = \"CardHeader\"\n\n/**\n * CardTitle 컴포넌트의 props / CardTitle component props\n * @typedef {Object} CardTitleProps\n * @extends {React.HTMLAttributes<HTMLHeadingElement>}\n */\nexport interface CardTitleProps extends React.HTMLAttributes<HTMLHeadingElement> {}\n\n/**\n * CardTitle 컴포넌트 / CardTitle component\n * 카드의 제목을 표시합니다. h3 태그로 렌더링됩니다.\n * Displays the card title. Renders as h3 tag.\n * \n * @component\n * @param {CardTitleProps} props - CardTitle 컴포넌트의 props / CardTitle component props\n * @param {React.Ref<HTMLParagraphElement>} ref - h3 요소 ref / h3 element ref\n * @returns {JSX.Element} CardTitle 컴포넌트 / CardTitle component\n */\nconst CardTitle = React.forwardRef<HTMLParagraphElement, CardTitleProps>(\n ({ className, ...props }, ref) => (\n <h3\n ref={ref}\n className={merge(\n \"text-2xl font-semibold leading-none tracking-tight\",\n className\n )}\n {...props}\n />\n )\n)\n\nCardTitle.displayName = \"CardTitle\"\n\n/**\n * CardDescription 컴포넌트의 props / CardDescription component props\n * @typedef {Object} CardDescriptionProps\n * @extends {React.HTMLAttributes<HTMLParagraphElement>}\n */\nexport interface CardDescriptionProps extends React.HTMLAttributes<HTMLParagraphElement> {}\n\n/**\n * CardDescription 컴포넌트 / CardDescription component\n * 카드의 설명 텍스트를 표시합니다.\n * Displays the card description text.\n * \n * @component\n * @param {CardDescriptionProps} props - CardDescription 컴포넌트의 props / CardDescription component props\n * @param {React.Ref<HTMLParagraphElement>} ref - p 요소 ref / p element ref\n * @returns {JSX.Element} CardDescription 컴포넌트 / CardDescription component\n */\nconst CardDescription = React.forwardRef<HTMLParagraphElement, CardDescriptionProps>(\n ({ className, ...props }, ref) => (\n <p\n ref={ref}\n className={merge(\"text-sm text-slate-500 dark:text-slate-400\", className)}\n {...props}\n />\n )\n)\n\nCardDescription.displayName = \"CardDescription\"\n\n/**\n * CardContent 컴포넌트의 props / CardContent component props\n * @typedef {Object} CardContentProps\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CardContentProps extends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * CardContent 컴포넌트 / CardContent component\n * 카드의 메인 콘텐츠 영역을 표시합니다.\n * Displays the main content area of a card.\n * \n * @component\n * @param {CardContentProps} props - CardContent 컴포넌트의 props / CardContent component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} CardContent 컴포넌트 / CardContent component\n */\nconst CardContent = React.forwardRef<HTMLDivElement, CardContentProps>(\n ({ className, ...props }, ref) => (\n <div ref={ref} className={merge(\"p-6 pt-0\", className)} {...props} />\n )\n)\n\nCardContent.displayName = \"CardContent\"\n\n/**\n * CardFooter 컴포넌트의 props / CardFooter component props\n * @typedef {Object} CardFooterProps\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CardFooterProps extends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * CardFooter 컴포넌트 / CardFooter component\n * 카드의 푸터 영역을 표시합니다. 주로 액션 버튼을 배치합니다.\n * Displays the footer area of a card. Typically used for action buttons.\n * \n * @component\n * @param {CardFooterProps} props - CardFooter 컴포넌트의 props / CardFooter component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} CardFooter 컴포넌트 / CardFooter component\n */\nconst CardFooter = React.forwardRef<HTMLDivElement, CardFooterProps>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"flex items-center p-6 pt-0\", className)}\n {...props}\n />\n )\n)\n\nCardFooter.displayName = \"CardFooter\"\n\nexport { Card, CardHeader, CardFooter, CardTitle, CardDescription, CardContent } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Card, CardProps } from \"./Card\"\n\n/**\n * Panel 컴포넌트의 props / Panel component props\n * @typedef {Object} PanelProps\n * @property {\"default\" | \"solid\" | \"glass\" | \"outline\" | \"elevated\" | \"neon\" | \"holographic\" | \"cyberpunk\" | \"minimal\" | \"luxury\"} [style=\"default\"] - Panel 스타일 / Panel style\n * @property {\"none\" | \"glow\" | \"shadow\" | \"gradient\" | \"animated\"} [effect=\"none\"] - Panel 효과 / Panel effect\n * @property {number} [transparency=1] - 투명도 (0-1) / Transparency (0-1)\n * @property {number} [blurIntensity=0] - backdrop-blur 강도 (px) / Backdrop blur intensity (px)\n * @property {number} [borderOpacity=1] - 보더 투명도 (0-1) / Border opacity (0-1)\n * @property {number} [shadowOpacity=1] - 그림자 투명도 (0-1) / Shadow opacity (0-1)\n * @property {number} [glowIntensity=0] - 글로우 강도 (px) / Glow intensity (px)\n * @property {string} [glowColor=\"blue\"] - 글로우 색상 / Glow color\n * @property {boolean} [particleEffect=false] - 파티클 효과 활성화 / Enable particle effect\n * @property {boolean} [hoverEffect=false] - 호버 효과 활성화 / Enable hover effect\n * @property {boolean} [animationEffect=false] - 애니메이션 효과 활성화 / Enable animation effect\n * @property {\"none\" | \"small\" | \"sm\" | \"medium\" | \"md\" | \"large\" | \"lg\" | \"xl\" | \"custom\"} [padding=\"md\"] - 패딩 크기 / Padding size\n * @property {string} [customPadding] - 커스텀 패딩 / Custom padding\n * @property {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\" | \"custom\"} [rounded=\"lg\"] - 둥근 모서리 크기 / Rounded corner size\n * @property {string} [customRounded] - 커스텀 둥근 모서리 / Custom rounded corners\n * @property {\"solid\" | \"gradient\" | \"pattern\" | \"image\" | \"video\"} [background=\"solid\"] - 배경 타입 / Background type\n * @property {string[]} [gradientColors] - 그라디언트 색상 배열 / Gradient color array\n * @property {\"dots\" | \"lines\" | \"grid\" | \"waves\" | \"custom\"} [patternType=\"dots\"] - 패턴 타입 / Pattern type\n * @property {string} [backgroundImage] - 배경 이미지 URL / Background image URL\n * @property {string} [backgroundVideo] - 배경 비디오 URL / Background video URL\n * @property {boolean} [interactive=false] - 인터랙티브 모드 활성화 / Enable interactive mode\n * @property {number} [hoverScale=1.05] - 호버 시 스케일 / Scale on hover\n * @property {number} [hoverRotate=0] - 호버 시 회전 각도 / Rotation angle on hover\n * @property {boolean} [hoverGlow=false] - 호버 시 글로우 효과 / Glow effect on hover\n * @extends {Omit<CardProps, 'variant' | 'style'>}\n */\nexport interface PanelProps extends Omit<CardProps, 'variant' | 'style'> {\n // 🆕 Panel 전용 고급 속성들\n style?: \"default\" | \"solid\" | \"glass\" | \"outline\" | \"elevated\" | \"neon\" | \"holographic\" | \"cyberpunk\" | \"minimal\" | \"luxury\"\n effect?: \"none\" | \"glow\" | \"shadow\" | \"gradient\" | \"animated\"\n \n // 고급 스타일링\n transparency?: number // 0-1 사이 투명도\n blurIntensity?: number // backdrop-blur 강도\n borderOpacity?: number // 보더 투명도\n shadowOpacity?: number // 그림자 투명도\n glowIntensity?: number // 글로우 강도\n glowColor?: string // 글로우 색상\n \n // 고급 효과\n particleEffect?: boolean\n hoverEffect?: boolean\n animationEffect?: boolean\n \n // 레이아웃 옵션\n padding?: \"none\" | \"small\" | \"sm\" | \"medium\" | \"md\" | \"large\" | \"lg\" | \"xl\" | \"custom\"\n customPadding?: string\n rounded?: \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\" | \"custom\"\n customRounded?: string\n \n // 배경 옵션\n background?: \"solid\" | \"gradient\" | \"pattern\" | \"image\" | \"video\"\n gradientColors?: string[]\n patternType?: \"dots\" | \"lines\" | \"grid\" | \"waves\" | \"custom\"\n backgroundImage?: string\n backgroundVideo?: string\n \n // 인터랙션\n interactive?: boolean\n hoverScale?: number\n hoverRotate?: number\n hoverGlow?: boolean\n}\n\n/**\n * Panel 컴포넌트 / Panel component\n * \n * 고급 스타일링 옵션을 가진 패널 컴포넌트입니다.\n * 다양한 스타일, 효과, 배경 옵션을 지원합니다.\n * Card 컴포넌트를 기반으로 하며, 추가적인 고급 기능을 제공합니다.\n * \n * Panel component with advanced styling options.\n * Supports various styles, effects, and background options.\n * Based on Card component with additional advanced features.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Panel>\n * <div>내용</div>\n * </Panel>\n * \n * @example\n * // Glass 스타일 / Glass style\n * <Panel style=\"glass\" effect=\"glow\">\n * <div>Glass 패널</div>\n * </Panel>\n * \n * @example\n * // 인터랙티브 패널 / Interactive panel\n * <Panel \n * style=\"neon\"\n * interactive\n * hoverScale={1.1}\n * hoverGlow\n * >\n * <div>호버 효과</div>\n * </Panel>\n * \n * @param {PanelProps} props - Panel 컴포넌트의 props / Panel component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Panel 컴포넌트 / Panel component\n */\nconst Panel = React.forwardRef<HTMLDivElement, PanelProps>(\n ({ \n className,\n style = \"default\",\n effect = \"none\",\n transparency = 1,\n blurIntensity = 0,\n borderOpacity = 1,\n shadowOpacity = 1,\n glowIntensity = 0,\n glowColor = \"blue\",\n particleEffect = false,\n hoverEffect = false,\n animationEffect = false,\n padding = \"md\",\n customPadding,\n rounded = \"lg\",\n customRounded,\n background = \"solid\",\n gradientColors = [\"#3B82F6\", \"#8B5CF6\"],\n patternType = \"dots\",\n backgroundImage,\n backgroundVideo,\n interactive = false,\n hoverScale = 1.05,\n hoverRotate = 0,\n hoverGlow = false,\n children,\n ...cardProps \n }, ref): React.ReactElement => {\n \n // 스타일별 클래스 생성 - useMemo로 메모이제이션\n const styleClasses = React.useMemo(() => {\n const baseClasses = \"transition-all duration-300\"\n \n switch (style) {\n case \"solid\":\n return merge(baseClasses, \"bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700\")\n case \"glass\":\n return merge(baseClasses, \"bg-white/10 backdrop-blur-md border border-white/20\")\n case \"outline\":\n return merge(baseClasses, \"bg-transparent border border-gray-300 dark:border-gray-600\")\n case \"elevated\":\n return merge(baseClasses, \"bg-white dark:bg-gray-800 shadow-lg border border-gray-100 dark:border-gray-700\")\n case \"neon\":\n return merge(baseClasses, \"bg-gray-900 border border-cyan-400/30 shadow-lg shadow-cyan-400/20\")\n case \"holographic\":\n return merge(baseClasses, \"bg-gradient-to-br from-white/20 via-purple-500/20 to-cyan-500/20 backdrop-blur-sm border border-white/30\")\n case \"cyberpunk\":\n return merge(baseClasses, \"bg-gray-900 border-2 border-pink-500 shadow-lg shadow-pink-500/30\")\n case \"minimal\":\n return merge(baseClasses, \"bg-white border border-gray-200 shadow-sm\")\n case \"luxury\":\n return merge(baseClasses, \"bg-gradient-to-br from-amber-50 to-yellow-100 border border-amber-200 shadow-xl\")\n default:\n return merge(baseClasses, \"bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700\")\n }\n }, [style])\n \n // 효과별 클래스 생성 - useMemo로 메모이제이션\n const effectClasses = React.useMemo(() => {\n switch (effect) {\n case \"glow\":\n return \"shadow-2xl shadow-blue-500/20 dark:shadow-cyan-400/20\"\n case \"shadow\":\n return \"shadow-xl\"\n case \"gradient\":\n return \"bg-gradient-to-r from-blue-500/10 via-purple-500/10 to-cyan-500/10\"\n case \"animated\":\n return \"animate-pulse\"\n default:\n return \"\"\n }\n }, [effect])\n \n // 패딩 클래스 생성 - useMemo로 메모이제이션\n const paddingClasses = React.useMemo(() => {\n if (customPadding) return customPadding\n \n switch (padding) {\n case \"none\": return \"p-0\"\n case \"small\":\n case \"sm\": return \"p-3\"\n case \"medium\":\n case \"md\": return \"p-6\"\n case \"large\":\n case \"lg\": return \"p-8\"\n case \"xl\": return \"p-12\"\n default: return \"p-6\"\n }\n }, [padding, customPadding])\n \n // 둥근 모서리 클래스 생성 - useMemo로 메모이제이션\n const roundedClasses = React.useMemo(() => {\n if (customRounded) return customRounded\n \n switch (rounded) {\n case \"none\": return \"rounded-none\"\n case \"sm\": return \"rounded-sm\"\n case \"md\": return \"rounded-md\"\n case \"lg\": return \"rounded-lg\"\n case \"xl\": return \"rounded-xl\"\n case \"full\": return \"rounded-full\"\n default: return \"rounded-lg\"\n }\n }, [rounded, customRounded])\n \n // 패턴 배경 생성 - useMemo로 메모이제이션\n const patternBackground = React.useMemo(() => {\n switch (patternType) {\n case \"dots\":\n return \"radial-gradient(circle, #000 1px, transparent 1px)\"\n case \"lines\":\n return \"linear-gradient(45deg, #000 1px, transparent 1px)\"\n case \"grid\":\n return \"linear-gradient(#000 1px, transparent 1px), linear-gradient(90deg, #000 1px, transparent 1px)\"\n case \"waves\":\n return \"repeating-linear-gradient(45deg, transparent, transparent 10px, rgba(0,0,0,0.1) 10px, rgba(0,0,0,0.1) 20px)\"\n default:\n return \"\"\n }\n }, [patternType])\n \n // 배경 스타일 생성 - useMemo로 메모이제이션\n const backgroundStyles = React.useMemo((): React.CSSProperties => {\n const styles: React.CSSProperties = {\n opacity: transparency,\n }\n \n if (blurIntensity > 0) {\n styles.backdropFilter = `blur(${blurIntensity}px)`\n }\n \n if (borderOpacity < 1) {\n styles.borderColor = `rgba(0, 0, 0, ${borderOpacity})`\n }\n \n if (shadowOpacity < 1) {\n styles.boxShadow = `0 4px 6px -1px rgba(0, 0, 0, ${shadowOpacity * 0.1})`\n }\n \n if (glowIntensity > 0) {\n styles.boxShadow = `${styles.boxShadow || ''}, 0 0 ${glowIntensity * 10}px ${glowColor}`\n }\n \n switch (background) {\n case \"gradient\":\n styles.background = `linear-gradient(135deg, ${gradientColors.join(', ')})`\n break\n case \"pattern\":\n styles.backgroundImage = patternBackground\n break\n case \"image\":\n if (backgroundImage) {\n styles.backgroundImage = `url(${backgroundImage})`\n styles.backgroundSize = 'cover'\n styles.backgroundPosition = 'center'\n }\n break\n case \"video\":\n // 비디오 배경은 별도 요소로 처리\n break\n }\n \n return styles\n }, [transparency, blurIntensity, borderOpacity, shadowOpacity, glowIntensity, glowColor, background, gradientColors, patternBackground, backgroundImage])\n \n // 호버 효과 클래스 생성 - useMemo로 메모이제이션\n const hoverClasses = React.useMemo(() => {\n if (!interactive) return \"\"\n \n const classes = []\n \n if (hoverScale !== 1) {\n classes.push(`hover:scale-${hoverScale}`)\n }\n \n if (hoverRotate !== 0) {\n classes.push(`hover:rotate-${hoverRotate}`)\n }\n \n if (hoverGlow) {\n classes.push(\"hover:shadow-2xl hover:shadow-blue-500/30\")\n }\n \n return classes.join(\" \")\n }, [interactive, hoverScale, hoverRotate, hoverGlow])\n \n // Panel 전용 클래스들 - useMemo로 메모이제이션\n const panelClasses = React.useMemo(() => merge(\n \"panel-component\",\n `panel-${style}`,\n `panel-effect-${effect}`,\n styleClasses,\n effectClasses,\n paddingClasses,\n roundedClasses,\n hoverClasses,\n className\n ), [style, effect, styleClasses, effectClasses, paddingClasses, roundedClasses, hoverClasses, className])\n \n return (\n <div className=\"relative\">\n {/* 비디오 배경 */}\n {background === \"video\" && backgroundVideo && (\n <video\n className=\"absolute inset-0 w-full h-full object-cover rounded-lg\"\n autoPlay\n muted\n loop\n playsInline\n >\n <source src={backgroundVideo} type=\"video/mp4\" />\n </video>\n )}\n \n {/* 파티클 효과 */}\n {particleEffect && (\n <div className=\"absolute inset-0 pointer-events-none\">\n {/* 파티클 효과 렌더링 */}\n </div>\n )}\n \n {/* 메인 Panel */}\n <Card\n ref={ref}\n className={panelClasses}\n style={backgroundStyles}\n {...cardProps}\n >\n {children}\n </Card>\n \n {/* 애니메이션 효과 */}\n {animationEffect && (\n <div className=\"absolute inset-0 pointer-events-none\">\n {/* 애니메이션 효과 렌더링 */}\n </div>\n )}\n </div>\n )\n }\n)\n\nPanel.displayName = \"Panel\"\n\nexport { Panel } ","\"use client\";\n\nimport React, { useMemo, useCallback } from 'react';\nimport { Button } from './Button';\nimport { Icon } from './Icon';\nimport type { IconName } from '../lib/icons';\nimport { merge } from '../lib/utils';\n\n/**\n * ActionButton 인터페이스\n * @typedef {Object} ActionButton\n * @property {string} label - 버튼 라벨 (데스크톱)\n * @property {string} [labelMobile] - 버튼 라벨 (모바일, 없으면 label 사용)\n * @property {IconName} [icon] - 버튼 아이콘\n * @property {() => void} onClick - 클릭 핸들러\n * @property {boolean} [disabled] - 비활성화 여부\n * @property {'default' | 'outline' | 'destructive' | 'ghost'} [variant='outline'] - 버튼 스타일\n * @property {Object} [badge] - 배지 정보\n * @property {number} badge.count - 배지 숫자\n * @property {'blue' | 'red' | 'gray' | 'green'} [badge.color='gray'] - 배지 색상\n * @property {string} [className] - 추가 CSS 클래스\n */\nexport interface ActionButton {\n label: string;\n labelMobile?: string; // 모바일에서 표시할 짧은 텍스트\n icon?: IconName;\n onClick: () => void;\n disabled?: boolean;\n variant?: 'default' | 'outline' | 'destructive' | 'ghost';\n badge?: {\n count: number;\n color?: 'blue' | 'red' | 'gray' | 'green';\n };\n className?: string;\n}\n\n/**\n * ActionToolbar 컴포넌트의 props / ActionToolbar component props\n * @typedef {Object} ActionToolbarProps\n * @property {boolean} [isSelectMode=false] - 선택 모드 활성화 여부 / Enable select mode\n * @property {number} [totalCount=0] - 전체 항목 개수 / Total item count\n * @property {number} [selectedCount=0] - 선택된 항목 개수 / Selected item count\n * @property {ActionButton[]} [actions=[]] - 일반 모드 액션 버튼들 / Normal mode action buttons\n * @property {ActionButton[]} [selectModeActions=[]] - 선택 모드 액션 버튼들 / Select mode action buttons\n * @property {() => void} [onToggleSelectMode] - 선택 모드 토글 함수 / Toggle select mode function\n * @property {() => void} [onToggleSelectAll] - 전체 선택/해제 함수 / Toggle select all function\n * @property {() => void} [onCancelSelect] - 선택 모드 취소 함수 / Cancel select mode function\n * @property {boolean} [loading=false] - 로딩 상태 / Loading state\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface ActionToolbarProps extends React.HTMLAttributes<HTMLDivElement> {\n /** 선택 모드 활성화 여부 */\n isSelectMode?: boolean;\n /** 전체 항목 개수 */\n totalCount?: number;\n /** 선택된 항목 개수 */\n selectedCount?: number;\n /** 일반 모드 액션 버튼들 */\n actions?: ActionButton[];\n /** 선택 모드 액션 버튼들 */\n selectModeActions?: ActionButton[];\n /** 선택 모드 토글 함수 */\n onToggleSelectMode?: () => void;\n /** 전체 선택/해제 함수 */\n onToggleSelectAll?: () => void;\n /** 선택 모드 취소 함수 */\n onCancelSelect?: () => void;\n /** 로딩 상태 */\n loading?: boolean;\n}\n\n/**\n * ActionToolbar 컴포넌트 / ActionToolbar component\n * \n * 범용 액션 툴바 컴포넌트입니다.\n * 알림, 로그 관리, 대시보드 등에서 재사용 가능한 액션 버튼 영역을 제공합니다.\n * 선택 모드, 일괄 액션, 반응형 레이아웃을 지원합니다.\n * \n * Universal action toolbar component.\n * Provides reusable action button area for notifications, log management, dashboard, etc.\n * Supports select mode, batch actions, and responsive layout.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * ```tsx\n * <ActionToolbar\n * isSelectMode={isSelectMode}\n * totalCount={notifications.length}\n * selectedCount={selectedIds.size}\n * actions={[\n * {\n * label: \"모두 읽음\",\n * labelMobile: \"읽음\",\n * icon: \"check\",\n * onClick: handleMarkAllAsRead,\n * disabled: unreadCount === 0,\n * badge: { count: unreadCount, color: 'blue' }\n * }\n * ]}\n * selectModeActions={[\n * {\n * label: \"선택 삭제\",\n * labelMobile: \"삭제\",\n * icon: \"delete\",\n * onClick: handleDeleteSelected,\n * disabled: selectedIds.size === 0,\n * badge: { count: selectedIds.size, color: 'red' }\n * }\n * ]}\n * onToggleSelectMode={() => setIsSelectMode(true)}\n * onToggleSelectAll={handleToggleSelectAll}\n * onCancelSelect={() => {\n * setIsSelectMode(false);\n * setSelectedIds(new Set());\n * }}\n * />\n * ```\n * \n * @param {ActionToolbarProps} props - ActionToolbar 컴포넌트의 props / ActionToolbar component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} ActionToolbar 컴포넌트 / ActionToolbar component\n */\nconst ActionToolbarComponent = React.forwardRef<HTMLDivElement, ActionToolbarProps>(\n (\n {\n isSelectMode = false,\n totalCount = 0,\n selectedCount = 0,\n actions = [],\n selectModeActions = [],\n onToggleSelectMode,\n onToggleSelectAll,\n onCancelSelect,\n loading = false,\n className,\n ...props\n },\n ref\n ) => {\n const getBadgeColor = useCallback((color?: string) => {\n switch (color) {\n case 'red':\n return 'bg-red-100 dark:bg-red-900 text-red-700 dark:text-red-300';\n case 'blue':\n return 'bg-blue-100 dark:bg-blue-900 text-blue-700 dark:text-blue-300';\n case 'green':\n return 'bg-green-100 dark:bg-green-900 text-green-700 dark:text-green-300';\n case 'gray':\n default:\n return 'bg-gray-100 dark:bg-gray-700 text-gray-700 dark:text-gray-300';\n }\n }, []);\n\n const renderButton = useCallback((action: ActionButton, key: string) => (\n <Button\n key={key}\n variant={action.variant || 'outline'}\n size=\"sm\"\n onClick={action.onClick}\n disabled={action.disabled || loading}\n className={merge('flex-1 sm:flex-initial', action.className)}\n >\n {action.icon && <Icon name={action.icon} className=\"h-4 w-4 sm:h-3.5 sm:w-3.5 mr-1 sm:mr-1.5\" />}\n <span className=\"hidden sm:inline\">{action.label}</span>\n <span className=\"sm:hidden\">{action.labelMobile || action.label}</span>\n {action.badge && action.badge.count > 0 && (\n <span className={merge('ml-1.5', getBadgeColor(action.badge.color), 'px-1.5 py-0.5 rounded-full text-xs font-semibold')}>\n {action.badge.count}\n </span>\n )}\n </Button>\n ), [getBadgeColor, loading]);\n\n return (\n <div\n ref={ref}\n className={merge(\n 'mb-4 bg-white dark:bg-gray-800 rounded-lg shadow-sm border border-gray-200 dark:border-gray-700 p-3 sm:p-4',\n className\n )}\n {...props}\n >\n {isSelectMode ? (\n <div className=\"flex flex-wrap items-center gap-2\">\n {/* 전체 선택/해제 버튼 */}\n {onToggleSelectAll && (\n <Button\n variant=\"outline\"\n size=\"sm\"\n onClick={onToggleSelectAll}\n className=\"flex-1 sm:flex-initial min-w-[100px]\"\n >\n <Icon name={selectedCount === totalCount ? \"square\" : \"check\"} className=\"h-4 w-4 sm:h-3.5 sm:w-3.5 mr-1 sm:mr-1.5\" />\n <span className=\"hidden sm:inline\">{selectedCount === totalCount ? '전체 해제' : '전체 선택'}</span>\n <span className=\"sm:hidden\">{selectedCount === totalCount ? '해제' : '전체'}</span>\n </Button>\n )}\n \n {/* 선택 모드 액션 버튼들 */}\n {selectModeActions.map((action, index) => (\n <div key={`select-action-${index}`} className={merge('flex-1 sm:flex-initial min-w-[100px]', action.className)}>\n {renderButton(action, `select-${index}`)}\n </div>\n ))}\n \n {/* 취소 버튼 */}\n {onCancelSelect && (\n <Button\n variant=\"outline\"\n size=\"sm\"\n onClick={onCancelSelect}\n className=\"flex-1 sm:flex-initial min-w-[80px]\"\n >\n 취소\n </Button>\n )}\n </div>\n ) : (\n <div className=\"flex flex-wrap items-center gap-2\">\n {/* 선택 모드 진입 버튼 */}\n {onToggleSelectMode && (\n <Button\n variant=\"outline\"\n size=\"sm\"\n onClick={onToggleSelectMode}\n disabled={totalCount === 0}\n className=\"flex-1 sm:flex-initial min-w-[80px] sm:min-w-[auto] px-2 sm:px-3\"\n title={totalCount === 0 ? \"항목이 없습니다\" : \"여러 항목 선택\"}\n >\n <Icon name=\"check\" className=\"h-4 w-4 sm:h-3.5 sm:w-3.5\" />\n <span className=\"hidden sm:inline ml-1.5 sm:ml-2\">선택</span>\n </Button>\n )}\n \n {/* 일반 모드 액션 버튼들 */}\n {actions.map((action, index) => (\n <div key={`action-${index}`} className={merge('flex-1 sm:flex-initial min-w-[100px]', action.className)}>\n {renderButton(action, `action-${index}`)}\n </div>\n ))}\n </div>\n )}\n </div>\n );\n }\n);\n\nActionToolbarComponent.displayName = 'ActionToolbar';\n\nexport const ActionToolbar = React.memo(ActionToolbarComponent);\n\n","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\n\n/**\n * Breadcrumb 항목 타입 / Breadcrumb item type\n */\nexport interface BreadcrumbItemData {\n label: string\n href?: string\n icon?: string\n}\n\n/**\n * Breadcrumb 컴포넌트의 props / Breadcrumb component props\n * @typedef {Object} BreadcrumbProps\n * @property {React.ReactNode} [children] - BreadcrumbItem 컴포넌트들 / BreadcrumbItem components\n * @property {BreadcrumbItemData[]} [items] - Breadcrumb 항목 배열 (children 대신 사용 가능) / Breadcrumb items array (alternative to children)\n * @property {number} [maxItems] - 최대 표시할 항목 수 (긴 경로 처리) / Maximum number of items to display (for long paths)\n * @property {boolean} [showHomeIcon] - 홈 아이콘 표시 여부 / Show home icon\n * @property {string} [homeLabel] - 홈 라벨 (기본: \"Home\") / Home label (default: \"Home\")\n * @property {React.ReactNode} [separator] - 항목 사이 구분자 (기본: chevronRight 아이콘) / Separator between items (default: chevronRight icon)\n * @property {'default' | 'subtle' | 'transparent' | 'glass'} [variant='default'] - Breadcrumb 스타일 변형 / Breadcrumb style variant\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface BreadcrumbProps extends React.HTMLAttributes<HTMLDivElement> {\n children?: React.ReactNode\n items?: BreadcrumbItemData[]\n maxItems?: number\n showHomeIcon?: boolean\n homeLabel?: string\n separator?: React.ReactNode\n variant?: 'default' | 'subtle' | 'transparent' | 'glass'\n}\n\n/**\n * BreadcrumbItem 컴포넌트의 props / BreadcrumbItem component props\n * @typedef {Object} BreadcrumbItemProps\n * @property {string} [href] - 링크 URL (없으면 일반 텍스트) / Link URL (plain text if not provided)\n * @property {boolean} [isCurrent=false] - 현재 페이지 여부 / Current page indicator\n * @property {React.ReactNode} children - 항목 텍스트 / Item text\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n */\nexport interface BreadcrumbItemProps {\n href?: string\n isCurrent?: boolean\n children: React.ReactNode\n className?: string\n}\n\n/**\n * Breadcrumb 컴포넌트 / Breadcrumb component\n * \n * 네비게이션 경로를 표시하는 breadcrumb 컴포넌트입니다.\n * 현재 위치와 경로를 시각적으로 표현합니다.\n * \n * Breadcrumb component for displaying navigation paths.\n * Visually represents current location and path.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Breadcrumb>\n * <BreadcrumbItem href=\"/\">홈</BreadcrumbItem>\n * <BreadcrumbItem href=\"/products\">상품</BreadcrumbItem>\n * <BreadcrumbItem isCurrent>상세</BreadcrumbItem>\n * </Breadcrumb>\n * \n * @example\n * // 커스텀 구분자 / Custom separator\n * <Breadcrumb separator={<span>/</span>}>\n * <BreadcrumbItem href=\"/\">홈</BreadcrumbItem>\n * <BreadcrumbItem isCurrent>현재</BreadcrumbItem>\n * </Breadcrumb>\n * \n * @param {BreadcrumbProps} props - Breadcrumb 컴포넌트의 props / Breadcrumb component props\n * @param {React.Ref<HTMLDivElement>} ref - nav 요소 ref / nav element ref\n * @returns {JSX.Element} Breadcrumb 컴포넌트 / Breadcrumb component\n */\nconst Breadcrumb = React.forwardRef<HTMLDivElement, BreadcrumbProps>(\n ({ \n className, \n children, \n items,\n maxItems,\n showHomeIcon,\n homeLabel = \"Home\",\n separator = <Icon name=\"chevronRight\" className=\"w-3 h-3 text-slate-400 dark:text-slate-500 flex-shrink-0\" />, \n variant = 'default', \n ...props \n }, ref) => {\n const variantStyles = {\n default: \"inline-flex items-center text-sm w-fit\",\n subtle: \"inline-flex items-center text-xs bg-white/40 dark:bg-slate-800/40 backdrop-blur-md rounded-md px-3 py-2 border border-slate-200/30 dark:border-white/20 w-fit shadow-sm\",\n transparent: \"inline-flex items-center text-xs w-fit\",\n glass: \"inline-flex items-center text-xs bg-white/30 dark:bg-slate-800/30 backdrop-blur-lg rounded-lg px-4 py-2 border border-slate-200/25 dark:border-white/15 w-fit shadow-lg\"\n }\n \n // items prop이 있으면 BreadcrumbItem으로 변환\n const renderItems = () => {\n if (items) {\n let displayItems = [...items]\n \n // maxItems 처리\n if (maxItems && displayItems.length > maxItems) {\n const firstItem = displayItems[0]\n const lastItems = displayItems.slice(-(maxItems - 1))\n displayItems = [firstItem, { label: '...', href: undefined }, ...lastItems]\n }\n \n // 마지막 항목은 isCurrent로 표시\n return displayItems.map((item, index) => {\n const isLast = index === displayItems.length - 1\n const isCurrent = isLast && !item.href\n \n return (\n <BreadcrumbItem\n key={index}\n href={item.href}\n isCurrent={isCurrent}\n >\n {item.icon && (\n <Icon name={item.icon as any} className=\"w-4 h-4 mr-1\" />\n )}\n {item.label}\n </BreadcrumbItem>\n )\n })\n }\n \n // children이 있으면 그대로 사용\n if (children) {\n return React.Children.map(children, (child, index) => {\n if (React.isValidElement(child)) {\n return (\n <li key={index} className=\"flex items-center\">\n {child}\n {index < React.Children.count(children) - 1 && (\n <span className=\"mx-3 text-slate-400 dark:text-slate-500 flex items-center justify-center\" aria-hidden=\"true\">\n {separator}\n </span>\n )}\n </li>\n )\n }\n return child\n })\n }\n \n return null\n }\n \n const renderedItems = renderItems()\n const itemsCount = items ? items.length : (children ? React.Children.count(children) : 0)\n \n return (\n <nav\n ref={ref}\n aria-label=\"Breadcrumb\"\n className={merge(variantStyles[variant], className)}\n {...props}\n >\n <ol className=\"inline-flex items-center\">\n {showHomeIcon && (\n <li className=\"flex items-center\">\n <BreadcrumbItem href=\"/\">\n <Icon name=\"home\" className=\"w-4 h-4 mr-1\" />\n {homeLabel}\n </BreadcrumbItem>\n {itemsCount > 0 && (\n <span className=\"mx-3 text-slate-400 dark:text-slate-500 flex items-center justify-center\" aria-hidden=\"true\">\n {separator}\n </span>\n )}\n </li>\n )}\n {items ? (\n renderedItems?.map((item, index) => (\n <li key={index} className=\"flex items-center\">\n {item}\n {index < (renderedItems?.length || 0) - 1 && (\n <span className=\"mx-3 text-slate-400 dark:text-slate-500 flex items-center justify-center\" aria-hidden=\"true\">\n {separator}\n </span>\n )}\n </li>\n ))\n ) : (\n renderedItems\n )}\n </ol>\n </nav>\n )\n }\n)\nBreadcrumb.displayName = \"Breadcrumb\"\n\n/**\n * BreadcrumbItem 컴포넌트\n * Breadcrumb의 개별 항목을 표시합니다.\n * \n * @component\n * @param {BreadcrumbItemProps} props - BreadcrumbItem 컴포넌트의 props\n * @param {React.Ref<HTMLLIElement>} ref - li 요소 ref\n * @returns {JSX.Element} BreadcrumbItem 컴포넌트\n */\nconst BreadcrumbItem = React.forwardRef<HTMLLIElement, BreadcrumbItemProps>(\n ({ className, href, isCurrent = false, children, ...props }, ref) => {\n if (isCurrent) {\n return (\n <span\n ref={ref}\n aria-current=\"page\"\n className={merge(\n \"text-slate-500 dark:text-slate-400 font-medium\",\n className\n )}\n {...props}\n >\n {children}\n </span>\n )\n }\n\n if (href) {\n return (\n <a\n href={href}\n className={merge(\n \"text-slate-400 hover:text-slate-600 dark:text-slate-500 dark:hover:text-slate-300 transition-colors\",\n className\n )}\n {...props}\n >\n {children}\n </a>\n )\n }\n\n return (\n <span\n ref={ref}\n className={merge(\n \"text-slate-400 dark:text-slate-500\",\n className\n )}\n {...props}\n >\n {children}\n </span>\n )\n }\n)\nBreadcrumbItem.displayName = \"BreadcrumbItem\"\n\nexport { Breadcrumb, BreadcrumbItem } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Breadcrumb, BreadcrumbItem } from \"./Breadcrumb\"\n\n/**\n * ComponentLayout 컴포넌트의 props / ComponentLayout component props\n * @typedef {Object} ComponentLayoutProps\n * @property {string} title - 페이지 제목 / Page title\n * @property {string} description - 페이지 설명 / Page description\n * @property {React.ReactNode} children - 페이지 내용 / Page content\n * @property {Object} [prevPage] - 이전 페이지 정보 / Previous page information\n * @property {string} prevPage.title - 이전 페이지 제목 / Previous page title\n * @property {string} prevPage.href - 이전 페이지 링크 / Previous page link\n * @property {Object} [nextPage] - 다음 페이지 정보 / Next page information\n * @property {string} nextPage.title - 다음 페이지 제목 / Next page title\n * @property {string} nextPage.href - 다음 페이지 링크 / Next page link\n * @property {Array<Object>} [breadcrumbItems] - Breadcrumb 항목들 / Breadcrumb items\n * @property {string} breadcrumbItems[].label - Breadcrumb 라벨 / Breadcrumb label\n * @property {string} [breadcrumbItems[].href] - Breadcrumb 링크 / Breadcrumb link\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface ComponentLayoutProps extends React.HTMLAttributes<HTMLDivElement> {\n title: string\n description: string\n children: React.ReactNode\n prevPage?: {\n title: string\n href: string\n }\n nextPage?: {\n title: string\n href: string\n }\n breadcrumbItems?: Array<{\n label: string\n href?: string\n }>\n}\n\n/**\n * ComponentLayout 컴포넌트 / ComponentLayout component\n * \n * 컴포넌트 문서 페이지 레이아웃을 제공하는 컴포넌트입니다.\n * 제목, 설명, Breadcrumb, 이전/다음 페이지 네비게이션을 포함합니다.\n * \n * Component that provides layout for component documentation pages.\n * Includes title, description, Breadcrumb, and previous/next page navigation.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <ComponentLayout\n * title=\"Button 컴포넌트\"\n * description=\"버튼 컴포넌트 사용법\"\n * >\n * <Button>예제</Button>\n * </ComponentLayout>\n * \n * @example\n * // 이전/다음 페이지 네비게이션 포함 / With previous/next page navigation\n * <ComponentLayout\n * title=\"Input 컴포넌트\"\n * description=\"입력 컴포넌트 사용법\"\n * prevPage={{ title: \"Button\", href: \"/components/button\" }}\n * nextPage={{ title: \"Select\", href: \"/components/select\" }}\n * >\n * <Input placeholder=\"입력하세요\" />\n * </ComponentLayout>\n * \n * @param {ComponentLayoutProps} props - ComponentLayout 컴포넌트의 props / ComponentLayout component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} ComponentLayout 컴포넌트 / ComponentLayout component\n */\nconst ComponentLayout = React.forwardRef<HTMLDivElement, ComponentLayoutProps>(\n ({ \n className, \n title, \n description, \n children, \n prevPage, \n nextPage,\n breadcrumbItems = [\n { label: \"Components\", href: \"/components\" }\n ],\n ...props \n }, ref) => {\n return (\n <div className=\"relative min-h-screen\">\n {/* 고정된 페이지 네비게이션 - 위쪽 */}\n <div className=\"fixed right-4 top-4 z-50 hidden lg:block\">\n <div className=\"flex flex-col space-y-4\">\n {prevPage && (\n <a\n href={prevPage.href}\n className=\"group p-3 bg-white/80 backdrop-blur-sm border border-slate-200 rounded-full shadow-lg hover:shadow-2xl hover:bg-white/90 active:scale-95 transition-all duration-200\"\n title={`이전: ${prevPage.title}`}\n >\n <svg \n className=\"w-5 h-5 text-slate-600 group-hover:text-blue-600 group-active:text-blue-800 transition-colors\" \n fill=\"none\" \n stroke=\"currentColor\" \n viewBox=\"0 0 24 24\"\n >\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M5 15l7-7 7 7\" />\n </svg>\n </a>\n )}\n </div>\n </div>\n\n {/* 고정된 페이지 네비게이션 - 아래쪽 */}\n <div className=\"fixed right-4 bottom-4 z-50 hidden lg:block\">\n <div className=\"flex flex-col space-y-4\">\n {nextPage && (\n <a\n href={nextPage.href}\n className=\"group p-3 bg-white/80 backdrop-blur-sm border border-slate-200 rounded-full shadow-lg hover:shadow-2xl hover:bg-white/90 active:scale-95 transition-all duration-200\"\n title={`다음: ${nextPage.title}`}\n >\n <svg \n className=\"w-5 h-5 text-slate-600 group-hover:text-blue-600 group-active:text-blue-800 transition-colors\" \n fill=\"none\" \n stroke=\"currentColor\" \n viewBox=\"0 0 24 24\"\n >\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M19 9l-7 7-7-7\" />\n </svg>\n </a>\n )}\n </div>\n </div>\n\n {/* 메인 콘텐츠 */}\n <div\n ref={ref}\n className={merge(\"container mx-auto px-4 py-8\", className)}\n {...props}\n >\n <div className=\"max-w-4xl mx-auto\">\n {/* 브레드크럼 */}\n <Breadcrumb className=\"mb-6\">\n {breadcrumbItems.map((item, index) => (\n <BreadcrumbItem \n key={index}\n href={item.href}\n isCurrent={index === breadcrumbItems.length - 1}\n >\n {item.label}\n </BreadcrumbItem>\n ))}\n </Breadcrumb>\n\n {/* 페이지 헤더 */}\n <div className=\"mb-8\">\n <h1 className=\"text-4xl font-bold mb-4\">{title}</h1>\n <p className=\"text-lg text-slate-600 dark:text-slate-400\">\n {description}\n </p>\n </div>\n\n {/* 페이지 콘텐츠 */}\n <div className=\"space-y-8\">\n {children}\n </div>\n\n {/* 모바일 페이지 네비게이션 */}\n <div className=\"mt-12 lg:hidden\">\n <div className=\"flex items-center justify-between py-4 border-t border-slate-200 dark:border-slate-700\">\n {prevPage && (\n <a\n href={prevPage.href}\n className=\"flex items-center text-sm text-slate-600 hover:text-slate-900 dark:text-slate-400 dark:hover:text-slate-100 transition-colors\"\n >\n <svg className=\"w-4 h-4 mr-2\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M15 19l-7-7 7-7\" />\n </svg>\n {prevPage.title}\n </a>\n )}\n {nextPage && (\n <a\n href={nextPage.href}\n className=\"flex items-center text-sm text-slate-600 hover:text-slate-900 dark:text-slate-400 dark:hover:text-slate-100 transition-colors\"\n >\n {nextPage.title}\n <svg className=\"w-4 h-4 ml-2\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M9 5l7 7-7 7\" />\n </svg>\n </a>\n )}\n </div>\n </div>\n </div>\n </div>\n </div>\n )\n }\n)\nComponentLayout.displayName = \"ComponentLayout\"\n\nexport { ComponentLayout } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Navigation 컴포넌트의 props / Navigation component props\n * @typedef {Object} NavigationProps\n * @property {string} [value] - 제어 모드에서 활성 탭 값 / Active tab value in controlled mode\n * @property {string} [defaultValue] - 비제어 모드에서 기본 활성 탭 값 / Default active tab value in uncontrolled mode\n * @property {(value: string) => void} [onValueChange] - 탭 변경 콜백 / Tab change callback\n * @property {\"pills\" | \"underline\" | \"cards\"} [variant=\"pills\"] - Navigation 스타일 변형 / Navigation style variant\n * @property {\"small\" | \"medium\" | \"large\"} [scale=\"medium\"] - Navigation 크기 / Navigation size\n * @extends {Omit<React.HTMLAttributes<HTMLDivElement>, 'style'>}\n */\nexport interface NavigationProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'style'> {\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n variant?: \"pills\" | \"underline\" | \"cards\"\n scale?: \"small\" | \"medium\" | \"large\"\n}\n\n/**\n * Navigation 컴포넌트 / Navigation component\n * \n * 탭 네비게이션 컴포넌트입니다.\n * NavigationList, NavigationItem, NavigationContent와 함께 사용합니다.\n * \n * Tab navigation component.\n * Used with NavigationList, NavigationItem, and NavigationContent.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Navigation>\n * <Navigation.List>\n * <Navigation.Item value=\"tab1\">탭 1</Navigation.Item>\n * <Navigation.Item value=\"tab2\">탭 2</Navigation.Item>\n * </Navigation.List>\n * <Navigation.Content value=\"tab1\">내용 1</Navigation.Content>\n * </Navigation>\n * \n * @param {NavigationProps} props - Navigation 컴포넌트의 props / Navigation component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Navigation 컴포넌트 / Navigation component\n */\nconst Navigation = React.forwardRef<HTMLDivElement, NavigationProps>(\n ({ \n className, \n value,\n defaultValue,\n onValueChange,\n variant = \"pills\",\n scale = \"medium\",\n children,\n ...props \n }, ref) => {\n const [activeTab, setActiveTab] = React.useState(value || defaultValue || \"\")\n const isControlled = value !== undefined\n const currentValue = isControlled ? value : activeTab\n\n const handleTabChange = (newValue: string) => {\n if (!isControlled) {\n setActiveTab(newValue)\n }\n onValueChange?.(newValue)\n }\n\n React.useEffect(() => {\n if (value !== undefined) {\n setActiveTab(value)\n }\n }, [value])\n\n return (\n <div\n ref={ref}\n className={merge(\n \"w-full\",\n className\n )}\n {...props}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return React.cloneElement(child, {\n value: currentValue,\n variant,\n scale\n } as Partial<NavigationListProps | NavigationItemProps>)\n }\n return child\n })}\n </div>\n )\n }\n)\nNavigation.displayName = \"Navigation\"\n\n/**\n * NavigationList 컴포넌트의 props / NavigationList component props\n * @typedef {Object} NavigationListProps\n * @property {string} [value] - 활성 탭 값 / Active tab value\n * @property {(value: string) => void} [onValueChange] - 탭 변경 콜백 / Tab change callback\n * @property {\"pills\" | \"underline\" | \"cards\"} [variant=\"pills\"] - Navigation 스타일 변형 / Navigation style variant\n * @property {\"small\" | \"medium\" | \"large\"} [scale=\"medium\"] - Navigation 크기 / Navigation size\n * @extends {Omit<React.HTMLAttributes<HTMLDivElement>, 'style'>}\n */\nexport interface NavigationListProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'style'> {\n value?: string\n onValueChange?: (value: string) => void\n variant?: \"pills\" | \"underline\" | \"cards\"\n scale?: \"small\" | \"medium\" | \"large\"\n}\n\nconst NavigationList = React.forwardRef<HTMLDivElement, NavigationListProps>(\n ({ \n className, \n value,\n onValueChange,\n variant = \"pills\",\n scale = \"medium\",\n children,\n ...props \n }, ref) => {\n const getStyleClasses = () => {\n switch (variant) {\n case \"pills\":\n return \"bg-slate-100 dark:bg-slate-800 p-1 rounded-xl\"\n case \"underline\":\n return \"border-b border-slate-200 dark:border-slate-700\"\n case \"cards\":\n return \"bg-slate-50 dark:bg-slate-900 p-1 rounded-xl\"\n default:\n return \"bg-slate-100 dark:bg-slate-800 p-1 rounded-xl\"\n }\n }\n\n const getScaleClasses = () => {\n switch (scale) {\n case \"small\":\n return \"gap-1\"\n case \"large\":\n return \"gap-3\"\n default:\n return \"gap-2\"\n }\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n \"flex\",\n getStyleClasses(),\n getScaleClasses(),\n className\n )}\n {...props}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return React.cloneElement(child, {\n value,\n variant,\n scale\n } as Partial<NavigationItemProps>)\n }\n return child\n })}\n </div>\n )\n }\n)\nNavigationList.displayName = \"NavigationList\"\n\n/**\n * NavigationItem 컴포넌트의 props / NavigationItem component props\n * @typedef {Object} NavigationItemProps\n * @property {string} value - 탭 값 / Tab value\n * @property {(value: string) => void} [onValueChange] - 탭 변경 콜백 / Tab change callback\n * @property {\"pills\" | \"underline\" | \"cards\"} [variant] - Navigation 스타일 변형 (자동으로 설정됨) / Navigation style variant (auto-set)\n * @property {\"small\" | \"medium\" | \"large\"} [scale] - Navigation 크기 (자동으로 설정됨) / Navigation size (auto-set)\n * @property {boolean} [active] - 활성 상태 (자동으로 설정됨) / Active state (auto-set)\n * @extends {Omit<React.ButtonHTMLAttributes<HTMLButtonElement>, 'style'>}\n */\nexport interface NavigationItemProps extends Omit<React.ButtonHTMLAttributes<HTMLButtonElement>, 'style'> {\n value: string\n onValueChange?: (value: string) => void\n variant?: \"pills\" | \"underline\" | \"cards\"\n scale?: \"small\" | \"medium\" | \"large\"\n active?: boolean\n}\n\nconst NavigationItem = React.forwardRef<HTMLButtonElement, NavigationItemProps>(\n ({ \n className, \n value,\n onValueChange,\n variant = \"pills\",\n scale = \"medium\",\n active = false,\n children,\n ...props \n }, ref) => {\n const getStyleClasses = () => {\n switch (variant) {\n case \"pills\":\n return merge(\n \"rounded-lg px-3 py-2 text-sm font-medium transition-all\",\n active \n ? \"bg-white dark:bg-slate-700 text-slate-900 dark:text-slate-100 shadow-sm\" \n : \"text-slate-600 dark:text-slate-400 hover:text-slate-900 dark:hover:text-slate-100\"\n )\n case \"underline\":\n return merge(\n \"border-b-2 px-3 py-2 text-sm font-medium transition-all\",\n active \n ? \"border-blue-500 text-blue-600 dark:text-blue-400\" \n : \"border-transparent text-slate-600 dark:text-slate-400 hover:text-slate-900 dark:hover:text-slate-100\"\n )\n case \"cards\":\n return merge(\n \"rounded-lg px-3 py-2 text-sm font-medium transition-all\",\n active \n ? \"bg-white dark:bg-slate-800 text-slate-900 dark:text-slate-100 shadow-sm border border-slate-200 dark:border-slate-700\" \n : \"text-slate-600 dark:text-slate-400 hover:text-slate-900 dark:hover:text-slate-100\"\n )\n default:\n return merge(\n \"rounded-lg px-3 py-2 text-sm font-medium transition-all\",\n active \n ? \"bg-white dark:bg-slate-700 text-slate-900 dark:text-slate-100 shadow-sm\" \n : \"text-slate-600 dark:text-slate-400 hover:text-slate-900 dark:hover:text-slate-100\"\n )\n }\n }\n\n const getScaleClasses = () => {\n switch (scale) {\n case \"small\":\n return \"text-xs px-2 py-1\"\n case \"large\":\n return \"text-base px-4 py-3\"\n default:\n return \"text-sm px-3 py-2\"\n }\n }\n\n const handleClick = () => {\n onValueChange?.(value)\n }\n\n return (\n <button\n ref={ref}\n className={merge(\n getStyleClasses(),\n getScaleClasses(),\n \"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-blue-400 focus-visible:ring-offset-2\",\n className\n )}\n onClick={handleClick}\n {...props}\n >\n {children}\n </button>\n )\n }\n)\nNavigationItem.displayName = \"NavigationItem\"\n\n/**\n * NavigationContent 컴포넌트의 props / NavigationContent component props\n * @typedef {Object} NavigationContentProps\n * @property {string} value - 탭 값 / Tab value\n * @property {boolean} [active] - 활성 상태 (자동으로 설정됨) / Active state (auto-set)\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface NavigationContentProps extends React.HTMLAttributes<HTMLDivElement> {\n value: string\n active?: boolean\n}\n\nconst NavigationContent = React.forwardRef<HTMLDivElement, NavigationContentProps>(\n ({ className, active = false, ...props }, ref) => {\n if (!active) return null\n\n return (\n <div\n ref={ref}\n className={merge(\"mt-4\", className)}\n {...props}\n />\n )\n }\n)\nNavigationContent.displayName = \"NavigationContent\"\n\n// 서브컴포넌트 타입 정의\nexport interface NavigationComponent extends React.ForwardRefExoticComponent<NavigationProps & React.RefAttributes<HTMLDivElement>> {\n List: typeof NavigationList\n Item: typeof NavigationItem\n Content: typeof NavigationContent\n}\n\nconst NavigationComponent = Navigation as NavigationComponent\nNavigationComponent.List = NavigationList\nNavigationComponent.Item = NavigationItem\nNavigationComponent.Content = NavigationContent\n\nexport { NavigationComponent as Navigation, NavigationList, NavigationItem, NavigationContent } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Pagination 컴포넌트의 props / Pagination component props\n * @typedef {Object} PaginationProps\n * @property {number} currentPage - 현재 페이지 번호 / Current page number\n * @property {number} totalPages - 전체 페이지 수 / Total number of pages\n * @property {(page: number) => void} onPageChange - 페이지 변경 콜백 / Page change callback\n * @property {boolean} [showFirstLast=true] - 첫/마지막 페이지 버튼 표시 여부 / Show first/last page buttons\n * @property {boolean} [showPrevNext=true] - 이전/다음 페이지 버튼 표시 여부 / Show previous/next page buttons\n * @property {number} [maxVisiblePages=5] - 최대 표시 페이지 수 / Maximum visible page numbers\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Pagination 크기 / Pagination size\n * @property {\"default\" | \"outlined\" | \"minimal\"} [variant=\"default\"] - Pagination 스타일 변형 / Pagination style variant\n * @property {\"square\" | \"circle\"} [shape=\"square\"] - 버튼 모양 / Button shape\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface PaginationProps extends React.HTMLAttributes<HTMLDivElement> {\n currentPage: number\n totalPages: number\n onPageChange: (page: number) => void\n showFirstLast?: boolean\n showPrevNext?: boolean\n maxVisiblePages?: number\n size?: \"sm\" | \"md\" | \"lg\"\n variant?: \"default\" | \"outlined\" | \"minimal\"\n shape?: \"square\" | \"circle\"\n}\n\n/**\n * Pagination 컴포넌트 / Pagination component\n * \n * 페이지네이션 컨트롤을 제공하는 컴포넌트입니다.\n * 첫/마지막 페이지, 이전/다음 페이지 버튼을 지원하며,\n * 많은 페이지가 있을 경우 자동으로 생략 표시(...)를 합니다.\n * \n * Component that provides pagination controls.\n * Supports first/last page and previous/next page buttons,\n * and automatically shows ellipsis (...) when there are many pages.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * const [page, setPage] = useState(1)\n * \n * <Pagination\n * currentPage={page}\n * totalPages={10}\n * onPageChange={setPage}\n * />\n * \n * @example\n * // Outlined 스타일, 원형 버튼 / Outlined style, circular buttons\n * <Pagination\n * currentPage={page}\n * totalPages={20}\n * onPageChange={setPage}\n * variant=\"outlined\"\n * shape=\"circle\"\n * />\n * \n * @param {PaginationProps} props - Pagination 컴포넌트의 props / Pagination component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Pagination 컴포넌트 / Pagination component\n */\nconst Pagination = React.forwardRef<HTMLDivElement, PaginationProps>(\n ({ \n className, \n currentPage,\n totalPages,\n onPageChange,\n showFirstLast = true,\n showPrevNext = true,\n maxVisiblePages = 5,\n size = \"md\",\n variant = \"default\",\n shape = \"square\",\n ...props \n }, ref) => {\n const getVisiblePages = () => {\n const pages: (number | string)[] = []\n const halfVisible = Math.floor(maxVisiblePages / 2)\n \n let start = Math.max(1, currentPage - halfVisible)\n let end = Math.min(totalPages, currentPage + halfVisible)\n \n // 조정\n if (end - start + 1 < maxVisiblePages) {\n if (start === 1) {\n end = Math.min(totalPages, start + maxVisiblePages - 1)\n } else {\n start = Math.max(1, end - maxVisiblePages + 1)\n }\n }\n \n // 첫 페이지\n if (start > 1) {\n pages.push(1)\n if (start > 2) {\n pages.push(\"...\")\n }\n }\n \n // 중간 페이지들\n for (let i = start; i <= end; i++) {\n pages.push(i)\n }\n \n // 마지막 페이지\n if (end < totalPages) {\n if (end < totalPages - 1) {\n pages.push(\"...\")\n }\n pages.push(totalPages)\n }\n \n return pages\n }\n\n const getSizeClasses = () => {\n switch (size) {\n case \"sm\":\n return \"h-8 px-2 text-sm\" // 32px 높이, 8px 패딩\n case \"lg\":\n return \"h-12 px-4 text-base\" // 48px 높이, 16px 패딩\n default:\n return \"h-10 px-3 text-sm\" // 40px 높이, 12px 패딩\n }\n }\n\n const getShapeClasses = () => {\n switch (shape) {\n case \"circle\":\n return \"rounded-full aspect-square flex items-center justify-center\"\n default:\n return \"rounded-md\"\n }\n }\n\n const getVariantClasses = (isActive: boolean = false) => {\n switch (variant) {\n case \"outlined\":\n return merge(\n \"border border-gray-300 dark:border-gray-600\",\n isActive \n ? \"bg-blue-500 border-blue-500 text-white\" \n : \"bg-white dark:bg-gray-800 text-gray-700 dark:text-gray-300 hover:bg-gray-50 dark:hover:bg-gray-700\"\n )\n case \"minimal\":\n return merge(\n \"border-0\",\n isActive \n ? \"bg-blue-100 dark:bg-blue-900 text-blue-700 dark:text-blue-300\" \n : \"bg-transparent text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700\"\n )\n default:\n return merge(\n \"border-0\",\n isActive \n ? \"bg-blue-500 text-white\" \n : \"bg-white dark:bg-gray-800 text-gray-700 dark:text-gray-300 hover:bg-gray-50 dark:hover:bg-gray-700\"\n )\n }\n }\n\n const handlePageClick = (page: number) => {\n if (page >= 1 && page <= totalPages && page !== currentPage) {\n onPageChange(page)\n }\n }\n\n const visiblePages = getVisiblePages()\n\n return (\n <div\n ref={ref}\n className={merge(\n \"flex items-center justify-center gap-1\",\n className\n )}\n {...props}\n >\n {/* 첫 페이지 버튼 */}\n {showFirstLast && currentPage > 1 && (\n <button\n onClick={() => handlePageClick(1)}\n className={merge(\n \"inline-flex items-center justify-center font-medium transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n getSizeClasses(),\n getShapeClasses(),\n getVariantClasses()\n )}\n aria-label=\"첫 페이지로 이동\"\n >\n <svg className=\"w-4 h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M11 19l-7-7 7-7M19 19l-7-7 7-7\" />\n </svg>\n </button>\n )}\n\n {/* 이전 페이지 버튼 */}\n {showPrevNext && currentPage > 1 && (\n <button\n onClick={() => handlePageClick(currentPage - 1)}\n className={merge(\n \"inline-flex items-center justify-center font-medium transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n getSizeClasses(),\n getShapeClasses(),\n getVariantClasses()\n )}\n aria-label=\"이전 페이지로 이동\"\n >\n <svg className=\"w-4 h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M15 19l-7-7 7-7\" />\n </svg>\n </button>\n )}\n\n {/* 페이지 번호들 */}\n {visiblePages.map((page, index) => (\n <React.Fragment key={index}>\n {page === \"...\" ? (\n <span className={merge(\n \"inline-flex items-center justify-center px-3 py-2 text-sm font-medium text-gray-500 dark:text-gray-400\",\n getSizeClasses()\n )}>\n ...\n </span>\n ) : (\n <button\n onClick={() => handlePageClick(page as number)}\n className={merge(\n \"inline-flex items-center justify-center font-medium transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n getSizeClasses(),\n getShapeClasses(),\n getVariantClasses(page === currentPage)\n )}\n aria-label={`${page}페이지로 이동`}\n aria-current={page === currentPage ? \"page\" : undefined}\n >\n {page}\n </button>\n )}\n </React.Fragment>\n ))}\n\n {/* 다음 페이지 버튼 */}\n {showPrevNext && currentPage < totalPages && (\n <button\n onClick={() => handlePageClick(currentPage + 1)}\n className={merge(\n \"inline-flex items-center justify-center font-medium transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n getSizeClasses(),\n getShapeClasses(),\n getVariantClasses()\n )}\n aria-label=\"다음 페이지로 이동\"\n >\n <svg className=\"w-4 h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M9 5l7 7-7 7\" />\n </svg>\n </button>\n )}\n\n {/* 마지막 페이지 버튼 */}\n {showFirstLast && currentPage < totalPages && (\n <button\n onClick={() => handlePageClick(totalPages)}\n className={merge(\n \"inline-flex items-center justify-center font-medium transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n getSizeClasses(),\n getShapeClasses(),\n getVariantClasses()\n )}\n aria-label=\"마지막 페이지로 이동\"\n >\n <svg className=\"w-4 h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M13 5l7 7-7 7M5 5l7 7-7 7\" />\n </svg>\n </button>\n )}\n </div>\n )\n }\n)\nPagination.displayName = \"Pagination\"\n\n// 편의 컴포넌트들\nexport const PaginationOutlined = React.forwardRef<HTMLDivElement, Omit<PaginationProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Pagination ref={ref} variant=\"outlined\" className={className} {...props} />\n )\n)\nPaginationOutlined.displayName = \"PaginationOutlined\"\n\nexport const PaginationMinimal = React.forwardRef<HTMLDivElement, Omit<PaginationProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Pagination ref={ref} variant=\"minimal\" className={className} {...props} />\n )\n)\nPaginationMinimal.displayName = \"PaginationMinimal\"\n\n// 복합 컴포넌트들\nexport const PaginationWithInfo = React.forwardRef<HTMLDivElement, PaginationProps & { \n totalItems?: number\n itemsPerPage?: number\n showInfo?: boolean\n}>(\n ({ \n totalItems = 0, \n itemsPerPage = 10, \n showInfo = true, \n className, \n ...props \n }, ref) => {\n const startItem = (props.currentPage - 1) * itemsPerPage + 1\n const endItem = Math.min(props.currentPage * itemsPerPage, totalItems)\n \n return (\n <div className={merge(\"flex flex-col sm:flex-row items-center justify-between gap-4\", className)}>\n {showInfo && (\n <div className=\"text-sm text-gray-700 dark:text-gray-300\">\n {totalItems > 0 ? (\n <>\n <span className=\"font-medium\">{startItem}</span>\n {\" - \"}\n <span className=\"font-medium\">{endItem}</span>\n {\" of \"}\n <span className=\"font-medium\">{totalItems}</span>\n {\" results\"}\n </>\n ) : (\n \"No results\"\n )}\n </div>\n )}\n <Pagination ref={ref} {...props} />\n </div>\n )\n }\n)\nPaginationWithInfo.displayName = \"PaginationWithInfo\"\n\nexport { Pagination } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\n\n/**\n * PageNavigation 컴포넌트의 props / PageNavigation component props\n * @typedef {Object} PageNavigationProps\n * @property {Object} [prevPage] - 이전 페이지 정보 / Previous page information\n * @property {string} prevPage.title - 이전 페이지 제목 / Previous page title\n * @property {string} prevPage.href - 이전 페이지 링크 / Previous page link\n * @property {Object} [nextPage] - 다음 페이지 정보 / Next page information\n * @property {string} nextPage.title - 다음 페이지 제목 / Next page title\n * @property {string} nextPage.href - 다음 페이지 링크 / Next page link\n * @property {boolean} [showOnMobile=false] - 모바일에서 표시 여부 / Show on mobile\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface PageNavigationProps extends React.HTMLAttributes<HTMLDivElement> {\n prevPage?: {\n title: string\n href: string\n }\n nextPage?: {\n title: string\n href: string\n }\n showOnMobile?: boolean\n}\n\n/**\n * PageNavigation 컴포넌트 / PageNavigation component\n * \n * 이전/다음 페이지로 이동하는 네비게이션 컴포넌트입니다.\n * 문서 페이지나 가이드 페이지에서 사용하기 적합합니다.\n * \n * Navigation component for moving to previous/next pages.\n * Suitable for documentation or guide pages.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <PageNavigation\n * prevPage={{ title: \"이전 페이지\", href: \"/prev\" }}\n * nextPage={{ title: \"다음 페이지\", href: \"/next\" }}\n * />\n * \n * @param {PageNavigationProps} props - PageNavigation 컴포넌트의 props / PageNavigation component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} PageNavigation 컴포넌트 / PageNavigation component\n */\nconst PageNavigation = React.forwardRef<HTMLDivElement, PageNavigationProps>(\n ({ \n className, \n prevPage, \n nextPage, \n showOnMobile = false,\n ...props \n }, ref) => {\n if (!prevPage && !nextPage) {\n return null\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n \"flex items-center justify-between py-4\",\n !showOnMobile && \"hidden md:flex\",\n className\n )}\n {...props}\n >\n {/* 이전 페이지 */}\n <div className=\"flex-1\">\n {prevPage && (\n <a\n href={prevPage.href}\n className=\"group inline-flex items-center text-sm text-slate-600 hover:text-slate-900 dark:text-slate-400 dark:hover:text-slate-100 transition-colors\"\n >\n <Icon \n name=\"chevronLeft\" \n className=\"w-4 h-4 mr-2 transition-transform group-hover:-translate-x-1\" \n />\n <span className=\"hidden sm:inline\">{prevPage.title}</span>\n </a>\n )}\n </div>\n\n {/* 다음 페이지 */}\n <div className=\"flex-1 flex justify-end\">\n {nextPage && (\n <a\n href={nextPage.href}\n className=\"group inline-flex items-center text-sm text-slate-600 hover:text-slate-900 dark:text-slate-400 dark:hover:text-slate-100 transition-colors\"\n >\n <span className=\"hidden sm:inline mr-2\">{nextPage.title}</span>\n <Icon \n name=\"chevronRight\" \n className=\"w-4 h-4 transition-transform group-hover:translate-x-1\" \n />\n </a>\n )}\n </div>\n </div>\n )\n }\n)\nPageNavigation.displayName = \"PageNavigation\"\n\nexport { PageNavigation } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * LoadingSpinner 컴포넌트의 props / LoadingSpinner component props\n * @typedef {Object} LoadingSpinnerProps\n * @property {\"sm\" | \"md\" | \"lg\" | \"xl\"} [size=\"md\"] - Spinner 크기 / Spinner size\n * @property {\"default\" | \"dots\" | \"bars\" | \"ring\" | \"ripple\"} [variant=\"default\"] - Spinner 애니메이션 타입 / Spinner animation type\n * @property {string} [text] - Spinner 아래 표시할 텍스트 / Text to display below spinner\n * @property {\"default\" | \"primary\" | \"secondary\" | \"success\" | \"warning\" | \"error\" | \"glass\"} [color=\"default\"] - Spinner 색상 / Spinner color\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n */\nexport interface LoadingSpinnerProps {\n size?: \"sm\" | \"md\" | \"lg\" | \"xl\"\n variant?: \"default\" | \"dots\" | \"bars\" | \"ring\" | \"ripple\"\n text?: string\n color?: \"default\" | \"primary\" | \"secondary\" | \"success\" | \"warning\" | \"error\" | \"glass\"\n className?: string\n}\n\n/**\n * LoadingSpinner 컴포넌트 / LoadingSpinner component\n * \n * 로딩 상태를 표시하는 스피너 컴포넌트입니다.\n * 다양한 애니메이션 타입과 크기를 지원합니다.\n * \n * Spinner component that displays loading state.\n * Supports various animation types and sizes.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <LoadingSpinner />\n * \n * @example\n * // 텍스트와 함께 / With text\n * <LoadingSpinner \n * text=\"로딩 중...\"\n * size=\"lg\"\n * color=\"primary\"\n * />\n * \n * @example\n * // 다양한 애니메이션 / Various animations\n * <LoadingSpinner variant=\"dots\" />\n * <LoadingSpinner variant=\"bars\" color=\"success\" />\n * <LoadingSpinner variant=\"ripple\" size=\"xl\" />\n * \n * @param {LoadingSpinnerProps} props - LoadingSpinner 컴포넌트의 props / LoadingSpinner component props\n * @returns {JSX.Element} LoadingSpinner 컴포넌트 / LoadingSpinner component\n */\nexport function LoadingSpinner({ \n className, \n size = \"md\", \n variant = \"default\", \n text, \n color = \"default\" \n}: LoadingSpinnerProps) {\n const sizeClasses = {\n sm: \"w-6 h-6\", // 24px - 더 넉넉한 크기\n md: \"w-8 h-8\", // 32px - 더 넉넉한 크기\n lg: \"w-12 h-12\", // 48px - 더 넉넉한 크기\n xl: \"w-16 h-16\" // 64px - 더 넉넉한 크기\n }\n\n // LoadingSpinner는 border 색상을 사용하므로 특화 색상 시스템 사용\n const spinnerColors: Record<string, string> = {\n default: \"border-gray-300 border-t-gray-600 dark:border-gray-600 dark:border-t-gray-300\",\n primary: \"border-blue-300 border-t-blue-600 dark:border-blue-600 dark:border-t-blue-300\",\n secondary: \"border-gray-300 border-t-gray-600 dark:border-gray-600 dark:border-t-gray-300\",\n success: \"border-green-300 border-t-green-600 dark:border-green-600 dark:border-t-green-300\",\n warning: \"border-yellow-300 border-t-yellow-600 dark:border-yellow-600 dark:border-t-yellow-300\",\n error: \"border-red-300 border-t-red-600 dark:border-red-600 dark:border-t-red-300\",\n glass: \"border-white/30 border-t-white/50 dark:border-slate-600/50 dark:border-t-slate-400/50\"\n }\n\n const renderSpinner = () => {\n switch (variant) {\n case \"dots\":\n return (\n <div className=\"flex space-x-1\">\n <div className=\"w-2 h-2 bg-current rounded-full animate-bounce\" />\n <div className=\"w-2 h-2 bg-current rounded-full animate-bounce delay-100\" />\n <div className=\"w-2 h-2 bg-current rounded-full animate-bounce delay-200\" />\n </div>\n )\n case \"bars\":\n return (\n <div className=\"flex space-x-1 h-full items-end\">\n <div className=\"w-1 bg-current animate-pulse\" style={{ height: '60%' }} />\n <div className=\"w-1 bg-current animate-pulse delay-100\" style={{ height: '80%' }} />\n <div className=\"w-1 bg-current animate-pulse delay-200\" style={{ height: '40%' }} />\n <div className=\"w-1 bg-current animate-pulse delay-300\" style={{ height: '100%' }} />\n <div className=\"w-1 bg-current animate-pulse delay-500\" style={{ height: '70%' }} />\n </div>\n )\n case \"ring\":\n return (\n <div className={merge(\n \"animate-spin rounded-full border-2\",\n spinnerColors[color] || spinnerColors.default\n )} />\n )\n case \"ripple\":\n return (\n <div className=\"relative\">\n <div className={merge(\n \"absolute inset-0 rounded-full border-2 animate-ping\",\n spinnerColors[color] || spinnerColors.default\n )} />\n <div className={merge(\n \"rounded-full border-2\",\n spinnerColors[color] || spinnerColors.default\n )} />\n </div>\n )\n default:\n return (\n <div className={merge(\n \"animate-spin rounded-full border-2\",\n spinnerColors[color] || spinnerColors.default\n )} />\n )\n }\n }\n\n return (\n <div className={merge(\"flex flex-col items-center justify-center\", className)}>\n <div className={merge(sizeClasses[size], \"text-gray-600 dark:text-gray-400\")}>\n {renderSpinner()}\n </div>\n {text && (\n <p className=\"mt-3 text-sm text-gray-600 dark:text-gray-400 text-center\">\n {text}\n </p>\n )}\n </div>\n )\n} ","'use client'\n\nimport React, { useState, useEffect } from 'react'\nimport { merge } from '../lib/utils'\nimport { LoadingSpinner } from './LoadingSpinner'\n\n/**\n * PageTransition 컴포넌트의 props / PageTransition component props\n * @typedef {Object} PageTransitionProps\n * @property {React.ReactNode} children - 페이지 내용 / Page content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {number} [duration=300] - 전환 지속 시간 (ms) / Transition duration (ms)\n * @property {'fade' | 'slide' | 'scale' | 'flip'} [variant='fade'] - 전환 애니메이션 타입 / Transition animation type\n * @property {'default' | 'dots' | 'bars' | 'ring' | 'ripple'} [loadingVariant='ripple'] - 로딩 스피너 타입 / Loading spinner type\n * @property {string} [loadingText='페이지 로딩 중...'] - 로딩 텍스트 / Loading text\n * @property {boolean} [showLoading=true] - 로딩 표시 여부 / Show loading\n * @property {() => void} [onTransitionStart] - 전환 시작 콜백 / Transition start callback\n * @property {() => void} [onTransitionEnd] - 전환 종료 콜백 / Transition end callback\n */\nexport interface PageTransitionProps {\n children: React.ReactNode\n className?: string\n duration?: number\n variant?: 'fade' | 'slide' | 'scale' | 'flip'\n loadingVariant?: 'default' | 'dots' | 'bars' | 'ring' | 'ripple'\n loadingText?: string\n showLoading?: boolean\n onTransitionStart?: () => void\n onTransitionEnd?: () => void\n}\n\n/**\n * PageTransition 컴포넌트 / PageTransition component\n * \n * 페이지 전환 애니메이션을 제공하는 컴포넌트입니다.\n * 다양한 전환 효과와 로딩 스피너를 지원합니다.\n * \n * Component that provides page transition animations.\n * Supports various transition effects and loading spinners.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <PageTransition>\n * <div>페이지 내용</div>\n * </PageTransition>\n * \n * @example\n * // Slide 전환 / Slide transition\n * <PageTransition\n * variant=\"slide\"\n * duration={500}\n * loadingVariant=\"dots\"\n * >\n * <div>페이지 내용</div>\n * </PageTransition>\n * \n * @param {PageTransitionProps} props - PageTransition 컴포넌트의 props / PageTransition component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} PageTransition 컴포넌트 / PageTransition component\n */\nexport const PageTransition = React.forwardRef<HTMLDivElement, PageTransitionProps>(({\n children,\n className,\n duration = 300,\n variant = 'fade',\n loadingVariant = 'ripple',\n loadingText = '페이지 로딩 중...',\n showLoading = true,\n onTransitionStart,\n onTransitionEnd\n}, ref) => {\n const [isLoading, setIsLoading] = useState(true)\n const [isVisible, setIsVisible] = useState(false)\n\n useEffect(() => {\n const timer = setTimeout(() => {\n setIsLoading(false)\n setIsVisible(true)\n onTransitionEnd?.()\n }, duration)\n\n onTransitionStart?.()\n\n return () => clearTimeout(timer)\n }, [duration, onTransitionStart, onTransitionEnd])\n\n const transitionClasses = {\n fade: merge(\n 'transition-opacity duration-300 ease-in-out',\n isVisible ? 'opacity-100' : 'opacity-0'\n ),\n slide: merge(\n 'transition-transform duration-300 ease-in-out',\n isVisible ? 'translate-x-0' : 'translate-x-full'\n ),\n scale: merge(\n 'transition-all duration-300 ease-in-out',\n isVisible ? 'scale-100 opacity-100' : 'scale-95 opacity-0'\n ),\n flip: merge(\n 'transition-all duration-500 ease-in-out',\n isVisible ? 'rotate-y-0 opacity-100' : 'rotate-y-90 opacity-0'\n )\n }\n\n if (isLoading && showLoading) {\n return (\n <div className={merge('flex flex-col items-center justify-center min-h-screen bg-gradient-to-br from-blue-50 to-purple-50 dark:from-slate-900 dark:to-slate-800', className)}>\n <LoadingSpinner\n size=\"lg\"\n variant={loadingVariant}\n text={loadingText}\n />\n </div>\n )\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n 'w-full',\n transitionClasses[variant],\n className\n )}\n style={{ transitionDuration: `${duration}ms` }}\n >\n {children}\n </div>\n )\n})\n\nPageTransition.displayName = 'PageTransition'\n\n// Convenience components for different transition types\nexport const FadeTransition = React.forwardRef<HTMLDivElement, Omit<PageTransitionProps, 'variant'>>((props, ref) => (\n <PageTransition ref={ref} variant=\"fade\" {...props} />\n))\n\nexport const SlideTransition = React.forwardRef<HTMLDivElement, Omit<PageTransitionProps, 'variant'>>((props, ref) => (\n <PageTransition ref={ref} variant=\"slide\" {...props} />\n))\n\nexport const ScaleTransition = React.forwardRef<HTMLDivElement, Omit<PageTransitionProps, 'variant'>>((props, ref) => (\n <PageTransition ref={ref} variant=\"scale\" {...props} />\n))\n\nexport const FlipTransition = React.forwardRef<HTMLDivElement, Omit<PageTransitionProps, 'variant'>>((props, ref) => (\n <PageTransition ref={ref} variant=\"flip\" {...props} />\n))\n\n// Add displayName for convenience components\nFadeTransition.displayName = 'FadeTransition'\nSlideTransition.displayName = 'SlideTransition'\nScaleTransition.displayName = 'ScaleTransition'\nFlipTransition.displayName = 'FlipTransition' ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Table 컴포넌트의 props / Table component props\n * @typedef {Object} TableProps\n * @property {React.ReactNode} children - TableHeader, TableBody, TableFooter 등 / TableHeader, TableBody, TableFooter, etc.\n * @property {\"default\" | \"bordered\" | \"striped\"} [variant=\"default\"] - Table 스타일 변형 / Table style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Table 크기 / Table size\n * @extends {React.HTMLAttributes<HTMLTableElement>}\n */\nexport interface TableProps extends React.HTMLAttributes<HTMLTableElement> {\n children: React.ReactNode\n variant?: \"default\" | \"bordered\" | \"striped\"\n size?: \"sm\" | \"md\" | \"lg\"\n}\n\n/**\n * TableHeader 컴포넌트의 props / TableHeader component props\n * @typedef {Object} TableHeaderProps\n * @property {React.ReactNode} children - TableHead 컴포넌트들 / TableHead components\n * @extends {React.HTMLAttributes<HTMLTableSectionElement>}\n */\nexport interface TableHeaderProps extends React.HTMLAttributes<HTMLTableSectionElement> {\n children: React.ReactNode\n}\n\n/**\n * TableBody 컴포넌트의 props / TableBody component props\n * @typedef {Object} TableBodyProps\n * @property {React.ReactNode} children - TableRow 컴포넌트들 / TableRow components\n * @extends {React.HTMLAttributes<HTMLTableSectionElement>}\n */\nexport interface TableBodyProps extends React.HTMLAttributes<HTMLTableSectionElement> {\n children: React.ReactNode\n}\n\n/**\n * TableFooter 컴포넌트의 props / TableFooter component props\n * @typedef {Object} TableFooterProps\n * @property {React.ReactNode} children - TableRow 컴포넌트들 / TableRow components\n * @extends {React.HTMLAttributes<HTMLTableSectionElement>}\n */\nexport interface TableFooterProps extends React.HTMLAttributes<HTMLTableSectionElement> {\n children: React.ReactNode\n}\n\n/**\n * TableRow 컴포넌트의 props / TableRow component props\n * @typedef {Object} TableRowProps\n * @property {React.ReactNode} children - TableHead 또는 TableCell 컴포넌트들 / TableHead or TableCell components\n * @property {\"default\" | \"hover\"} [variant=\"default\"] - Row 스타일 변형 / Row style variant\n * @extends {React.HTMLAttributes<HTMLTableRowElement>}\n */\nexport interface TableRowProps extends React.HTMLAttributes<HTMLTableRowElement> {\n children: React.ReactNode\n variant?: \"default\" | \"hover\"\n}\n\n/**\n * TableHead 컴포넌트의 props / TableHead component props\n * @typedef {Object} TableHeadProps\n * @property {React.ReactNode} children - 헤더 셀 내용 / Header cell content\n * @extends {React.ThHTMLAttributes<HTMLTableCellElement>}\n */\nexport interface TableHeadProps extends React.ThHTMLAttributes<HTMLTableCellElement> {\n children: React.ReactNode\n}\n\n/**\n * TableCell 컴포넌트의 props / TableCell component props\n * @typedef {Object} TableCellProps\n * @property {React.ReactNode} children - 셀 내용 / Cell content\n * @extends {React.TdHTMLAttributes<HTMLTableCellElement>}\n */\nexport interface TableCellProps extends React.TdHTMLAttributes<HTMLTableCellElement> {\n children: React.ReactNode\n}\n\n/**\n * Table 컴포넌트 / Table component\n * \n * 데이터를 표 형태로 표시하는 테이블 컴포넌트입니다.\n * TableHeader, TableBody, TableFooter, TableRow, TableHead, TableCell과 함께 사용합니다.\n * \n * Table component that displays data in tabular format.\n * Used with TableHeader, TableBody, TableFooter, TableRow, TableHead, and TableCell.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Table>\n * <TableHeader>\n * <TableRow>\n * <TableHead>이름</TableHead>\n * <TableHead>나이</TableHead>\n * </TableRow>\n * </TableHeader>\n * <TableBody>\n * <TableRow>\n * <TableCell>홍길동</TableCell>\n * <TableCell>30</TableCell>\n * </TableRow>\n * </TableBody>\n * </Table>\n * \n * @example\n * // Bordered 스타일 / Bordered style\n * <Table variant=\"bordered\">\n * <TableHeader>\n * <TableRow>\n * <TableHead>항목</TableHead>\n * </TableRow>\n * </TableHeader>\n * <TableBody>\n * <TableRow>\n * <TableCell>값</TableCell>\n * </TableRow>\n * </TableBody>\n * </Table>\n * \n * @example\n * // Striped 스타일, 호버 효과 / Striped style with hover effect\n * <Table variant=\"striped\">\n * <TableBody>\n * <TableRow variant=\"hover\">\n * <TableCell>데이터</TableCell>\n * </TableRow>\n * </TableBody>\n * </Table>\n * \n * @param {TableProps} props - Table 컴포넌트의 props / Table component props\n * @param {React.Ref<HTMLTableElement>} ref - table 요소 ref / table element ref\n * @returns {JSX.Element} Table 컴포넌트 / Table component\n */\nconst Table = React.forwardRef<HTMLTableElement, TableProps>(\n ({ className, variant = \"default\", size = \"md\", ...props }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"bordered\":\n return \"border border-slate-200 dark:border-slate-700 divide-x divide-slate-200 dark:divide-slate-700\"\n case \"striped\":\n return \"divide-y divide-slate-200 dark:divide-slate-700\"\n default:\n return \"\"\n }\n }\n\n const getSizeClasses = () => {\n switch (size) {\n case \"sm\":\n return \"text-sm\"\n case \"lg\":\n return \"text-base\"\n default:\n return \"text-sm\"\n }\n }\n\n return (\n <div className=\"w-full overflow-auto\">\n <table\n ref={ref}\n className={merge(\n \"w-full caption-bottom\",\n getVariantClasses(),\n getSizeClasses(),\n className\n )}\n {...props}\n />\n </div>\n )\n }\n)\nTable.displayName = \"Table\"\n\n/**\n * TableHeader 컴포넌트 / TableHeader component\n * 테이블의 헤더 영역을 표시합니다.\n * Displays the header area of a table.\n * \n * @component\n * @param {TableHeaderProps} props - TableHeader 컴포넌트의 props / TableHeader component props\n * @param {React.Ref<HTMLTableSectionElement>} ref - thead 요소 ref / thead element ref\n * @returns {JSX.Element} TableHeader 컴포넌트 / TableHeader component\n */\nconst TableHeader = React.forwardRef<HTMLTableSectionElement, TableHeaderProps>(\n ({ className, ...props }, ref) => (\n <thead ref={ref} className={merge(\"[&_tr]:border-b\", className)} {...props} />\n )\n)\nTableHeader.displayName = \"TableHeader\"\n\n/**\n * TableBody 컴포넌트 / TableBody component\n * 테이블의 본문 영역을 표시합니다.\n * Displays the body area of a table.\n * \n * @component\n * @param {TableBodyProps} props - TableBody 컴포넌트의 props / TableBody component props\n * @param {React.Ref<HTMLTableSectionElement>} ref - tbody 요소 ref / tbody element ref\n * @returns {JSX.Element} TableBody 컴포넌트 / TableBody component\n */\nconst TableBody = React.forwardRef<HTMLTableSectionElement, TableBodyProps>(\n ({ className, ...props }, ref) => (\n <tbody\n ref={ref}\n className={merge(\"[&_tr:last-child]:border-0\", className)}\n {...props}\n />\n )\n)\nTableBody.displayName = \"TableBody\"\n\n/**\n * TableFooter 컴포넌트 / TableFooter component\n * 테이블의 푸터 영역을 표시합니다.\n * Displays the footer area of a table.\n * \n * @component\n * @param {TableFooterProps} props - TableFooter 컴포넌트의 props / TableFooter component props\n * @param {React.Ref<HTMLTableSectionElement>} ref - tfoot 요소 ref / tfoot element ref\n * @returns {JSX.Element} TableFooter 컴포넌트 / TableFooter component\n */\nconst TableFooter = React.forwardRef<HTMLTableSectionElement, TableFooterProps>(\n ({ className, ...props }, ref) => (\n <tfoot\n ref={ref}\n className={merge(\n \"border-t bg-slate-50 dark:bg-slate-800/50 font-medium [&>tr]:last:border-b-0\",\n className\n )}\n {...props}\n />\n )\n)\nTableFooter.displayName = \"TableFooter\"\n\n/**\n * TableRow 컴포넌트 / TableRow component\n * 테이블의 행을 표시합니다.\n * Displays a table row.\n * \n * @component\n * @param {TableRowProps} props - TableRow 컴포넌트의 props / TableRow component props\n * @param {React.Ref<HTMLTableRowElement>} ref - tr 요소 ref / tr element ref\n * @returns {JSX.Element} TableRow 컴포넌트 / TableRow component\n */\nconst TableRow = React.forwardRef<HTMLTableRowElement, TableRowProps>(\n ({ className, variant = \"default\", ...props }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"hover\":\n return \"hover:bg-slate-50 dark:hover:bg-slate-800/50\"\n default:\n return \"\"\n }\n }\n\n return (\n <tr\n ref={ref}\n className={merge(\n \"border-b transition-colors data-[state=selected]:bg-slate-50 dark:data-[state=selected]:bg-slate-800/50\",\n getVariantClasses(),\n className\n )}\n {...props}\n />\n )\n }\n)\nTableRow.displayName = \"TableRow\"\n\n/**\n * TableHead 컴포넌트 / TableHead component\n * 테이블의 헤더 셀을 표시합니다.\n * Displays a table header cell.\n * \n * @component\n * @param {TableHeadProps} props - TableHead 컴포넌트의 props / TableHead component props\n * @param {React.Ref<HTMLTableCellElement>} ref - th 요소 ref / th element ref\n * @returns {JSX.Element} TableHead 컴포넌트 / TableHead component\n */\nconst TableHead = React.forwardRef<HTMLTableCellElement, TableHeadProps>(\n ({ className, ...props }, ref) => (\n <th\n ref={ref}\n className={merge(\n \"h-12 px-4 text-left align-middle font-medium text-slate-500 dark:text-slate-400 [&:has([role=checkbox])]:pr-0\",\n className\n )}\n {...props}\n />\n )\n)\nTableHead.displayName = \"TableHead\"\n\n/**\n * TableCell 컴포넌트 / TableCell component\n * 테이블의 데이터 셀을 표시합니다.\n * Displays a table data cell.\n * \n * @component\n * @param {TableCellProps} props - TableCell 컴포넌트의 props / TableCell component props\n * @param {React.Ref<HTMLTableCellElement>} ref - td 요소 ref / td element ref\n * @returns {JSX.Element} TableCell 컴포넌트 / TableCell component\n */\nconst TableCell = React.forwardRef<HTMLTableCellElement, TableCellProps>(\n ({ className, ...props }, ref) => (\n <td\n ref={ref}\n className={merge(\"p-4 align-middle [&:has([role=checkbox])]:pr-0\", className)}\n {...props}\n />\n )\n)\nTableCell.displayName = \"TableCell\"\n\n/**\n * TableCaption 컴포넌트 / TableCaption component\n * 테이블의 캡션을 표시합니다.\n * Displays a table caption.\n * \n * @component\n * @param {React.HTMLAttributes<HTMLTableCaptionElement>} props - TableCaption 컴포넌트의 props / TableCaption component props\n * @param {React.Ref<HTMLTableCaptionElement>} ref - caption 요소 ref / caption element ref\n * @returns {JSX.Element} TableCaption 컴포넌트 / TableCaption component\n */\nconst TableCaption = React.forwardRef<HTMLTableCaptionElement, React.HTMLAttributes<HTMLTableCaptionElement>>(\n ({ className, ...props }, ref) => (\n <caption\n ref={ref}\n className={merge(\"mt-4 text-sm text-slate-500 dark:text-slate-400\", className)}\n {...props}\n />\n )\n)\nTableCaption.displayName = \"TableCaption\"\n\nexport {\n Table,\n TableHeader,\n TableBody,\n TableFooter,\n TableHead,\n TableRow,\n TableCell,\n TableCaption,\n} ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Badge 컴포넌트의 props / Badge component props\n * @typedef {Object} BadgeProps\n * @property {\"default\" | \"secondary\" | \"destructive\" | \"error\" | \"outline\" | \"glass\"} [variant=\"default\"] - Badge 스타일 변형 / Badge style variant\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface BadgeProps extends React.HTMLAttributes<HTMLDivElement> {\n variant?: \"default\" | \"secondary\" | \"destructive\" | \"error\" | \"outline\" | \"glass\"\n}\n\n/**\n * Badge 컴포넌트 / Badge component\n * \n * 상태나 카테고리를 표시하는 작은 배지 컴포넌트입니다.\n * React.memo로 최적화되어 있어 불필요한 리렌더링을 방지합니다.\n * \n * Small badge component for displaying status or category.\n * Optimized with React.memo to prevent unnecessary re-renders.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Badge>New</Badge>\n * \n * @example\n * // 다양한 변형 / Various variants\n * <Badge variant=\"destructive\">완료</Badge>\n * <Badge variant=\"error\">오류</Badge>\n * <Badge variant=\"outline\">대기</Badge>\n * \n * @param {BadgeProps} props - Badge 컴포넌트의 props / Badge component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Badge 컴포넌트 / Badge component\n */\nconst Badge = React.memo(React.forwardRef<HTMLDivElement, BadgeProps>(\n ({ className, variant = \"default\", ...props }, ref) => {\n const variantClasses = React.useMemo(() => ({\n default: \"bg-slate-900 text-slate-50 hover:bg-slate-900/80 dark:bg-slate-50 dark:text-slate-900 dark:hover:bg-slate-50/80\",\n secondary: \"bg-slate-100 text-slate-900 hover:bg-slate-100/80 dark:bg-slate-800 dark:text-slate-50 dark:hover:bg-slate-800/80\",\n destructive: \"bg-red-500 text-slate-50 hover:bg-red-500/80 dark:bg-red-900 dark:text-slate-50 dark:hover:bg-red-900/80\",\n error: \"bg-red-500 text-slate-50 hover:bg-red-500/80 dark:bg-red-900 dark:text-slate-50 dark:hover:bg-red-900/80\", // error는 destructive와 동일\n outline: \"text-slate-950 border border-slate-200 hover:bg-slate-100 hover:text-slate-900 dark:border-slate-800 dark:text-slate-50 dark:hover:bg-slate-800 dark:hover:text-slate-50\",\n glass: \"bg-white/20 backdrop-blur-sm border border-white/30 text-white hover:bg-white/30 dark:bg-slate-800/20 dark:border-slate-700/50 dark:text-slate-200 dark:hover:bg-slate-700/30\"\n }), [])\n\n return (\n <div\n ref={ref}\n className={merge(\n \"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-gray-400 focus:ring-offset-2\",\n variantClasses[variant],\n className\n )}\n {...props}\n />\n )\n }\n))\nBadge.displayName = \"Badge\"\n\nexport { Badge } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Progress 컴포넌트의 props\n * @typedef {Object} ProgressProps\n * @property {number} [value=0] - 진행률 값\n * @property {number} [max=100] - 최대값\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Progress 바 크기\n * @property {\"default\" | \"success\" | \"warning\" | \"error\" | \"info\" | \"glass\"} [variant=\"default\"] - Progress 스타일 변형\n * @property {boolean} [showValue=false] - 진행률 퍼센트 표시 여부\n * @property {boolean} [animated=true] - 애니메이션 활성화 여부\n * @property {boolean} [striped=false] - 줄무늬 패턴 표시 여부\n * @property {string} [label] - Progress 라벨 텍스트\n * @property {string} [description] - Progress 설명 텍스트\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface ProgressProps extends React.HTMLAttributes<HTMLDivElement> {\n value?: number\n max?: number\n size?: \"sm\" | \"md\" | \"lg\"\n variant?: \"default\" | \"success\" | \"warning\" | \"error\" | \"info\" | \"glass\"\n showValue?: boolean\n animated?: boolean\n striped?: boolean\n label?: string\n description?: string\n}\n\n/**\n * Progress 컴포넌트 / Progress component\n * \n * 진행률을 표시하는 프로그레스 바 컴포넌트입니다.\n * 다양한 스타일과 애니메이션을 지원합니다.\n * \n * Progress bar component that displays progress.\n * Supports various styles and animations.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Progress value={50} />\n * \n * @example\n * // 라벨과 값 표시 / Show label and value\n * <Progress \n * value={75} \n * label=\"업로드 진행률\"\n * showValue\n * />\n * \n * @example\n * // Success 스타일, 줄무늬 패턴 / Success style, striped pattern\n * <Progress \n * value={90}\n * variant=\"success\"\n * striped\n * animated\n * />\n * \n * @param {ProgressProps} props - Progress 컴포넌트의 props / Progress component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Progress 컴포넌트 / Progress component\n */\nconst Progress = React.forwardRef<HTMLDivElement, ProgressProps>(\n ({ \n className, \n value = 0,\n max = 100,\n size = \"md\",\n variant = \"default\",\n showValue = false,\n animated = true,\n striped = false,\n label,\n description,\n ...props \n }, ref) => {\n const percentage = Math.min(Math.max((value / max) * 100, 0), 100)\n\n const sizeClasses = {\n sm: \"h-2\", // 8px 높이\n md: \"h-3\", // 12px 높이\n lg: \"h-4\" // 16px 높이\n }\n\n const getVariantClasses = () => {\n switch (variant) {\n case \"success\":\n return \"bg-green-500 dark:bg-green-400\"\n case \"warning\":\n return \"bg-yellow-500 dark:bg-yellow-400\"\n case \"error\":\n return \"bg-red-500 dark:bg-red-400\"\n case \"info\":\n return \"bg-blue-500 dark:bg-blue-400\"\n case \"glass\":\n return \"bg-white/50 backdrop-blur-sm\"\n default:\n return \"bg-gray-900 dark:bg-gray-100\"\n }\n }\n\n const getStripedClasses = () => {\n if (!striped) return \"\"\n return \"bg-gradient-to-r from-transparent via-white/20 to-transparent bg-[length:20px_100%] animate-pulse\"\n }\n\n return (\n <div className={merge(\"w-full\", className)} {...props}>\n {/* 라벨과 값 */}\n {(label || showValue) && (\n <div className=\"flex items-center justify-between mb-2\"> {/* 8px 여백 */}\n {label && (\n <span className=\"text-sm font-medium text-gray-700 dark:text-gray-300\">\n {label}\n </span>\n )}\n {showValue && (\n <span className=\"text-sm text-gray-600 dark:text-gray-400\">\n {Math.round(percentage)}%\n </span>\n )}\n </div>\n )}\n\n {/* 프로그레스 바 */}\n <div\n ref={ref}\n className={merge(\n \"relative w-full overflow-hidden rounded-full\",\n variant === \"glass\" \n ? \"bg-white/10 backdrop-blur-sm border border-white/20 dark:bg-slate-800/10 dark:border-slate-700/50\"\n : \"bg-gray-200 dark:bg-gray-700\",\n sizeClasses[size]\n )}\n >\n <div\n className={merge(\n \"h-full rounded-full transition-all duration-300 ease-out\",\n getVariantClasses(),\n getStripedClasses(),\n animated && \"animate-pulse\"\n )}\n style={{\n width: `${percentage}%`,\n transition: animated ? \"width 0.3s ease-out\" : \"none\"\n }}\n />\n </div>\n\n {/* 설명 */}\n {description && (\n <p className=\"mt-2 text-xs text-gray-500 dark:text-gray-400\"> {/* 8px 여백 */}\n {description}\n </p>\n )}\n </div>\n )\n }\n)\nProgress.displayName = \"Progress\"\n\n// 편의 컴포넌트들\nexport const ProgressSuccess = React.forwardRef<HTMLDivElement, Omit<ProgressProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Progress ref={ref} variant=\"success\" className={className} {...props} />\n )\n)\nProgressSuccess.displayName = \"ProgressSuccess\"\n\nexport const ProgressWarning = React.forwardRef<HTMLDivElement, Omit<ProgressProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Progress ref={ref} variant=\"warning\" className={className} {...props} />\n )\n)\nProgressWarning.displayName = \"ProgressWarning\"\n\nexport const ProgressError = React.forwardRef<HTMLDivElement, Omit<ProgressProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Progress ref={ref} variant=\"error\" className={className} {...props} />\n )\n)\nProgressError.displayName = \"ProgressError\"\n\nexport const ProgressInfo = React.forwardRef<HTMLDivElement, Omit<ProgressProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Progress ref={ref} variant=\"info\" className={className} {...props} />\n )\n)\nProgressInfo.displayName = \"ProgressInfo\"\n\n// 복합 Progress 컴포넌트들\nexport const ProgressWrapper = React.forwardRef<HTMLDivElement, ProgressProps & { title?: string }>(\n ({ title, className, ...props }, ref) => (\n <div className={merge(\"p-4 bg-white dark:bg-gray-800 rounded-lg border border-gray-200 dark:border-gray-700\", className)}>\n {title && (\n <h3 className=\"text-sm font-semibold text-gray-900 dark:text-white mb-3\"> {/* 12px 여백 */}\n {title}\n </h3>\n )}\n <Progress ref={ref} {...props} />\n </div>\n )\n)\nProgressWrapper.displayName = \"ProgressWrapper\"\n\nexport const ProgressGroup = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"space-y-4\", className)} // 16px 간격\n {...props}\n >\n {children}\n </div>\n )\n)\nProgressGroup.displayName = \"ProgressGroup\"\n\nexport { Progress } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Skeleton 컴포넌트의 props\n * @typedef {Object} SkeletonProps\n * @property {\"text\" | \"circular\" | \"rectangular\" | \"rounded\"} [variant=\"text\"] - Skeleton 모양\n * @property {string | number} [width] - 너비 (기본값: variant에 따라 다름)\n * @property {string | number} [height] - 높이 (기본값: variant에 따라 다름)\n * @property {\"pulse\" | \"wave\" | \"shimmer\"} [animation=\"pulse\"] - 애니메이션 타입\n * @property {string} [className] - 추가 CSS 클래스\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface SkeletonProps extends React.HTMLAttributes<HTMLDivElement> {\n variant?: \"text\" | \"circular\" | \"rectangular\" | \"rounded\"\n width?: string | number\n height?: string | number\n animation?: \"pulse\" | \"wave\" | \"shimmer\"\n className?: string\n}\n\n/**\n * Skeleton 컴포넌트 / Skeleton component\n * \n * 로딩 중 콘텐츠의 플레이스홀더를 표시하는 스켈레톤 컴포넌트입니다.\n * 다양한 모양과 애니메이션을 지원합니다.\n * \n * Skeleton component that displays placeholders for content while loading.\n * Supports various shapes and animations.\n * \n * @component\n * @example\n * // 기본 사용 (텍스트) / Basic usage (text)\n * <Skeleton />\n * \n * @example\n * // 원형 아바타 / Circular avatar\n * <Skeleton variant=\"circular\" width={40} height={40} />\n * \n * @example\n * // Wave 애니메이션 / Wave animation\n * <Skeleton \n * variant=\"rounded\" \n * width=\"100%\" \n * height={200}\n * animation=\"wave\"\n * />\n * \n * @param {SkeletonProps} props - Skeleton 컴포넌트의 props / Skeleton component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Skeleton 컴포넌트 / Skeleton component\n */\nconst Skeleton = React.forwardRef<HTMLDivElement, SkeletonProps>(\n ({ \n className, \n variant = \"text\",\n width,\n height,\n animation = \"pulse\",\n ...props \n }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"circular\":\n return \"rounded-full\"\n case \"rounded\":\n return \"rounded-lg\"\n case \"rectangular\":\n return \"rounded-none\"\n case \"text\":\n default:\n return \"rounded\"\n }\n }\n\n const getAnimationClasses = () => {\n switch (animation) {\n case \"wave\":\n return \"animate-pulse bg-gradient-to-r from-gray-200 via-gray-300 to-gray-200 bg-[length:200%_100%] animate-shimmer\"\n case \"shimmer\":\n return \"bg-gradient-to-r from-gray-200 via-gray-300 to-gray-200 bg-[length:200%_100%] animate-shimmer\"\n case \"pulse\":\n default:\n return \"animate-pulse bg-gray-200 dark:bg-gray-700\"\n }\n }\n\n const getDefaultDimensions = () => {\n switch (variant) {\n case \"circular\":\n return { width: \"40px\", height: \"40px\" }\n case \"text\":\n return { width: \"100%\", height: \"1em\" }\n case \"rounded\":\n return { width: \"100%\", height: \"200px\" }\n case \"rectangular\":\n return { width: \"100%\", height: \"200px\" }\n default:\n return { width: \"100%\", height: \"1em\" }\n }\n }\n\n const defaultDims = getDefaultDimensions()\n const finalWidth = width || defaultDims.width\n const finalHeight = height || defaultDims.height\n\n return (\n <div\n ref={ref}\n className={merge(\n \"block\",\n getVariantClasses(),\n getAnimationClasses(),\n className\n )}\n style={{\n width: typeof finalWidth === \"number\" ? `${finalWidth}px` : finalWidth,\n height: typeof finalHeight === \"number\" ? `${finalHeight}px` : finalHeight,\n }}\n {...props}\n />\n )\n }\n)\nSkeleton.displayName = \"Skeleton\"\n\n// 편의 컴포넌트들\nexport const SkeletonText = React.forwardRef<HTMLDivElement, Omit<SkeletonProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Skeleton ref={ref} variant=\"text\" className={className} {...props} />\n )\n)\nSkeletonText.displayName = \"SkeletonText\"\n\nexport const SkeletonCircle = React.forwardRef<HTMLDivElement, Omit<SkeletonProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Skeleton ref={ref} variant=\"circular\" className={className} {...props} />\n )\n)\nSkeletonCircle.displayName = \"SkeletonCircle\"\n\nexport const SkeletonRectangle = React.forwardRef<HTMLDivElement, Omit<SkeletonProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Skeleton ref={ref} variant=\"rectangular\" className={className} {...props} />\n )\n)\nSkeletonRectangle.displayName = \"SkeletonRectangle\"\n\nexport const SkeletonRounded = React.forwardRef<HTMLDivElement, Omit<SkeletonProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Skeleton ref={ref} variant=\"rounded\" className={className} {...props} />\n )\n)\nSkeletonRounded.displayName = \"SkeletonRounded\"\n\n// 복합 스켈레톤 컴포넌트들\nexport const SkeletonCard = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"space-y-4 p-6\", className)} // 16px 간격, 24px 패딩\n {...props}\n >\n <div className=\"flex items-center space-x-4\"> {/* 16px 간격 */}\n <SkeletonCircle className=\"w-12 h-12\" /> {/* 48px 크기 */}\n <div className=\"space-y-2 flex-1\"> {/* 8px 간격 */}\n <SkeletonText className=\"h-4 w-3/4\" /> {/* 16px 높이, 75% 너비 */}\n <SkeletonText className=\"h-3 w-1/2\" /> {/* 12px 높이, 50% 너비 */}\n </div>\n </div>\n <SkeletonRounded className=\"w-full h-32\" /> {/* 128px 높이 */}\n <div className=\"space-y-2\"> {/* 8px 간격 */}\n <SkeletonText className=\"h-4 w-full\" />\n <SkeletonText className=\"h-4 w-5/6\" />\n <SkeletonText className=\"h-4 w-4/6\" />\n </div>\n </div>\n )\n)\nSkeletonCard.displayName = \"SkeletonCard\"\n\nexport const SkeletonAvatar = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"flex items-center space-x-4\", className)} // 16px 간격\n {...props}\n >\n <SkeletonCircle className=\"w-12 h-12\" /> {/* 48px 크기 */}\n <div className=\"space-y-2 flex-1\"> {/* 8px 간격 */}\n <SkeletonText className=\"h-4 w-3/4\" />\n <SkeletonText className=\"h-3 w-1/2\" />\n </div>\n </div>\n )\n)\nSkeletonAvatar.displayName = \"SkeletonAvatar\"\n\nexport const SkeletonImage = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"space-y-2\", className)} // 8px 간격\n {...props}\n >\n <SkeletonRounded className=\"w-full h-48\" /> {/* 192px 높이 */}\n <SkeletonText className=\"h-4 w-1/2\" />\n </div>\n )\n)\nSkeletonImage.displayName = \"SkeletonImage\"\n\nexport const SkeletonUserProfile = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"space-y-4\", className)} // 16px 간격\n {...props}\n >\n <div className=\"flex items-center space-x-4\"> {/* 16px 간격 */}\n <SkeletonCircle className=\"w-16 h-16\" /> {/* 64px 크기 */}\n <div className=\"space-y-2 flex-1\"> {/* 8px 간격 */}\n <SkeletonText className=\"h-5 w-1/2\" />\n <SkeletonText className=\"h-3 w-1/3\" />\n </div>\n </div>\n <div className=\"space-y-2\"> {/* 8px 간격 */}\n <SkeletonText className=\"h-4 w-full\" />\n <SkeletonText className=\"h-4 w-5/6\" />\n </div>\n </div>\n )\n)\nSkeletonUserProfile.displayName = \"SkeletonUserProfile\"\n\nexport const SkeletonList = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"space-y-4\", className)} // 16px 간격\n {...props}\n >\n {Array.from({ length: 3 }).map((_, index) => (\n <div key={index} className=\"flex items-center space-x-4\"> {/* 16px 간격 */}\n <SkeletonCircle className=\"w-10 h-10\" /> {/* 40px 크기 */}\n <div className=\"space-y-2 flex-1\"> {/* 8px 간격 */}\n <SkeletonText className=\"h-4 w-3/4\" />\n <SkeletonText className=\"h-3 w-1/2\" />\n </div>\n </div>\n ))}\n </div>\n )\n)\nSkeletonList.displayName = \"SkeletonList\"\n\nexport const SkeletonTable = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"space-y-4\", className)} // 16px 간격\n {...props}\n >\n {/* 헤더 */}\n <div className=\"flex space-x-4\"> {/* 16px 간격 */}\n <SkeletonText className=\"h-4 w-1/4\" />\n <SkeletonText className=\"h-4 w-1/4\" />\n <SkeletonText className=\"h-4 w-1/4\" />\n <SkeletonText className=\"h-4 w-1/4\" />\n </div>\n {/* 행들 */}\n {Array.from({ length: 5 }).map((_, index) => (\n <div key={index} className=\"flex space-x-4\"> {/* 16px 간격 */}\n <SkeletonText className=\"h-4 w-1/4\" />\n <SkeletonText className=\"h-4 w-1/4\" />\n <SkeletonText className=\"h-4 w-1/4\" />\n <SkeletonText className=\"h-4 w-1/4\" />\n </div>\n ))}\n </div>\n )\n)\nSkeletonTable.displayName = \"SkeletonTable\"\n\nexport { Skeleton } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Alert 컴포넌트의 props\n * @typedef {Object} AlertProps\n * @property {\"default\" | \"success\" | \"warning\" | \"error\" | \"info\"} [variant=\"default\"] - Alert 스타일 변형\n * @property {string} [title] - Alert 제목\n * @property {string} [description] - Alert 설명\n * @property {React.ReactNode} [icon] - 커스텀 아이콘\n * @property {React.ReactNode} [action] - 액션 버튼/요소\n * @property {boolean} [closable=false] - 닫기 버튼 표시 여부\n * @property {() => void} [onClose] - 닫기 버튼 클릭 시 호출되는 콜백\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface AlertProps extends React.HTMLAttributes<HTMLDivElement> {\n variant?: \"default\" | \"success\" | \"warning\" | \"error\" | \"info\"\n title?: string\n description?: string\n icon?: React.ReactNode\n action?: React.ReactNode\n closable?: boolean\n onClose?: () => void\n}\n\n/**\n * Alert 컴포넌트 / Alert component\n * \n * 사용자에게 중요한 정보나 경고를 표시하는 컴포넌트입니다.\n * 다양한 변형(variant)을 지원하며, 아이콘, 제목, 설명, 액션 버튼을 포함할 수 있습니다.\n * \n * Component for displaying important information or warnings to users.\n * Supports various variants and can include icons, titles, descriptions, and action buttons.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Alert variant=\"info\" title=\"정보\" description=\"이것은 정보 메시지입니다.\" />\n * \n * @example\n * // 닫기 버튼 포함 / With close button\n * <Alert \n * variant=\"warning\" \n * title=\"경고\" \n * closable \n * onClose={() => console.log('닫기')}\n * />\n * \n * @example\n * // 커스텀 아이콘과 액션 / Custom icon and action\n * <Alert \n * variant=\"success\"\n * icon={<Icon name=\"check\" />}\n * action={<Button size=\"sm\">확인</Button>}\n * >\n * 작업이 완료되었습니다.\n * </Alert>\n * \n * @param {AlertProps} props - Alert 컴포넌트의 props / Alert component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Alert 컴포넌트 / Alert component\n */\nconst Alert = React.forwardRef<HTMLDivElement, AlertProps>(\n ({ \n className, \n variant = \"default\",\n title,\n description,\n icon,\n action,\n closable = false,\n onClose,\n children,\n ...props \n }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"success\":\n return \"bg-green-500/10 backdrop-blur-sm border-green-400/30 text-green-200 dark:bg-green-500/10 dark:border-green-400/30 dark:text-green-200\"\n case \"warning\":\n return \"bg-yellow-500/10 backdrop-blur-sm border-yellow-400/30 text-yellow-200 dark:bg-yellow-500/10 dark:border-yellow-400/30 dark:text-yellow-200\"\n case \"error\":\n return \"bg-red-500/10 backdrop-blur-sm border-red-400/30 text-red-200 dark:bg-red-500/10 dark:border-red-400/30 dark:text-red-200\"\n case \"info\":\n return \"bg-blue-500/10 backdrop-blur-sm border-blue-400/30 text-blue-200 dark:bg-blue-500/10 dark:border-blue-400/30 dark:text-blue-200\"\n default:\n return \"bg-white/10 backdrop-blur-sm border-white/30 text-white dark:bg-slate-800/20 dark:border-slate-700/50 dark:text-slate-200\"\n }\n }\n\n const getIconClasses = () => {\n switch (variant) {\n case \"success\":\n return \"text-green-500 dark:text-green-400\"\n case \"warning\":\n return \"text-yellow-500 dark:text-yellow-400\"\n case \"error\":\n return \"text-red-500 dark:text-red-400\"\n case \"info\":\n return \"text-blue-500 dark:text-blue-400\"\n default:\n return \"text-gray-500 dark:text-gray-400\"\n }\n }\n\n const getDefaultIcon = () => {\n switch (variant) {\n case \"success\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M5 13l4 4L19 7\" />\n </svg>\n )\n case \"warning\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-2.5L13.732 4c-.77-.833-1.964-.833-2.732 0L3.732 16.5c-.77.833.192 2.5 1.732 2.5z\" />\n </svg>\n )\n case \"error\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n )\n case \"info\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z\" />\n </svg>\n )\n default:\n return null\n }\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n \"relative rounded-lg border p-4\", // 16px 패딩\n getVariantClasses(),\n className\n )}\n {...props}\n >\n <div className=\"flex items-start gap-3\"> {/* 12px 간격 */}\n {/* 아이콘 */}\n {(icon || getDefaultIcon()) && (\n <div className={merge(\"flex-shrink-0 mt-0.5\", getIconClasses())}>\n {icon || getDefaultIcon()}\n </div>\n )}\n\n {/* 내용 */}\n <div className=\"flex-1 min-w-0\">\n {title && (\n <h4 className=\"text-sm font-semibold mb-1\"> {/* 4px 여백 */}\n {title}\n </h4>\n )}\n {description && (\n <p className=\"text-sm leading-relaxed\">\n {description}\n </p>\n )}\n {children && (\n <div className=\"mt-2\"> {/* 8px 여백 */}\n {children}\n </div>\n )}\n </div>\n\n {/* 액션 */}\n {(action || closable) && (\n <div className=\"flex-shrink-0 flex items-center gap-2\"> {/* 8px 간격 */}\n {action}\n {closable && (\n <button\n onClick={onClose}\n className={merge(\n \"inline-flex rounded-md p-1.5 focus:outline-none focus:ring-2 focus:ring-offset-2 transition-all duration-200 hover:bg-black/5 dark:hover:bg-white/5\",\n getIconClasses()\n )}\n aria-label=\"닫기\"\n >\n <svg className=\"w-4 h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n </button>\n )}\n </div>\n )}\n </div>\n </div>\n )\n }\n)\nAlert.displayName = \"Alert\"\n\n// 편의 컴포넌트들\nexport const AlertSuccess = React.forwardRef<HTMLDivElement, Omit<AlertProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Alert ref={ref} variant=\"success\" className={className} {...props} />\n )\n)\nAlertSuccess.displayName = \"AlertSuccess\"\n\nexport const AlertWarning = React.forwardRef<HTMLDivElement, Omit<AlertProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Alert ref={ref} variant=\"warning\" className={className} {...props} />\n )\n)\nAlertWarning.displayName = \"AlertWarning\"\n\nexport const AlertError = React.forwardRef<HTMLDivElement, Omit<AlertProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Alert ref={ref} variant=\"error\" className={className} {...props} />\n )\n)\nAlertError.displayName = \"AlertError\"\n\nexport const AlertInfo = React.forwardRef<HTMLDivElement, Omit<AlertProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Alert ref={ref} variant=\"info\" className={className} {...props} />\n )\n)\nAlertInfo.displayName = \"AlertInfo\"\n\nexport { Alert } ","\"use client\"\n\nimport React from \"react\"\nimport { createContext, useContext, useState, useCallback } from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Toast 메시지 타입 / Toast message type\n * @typedef {Object} Toast\n * @property {string} id - Toast 고유 ID / Toast unique ID\n * @property {\"success\" | \"error\" | \"warning\" | \"info\"} type - Toast 타입 / Toast type\n * @property {string} [title] - Toast 제목 / Toast title\n * @property {string} message - Toast 메시지 / Toast message\n * @property {number} [duration] - 표시 시간(ms), 0이면 자동 제거 안 함 / Display duration (ms), 0 means no auto-remove\n * @property {Object} [action] - 액션 버튼 / Action button\n * @property {string} action.label - 액션 버튼 레이블 / Action button label\n * @property {() => void} action.onClick - 액션 버튼 클릭 핸들러 / Action button click handler\n */\nexport interface Toast {\n id: string\n type: \"success\" | \"error\" | \"warning\" | \"info\"\n title?: string\n message: string\n duration?: number\n action?: {\n label: string\n onClick: () => void\n }\n}\n\n// Toast Context 타입\ninterface ToastContextType {\n toasts: Toast[]\n addToast: (toast: Omit<Toast, \"id\">) => void\n removeToast: (id: string) => void\n clearToasts: () => void\n}\n\n// Toast Context 생성\nconst ToastContext = createContext<ToastContextType | undefined>(undefined)\n\n/**\n * useToast Hook\n * \n * Toast를 추가, 제거, 초기화하는 훅입니다.\n * ToastProvider 내부에서만 사용 가능합니다.\n * \n * Hook for adding, removing, and clearing toasts.\n * Can only be used within ToastProvider.\n * \n * @example\n * const { addToast, removeToast, clearToasts } = useToast()\n * \n * addToast({\n * type: \"success\",\n * message: \"저장되었습니다\",\n * duration: 3000\n * })\n * \n * @returns {ToastContextType} Toast 컨텍스트 값 / Toast context value\n * @throws {Error} ToastProvider 외부에서 사용 시 에러 발생 / Error when used outside ToastProvider\n */\nexport function useToast(): ToastContextType {\n const context = useContext(ToastContext)\n if (!context) {\n throw new Error(\"useToast must be used within a ToastProvider\")\n }\n return context\n}\n\n/**\n * ToastProvider 컴포넌트의 props / ToastProvider component props\n * @typedef {Object} ToastProviderProps\n * @property {React.ReactNode} children - 자식 컴포넌트 / Child components\n * @property {number} [maxToasts=5] - 최대 Toast 개수 / Maximum number of toasts\n * @property {\"top-right\" | \"top-left\" | \"bottom-right\" | \"bottom-left\" | \"top-center\" | \"bottom-center\"} [position=\"top-right\"] - Toast 표시 위치 / Toast display position\n */\ninterface ToastProviderProps {\n children: React.ReactNode\n maxToasts?: number\n position?: \"top-right\" | \"top-left\" | \"bottom-right\" | \"bottom-left\" | \"top-center\" | \"bottom-center\"\n}\n\n/**\n * ToastProvider 컴포넌트 / ToastProvider component\n * \n * Toast 시스템의 컨텍스트를 제공하는 Provider 컴포넌트입니다.\n * 앱의 루트 레벨에서 사용하여 전역 Toast 기능을 활성화합니다.\n * \n * Provider component that provides context for the Toast system.\n * Use at the root level of your app to enable global Toast functionality.\n * \n * @component\n * @example\n * // App.tsx\n * <ToastProvider position=\"top-center\" maxToasts={3}>\n * <App />\n * </ToastProvider>\n * \n * @example\n * // 컴포넌트에서 사용 / Usage in component\n * const { addToast } = useToast()\n * \n * const handleSave = () => {\n * addToast({\n * type: \"success\",\n * message: \"저장되었습니다\",\n * title: \"성공\"\n * })\n * }\n * \n * @param {ToastProviderProps} props - ToastProvider 컴포넌트의 props / ToastProvider component props\n * @returns {JSX.Element} ToastProvider 컴포넌트 / ToastProvider component\n * \n * @todo 접근성 개선: ToastItem에 role=\"alert\" 또는 role=\"status\" 추가 필요 / Accessibility: Add role=\"alert\" or role=\"status\" to ToastItem\n * @todo 접근성 개선: aria-live=\"polite\" 또는 aria-live=\"assertive\" 추가 필요 / Accessibility: Add aria-live=\"polite\" or aria-live=\"assertive\"\n */\nexport function ToastProvider({ \n children, \n maxToasts = 5,\n position = \"top-right\" \n}: ToastProviderProps) {\n const [toasts, setToasts] = useState<Toast[]>([])\n\n const removeToast = useCallback((id: string) => {\n setToasts(prev => prev.filter(toast => toast.id !== id))\n }, [])\n\n const addToast = useCallback((toast: Omit<Toast, \"id\">) => {\n const id = Math.random().toString(36).substr(2, 9)\n const newToast: Toast = { ...toast, id }\n \n setToasts(prev => {\n const updatedToasts = [...prev, newToast]\n return updatedToasts.slice(-maxToasts) // 최대 개수 제한\n })\n \n // 자동 제거\n if (toast.duration !== 0) {\n setTimeout(() => {\n removeToast(id)\n }, toast.duration || 5000)\n }\n }, [maxToasts, removeToast])\n\n const clearToasts = useCallback(() => {\n setToasts([])\n }, [])\n\n return (\n <ToastContext.Provider value={{ toasts, addToast, removeToast, clearToasts }}>\n {children}\n <ToastContainer toasts={toasts} removeToast={removeToast} position={position} />\n </ToastContext.Provider>\n )\n}\n\n// Toast Container Props\ninterface ToastContainerProps {\n toasts: Toast[]\n removeToast: (id: string) => void\n position: string\n}\n\n// Toast Container\nfunction ToastContainer({ toasts, removeToast, position }: ToastContainerProps) {\n const positionClasses = {\n \"top-right\": \"top-4 right-4\",\n \"top-left\": \"top-4 left-4\",\n \"bottom-right\": \"bottom-4 right-4\",\n \"bottom-left\": \"bottom-4 left-4\",\n \"top-center\": \"top-4 left-1/2 transform -translate-x-1/2\",\n \"bottom-center\": \"bottom-4 left-1/2 transform -translate-x-1/2\"\n }\n\n if (toasts.length === 0) return null\n\n return (\n <div className={merge(\n \"fixed z-50 space-y-3 max-w-sm\", // 12px 간격\n positionClasses[position as keyof typeof positionClasses]\n )}>\n {toasts.map((toast) => (\n <ToastItem key={toast.id} toast={toast} onRemove={removeToast} />\n ))}\n </div>\n )\n}\n\n// Toast Item Props\ninterface ToastItemProps {\n toast: Toast\n onRemove: (id: string) => void\n}\n\n// Toast Item\nfunction ToastItem({ toast, onRemove }: ToastItemProps) {\n const [isVisible, setIsVisible] = useState(false)\n\n React.useEffect(() => {\n setIsVisible(true)\n }, [])\n\n const handleRemove = () => {\n setIsVisible(false)\n setTimeout(() => onRemove(toast.id), 300)\n }\n\n const getToastStyles = (type: Toast[\"type\"]) => {\n switch (type) {\n case \"success\":\n return \"bg-green-50 dark:bg-green-900/20 border-green-200 dark:border-green-800 text-green-800 dark:text-green-200\"\n case \"error\":\n return \"bg-red-50 dark:bg-red-900/20 border-red-200 dark:border-red-800 text-red-800 dark:text-red-200\"\n case \"warning\":\n return \"bg-yellow-50 dark:bg-yellow-900/20 border-yellow-200 dark:border-yellow-800 text-yellow-800 dark:text-yellow-200\"\n case \"info\":\n return \"bg-blue-50 dark:bg-blue-900/20 border-blue-200 dark:border-blue-800 text-blue-800 dark:text-blue-200\"\n }\n }\n\n const getIconStyles = (type: Toast[\"type\"]) => {\n switch (type) {\n case \"success\":\n return \"text-green-500 dark:text-green-400\"\n case \"error\":\n return \"text-red-500 dark:text-red-400\"\n case \"warning\":\n return \"text-yellow-500 dark:text-yellow-400\"\n case \"info\":\n return \"text-blue-500 dark:text-blue-400\"\n }\n }\n\n const getToastIcon = (type: Toast[\"type\"]) => {\n switch (type) {\n case \"success\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M5 13l4 4L19 7\" />\n </svg>\n )\n case \"error\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n )\n case \"warning\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-2.5L13.732 4c-.77-.833-1.964-.833-2.732 0L3.732 16.5c-.77.833.192 2.5 1.732 2.5z\" />\n </svg>\n )\n case \"info\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z\" />\n </svg>\n )\n }\n }\n\n return (\n <div\n className={merge(\n \"flex items-start p-4 rounded-xl border shadow-lg backdrop-blur-sm transition-all duration-300 transform\",\n getToastStyles(toast.type),\n isVisible \n ? \"translate-x-0 opacity-100 scale-100\" \n : \"translate-x-full opacity-0 scale-95\"\n )}\n style={{\n animation: isVisible ? \"slideInRight 0.3s cubic-bezier(0.16, 1, 0.3, 1)\" : undefined\n }}\n >\n {/* 아이콘 */}\n <div className={merge(\"flex-shrink-0 mr-3\", getIconStyles(toast.type))}> {/* 12px 여백 */}\n {getToastIcon(toast.type)}\n </div>\n\n {/* 내용 */}\n <div className=\"flex-1 min-w-0\">\n {toast.title && (\n <h4 className=\"text-sm font-semibold mb-1\"> {/* 4px 여백 */}\n {toast.title}\n </h4>\n )}\n <p className=\"text-sm leading-relaxed\">\n {toast.message}\n </p>\n \n {/* 액션 버튼 */}\n {toast.action && (\n <button\n onClick={toast.action.onClick}\n className=\"mt-3 text-sm font-medium underline hover:no-underline transition-all duration-200\" // 12px 여백\n >\n {toast.action.label}\n </button>\n )}\n </div>\n\n {/* 닫기 버튼 */}\n <div className=\"flex-shrink-0 ml-4\"> {/* 16px 여백 */}\n <button\n onClick={handleRemove}\n className={merge(\n \"inline-flex rounded-md p-1.5 focus:outline-none focus:ring-2 focus:ring-offset-2 transition-all duration-200 hover:bg-black/5 dark:hover:bg-white/5\",\n getIconStyles(toast.type)\n )}\n aria-label=\"닫기\"\n >\n <svg className=\"w-4 h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n </button>\n </div>\n </div>\n )\n}\n\n// 편의 함수들\nexport const showToast = (toast: Omit<Toast, \"id\">) => {\n // 이 함수는 ToastProvider 내부에서만 사용 가능\n console.warn(\"showToast is deprecated. Use useToast hook instead.\")\n}\n\nexport const showSuccessToast = (message: string, title?: string, duration?: number) => {\n console.warn(\"showSuccessToast is deprecated. Use useToast hook instead.\")\n}\n\nexport const showErrorToast = (message: string, title?: string, duration?: number) => {\n console.warn(\"showErrorToast is deprecated. Use useToast hook instead.\")\n}\n\nexport const showWarningToast = (message: string, title?: string, duration?: number) => {\n console.warn(\"showWarningToast is deprecated. Use useToast hook instead.\")\n}\n\nexport const showInfoToast = (message: string, title?: string, duration?: number) => {\n console.warn(\"showInfoToast is deprecated. Use useToast hook instead.\")\n} ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Tooltip 컴포넌트의 props / Tooltip component props\n * @typedef {Object} TooltipProps\n * @property {string} content - Tooltip 내용 / Tooltip content\n * @property {React.ReactNode} children - Tooltip이 연결될 요소 / Element to attach tooltip to\n * @property {\"top\" | \"bottom\" | \"left\" | \"right\"} [position=\"top\"] - Tooltip 표시 위치 / Tooltip display position\n * @property {\"default\" | \"light\" | \"dark\"} [variant=\"default\"] - Tooltip 스타일 변형 / Tooltip style variant\n * @property {number} [delay=300] - Tooltip 표시 지연 시간(ms) / Tooltip display delay (ms)\n * @property {boolean} [disabled=false] - Tooltip 비활성화 여부 / Disable tooltip\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface TooltipProps extends React.HTMLAttributes<HTMLDivElement> {\n content: string\n children: React.ReactNode\n position?: \"top\" | \"bottom\" | \"left\" | \"right\"\n variant?: \"default\" | \"light\" | \"dark\"\n delay?: number\n disabled?: boolean\n}\n\n/**\n * Tooltip 컴포넌트 / Tooltip component\n * \n * 호버 시 추가 정보를 표시하는 툴팁 컴포넌트입니다.\n * 마우스 호버 시 지연 시간 후 표시됩니다.\n * \n * Tooltip component that displays additional information on hover.\n * Appears after a delay when the mouse hovers over the element.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Tooltip content=\"이것은 도움말입니다\">\n * <Button>호버하세요</Button>\n * </Tooltip>\n * \n * @example\n * // 다양한 위치 / Different positions\n * <Tooltip content=\"위치 변경\" position=\"bottom\">\n * <Icon name=\"info\" />\n * </Tooltip>\n * \n * @example\n * // 커스텀 스타일 / Custom styles\n * <Tooltip content=\"라이트 스타일\" variant=\"light\" delay={500}>\n * <span>호버</span>\n * </Tooltip>\n * \n * @param {TooltipProps} props - Tooltip 컴포넌트의 props / Tooltip component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Tooltip 컴포넌트 / Tooltip component\n * \n * @todo 접근성 개선: role=\"tooltip\" 추가 필요 / Accessibility: Add role=\"tooltip\"\n * @todo 접근성 개선: aria-describedby 연결 필요 / Accessibility: Connect aria-describedby\n * @todo 접근성 개선: 키보드 포커스 시 Tooltip 표시 필요 / Accessibility: Show tooltip on keyboard focus\n */\nconst Tooltip = React.forwardRef<HTMLDivElement, TooltipProps>(\n ({ \n className, \n content,\n children,\n position = \"top\",\n variant = \"default\",\n delay = 300,\n disabled = false,\n ...props \n }, ref) => {\n const [isVisible, setIsVisible] = React.useState(false)\n const [coords, setCoords] = React.useState({ x: 0, y: 0 })\n const timeoutRef = React.useRef<number | undefined>(undefined)\n const tooltipRef = React.useRef<HTMLDivElement>(null)\n\n const showTooltip = (e: React.MouseEvent) => {\n if (disabled) return\n \n const rect = e.currentTarget.getBoundingClientRect()\n const tooltipRect = tooltipRef.current?.getBoundingClientRect()\n \n let x = 0\n let y = 0\n \n switch (position) {\n case \"top\":\n x = rect.left + rect.width / 2\n y = rect.top - 8 // 8px 간격\n break\n case \"bottom\":\n x = rect.left + rect.width / 2\n y = rect.bottom + 8 // 8px 간격\n break\n case \"left\":\n x = rect.left - 8 // 8px 간격\n y = rect.top + rect.height / 2\n break\n case \"right\":\n x = rect.right + 8 // 8px 간격\n y = rect.top + rect.height / 2\n break\n }\n \n setCoords({ x, y })\n \n timeoutRef.current = window.setTimeout(() => {\n setIsVisible(true)\n }, delay)\n }\n\n const hideTooltip = () => {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current)\n }\n setIsVisible(false)\n }\n\n React.useEffect(() => {\n return () => {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current)\n }\n }\n }, [])\n\n const getVariantClasses = () => {\n switch (variant) {\n case \"light\":\n return \"bg-white text-gray-900 border border-gray-200 shadow-lg\"\n case \"dark\":\n return \"bg-gray-900 text-white shadow-lg\"\n default:\n return \"bg-gray-800 text-white shadow-lg\"\n }\n }\n\n const getPositionClasses = () => {\n switch (position) {\n case \"top\":\n return \"bottom-full left-1/2 -translate-x-1/2 mb-2\" // 8px 간격\n case \"bottom\":\n return \"top-full left-1/2 -translate-x-1/2 mt-2\" // 8px 간격\n case \"left\":\n return \"right-full top-1/2 -translate-y-1/2 mr-2\" // 8px 간격\n case \"right\":\n return \"left-full top-1/2 -translate-y-1/2 ml-2\" // 8px 간격\n default:\n return \"bottom-full left-1/2 -translate-x-1/2 mb-2\"\n }\n }\n\n const getArrowClasses = () => {\n switch (position) {\n case \"top\":\n return \"top-full left-1/2 -translate-x-1/2 border-t-gray-800 dark:border-t-gray-800\"\n case \"bottom\":\n return \"bottom-full left-1/2 -translate-x-1/2 border-b-gray-800 dark:border-b-gray-800\"\n case \"left\":\n return \"left-full top-1/2 -translate-y-1/2 border-l-gray-800 dark:border-l-gray-800\"\n case \"right\":\n return \"right-full top-1/2 -translate-y-1/2 border-r-gray-800 dark:border-r-gray-800\"\n default:\n return \"top-full left-1/2 -translate-x-1/2 border-t-gray-800 dark:border-t-gray-800\"\n }\n }\n\n return (\n <div\n ref={ref}\n className={merge(\"relative inline-block\", className)}\n onMouseEnter={showTooltip}\n onMouseLeave={hideTooltip}\n {...props}\n >\n {children}\n \n {isVisible && (\n <div\n ref={tooltipRef}\n className={merge(\n \"fixed z-50 px-3 py-2 text-sm rounded-lg whitespace-nowrap pointer-events-none\", // 12px, 8px 패딩\n getVariantClasses()\n )}\n style={{\n left: `${coords.x}px`,\n top: `${coords.y}px`,\n transform: 'translate(-50%, -50%)'\n }}\n >\n {content}\n {/* 화살표 */}\n <div\n className={merge(\n \"absolute w-0 h-0 border-4 border-transparent\",\n getArrowClasses()\n )}\n />\n </div>\n )}\n </div>\n )\n }\n)\nTooltip.displayName = \"Tooltip\"\n\n// 편의 컴포넌트들\nexport const TooltipLight = React.forwardRef<HTMLDivElement, Omit<TooltipProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Tooltip ref={ref} variant=\"light\" className={className} {...props} />\n )\n)\nTooltipLight.displayName = \"TooltipLight\"\n\nexport const TooltipDark = React.forwardRef<HTMLDivElement, Omit<TooltipProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Tooltip ref={ref} variant=\"dark\" className={className} {...props} />\n )\n)\nTooltipDark.displayName = \"TooltipDark\"\n\nexport { Tooltip } ","\"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 * Dropdown 컴포넌트의 props / Dropdown component props\n * @typedef {Object} DropdownProps\n * @property {React.ReactNode} trigger - Dropdown을 열기 위한 트리거 요소 / Trigger element to open dropdown\n * @property {React.ReactNode} children - Dropdown 내용 / Dropdown content\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\"} [placement=\"bottom\"] - Dropdown 표시 위치 / Dropdown display position\n * @property {\"start\" | \"center\" | \"end\"} [align=\"start\"] - Dropdown 정렬 / Dropdown alignment\n * @property {number} [offset=8] - 트리거와 Dropdown 사이 간격 (px) / Spacing between trigger and dropdown (px)\n * @property {boolean} [disabled=false] - Dropdown 비활성화 여부 / Disable dropdown\n * @property {boolean} [showArrow=true] - 화살표 표시 여부 / Show arrow\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface DropdownProps extends React.HTMLAttributes<HTMLDivElement> {\n trigger: React.ReactNode\n children: React.ReactNode\n open?: boolean\n onOpenChange?: (open: boolean) => void\n placement?: \"top\" | \"bottom\" | \"left\" | \"right\"\n align?: \"start\" | \"center\" | \"end\"\n offset?: number\n disabled?: boolean\n showArrow?: boolean\n}\n\n/**\n * Dropdown 컴포넌트 / Dropdown component\n * \n * 트리거 요소를 클릭하면 표시되는 드롭다운 메뉴 컴포넌트입니다.\n * 외부 클릭 시 자동으로 닫히며, 뷰포트 경계를 자동으로 감지하여 위치를 조정합니다.\n * \n * Dropdown menu component that appears when the trigger element is clicked.\n * Automatically closes on outside click and adjusts position by detecting viewport boundaries.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Dropdown trigger={<Button>메뉴</Button>}>\n * <Menu>\n * <MenuItem>항목 1</MenuItem>\n * <MenuItem>항목 2</MenuItem>\n * </Menu>\n * </Dropdown>\n * \n * @example\n * // 제어 모드, 화살표 없음 / Controlled mode, no arrow\n * const [open, setOpen] = useState(false)\n * <Dropdown \n * open={open}\n * onOpenChange={setOpen}\n * trigger={<Button>제어 모드</Button>}\n * placement=\"top\"\n * showArrow={false}\n * >\n * <div className=\"p-4\">내용</div>\n * </Dropdown>\n * \n * @param {DropdownProps} props - Dropdown 컴포넌트의 props / Dropdown component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Dropdown 컴포넌트 / Dropdown component\n */\nconst Dropdown = React.forwardRef<HTMLDivElement, DropdownProps>(\n ({ \n className, \n trigger,\n children,\n open: controlledOpen,\n onOpenChange,\n placement = \"bottom\",\n align = \"start\",\n offset = 8,\n disabled = false,\n showArrow = true,\n ...props \n }, ref) => {\n const [internalOpen, setInternalOpen] = React.useState(false)\n const [coords, setCoords] = React.useState({ x: 0, y: 0 })\n const triggerRef = React.useRef<HTMLDivElement>(null)\n const dropdownRef = 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 const updatePosition = React.useCallback(() => {\n if (!triggerRef.current || !dropdownRef.current) return\n\n const triggerRect = triggerRef.current.getBoundingClientRect()\n const dropdownRect = dropdownRef.current.getBoundingClientRect()\n const viewportWidth = window.innerWidth\n const viewportHeight = window.innerHeight\n\n let x = 0\n let y = 0\n\n // 기본 위치 계산\n switch (placement) {\n case \"top\":\n x = triggerRect.left\n y = triggerRect.top - offset\n break\n case \"bottom\":\n x = triggerRect.left\n y = triggerRect.bottom + offset\n break\n case \"left\":\n x = triggerRect.left - offset\n y = triggerRect.top\n break\n case \"right\":\n x = triggerRect.right + offset\n y = triggerRect.top\n break\n }\n\n // 정렬 조정\n switch (align) {\n case \"center\":\n if (placement === \"top\" || placement === \"bottom\") {\n x = triggerRect.left + triggerRect.width / 2 - dropdownRect.width / 2\n } else {\n y = triggerRect.top + triggerRect.height / 2 - dropdownRect.height / 2\n }\n break\n case \"end\":\n if (placement === \"top\" || placement === \"bottom\") {\n x = triggerRect.right - dropdownRect.width\n } else {\n y = triggerRect.bottom - dropdownRect.height\n }\n break\n case \"start\":\n default:\n // 기본값은 이미 start 정렬\n break\n }\n\n // 뷰포트 경계 확인 및 조정\n if (x < 8) x = 8 // 8px 여백\n if (x + dropdownRect.width > viewportWidth - 8) {\n x = viewportWidth - dropdownRect.width - 8 // 8px 여백\n }\n if (y < 8) y = 8 // 8px 여백\n if (y + dropdownRect.height > viewportHeight - 8) {\n y = viewportHeight - dropdownRect.height - 8 // 8px 여백\n }\n\n setCoords({ x, y })\n }, [placement, align, offset])\n\n React.useEffect(() => {\n if (isOpen) {\n updatePosition()\n window.addEventListener('resize', updatePosition)\n window.addEventListener('scroll', updatePosition)\n \n return () => {\n window.removeEventListener('resize', updatePosition)\n window.removeEventListener('scroll', updatePosition)\n }\n }\n }, [isOpen, updatePosition])\n\n React.useEffect(() => {\n const handleClickOutside = (event: MouseEvent) => {\n if (\n triggerRef.current && \n dropdownRef.current && \n !triggerRef.current.contains(event.target as Node) &&\n !dropdownRef.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 getPlacementClasses = () => {\n switch (placement) {\n case \"top\":\n return \"bottom-full left-0 mb-2\" // 8px 간격\n case \"bottom\":\n return \"top-full left-0 mt-2\" // 8px 간격\n case \"left\":\n return \"right-full top-0 mr-2\" // 8px 간격\n case \"right\":\n return \"left-full top-0 ml-2\" // 8px 간격\n default:\n return \"top-full left-0 mt-2\"\n }\n }\n\n const getArrowClasses = () => {\n switch (placement) {\n case \"top\":\n return \"top-full left-4 -translate-x-1/2 border-t-gray-100 dark:border-t-gray-800\"\n case \"bottom\":\n return \"bottom-full left-4 -translate-x-1/2 border-b-gray-100 dark:border-b-gray-800\"\n case \"left\":\n return \"left-full top-4 -translate-y-1/2 border-l-gray-100 dark:border-l-gray-800\"\n case \"right\":\n return \"right-full top-4 -translate-y-1/2 border-r-gray-100 dark:border-r-gray-800\"\n default:\n return \"bottom-full left-4 -translate-x-1/2 border-b-gray-100 dark:border-b-gray-800\"\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={dropdownRef}\n className={merge(\n \"absolute z-50 bg-white dark:bg-gray-800 rounded-lg shadow-xl backdrop-blur-sm\", // 보더 대신 섀도우 사용\n \"min-w-[200px] py-2\", // 16px 패딩\n getPlacementClasses()\n )}\n style={{\n transform: `translate(${coords.x}px, ${coords.y}px)`,\n boxShadow: \"0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04)\"\n }}\n >\n {/* 화살표 */}\n {showArrow && (\n <div\n className={merge(\n \"absolute w-0 h-0 border-4 border-transparent\",\n getArrowClasses()\n )}\n />\n )}\n \n {/* 내용 */}\n <div className=\"relative z-10\">\n {children}\n </div>\n </div>\n )}\n </div>\n )\n }\n)\nDropdown.displayName = \"Dropdown\"\n\n// 드롭다운 아이템 컴포넌트들\nexport interface DropdownItemProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n icon?: React.ReactNode\n variant?: \"default\" | \"destructive\" | \"disabled\"\n}\n\nconst DropdownItem = React.forwardRef<HTMLButtonElement, DropdownItemProps>(\n ({ \n className, \n icon,\n variant = \"default\",\n children,\n disabled,\n ...props \n }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"destructive\":\n return \"text-red-600 dark:text-red-400 hover:bg-red-50 dark:hover:bg-red-900/20\"\n case \"disabled\":\n return \"text-gray-400 dark:text-gray-500 cursor-not-allowed\"\n default:\n return \"text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700\"\n }\n }\n\n return (\n <button\n ref={ref}\n className={merge(\n \"w-full flex items-center gap-3 px-4 py-3 text-sm font-medium transition-colors focus:outline-none focus:bg-gray-100 dark:focus:bg-gray-700\", // 16px, 12px 패딩\n getVariantClasses(),\n className\n )}\n disabled={disabled || variant === \"disabled\"}\n {...props}\n >\n {icon && (\n <div className=\"flex-shrink-0 w-4 h-4\">\n {icon}\n </div>\n )}\n <span className=\"flex-1 text-left\">{children}</span>\n </button>\n )\n }\n)\nDropdownItem.displayName = \"DropdownItem\"\n\nexport interface DropdownSeparatorProps extends React.HTMLAttributes<HTMLDivElement> {}\n\nconst DropdownSeparator = React.forwardRef<HTMLDivElement, DropdownSeparatorProps>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"h-px bg-gray-200 dark:bg-gray-700 my-2\", className)} // 8px 여백\n {...props}\n />\n )\n)\nDropdownSeparator.displayName = \"DropdownSeparator\"\n\nexport interface DropdownLabelProps extends React.HTMLAttributes<HTMLDivElement> {}\n\nconst DropdownLabel = React.forwardRef<HTMLDivElement, DropdownLabelProps>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"px-4 py-2 text-xs font-semibold text-gray-500 dark:text-gray-400 uppercase tracking-wide\", className)} // 16px, 8px 패딩\n {...props}\n >\n {children}\n </div>\n )\n)\nDropdownLabel.displayName = \"DropdownLabel\"\n\n// 편의 컴포넌트들\nconst DropdownMenu = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"py-1\", className)} // 4px 패딩\n {...props}\n >\n {children}\n </div>\n )\n)\nDropdownMenu.displayName = \"DropdownMenu\"\n\nconst DropdownGroup = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"space-y-1\", className)} // 4px 간격\n {...props}\n >\n {children}\n </div>\n )\n)\nDropdownGroup.displayName = \"DropdownGroup\"\n\nexport { Dropdown, DropdownItem, DropdownSeparator, DropdownLabel, DropdownMenu, DropdownGroup } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\n\n/**\n * Drawer 컴포넌트의 props / Drawer component props\n * @typedef {Object} DrawerProps\n * @property {boolean} open - Drawer 열림/닫힘 상태 / Drawer open/close state\n * @property {(open: boolean) => void} onOpenChange - 상태 변경 콜백 / State change callback\n * @property {React.ReactNode} children - Drawer 내용 / Drawer content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {\"left\" | \"right\" | \"top\" | \"bottom\"} [side=\"right\"] - Drawer 표시 위치 / Drawer display position\n * @property {\"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\"} [size=\"md\"] - Drawer 크기 / Drawer size\n * @property {boolean} [showBackdrop=true] - 배경 오버레이 표시 여부 / Show backdrop overlay\n * @property {string} [backdropClassName] - 배경 오버레이 추가 CSS 클래스 / Backdrop overlay additional CSS class\n * @property {boolean} [closeOnBackdropClick=true] - 배경 클릭 시 닫기 여부 / Close on backdrop click\n * @property {boolean} [closeOnEscape=true] - ESC 키로 닫기 여부 / Close on ESC key\n */\ninterface DrawerProps {\n open: boolean\n onOpenChange: (open: boolean) => void\n children: React.ReactNode\n className?: string\n side?: \"left\" | \"right\" | \"top\" | \"bottom\"\n size?: \"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\"\n showBackdrop?: boolean\n backdropClassName?: string\n closeOnBackdropClick?: boolean\n closeOnEscape?: boolean\n}\n\n/**\n * Drawer 컴포넌트 / Drawer component\n * \n * 사이드에서 슬라이드되는 패널 컴포넌트입니다.\n * Modal과 유사하지만 특정 방향에서 슬라이드되는 애니메이션을 제공합니다.\n * ESC 키로 닫기, 배경 클릭으로 닫기 기능을 지원합니다.\n * \n * Panel component that slides from the side.\n * Similar to Modal but provides slide animation from a specific direction.\n * Supports closing with ESC key and backdrop click.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * const [open, setOpen] = useState(false)\n * \n * <Drawer open={open} onOpenChange={setOpen}>\n * <DrawerHeader>제목</DrawerHeader>\n * <DrawerContent>내용</DrawerContent>\n * <DrawerFooter>\n * <Button onClick={() => setOpen(false)}>닫기</Button>\n * </DrawerFooter>\n * </Drawer>\n * \n * @example\n * // 왼쪽에서 열기 / Open from left\n * <Drawer open={open} onOpenChange={setOpen} side=\"left\" size=\"lg\">\n * <DrawerContent>사이드바 내용</DrawerContent>\n * </Drawer>\n * \n * @param {DrawerProps} props - Drawer 컴포넌트의 props / Drawer component props\n * @param {React.Ref<HTMLDivElement>} ref - Drawer 컨테이너 ref / Drawer container ref\n * @returns {JSX.Element} Drawer 컴포넌트 / Drawer component\n * \n * @todo 접근성 개선: role=\"dialog\", aria-modal=\"true\" 추가 필요 / Accessibility: Add role=\"dialog\", aria-modal=\"true\"\n * @todo 접근성 개선: aria-labelledby, aria-describedby 연결 필요 / Accessibility: Connect aria-labelledby, aria-describedby\n */\nconst Drawer = React.forwardRef<HTMLDivElement, DrawerProps>(\n ({ \n open, \n onOpenChange, \n children, \n className,\n side = \"right\",\n size = \"md\",\n showBackdrop = true,\n backdropClassName,\n closeOnBackdropClick = true,\n closeOnEscape = true,\n ...props \n }, ref) => {\n const [isVisible, setIsVisible] = React.useState(false)\n const [isAnimating, setIsAnimating] = React.useState(false)\n\n React.useEffect(() => {\n if (open) {\n setIsVisible(true)\n setIsAnimating(true)\n // 애니메이션 시작을 위한 지연\n const timer = setTimeout(() => setIsAnimating(false), 50)\n return () => clearTimeout(timer)\n } else {\n setIsAnimating(true)\n const timer = setTimeout(() => {\n setIsVisible(false)\n setIsAnimating(false)\n }, 300) // 애니메이션 완료 후 숨김\n return () => clearTimeout(timer)\n }\n }, [open])\n\n React.useEffect(() => {\n if (!closeOnEscape) return\n\n const handleEscape = (e: KeyboardEvent) => {\n if (e.key === \"Escape\" && open) {\n onOpenChange(false)\n }\n }\n\n if (open) {\n document.addEventListener(\"keydown\", handleEscape)\n document.body.style.overflow = \"hidden\"\n }\n\n return () => {\n document.removeEventListener(\"keydown\", handleEscape)\n document.body.style.overflow = \"\"\n }\n }, [open, closeOnEscape, onOpenChange])\n\n if (!isVisible) return null\n\n const sizeClasses = {\n sm: side === \"left\" || side === \"right\" ? \"w-80\" : \"h-64\",\n md: side === \"left\" || side === \"right\" ? \"w-96\" : \"h-96\",\n lg: side === \"left\" || side === \"right\" ? \"w-[28rem]\" : \"h-[32rem]\",\n xl: side === \"left\" || side === \"right\" ? \"w-[32rem]\" : \"h-[40rem]\",\n full: side === \"left\" || side === \"right\" ? \"w-full\" : \"h-full\"\n }\n\n const sideClasses = {\n left: \"left-0 top-0 h-full translate-x-0\",\n right: \"right-0 top-0 h-full translate-x-0\",\n top: \"top-0 left-0 w-full translate-y-0\",\n bottom: \"bottom-0 left-0 w-full translate-y-0\"\n }\n\n const transformClasses = {\n left: isAnimating ? (open ? \"translate-x-0\" : \"-translate-x-full\") : \"\",\n right: isAnimating ? (open ? \"translate-x-0\" : \"translate-x-full\") : \"\",\n top: isAnimating ? (open ? \"translate-y-0\" : \"-translate-y-full\") : \"\",\n bottom: isAnimating ? (open ? \"translate-y-0\" : \"translate-y-full\") : \"\"\n }\n\n return (\n <div className=\"fixed inset-0 z-50\">\n {/* Backdrop */}\n {showBackdrop && (\n <div\n className={merge(\n \"absolute inset-0 bg-black/60 backdrop-blur-md transition-opacity duration-300\",\n isAnimating ? (open ? \"opacity-100\" : \"opacity-0\") : \"\",\n backdropClassName\n )}\n onClick={closeOnBackdropClick ? () => onOpenChange(false) : undefined}\n />\n )}\n\n {/* Drawer Content */}\n <div\n ref={ref}\n className={merge(\n \"absolute bg-white/95 dark:!bg-gray-800/95 backdrop-blur-xl border border-gray-200/50 dark:!border-gray-600/50 shadow-2xl transition-transform duration-300 ease-out\",\n sizeClasses[size],\n sideClasses[side],\n transformClasses[side],\n className\n )}\n {...props}\n >\n {children}\n </div>\n </div>\n )\n }\n)\nDrawer.displayName = \"Drawer\"\n\n/**\n * DrawerHeader 컴포넌트의 props / DrawerHeader component props\n * @typedef {Object} DrawerHeaderProps\n * @property {React.ReactNode} children - 헤더 내용 / Header content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {boolean} [showCloseButton=true] - 닫기 버튼 표시 여부 / Show close button\n * @property {() => void} [onClose] - 닫기 버튼 클릭 콜백 / Close button click callback\n */\ninterface DrawerHeaderProps {\n children: React.ReactNode\n className?: string\n showCloseButton?: boolean\n onClose?: () => void\n}\n\n/**\n * DrawerHeader 컴포넌트 / DrawerHeader component\n * Drawer의 헤더 영역을 표시합니다.\n * Displays the header area of a Drawer.\n * \n * @component\n * @param {DrawerHeaderProps} props - DrawerHeader 컴포넌트의 props / DrawerHeader component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} DrawerHeader 컴포넌트 / DrawerHeader component\n */\nconst DrawerHeader = React.forwardRef<HTMLDivElement, DrawerHeaderProps>(\n ({ children, className, showCloseButton = true, onClose, ...props }, ref) => {\n return (\n <div\n ref={ref}\n className={merge(\"flex items-center justify-between p-6 border-b border-gray-200/50 dark:border-gray-700/50\", className)}\n {...props}\n >\n <div className=\"flex-1\">{children}</div>\n {showCloseButton && (\n <button\n onClick={onClose}\n className=\"p-2 rounded-lg hover:bg-gray-100/80 dark:hover:bg-gray-800/80 transition-colors\"\n >\n <Icon name=\"close\" size={20} />\n </button>\n )}\n </div>\n )\n }\n)\nDrawerHeader.displayName = \"DrawerHeader\"\n\n/**\n * DrawerContent 컴포넌트의 props / DrawerContent component props\n * @typedef {Object} DrawerContentProps\n * @property {React.ReactNode} children - 콘텐츠 / Content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n */\ninterface DrawerContentProps {\n children: React.ReactNode\n className?: string\n}\n\n/**\n * DrawerContent 컴포넌트 / DrawerContent component\n * Drawer의 메인 콘텐츠 영역을 표시합니다.\n * Displays the main content area of a Drawer.\n * \n * @component\n * @param {DrawerContentProps} props - DrawerContent 컴포넌트의 props / DrawerContent component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} DrawerContent 컴포넌트 / DrawerContent component\n */\nconst DrawerContent = React.forwardRef<HTMLDivElement, DrawerContentProps>(\n ({ children, className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n className={merge(\"flex-1 p-6 overflow-y-auto\", className)}\n {...props}\n >\n {children}\n </div>\n )\n }\n)\nDrawerContent.displayName = \"DrawerContent\"\n\n/**\n * DrawerFooter 컴포넌트의 props / DrawerFooter component props\n * @typedef {Object} DrawerFooterProps\n * @property {React.ReactNode} children - 푸터 내용 / Footer content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n */\ninterface DrawerFooterProps {\n children: React.ReactNode\n className?: string\n}\n\n/**\n * DrawerFooter 컴포넌트 / DrawerFooter component\n * Drawer의 푸터 영역을 표시합니다. 주로 액션 버튼을 배치합니다.\n * Displays the footer area of a Drawer. Typically used for action buttons.\n * \n * @component\n * @param {DrawerFooterProps} props - DrawerFooter 컴포넌트의 props / DrawerFooter component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} DrawerFooter 컴포넌트 / DrawerFooter component\n */\nconst DrawerFooter = React.forwardRef<HTMLDivElement, DrawerFooterProps>(\n ({ children, className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n className={merge(\"flex items-center justify-end gap-3 p-6 border-t border-gray-200/50 dark:border-gray-700/50\", className)}\n {...props}\n >\n {children}\n </div>\n )\n }\n)\nDrawerFooter.displayName = \"DrawerFooter\"\n\nexport { Drawer, DrawerHeader, DrawerContent, DrawerFooter } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\n\n/**\n * BottomSheet 컴포넌트의 props / BottomSheet component props\n * @typedef {Object} BottomSheetProps\n * @property {boolean} open - BottomSheet 열림/닫힘 상태 / BottomSheet open/close state\n * @property {(open: boolean) => void} onOpenChange - 상태 변경 콜백 / State change callback\n * @property {React.ReactNode} children - BottomSheet 내용 / BottomSheet content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {\"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\"} [height=\"md\"] - BottomSheet 높이 / BottomSheet height\n * @property {boolean} [showBackdrop=true] - 배경 오버레이 표시 여부 / Show backdrop overlay\n * @property {string} [backdropClassName] - 배경 오버레이 추가 CSS 클래스 / Backdrop overlay additional CSS class\n * @property {boolean} [closeOnBackdropClick=true] - 배경 클릭 시 닫기 여부 / Close on backdrop click\n * @property {boolean} [closeOnEscape=true] - ESC 키로 닫기 여부 / Close on ESC key\n * @property {boolean} [showDragHandle=true] - 드래그 핸들 표시 여부 / Show drag handle\n * @property {number[]} [snapPoints=[25, 50, 75, 100]] - 스냅 포인트 (퍼센트) / Snap points (percentage)\n * @property {number} [defaultSnap=50] - 기본 스냅 포인트 (퍼센트) / Default snap point (percentage)\n */\ninterface BottomSheetProps {\n open: boolean\n onOpenChange: (open: boolean) => void\n children: React.ReactNode\n className?: string\n height?: \"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\"\n showBackdrop?: boolean\n backdropClassName?: string\n closeOnBackdropClick?: boolean\n closeOnEscape?: boolean\n showDragHandle?: boolean\n snapPoints?: number[]\n defaultSnap?: number\n}\n\n/**\n * BottomSheet 컴포넌트 / BottomSheet component\n * \n * 화면 하단에서 올라오는 시트 컴포넌트입니다.\n * 모바일 친화적인 UI를 제공하며, 드래그로 높이를 조절할 수 있습니다.\n * 스냅 포인트를 지원하여 특정 높이에서 멈출 수 있습니다.\n * \n * Sheet component that slides up from the bottom of the screen.\n * Provides mobile-friendly UI and allows height adjustment by dragging.\n * Supports snap points to stop at specific heights.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * const [open, setOpen] = useState(false)\n * \n * <BottomSheet open={open} onOpenChange={setOpen}>\n * <BottomSheetHeader>제목</BottomSheetHeader>\n * <BottomSheetContent>내용</BottomSheetContent>\n * </BottomSheet>\n * \n * @example\n * // 커스텀 스냅 포인트 / Custom snap points\n * <BottomSheet \n * open={open} \n * onOpenChange={setOpen}\n * snapPoints={[30, 60, 90]}\n * defaultSnap={30}\n * >\n * <BottomSheetContent>내용</BottomSheetContent>\n * </BottomSheet>\n * \n * @param {BottomSheetProps} props - BottomSheet 컴포넌트의 props / BottomSheet component props\n * @param {React.Ref<HTMLDivElement>} ref - BottomSheet 컨테이너 ref / BottomSheet container ref\n * @returns {JSX.Element} BottomSheet 컴포넌트 / BottomSheet component\n * \n * @todo 접근성 개선: role=\"dialog\", aria-modal=\"true\" 추가 필요 / Accessibility: Add role=\"dialog\", aria-modal=\"true\"\n * @todo 접근성 개선: aria-labelledby, aria-describedby 연결 필요 / Accessibility: Connect aria-labelledby, aria-describedby\n */\nconst BottomSheet = React.forwardRef<HTMLDivElement, BottomSheetProps>(\n ({ \n open, \n onOpenChange, \n children, \n className,\n height = \"md\",\n showBackdrop = true,\n backdropClassName,\n closeOnBackdropClick = true,\n closeOnEscape = true,\n showDragHandle = true,\n snapPoints = [25, 50, 75, 100],\n defaultSnap = 50,\n ...props \n }, ref) => {\n const [isVisible, setIsVisible] = React.useState(false)\n const [isAnimating, setIsAnimating] = React.useState(false)\n const [currentHeight, setCurrentHeight] = React.useState(defaultSnap)\n const [isDragging, setIsDragging] = React.useState(false)\n const [startY, setStartY] = React.useState(0)\n const [currentY, setCurrentY] = React.useState(0)\n\n const heightClasses = {\n sm: \"h-64\",\n md: \"h-96\",\n lg: \"h-[32rem]\",\n xl: \"h-[40rem]\",\n full: \"h-full\"\n }\n\n React.useEffect(() => {\n if (open) {\n setIsVisible(true)\n setIsAnimating(true)\n const timer = setTimeout(() => setIsAnimating(false), 50)\n return () => clearTimeout(timer)\n } else {\n setIsAnimating(true)\n const timer = setTimeout(() => {\n setIsVisible(false)\n setIsAnimating(false)\n }, 300)\n return () => clearTimeout(timer)\n }\n }, [open])\n\n React.useEffect(() => {\n if (!closeOnEscape) return\n\n const handleEscape = (e: KeyboardEvent) => {\n if (e.key === \"Escape\" && open) {\n onOpenChange(false)\n }\n }\n\n if (open) {\n document.addEventListener(\"keydown\", handleEscape)\n document.body.style.overflow = \"hidden\"\n }\n\n return () => {\n document.removeEventListener(\"keydown\", handleEscape)\n document.body.style.overflow = \"\"\n }\n }, [open, closeOnEscape, onOpenChange])\n\n const handleTouchStart = (e: React.TouchEvent) => {\n setIsDragging(true)\n setStartY(e.touches[0].clientY)\n setCurrentY(e.touches[0].clientY)\n }\n\n const handleTouchMove = (e: React.TouchEvent) => {\n if (!isDragging) return\n setCurrentY(e.touches[0].clientY)\n }\n\n const handleTouchEnd = () => {\n if (!isDragging) return\n setIsDragging(false)\n\n const deltaY = currentY - startY\n const threshold = 100\n\n if (deltaY > threshold) {\n // 아래로 드래그 - 닫기\n onOpenChange(false)\n } else if (deltaY < -threshold) {\n // 위로 드래그 - 다음 스냅 포인트\n const currentIndex = snapPoints.indexOf(currentHeight)\n const nextIndex = Math.min(currentIndex + 1, snapPoints.length - 1)\n setCurrentHeight(snapPoints[nextIndex])\n }\n }\n\n if (!isVisible) return null\n\n return (\n <div className=\"fixed inset-0 z-50\">\n {/* Backdrop */}\n {showBackdrop && (\n <div\n className={merge(\n \"absolute inset-0 bg-black/60 backdrop-blur-md transition-opacity duration-300\",\n isAnimating ? (open ? \"opacity-100\" : \"opacity-0\") : \"\",\n backdropClassName\n )}\n onClick={closeOnBackdropClick ? () => onOpenChange(false) : undefined}\n />\n )}\n\n {/* Bottom Sheet */}\n <div\n ref={ref}\n className={merge(\n \"absolute bottom-0 left-0 right-0 bg-white/95 dark:!bg-gray-800/95 backdrop-blur-xl border-t border-gray-200/50 dark:!border-gray-600/50 shadow-2xl rounded-t-lg transition-transform duration-300 ease-out pb-safe\",\n heightClasses[height],\n isAnimating ? (open ? \"translate-y-0\" : \"translate-y-full\") : \"\",\n className\n )}\n style={{\n height: `${currentHeight}%`,\n transform: isDragging ? `translateY(${currentY - startY}px)` : undefined\n }}\n onTouchStart={handleTouchStart}\n onTouchMove={handleTouchMove}\n onTouchEnd={handleTouchEnd}\n {...props}\n >\n {/* Drag Handle */}\n {showDragHandle && (\n <div className=\"flex justify-center pt-3 pb-2\">\n <div className=\"w-12 h-1.5 bg-gray-300 dark:bg-gray-600 rounded-full\" />\n </div>\n )}\n\n {children}\n </div>\n </div>\n )\n }\n)\nBottomSheet.displayName = \"BottomSheet\"\n\n/**\n * BottomSheetHeader 컴포넌트의 props / BottomSheetHeader component props\n * @typedef {Object} BottomSheetHeaderProps\n * @property {React.ReactNode} children - 헤더 내용 / Header content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {boolean} [showCloseButton=true] - 닫기 버튼 표시 여부 / Show close button\n * @property {() => void} [onClose] - 닫기 버튼 클릭 콜백 / Close button click callback\n */\ninterface BottomSheetHeaderProps {\n children: React.ReactNode\n className?: string\n showCloseButton?: boolean\n onClose?: () => void\n}\n\n/**\n * BottomSheetHeader 컴포넌트 / BottomSheetHeader component\n * BottomSheet의 헤더 영역을 표시합니다.\n * Displays the header area of a BottomSheet.\n * \n * @component\n * @param {BottomSheetHeaderProps} props - BottomSheetHeader 컴포넌트의 props / BottomSheetHeader component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} BottomSheetHeader 컴포넌트 / BottomSheetHeader component\n */\nconst BottomSheetHeader = React.forwardRef<HTMLDivElement, BottomSheetHeaderProps>(\n ({ children, className, showCloseButton = true, onClose, ...props }, ref) => {\n return (\n <div\n ref={ref}\n className={merge(\"flex items-center justify-between px-6 py-4\", className)}\n {...props}\n >\n <div className=\"flex-1\">{children}</div>\n {showCloseButton && (\n <button\n onClick={onClose}\n className=\"p-2 rounded-lg hover:bg-gray-100/80 dark:hover:bg-gray-800/80 transition-colors\"\n >\n <Icon name=\"close\" size={20} />\n </button>\n )}\n </div>\n )\n }\n)\nBottomSheetHeader.displayName = \"BottomSheetHeader\"\n\n/**\n * BottomSheetContent 컴포넌트의 props / BottomSheetContent component props\n * @typedef {Object} BottomSheetContentProps\n * @property {React.ReactNode} children - 콘텐츠 / Content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n */\ninterface BottomSheetContentProps {\n children: React.ReactNode\n className?: string\n}\n\n/**\n * BottomSheetContent 컴포넌트 / BottomSheetContent component\n * BottomSheet의 메인 콘텐츠 영역을 표시합니다.\n * Displays the main content area of a BottomSheet.\n * \n * @component\n * @param {BottomSheetContentProps} props - BottomSheetContent 컴포넌트의 props / BottomSheetContent component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} BottomSheetContent 컴포넌트 / BottomSheetContent component\n */\nconst BottomSheetContent = React.forwardRef<HTMLDivElement, BottomSheetContentProps>(\n ({ children, className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n className={merge(\"flex-1 px-6 pb-6 overflow-y-auto\", className)}\n {...props}\n >\n {children}\n </div>\n )\n }\n)\nBottomSheetContent.displayName = \"BottomSheetContent\"\n\nexport { BottomSheet, BottomSheetHeader, BottomSheetContent } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Modal } from \"./Modal\"\nimport { Button } from \"./Button\"\n\n/**\n * ConfirmModal 컴포넌트의 props / ConfirmModal component props\n * @typedef {Object} ConfirmModalProps\n * @property {boolean} isOpen - 모달 열림/닫힘 상태 / Modal open/close state\n * @property {() => void} onClose - 닫기 콜백 / Close callback\n * @property {() => void} onConfirm - 확인 콜백 / Confirm callback\n * @property {string} title - 모달 제목 / Modal title\n * @property {string} message - 모달 메시지 / Modal message\n * @property {string} [warning] - 경고 메시지 / Warning message\n * @property {string} [confirmText=\"확인\"] - 확인 버튼 텍스트 / Confirm button text\n * @property {string} [cancelText=\"취소\"] - 취소 버튼 텍스트 / Cancel button text\n * @property {string} [confirmButtonText] - 확인 버튼 커스텀 텍스트 / Custom confirm button text\n * @property {\"danger\" | \"warning\" | \"info\" | \"success\" | \"error\"} [type=\"danger\"] - 모달 타입 / Modal type\n * @property {boolean} [loading=false] - 로딩 상태 / Loading state\n * @property {boolean} [disabled=false] - 비활성화 여부 / Disabled state\n * @property {boolean} [showInput=false] - 입력 필드 표시 여부 / Show input field\n * @property {string} [inputValue=\"\"] - 입력 필드 값 / Input field value\n * @property {(value: string) => void} [onInputChange] - 입력 값 변경 콜백 / Input value change callback\n * @property {string} [inputPlaceholder] - 입력 필드 플레이스홀더 / Input field placeholder\n * @property {string} [inputLabel] - 입력 필드 라벨 / Input field label\n * @property {string} [requiredInputValue] - 필수 입력 값 (확인 버튼 활성화 조건) / Required input value (confirm button activation condition)\n * @property {boolean} [showCancel=true] - 취소 버튼 표시 여부 / Show cancel button\n * @property {\"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\"} [size=\"md\"] - 모달 크기 / Modal size\n */\nexport interface ConfirmModalProps {\n isOpen: boolean\n onClose: () => void\n onConfirm: () => void\n title: string\n message: string\n warning?: string\n confirmText?: string\n cancelText?: string\n confirmButtonText?: string\n type?: \"danger\" | \"warning\" | \"info\" | \"success\" | \"error\"\n loading?: boolean\n disabled?: boolean\n showInput?: boolean\n inputValue?: string\n onInputChange?: (value: string) => void\n inputPlaceholder?: string\n inputLabel?: string\n requiredInputValue?: string\n showCancel?: boolean\n size?: \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\"\n}\n\n/**\n * ConfirmModal 컴포넌트 / ConfirmModal component\n * \n * 확인/취소가 필요한 모달 컴포넌트입니다.\n * 다양한 타입(danger, warning, info, success, error)을 지원하며,\n * 입력 필드와 필수 입력 값 검증을 지원합니다.\n * \n * Modal component that requires confirmation/cancellation.\n * Supports various types (danger, warning, info, success, error),\n * and supports input fields and required input value validation.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <ConfirmModal\n * isOpen={isOpen}\n * onClose={() => setIsOpen(false)}\n * onConfirm={handleConfirm}\n * title=\"삭제 확인\"\n * message=\"정말 삭제하시겠습니까?\"\n * />\n * \n * @example\n * // 입력 필드와 함께 / With input field\n * <ConfirmModal\n * isOpen={isOpen}\n * onClose={() => setIsOpen(false)}\n * onConfirm={handleDelete}\n * title=\"삭제 확인\"\n * message=\"삭제하려면 'DELETE'를 입력하세요\"\n * showInput\n * inputLabel=\"확인 입력\"\n * requiredInputValue=\"DELETE\"\n * inputValue={inputValue}\n * onInputChange={setInputValue}\n * />\n * \n * @param {ConfirmModalProps} props - ConfirmModal 컴포넌트의 props / ConfirmModal component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} ConfirmModal 컴포넌트 / ConfirmModal component\n */\nconst ConfirmModal = React.forwardRef<HTMLDivElement, ConfirmModalProps>(\n ({\n isOpen,\n onClose,\n onConfirm,\n title,\n message,\n warning,\n confirmText = \"확인\",\n cancelText = \"취소\",\n confirmButtonText,\n type = \"danger\",\n loading = false,\n disabled = false,\n showInput = false,\n inputValue = \"\",\n onInputChange,\n inputPlaceholder,\n inputLabel,\n requiredInputValue,\n showCancel = true,\n size = \"md\"\n }, ref) => {\n // 타입별 아이콘과 색상\n const typeConfig = {\n danger: {\n icon: (\n <svg className=\"h-6 w-6 text-red-600 dark:text-red-400\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-2.5L13.732 4c-.77-.833-1.964-.833-2.732 0L3.732 16.5c-.77.833.192 2.5 1.732 2.5z\" />\n </svg>\n ),\n bgColor: \"bg-red-100 dark:bg-red-900/20\",\n buttonColor: \"bg-red-600 hover:bg-red-700 focus:ring-red-500\",\n textColor: \"text-red-600 dark:text-red-400\"\n },\n warning: {\n icon: (\n <svg className=\"h-6 w-6 text-yellow-600 dark:text-yellow-400\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-2.5L13.732 4c-.77-.833-1.964-.833-2.732 0L3.732 16.5c-.77.833.192 2.5 1.732 2.5z\" />\n </svg>\n ),\n bgColor: \"bg-yellow-100 dark:bg-yellow-900/20\",\n buttonColor: \"bg-yellow-600 hover:bg-yellow-700 focus:ring-yellow-500\",\n textColor: \"text-yellow-600 dark:text-yellow-400\"\n },\n info: {\n icon: (\n <svg className=\"h-6 w-6 text-blue-600 dark:text-blue-400\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z\" />\n </svg>\n ),\n bgColor: \"bg-blue-100 dark:bg-blue-900/20\",\n buttonColor: \"bg-blue-600 hover:bg-blue-700 focus:ring-blue-500\",\n textColor: \"text-blue-600 dark:text-blue-400\"\n },\n success: {\n icon: (\n <svg className=\"h-6 w-6 text-green-600 dark:text-green-400\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M5 13l4 4L19 7\" />\n </svg>\n ),\n bgColor: \"bg-green-100 dark:bg-green-900/20\",\n buttonColor: \"bg-green-600 hover:bg-green-700 focus:ring-green-500\",\n textColor: \"text-green-600 dark:text-green-400\"\n },\n error: {\n icon: (\n <svg className=\"h-6 w-6 text-red-600 dark:text-red-400\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n ),\n bgColor: \"bg-red-100 dark:bg-red-900/20\",\n buttonColor: \"bg-red-600 hover:bg-red-700 focus:ring-red-500\",\n textColor: \"text-red-600 dark:text-red-400\"\n }\n }\n\n const config = typeConfig[type]\n const isInputValid = !showInput || !requiredInputValue || inputValue === requiredInputValue\n const isDisabled = disabled || loading || !isInputValid\n\n return (\n <Modal \n isOpen={isOpen} \n onClose={onClose} \n showCloseButton={false}\n size={size}\n >\n <div className=\"text-center\">\n {/* 아이콘 */}\n <div className={merge(\n \"mx-auto flex items-center justify-center h-16 w-16 rounded-full mb-6\", // 64px 아이콘, 24px 여백\n config.bgColor\n )}>\n {config.icon}\n </div>\n\n {/* 제목 */}\n <h3 className=\"text-xl font-semibold text-gray-900 dark:text-white mb-4\"> {/* 16px 여백 */}\n {title}\n </h3>\n\n {/* 메시지 */}\n <div className=\"mb-6\"> {/* 24px 여백 */}\n <p className=\"text-sm text-gray-600 dark:text-gray-400\">\n {message}\n </p>\n \n {/* 경고 메시지 */}\n {warning && (\n <p className={merge(\n \"text-sm mt-3 font-medium\", // 12px 여백\n config.textColor\n )}>\n {warning}\n </p>\n )}\n </div>\n\n {/* 입력 필드 */}\n {showInput && (\n <div className=\"mb-6\"> {/* 24px 여백 */}\n <label htmlFor=\"confirmInput\" className=\"block text-sm font-medium text-gray-700 dark:text-gray-300 mb-3 text-left\"> {/* 12px 여백 */}\n {inputLabel}\n </label>\n <input\n type=\"text\"\n id=\"confirmInput\"\n value={inputValue}\n onChange={(e) => onInputChange?.(e.target.value)}\n placeholder={inputPlaceholder}\n className=\"w-full px-4 py-3 border border-gray-300 dark:border-gray-600 rounded-lg focus:outline-none focus:ring-2 focus:ring-red-500 focus:border-transparent dark:bg-gray-700 dark:text-white transition-colors\" // 16px, 12px 패딩\n />\n </div>\n )}\n\n {/* 버튼 */}\n <div className={merge(\n \"flex gap-3\", // 12px 간격\n showCancel ? \"justify-center\" : \"justify-center\"\n )}>\n {showCancel && (\n <Button\n variant=\"outline\"\n onClick={onClose}\n disabled={loading}\n className=\"px-6 py-3\" // 24px, 12px 패딩\n >\n {cancelText}\n </Button>\n )}\n <Button\n variant=\"default\"\n onClick={onConfirm}\n disabled={isDisabled}\n className={merge(\n \"px-6 py-3\", // 24px, 12px 패딩\n config.buttonColor\n )}\n >\n {loading ? (\n <div className=\"flex items-center\">\n <svg className=\"animate-spin -ml-1 mr-2 h-4 w-4 text-white\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\">\n <circle className=\"opacity-25\" cx=\"12\" cy=\"12\" r=\"10\" stroke=\"currentColor\" strokeWidth=\"4\"></circle>\n <path className=\"opacity-75\" fill=\"currentColor\" d=\"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z\"></path>\n </svg>\n 처리 중...\n </div>\n ) : (\n confirmButtonText || confirmText\n )}\n </Button>\n </div>\n </div>\n </Modal>\n )\n }\n)\nConfirmModal.displayName = \"ConfirmModal\"\n\nexport { ConfirmModal } ","\"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","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\n\n/**\n * Accordion 컴포넌트의 props / Accordion component props\n * @typedef {Object} AccordionProps\n * @property {React.ReactNode} children - AccordionItem 컴포넌트들 / AccordionItem components\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {\"single\" | \"multiple\"} [type=\"single\"] - 단일 또는 다중 아이템 열기 허용 / Allow single or multiple items to be open\n * @property {string | string[]} [defaultValue] - 초기 열린 아이템 값 (비제어 컴포넌트) / Initial open item value (uncontrolled component)\n * @property {string | string[]} [value] - 현재 열린 아이템 값 (제어 컴포넌트) / Current open item value (controlled component)\n * @property {(value: string | string[]) => void} [onValueChange] - 아이템 열림/닫힘 콜백 / Item open/close callback\n * @property {boolean} [collapsible=false] - 단일 모드에서 열린 아이템을 닫을 수 있는지 여부 / Whether open item can be closed in single mode\n */\ninterface AccordionProps {\n children: React.ReactNode\n className?: string\n type?: \"single\" | \"multiple\"\n defaultValue?: string | string[]\n value?: string | string[]\n onValueChange?: (value: string | string[]) => void\n collapsible?: boolean\n}\n\n/**\n * Accordion 컴포넌트 / Accordion component\n * \n * 접을 수 있는 콘텐츠 섹션을 제공하는 컴포넌트입니다.\n * 키보드 네비게이션(Arrow keys, Home/End)을 지원하며, ARIA 속성을 자동으로 설정합니다.\n * \n * Component that provides collapsible content sections.\n * Supports keyboard navigation (Arrow keys, Home/End) and automatically sets ARIA attributes.\n * \n * @component\n * @example\n * // 기본 사용 (단일 열기) / Basic usage (single open)\n * <Accordion type=\"single\">\n * <AccordionItem value=\"item1\">\n * <AccordionTrigger>제목 1</AccordionTrigger>\n * <AccordionContent>내용 1</AccordionContent>\n * </AccordionItem>\n * <AccordionItem value=\"item2\">\n * <AccordionTrigger>제목 2</AccordionTrigger>\n * <AccordionContent>내용 2</AccordionContent>\n * </AccordionItem>\n * </Accordion>\n * \n * @example\n * // 다중 열기 / Multiple open\n * <Accordion type=\"multiple\" defaultValue={[\"item1\", \"item2\"]}>\n * <AccordionItem value=\"item1\">\n * <AccordionTrigger>제목 1</AccordionTrigger>\n * <AccordionContent>내용 1</AccordionContent>\n * </AccordionItem>\n * </Accordion>\n * \n * @example\n * // 제어 컴포넌트 / Controlled component\n * const [openItems, setOpenItems] = useState<string[]>([])\n * <Accordion type=\"multiple\" value={openItems} onValueChange={setOpenItems}>\n * <AccordionItem value=\"item1\">\n * <AccordionTrigger>제목</AccordionTrigger>\n * <AccordionContent>내용</AccordionContent>\n * </AccordionItem>\n * </Accordion>\n * \n * @param {AccordionProps} props - Accordion 컴포넌트의 props / Accordion component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Accordion 컴포넌트 / Accordion component\n */\nconst Accordion = React.forwardRef<HTMLDivElement, AccordionProps>(\n ({ \n children, \n className,\n type = \"single\",\n defaultValue,\n value,\n onValueChange,\n collapsible = false,\n ...props \n }, ref) => {\n const [openItems, setOpenItems] = React.useState<string[]>(\n value ? (Array.isArray(value) ? value : [value]) : \n defaultValue ? (Array.isArray(defaultValue) ? defaultValue : [defaultValue]) : []\n )\n\n React.useEffect(() => {\n if (value !== undefined) {\n setOpenItems(Array.isArray(value) ? value : [value])\n }\n }, [value])\n\n const handleItemToggle = (itemValue: string) => {\n let newOpenItems: string[]\n\n if (type === \"single\") {\n if (openItems.includes(itemValue)) {\n newOpenItems = collapsible ? [] : openItems\n } else {\n newOpenItems = [itemValue]\n }\n } else {\n if (openItems.includes(itemValue)) {\n newOpenItems = openItems.filter(item => item !== itemValue)\n } else {\n newOpenItems = [...openItems, itemValue]\n }\n }\n\n setOpenItems(newOpenItems)\n onValueChange?.(type === \"single\" ? newOpenItems[0] || \"\" : newOpenItems)\n }\n\n // 모든 아이템의 value를 수집\n const itemValues = React.useMemo(() => {\n const values: string[] = []\n React.Children.forEach(children, (child) => {\n if (React.isValidElement(child)) {\n const childProps = child.props as { value?: string }\n if (childProps.value) {\n values.push(childProps.value)\n }\n }\n })\n return values\n }, [children])\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLDivElement>) => {\n const target = e.target as HTMLElement\n if (!target.hasAttribute('data-accordion-trigger')) return\n\n const currentValue = target.getAttribute('data-accordion-value')\n if (!currentValue) return\n\n const currentIndex = itemValues.indexOf(currentValue)\n if (currentIndex === -1) return\n\n let newIndex = currentIndex\n\n if (e.key === \"ArrowDown\") {\n e.preventDefault()\n newIndex = currentIndex < itemValues.length - 1 ? currentIndex + 1 : 0\n } else if (e.key === \"ArrowUp\") {\n e.preventDefault()\n newIndex = currentIndex > 0 ? currentIndex - 1 : itemValues.length - 1\n } else if (e.key === \"Home\") {\n e.preventDefault()\n newIndex = 0\n } else if (e.key === \"End\") {\n e.preventDefault()\n newIndex = itemValues.length - 1\n }\n\n if (newIndex !== currentIndex && itemValues[newIndex]) {\n const triggerElement = target.closest('[data-accordion-item]')?.querySelector(\n `[data-accordion-value=\"${itemValues[newIndex]}\"]`\n ) as HTMLElement\n triggerElement?.focus()\n }\n }\n\n return (\n <div\n ref={ref}\n className={merge(\"space-y-2\", className)}\n onKeyDown={handleKeyDown}\n {...props}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return React.cloneElement(child, {\n openItems,\n onToggle: handleItemToggle\n } as Partial<AccordionItemProps>)\n }\n return child\n })}\n </div>\n )\n }\n)\nAccordion.displayName = \"Accordion\"\n\n/**\n * AccordionItem 컴포넌트의 props / AccordionItem component props\n * @typedef {Object} AccordionItemProps\n * @property {string} value - 아이템의 고유 값 / Item unique value\n * @property {React.ReactNode} children - AccordionTrigger와 AccordionContent / AccordionTrigger and AccordionContent\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {boolean} [disabled=false] - 아이템 비활성화 여부 / Item disabled state\n * @property {string[]} [openItems] - 열린 아이템 목록 (Accordion에서 자동 전달) / Open items list (auto-passed from Accordion)\n * @property {(value: string) => void} [onToggle] - 토글 콜백 (Accordion에서 자동 전달) / Toggle callback (auto-passed from Accordion)\n */\ninterface AccordionItemProps {\n value: string\n children: React.ReactNode\n className?: string\n disabled?: boolean\n openItems?: string[]\n onToggle?: (value: string) => void\n}\n\n/**\n * AccordionItem 컴포넌트 / AccordionItem component\n * 아코디언의 개별 아이템을 감싸는 컨테이너입니다.\n * Container that wraps an individual accordion item.\n * \n * @component\n * @param {AccordionItemProps} props - AccordionItem 컴포넌트의 props / AccordionItem component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} AccordionItem 컴포넌트 / AccordionItem component\n */\nconst AccordionItem = React.forwardRef<HTMLDivElement, AccordionItemProps>(\n ({ \n value, \n children, \n className,\n disabled = false,\n openItems = [],\n onToggle,\n ...props \n }, ref) => {\n const isOpen = openItems.includes(value)\n\n return (\n <div\n ref={ref}\n data-accordion-item\n className={merge(\n \"border border-gray-200/50 dark:border-gray-700/50 rounded-lg overflow-hidden\",\n disabled && \"opacity-50 pointer-events-none\",\n className\n )}\n {...props}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return React.cloneElement(child, {\n value,\n isOpen,\n disabled,\n onToggle: () => onToggle?.(value),\n 'data-accordion-value': value\n } as Partial<AccordionTriggerProps | AccordionContentProps>)\n }\n return child\n })}\n </div>\n )\n }\n)\nAccordionItem.displayName = \"AccordionItem\"\n\ninterface AccordionTriggerProps {\n children: React.ReactNode\n className?: string\n icon?: React.ReactNode\n iconPosition?: \"left\" | \"right\"\n value?: string // Optional: AccordionItem에서 자동으로 전달됨 / Optional: Auto-passed from AccordionItem\n isOpen?: boolean\n disabled?: boolean\n onToggle?: () => void\n}\n\nconst AccordionTrigger = React.forwardRef<HTMLButtonElement, AccordionTriggerProps>(\n ({ \n children, \n className,\n icon,\n iconPosition = \"right\",\n value,\n isOpen = false,\n disabled = false,\n onToggle,\n ...props \n }, ref) => {\n const defaultIcon = (\n <Icon \n name=\"chevronDown\" \n size={20} \n className={merge(\n \"transition-transform duration-300 ease-out text-gray-500 dark:text-gray-400\",\n isOpen && \"rotate-180\"\n )} \n />\n )\n\n const contentId = `accordion-content-${value}`\n const triggerId = `accordion-trigger-${value}`\n\n return (\n <button\n ref={ref}\n id={triggerId}\n data-accordion-trigger\n data-accordion-value={value}\n aria-expanded={isOpen}\n aria-controls={contentId}\n onClick={onToggle}\n disabled={disabled}\n className={merge(\n \"flex w-full items-center justify-between px-6 py-4 text-left font-medium transition-all hover:bg-gray-50/80 dark:hover:bg-gray-800/80 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-blue-500/50 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n className\n )}\n {...props}\n >\n <div className=\"flex items-center gap-3 flex-1\">\n {iconPosition === \"left\" && (icon || defaultIcon)}\n <span className=\"flex-1\">{children}</span>\n </div>\n {iconPosition === \"right\" && (icon || defaultIcon)}\n </button>\n )\n }\n)\nAccordionTrigger.displayName = \"AccordionTrigger\"\n\n/**\n * AccordionTrigger 컴포넌트 / AccordionTrigger component\n * 아코디언 아이템을 열고 닫는 트리거 버튼입니다.\n * Button that opens and closes an accordion item.\n * \n * @component\n * @param {AccordionTriggerProps} props - AccordionTrigger 컴포넌트의 props / AccordionTrigger component props\n * @param {React.Ref<HTMLButtonElement>} ref - button 요소 ref / button element ref\n * @returns {JSX.Element} AccordionTrigger 컴포넌트 / AccordionTrigger component\n */\n\n/**\n * AccordionContent 컴포넌트의 props\n * @typedef {Object} AccordionContentProps\n * @property {React.ReactNode} children - 콘텐츠\n * @property {string} [className] - 추가 CSS 클래스\n * @property {boolean} [isOpen] - 열림 상태 (AccordionItem에서 자동 전달)\n * @property {string} [value] - 아이템 값 (AccordionItem에서 자동 전달)\n * @property {string} ['data-accordion-value'] - 아이템 값 (내부 사용)\n */\ninterface AccordionContentProps {\n children: React.ReactNode\n className?: string\n isOpen?: boolean\n value?: string\n 'data-accordion-value'?: string\n}\n\n/**\n * AccordionContent 컴포넌트 / AccordionContent component\n * 아코디언 아이템의 콘텐츠를 표시합니다.\n * Displays the content of an accordion item.\n * \n * @component\n * @param {AccordionContentProps} props - AccordionContent 컴포넌트의 props / AccordionContent component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} AccordionContent 컴포넌트 / AccordionContent component\n */\nconst AccordionContent = React.forwardRef<HTMLDivElement, AccordionContentProps>(\n ({ children, className, isOpen = false, value, 'data-accordion-value': dataValue, ...props }, ref) => {\n const [height, setHeight] = React.useState(0)\n const contentRef = React.useRef<HTMLDivElement>(null)\n const itemValue = value || dataValue || 'unknown'\n\n React.useEffect(() => {\n if (contentRef.current) {\n if (isOpen) {\n setHeight(contentRef.current.scrollHeight)\n } else {\n setHeight(0)\n }\n }\n }, [isOpen, children])\n\n const triggerId = `accordion-trigger-${itemValue}`\n const contentId = `accordion-content-${itemValue}`\n\n return (\n <div\n ref={ref}\n id={contentId}\n role=\"region\"\n aria-labelledby={triggerId}\n hidden={!isOpen}\n className=\"overflow-hidden transition-all duration-300 ease-out\"\n style={{ height: `${height}px` }}\n {...props}\n >\n <div\n ref={contentRef}\n className={merge(\"px-6 pt-2 pb-4\", className)}\n >\n {children}\n </div>\n </div>\n )\n }\n)\nAccordionContent.displayName = \"AccordionContent\"\n\nexport { Accordion, AccordionItem, AccordionTrigger, AccordionContent } ","\"use client\"\n\nimport React from 'react'\nimport { merge } from '../lib/utils'\n\n/**\n * TabsContent 컴포넌트의 props / TabsContent component props\n * @typedef {Object} TabsContentProps\n * @property {string} value - 탭 패널의 고유 값 (TabsTrigger의 value와 일치해야 함) / Unique value for tab panel (must match TabsTrigger value)\n * @property {boolean} [active] - 탭 패널 활성화 상태 (자동 설정됨) / Tab panel active state (auto-set)\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface TabsContentProps extends React.HTMLAttributes<HTMLDivElement> {\n value: string\n active?: boolean\n}\n\n/**\n * TabsContent 컴포넌트 / TabsContent component\n * 탭의 콘텐츠 패널을 표시합니다. Tabs 컴포넌트 내부에서 사용됩니다.\n * Displays the tab content panel. Used inside Tabs component.\n * \n * @component\n * @param {TabsContentProps} props - TabsContent 컴포넌트의 props / TabsContent component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} TabsContent 컴포넌트 / TabsContent component\n */\nconst TabsContent = React.forwardRef<HTMLDivElement, TabsContentProps>(\n ({ className, value, active, children, ...props }, ref) => {\n // active prop이 명시적으로 false로 설정된 경우에만 숨김\n if (active === false) return null\n\n return (\n <div\n ref={ref}\n role=\"tabpanel\"\n id={`tabpanel-${value}`}\n aria-labelledby={`tab-${value}`}\n hidden={!active}\n className={merge(\n \"mt-2 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2\",\n className\n )}\n {...props}\n >\n {children}\n </div>\n )\n }\n)\nTabsContent.displayName = \"TabsContent\"\n\n/**\n * Tabs 컴포넌트의 props / Tabs component props\n * @typedef {Object} TabsProps\n * @property {string} [value] - 현재 활성화된 탭 값 (제어 컴포넌트) / Currently active tab value (controlled component)\n * @property {string} [defaultValue] - 초기 활성화된 탭 값 (비제어 컴포넌트) / Initial active tab value (uncontrolled component)\n * @property {(value: string) => void} [onValueChange] - 탭 변경 시 호출되는 콜백 / Callback when tab changes\n * @property {\"horizontal\" | \"vertical\"} [orientation=\"horizontal\"] - 탭 방향 / Tab orientation\n * @property {\"default\" | \"pills\" | \"underline\" | \"cards\"} [variant=\"default\"] - 탭 스타일 변형 / Tab style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - 탭 크기 / Tab size\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface TabsProps extends React.HTMLAttributes<HTMLDivElement> {\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n orientation?: \"horizontal\" | \"vertical\"\n variant?: \"default\" | \"pills\" | \"underline\" | \"cards\"\n size?: \"sm\" | \"md\" | \"lg\"\n}\n\n/**\n * Tabs 컴포넌트 / Tabs component\n * \n * 탭 네비게이션을 제공하는 컴포넌트입니다.\n * 키보드 네비게이션(Arrow keys, Home/End)을 지원하며, ARIA 속성을 자동으로 설정합니다.\n * \n * Component that provides tab navigation.\n * Supports keyboard navigation (Arrow keys, Home/End) and automatically sets ARIA attributes.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Tabs defaultValue=\"tab1\">\n * <TabsList>\n * <TabsTrigger value=\"tab1\">탭 1</TabsTrigger>\n * <TabsTrigger value=\"tab2\">탭 2</TabsTrigger>\n * </TabsList>\n * <TabsContent value=\"tab1\">탭 1 내용</TabsContent>\n * <TabsContent value=\"tab2\">탭 2 내용</TabsContent>\n * </Tabs>\n * \n * @example\n * // 제어 컴포넌트 / Controlled component\n * const [activeTab, setActiveTab] = useState(\"tab1\")\n * <Tabs value={activeTab} onValueChange={setActiveTab}>\n * <TabsList>\n * <TabsTrigger value=\"tab1\">탭 1</TabsTrigger>\n * </TabsList>\n * <TabsContent value=\"tab1\">내용</TabsContent>\n * </Tabs>\n * \n * @example\n * // 다양한 변형 / Various variants\n * <Tabs variant=\"pills\" size=\"lg\">\n * <TabsList>\n * <TabsTrigger value=\"tab1\">Pills 스타일</TabsTrigger>\n * </TabsList>\n * </Tabs>\n * \n * @param {TabsProps} props - Tabs 컴포넌트의 props / Tabs component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Tabs 컴포넌트 / Tabs component\n */\nconst Tabs = React.forwardRef<HTMLDivElement, TabsProps>(\n ({ \n className, \n value,\n defaultValue,\n onValueChange,\n orientation = \"horizontal\",\n variant = \"default\",\n size = \"md\",\n children,\n ...props \n }, ref) => {\n const [activeTab, setActiveTab] = React.useState(value || defaultValue || \"\")\n const isControlled = value !== undefined\n const currentValue = isControlled ? value : activeTab\n\n const handleTabChange = (newValue: string) => {\n if (!isControlled) {\n setActiveTab(newValue)\n }\n onValueChange?.(newValue)\n }\n\n React.useEffect(() => {\n if (value !== undefined) {\n setActiveTab(value)\n }\n }, [value])\n\n return (\n <div\n ref={ref}\n className={merge(\n \"w-full\",\n orientation === \"vertical\" && \"flex\",\n className\n )}\n {...props}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n // TabsContent인 경우 active prop을 자동으로 설정\n if (child.type === TabsContent) {\n const childProps = child.props as TabsContentProps\n return React.cloneElement(child, {\n value: currentValue,\n onValueChange: handleTabChange,\n orientation,\n variant,\n size,\n active: childProps.value === currentValue\n } as Partial<TabsContentProps>)\n }\n // 다른 컴포넌트들\n return React.cloneElement(child, {\n value: currentValue,\n onValueChange: handleTabChange,\n orientation,\n variant,\n size\n } as Partial<TabsTriggerProps | TabsListProps>)\n }\n return child\n })}\n </div>\n )\n }\n)\nTabs.displayName = \"Tabs\"\n\n/**\n * TabsList 컴포넌트의 props / TabsList component props\n * @typedef {Object} TabsListProps\n * @property {string} [value] - 현재 활성화된 탭 값 (Tabs에서 자동 전달) / Currently active tab value (auto-passed from Tabs)\n * @property {(value: string) => void} [onValueChange] - 탭 변경 콜백 (Tabs에서 자동 전달) / Tab change callback (auto-passed from Tabs)\n * @property {\"horizontal\" | \"vertical\"} [orientation] - 탭 방향 (Tabs에서 자동 전달) / Tab orientation (auto-passed from Tabs)\n * @property {\"default\" | \"pills\" | \"underline\" | \"cards\"} [variant] - 탭 스타일 (Tabs에서 자동 전달) / Tab style (auto-passed from Tabs)\n * @property {\"sm\" | \"md\" | \"lg\"} [size] - 탭 크기 (Tabs에서 자동 전달) / Tab size (auto-passed from Tabs)\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface TabsListProps extends React.HTMLAttributes<HTMLDivElement> {\n value?: string\n onValueChange?: (value: string) => void\n orientation?: \"horizontal\" | \"vertical\"\n variant?: \"default\" | \"pills\" | \"underline\" | \"cards\"\n size?: \"sm\" | \"md\" | \"lg\"\n}\n\n/**\n * TabsList 컴포넌트 / TabsList component\n * 탭 트리거 목록을 표시합니다. Tabs 컴포넌트 내부에서 사용됩니다.\n * Displays the list of tab triggers. Used inside Tabs component.\n * \n * @component\n * @param {TabsListProps} props - TabsList 컴포넌트의 props / TabsList component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} TabsList 컴포넌트 / TabsList component\n */\nconst TabsList = React.forwardRef<HTMLDivElement, TabsListProps>(\n ({ \n className, \n value,\n onValueChange,\n orientation = \"horizontal\",\n variant = \"default\",\n size = \"md\",\n children,\n ...props \n }, ref) => {\n const listRef = React.useRef<HTMLDivElement>(null)\n React.useImperativeHandle(ref, () => listRef.current as HTMLDivElement)\n \n // 모든 탭 트리거의 value를 수집\n const tabValues = React.useMemo(() => {\n const values: string[] = []\n React.Children.forEach(children, (child) => {\n if (React.isValidElement(child)) {\n const childProps = child.props as { value?: string }\n if (childProps.value) {\n values.push(childProps.value)\n }\n }\n })\n return values\n }, [children])\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLDivElement>) => {\n if (!value || tabValues.length === 0) return\n\n const currentIndex = tabValues.indexOf(value)\n if (currentIndex === -1) return\n\n let newIndex = currentIndex\n\n if (orientation === \"horizontal\") {\n if (e.key === \"ArrowLeft\") {\n e.preventDefault()\n newIndex = currentIndex > 0 ? currentIndex - 1 : tabValues.length - 1\n } else if (e.key === \"ArrowRight\") {\n e.preventDefault()\n newIndex = currentIndex < tabValues.length - 1 ? currentIndex + 1 : 0\n } else if (e.key === \"Home\") {\n e.preventDefault()\n newIndex = 0\n } else if (e.key === \"End\") {\n e.preventDefault()\n newIndex = tabValues.length - 1\n }\n } else {\n if (e.key === \"ArrowUp\") {\n e.preventDefault()\n newIndex = currentIndex > 0 ? currentIndex - 1 : tabValues.length - 1\n } else if (e.key === \"ArrowDown\") {\n e.preventDefault()\n newIndex = currentIndex < tabValues.length - 1 ? currentIndex + 1 : 0\n } else if (e.key === \"Home\") {\n e.preventDefault()\n newIndex = 0\n } else if (e.key === \"End\") {\n e.preventDefault()\n newIndex = tabValues.length - 1\n }\n }\n\n if (newIndex !== currentIndex && tabValues[newIndex]) {\n onValueChange?.(tabValues[newIndex])\n // 포커스 이동\n const triggerElement = listRef.current?.querySelector(\n `[data-tab-value=\"${tabValues[newIndex]}\"]`\n ) as HTMLElement\n triggerElement?.focus()\n }\n }\n const getVariantClasses = () => {\n switch (variant) {\n case \"pills\":\n return \"bg-gray-50 dark:bg-gray-800/80 p-3 rounded-xl border border-gray-200/50 dark:border-gray-700/50\"\n case \"underline\":\n return \"border-b border-gray-200 dark:border-gray-700\"\n case \"cards\":\n return \"bg-gray-50/80 dark:bg-gray-900/80 p-3 rounded-xl border border-gray-200/50 dark:border-gray-700/50\"\n default:\n return \"bg-gray-50 dark:bg-gray-800/80 p-3 rounded-xl border border-gray-200/50 dark:border-gray-700/50\"\n }\n }\n\n const getSizeClasses = () => {\n switch (size) {\n case \"sm\":\n return \"h-12\"\n case \"lg\":\n return \"h-16\"\n default:\n return \"h-14\"\n }\n }\n\n return (\n <div\n ref={listRef}\n role=\"tablist\"\n aria-orientation={orientation}\n onKeyDown={handleKeyDown}\n className={merge(\n \"flex items-center justify-center\",\n orientation === \"vertical\" && \"flex-col\",\n getVariantClasses(),\n getSizeClasses(),\n className\n )}\n {...props}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return React.cloneElement(child, {\n value,\n onValueChange,\n orientation,\n variant,\n size\n } as Partial<TabsTriggerProps>)\n }\n return child\n })}\n </div>\n )\n }\n)\nTabsList.displayName = \"TabsList\"\n\n/**\n * TabsTrigger 컴포넌트의 props\n * @typedef {Object} TabsTriggerProps\n * @property {string} value - 탭 트리거의 고유 값 (TabsContent의 value와 일치해야 함)\n * @property {(value: string) => void} [onValueChange] - 탭 변경 콜백 (TabsList에서 자동 전달)\n * @property {\"horizontal\" | \"vertical\"} [orientation] - 탭 방향 (TabsList에서 자동 전달)\n * @property {\"default\" | \"pills\" | \"underline\" | \"cards\"} [variant] - 탭 스타일 (TabsList에서 자동 전달)\n * @property {\"sm\" | \"md\" | \"lg\"} [size] - 탭 크기 (TabsList에서 자동 전달)\n * @property {boolean} [active] - 탭 활성화 상태 (자동 설정됨)\n * @extends {React.ButtonHTMLAttributes<HTMLButtonElement>}\n */\nexport interface TabsTriggerProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n value: string\n onValueChange?: (value: string) => void\n orientation?: \"horizontal\" | \"vertical\"\n variant?: \"default\" | \"pills\" | \"underline\" | \"cards\"\n size?: \"sm\" | \"md\" | \"lg\"\n active?: boolean\n}\n\n/**\n * TabsTrigger 컴포넌트 / TabsTrigger component\n * 탭을 활성화하는 버튼입니다. TabsList 컴포넌트 내부에서 사용됩니다.\n * Button that activates a tab. Used inside TabsList component.\n * \n * @component\n * @param {TabsTriggerProps} props - TabsTrigger 컴포넌트의 props / TabsTrigger component props\n * @param {React.Ref<HTMLButtonElement>} ref - button 요소 ref / button element ref\n * @returns {JSX.Element} TabsTrigger 컴포넌트 / TabsTrigger component\n */\nconst TabsTrigger = React.forwardRef<HTMLButtonElement, TabsTriggerProps>(\n ({ \n className, \n value,\n onValueChange,\n orientation = \"horizontal\",\n variant = \"default\",\n size = \"md\",\n active = false,\n children,\n ...props \n }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"pills\":\n return merge(\n \"inline-flex items-center justify-center whitespace-nowrap rounded-lg px-4 py-2.5 text-sm font-medium ring-offset-background transition-all duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n active \n ? \"bg-white dark:bg-gray-900 text-gray-900 dark:text-white shadow-md\" \n : \"text-gray-600 dark:text-gray-400 hover:text-gray-900 dark:hover:text-white hover:bg-gray-100 dark:hover:bg-gray-800\"\n )\n case \"underline\":\n return merge(\n \"inline-flex items-center justify-center whitespace-nowrap border-b-2 px-4 py-2.5 text-sm font-medium ring-offset-background transition-all duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n active \n ? \"border-blue-500 text-blue-600 dark:text-blue-400\" \n : \"border-transparent text-gray-600 dark:text-gray-400 hover:text-gray-900 dark:hover:text-white\"\n )\n case \"cards\":\n return merge(\n \"inline-flex items-center justify-center whitespace-nowrap rounded-lg px-4 py-2.5 text-sm font-medium ring-offset-background transition-all duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n active \n ? \"bg-white dark:bg-gray-900 text-gray-900 dark:text-white shadow-md\" \n : \"text-gray-600 dark:text-gray-400 hover:text-gray-900 dark:hover:text-white hover:bg-gray-100 dark:hover:bg-gray-800\"\n )\n default:\n return merge(\n \"inline-flex items-center justify-center whitespace-nowrap rounded-lg px-4 py-2.5 text-sm font-medium ring-offset-background transition-all duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n active \n ? \"bg-white dark:bg-gray-900 text-gray-900 dark:text-white shadow-md\" \n : \"text-gray-600 dark:text-gray-400 hover:text-gray-900 dark:hover:text-white hover:bg-gray-100 dark:hover:bg-gray-800\"\n )\n }\n }\n\n const getSizeClasses = () => {\n switch (size) {\n case \"sm\":\n return \"h-10 px-4 py-2 text-xs\"\n case \"lg\":\n return \"h-14 px-6 py-3 text-base\"\n default:\n return \"h-12 px-5 py-2.5 text-sm\"\n }\n }\n\n const handleClick = () => {\n console.log('TabsTrigger clicked:', value, 'onValueChange:', !!onValueChange)\n if (onValueChange) {\n onValueChange(value)\n }\n }\n\n return (\n <button\n ref={ref}\n role=\"tab\"\n aria-selected={active}\n aria-controls={`tabpanel-${value}`}\n id={`tab-${value}`}\n data-tab-value={value}\n tabIndex={active ? 0 : -1}\n className={merge(\n getVariantClasses(),\n getSizeClasses(),\n className\n )}\n onClick={handleClick}\n type=\"button\"\n {...props}\n >\n {children}\n </button>\n )\n }\n)\nTabsTrigger.displayName = \"TabsTrigger\"\n\n// 편의 컴포넌트들\nconst TabsPills = React.forwardRef<HTMLDivElement, TabsProps>(\n (props, ref) => <Tabs ref={ref} variant=\"pills\" {...props} />\n)\nTabsPills.displayName = \"TabsPills\"\n\nconst TabsUnderline = React.forwardRef<HTMLDivElement, TabsProps>(\n (props, ref) => <Tabs ref={ref} variant=\"underline\" {...props} />\n)\nTabsUnderline.displayName = \"TabsUnderline\"\n\nconst TabsCards = React.forwardRef<HTMLDivElement, TabsProps>(\n (props, ref) => <Tabs ref={ref} variant=\"cards\" {...props} />\n)\nTabsCards.displayName = \"TabsCards\"\n\nexport { Tabs, TabsList, TabsTrigger, TabsContent, TabsPills, TabsUnderline, TabsCards } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Menu 컴포넌트의 props / Menu component props\n * @typedef {Object} MenuProps\n * @property {React.ReactNode} children - MenuItem, MenuSeparator, MenuLabel 컴포넌트들 / MenuItem, MenuSeparator, MenuLabel components\n * @property {\"default\" | \"horizontal\" | \"vertical\" | \"compact\"} [variant=\"default\"] - 메뉴 방향 및 스타일 / Menu direction and style\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - 메뉴 아이템 크기 / Menu item size\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface MenuProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n variant?: \"default\" | \"horizontal\" | \"vertical\" | \"compact\"\n size?: \"sm\" | \"md\" | \"lg\"\n}\n\n/**\n * Menu 컴포넌트 / Menu component\n * \n * 메뉴 리스트를 제공하는 컴포넌트입니다.\n * MenuItem, MenuSeparator, MenuLabel과 함께 사용합니다.\n * \n * Component that provides menu lists.\n * Used with MenuItem, MenuSeparator, and MenuLabel.\n * \n * @component\n * @example\n * // 기본 수직 메뉴 / Basic vertical menu\n * <Menu>\n * <MenuItem icon={<Icon name=\"home\" />}>홈</MenuItem>\n * <MenuItem icon={<Icon name=\"settings\" />}>설정</MenuItem>\n * <MenuSeparator />\n * <MenuItem>로그아웃</MenuItem>\n * </Menu>\n * \n * @example\n * // 수평 메뉴 / Horizontal menu\n * <Menu variant=\"horizontal\">\n * <MenuItem>메뉴 1</MenuItem>\n * <MenuItem>메뉴 2</MenuItem>\n * </Menu>\n * \n * @param {MenuProps} props - Menu 컴포넌트의 props / Menu component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Menu 컴포넌트 / Menu component\n */\nconst Menu = React.forwardRef<HTMLDivElement, MenuProps>(\n ({ \n className, \n children,\n variant = \"default\",\n size = \"md\",\n ...props \n }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"horizontal\":\n return \"flex items-center space-x-1\" // 4px 간격\n case \"vertical\":\n return \"flex flex-col space-y-1\" // 4px 간격\n case \"compact\":\n return \"flex flex-col space-y-0.5\" // 2px 간격\n default:\n return \"flex flex-col space-y-1\" // 4px 간격\n }\n }\n\n const getSizeClasses = () => {\n switch (size) {\n case \"sm\":\n return \"text-sm\"\n case \"lg\":\n return \"text-base\"\n default:\n return \"text-sm\"\n }\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n getVariantClasses(),\n getSizeClasses(),\n className\n )}\n {...props}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return React.cloneElement(child, {\n variant,\n size\n } as Partial<MenuItemProps | MenuSeparatorProps | MenuLabelProps>)\n }\n return child\n })}\n </div>\n )\n }\n)\nMenu.displayName = \"Menu\"\n\n/**\n * MenuItem 컴포넌트의 props / MenuItem component props\n * @typedef {Object} MenuItemProps\n * @property {React.ReactNode} [icon] - 메뉴 아이템 아이콘 / Menu item icon\n * @property {\"default\" | \"horizontal\" | \"vertical\" | \"compact\"} [variant] - 메뉴 변형 (Menu에서 자동 전달) / Menu variant (auto-passed from Menu)\n * @property {\"sm\" | \"md\" | \"lg\"} [size] - 메뉴 크기 (Menu에서 자동 전달) / Menu size (auto-passed from Menu)\n * @property {boolean} [active=false] - 활성화 상태 / Active state\n * @property {boolean} [disabled=false] - 비활성화 상태 / Disabled state\n * @extends {React.ButtonHTMLAttributes<HTMLButtonElement>}\n */\nexport interface MenuItemProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n icon?: React.ReactNode\n variant?: \"default\" | \"horizontal\" | \"vertical\" | \"compact\"\n size?: \"sm\" | \"md\" | \"lg\"\n active?: boolean\n disabled?: boolean\n}\n\n/**\n * MenuItem 컴포넌트 / MenuItem component\n * 메뉴의 개별 아이템을 표시합니다.\n * Displays an individual menu item.\n * \n * @component\n * @param {MenuItemProps} props - MenuItem 컴포넌트의 props / MenuItem component props\n * @param {React.Ref<HTMLButtonElement>} ref - button 요소 ref / button element ref\n * @returns {JSX.Element} MenuItem 컴포넌트 / MenuItem component\n */\nconst MenuItem = React.forwardRef<HTMLButtonElement, MenuItemProps>(\n ({ \n className, \n icon,\n variant = \"default\",\n size = \"md\",\n active = false,\n disabled = false,\n children,\n ...props \n }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"horizontal\":\n return merge(\n \"flex items-center gap-2 px-3 py-2 rounded-md text-sm font-medium transition-colors\", // 12px, 8px 패딩\n active \n ? \"bg-blue-100 dark:bg-blue-900 text-blue-700 dark:text-blue-300\" \n : \"text-gray-700 dark:text-gray-300 hover:text-gray-900 dark:hover:text-gray-100 hover:bg-gray-100 dark:hover:bg-gray-700\"\n )\n case \"vertical\":\n return merge(\n \"flex items-center gap-3 px-4 py-3 rounded-md text-sm font-medium transition-colors\", // 16px, 12px 패딩\n active \n ? \"bg-blue-100 dark:bg-blue-900 text-blue-700 dark:text-blue-300\" \n : \"text-gray-700 dark:text-gray-300 hover:text-gray-900 dark:hover:text-gray-100 hover:bg-gray-100 dark:hover:bg-gray-700\"\n )\n case \"compact\":\n return merge(\n \"flex items-center gap-2 px-2 py-1.5 rounded text-sm font-medium transition-colors\", // 8px, 6px 패딩\n active \n ? \"bg-blue-100 dark:bg-blue-900 text-blue-700 dark:text-blue-300\" \n : \"text-gray-700 dark:text-gray-300 hover:text-gray-900 dark:hover:text-gray-100 hover:bg-gray-100 dark:hover:bg-gray-700\"\n )\n default:\n return merge(\n \"flex items-center gap-3 px-4 py-3 rounded-md text-sm font-medium transition-colors\", // 16px, 12px 패딩\n active \n ? \"bg-blue-100 dark:bg-blue-900 text-blue-700 dark:text-blue-300\" \n : \"text-gray-700 dark:text-gray-300 hover:text-gray-900 dark:hover:text-gray-100 hover:bg-gray-100 dark:hover:bg-gray-700\"\n )\n }\n }\n\n const getSizeClasses = () => {\n switch (size) {\n case \"sm\":\n return \"text-xs\"\n case \"lg\":\n return \"text-base\"\n default:\n return \"text-sm\"\n }\n }\n\n return (\n <button\n ref={ref}\n className={merge(\n getVariantClasses(),\n getSizeClasses(),\n disabled && \"opacity-50 cursor-not-allowed\",\n className\n )}\n disabled={disabled}\n {...props}\n >\n {icon && (\n <div className=\"flex-shrink-0 w-4 h-4\">\n {icon}\n </div>\n )}\n <span className=\"flex-1 text-left\">{children}</span>\n </button>\n )\n }\n)\nMenuItem.displayName = \"MenuItem\"\n\n/**\n * MenuSeparator 컴포넌트의 props / MenuSeparator component props\n * @typedef {Object} MenuSeparatorProps\n * @property {\"default\" | \"horizontal\" | \"vertical\" | \"compact\"} [variant] - 메뉴 변형 (Menu에서 자동 전달) / Menu variant (auto-passed from Menu)\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface MenuSeparatorProps extends React.HTMLAttributes<HTMLDivElement> {\n variant?: \"default\" | \"horizontal\" | \"vertical\" | \"compact\"\n}\n\n/**\n * MenuSeparator 컴포넌트 / MenuSeparator component\n * 메뉴 아이템들을 구분하는 구분선을 표시합니다.\n * Displays a separator line between menu items.\n * \n * @component\n * @param {MenuSeparatorProps} props - MenuSeparator 컴포넌트의 props / MenuSeparator component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} MenuSeparator 컴포넌트 / MenuSeparator component\n */\nconst MenuSeparator = React.forwardRef<HTMLDivElement, MenuSeparatorProps>(\n ({ className, variant = \"default\", ...props }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"horizontal\":\n return \"w-px h-4 bg-gray-200 dark:bg-gray-700 mx-1\" // 4px 여백\n case \"vertical\":\n case \"compact\":\n default:\n return \"h-px bg-gray-200 dark:bg-gray-700 my-2\" // 8px 여백\n }\n }\n\n return (\n <div\n ref={ref}\n className={merge(getVariantClasses(), className)}\n {...props}\n />\n )\n }\n)\nMenuSeparator.displayName = \"MenuSeparator\"\n\n/**\n * MenuLabel 컴포넌트의 props / MenuLabel component props\n * @typedef {Object} MenuLabelProps\n * @property {\"default\" | \"horizontal\" | \"vertical\" | \"compact\"} [variant] - 메뉴 변형 (Menu에서 자동 전달) / Menu variant (auto-passed from Menu)\n * @property {\"sm\" | \"md\" | \"lg\"} [size] - 메뉴 크기 (Menu에서 자동 전달) / Menu size (auto-passed from Menu)\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface MenuLabelProps extends React.HTMLAttributes<HTMLDivElement> {\n variant?: \"default\" | \"horizontal\" | \"vertical\" | \"compact\"\n size?: \"sm\" | \"md\" | \"lg\"\n}\n\n/**\n * MenuLabel 컴포넌트 / MenuLabel component\n * 메뉴 섹션의 레이블을 표시합니다.\n * Displays a label for a menu section.\n * \n * @component\n * @param {MenuLabelProps} props - MenuLabel 컴포넌트의 props / MenuLabel component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} MenuLabel 컴포넌트 / MenuLabel component\n */\nconst MenuLabel = React.forwardRef<HTMLDivElement, MenuLabelProps>(\n ({ className, variant = \"default\", size = \"md\", children, ...props }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"horizontal\":\n return \"px-3 py-1 text-xs font-semibold text-gray-500 dark:text-gray-400 uppercase tracking-wide\" // 12px, 4px 패딩\n case \"vertical\":\n case \"compact\":\n default:\n return \"px-4 py-2 text-xs font-semibold text-gray-500 dark:text-gray-400 uppercase tracking-wide\" // 16px, 8px 패딩\n }\n }\n\n const getSizeClasses = () => {\n switch (size) {\n case \"sm\":\n return \"text-xs\"\n case \"lg\":\n return \"text-sm\"\n default:\n return \"text-xs\"\n }\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n getVariantClasses(),\n getSizeClasses(),\n className\n )}\n {...props}\n >\n {children}\n </div>\n )\n }\n)\nMenuLabel.displayName = \"MenuLabel\"\n\n// 편의 컴포넌트들\nexport const MenuHorizontal = React.forwardRef<HTMLDivElement, Omit<MenuProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Menu ref={ref} variant=\"horizontal\" className={className} {...props} />\n )\n)\nMenuHorizontal.displayName = \"MenuHorizontal\"\n\nexport const MenuVertical = React.forwardRef<HTMLDivElement, Omit<MenuProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Menu ref={ref} variant=\"vertical\" className={className} {...props} />\n )\n)\nMenuVertical.displayName = \"MenuVertical\"\n\nexport const MenuCompact = React.forwardRef<HTMLDivElement, Omit<MenuProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Menu ref={ref} variant=\"compact\" className={className} {...props} />\n )\n)\nMenuCompact.displayName = \"MenuCompact\"\n\nexport { Menu, MenuItem, MenuSeparator, MenuLabel } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * ContextMenu 컴포넌트의 props / ContextMenu component props\n * @typedef {Object} ContextMenuProps\n * @property {React.ReactNode} children - ContextMenu 내용 / ContextMenu content\n * @property {boolean} [open] - 제어 모드에서 열림/닫힘 상태 / Open/close state in controlled mode\n * @property {(open: boolean) => void} [onOpenChange] - 상태 변경 콜백 / State change callback\n * @property {React.ReactNode} [trigger] - ContextMenu를 열기 위한 트리거 요소 (우클릭 이벤트) / Trigger element to open context menu (right-click event)\n * @property {\"top\" | \"bottom\" | \"left\" | \"right\"} [placement=\"bottom\"] - ContextMenu 표시 위치 / ContextMenu display position\n * @property {\"start\" | \"center\" | \"end\"} [align=\"start\"] - ContextMenu 정렬 / ContextMenu alignment\n * @property {number} [offset=8] - 트리거와 ContextMenu 사이 간격 (px) / Spacing between trigger and context menu (px)\n * @property {boolean} [disabled=false] - ContextMenu 비활성화 여부 / Disable context menu\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface ContextMenuProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n open?: boolean\n onOpenChange?: (open: boolean) => void\n trigger?: React.ReactNode\n placement?: \"top\" | \"bottom\" | \"left\" | \"right\"\n align?: \"start\" | \"center\" | \"end\"\n offset?: number\n disabled?: boolean\n}\n\n/**\n * ContextMenu 컴포넌트 / ContextMenu component\n * \n * 우클릭 시 표시되는 컨텍스트 메뉴 컴포넌트입니다.\n * 트리거 요소에 우클릭 이벤트를 자동으로 연결합니다.\n * \n * Context menu component that appears on right-click.\n * Automatically connects right-click events to the trigger element.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <ContextMenu trigger={<div>우클릭하세요</div>}>\n * <div className=\"p-2\">\n * <button>항목 1</button>\n * <button>항목 2</button>\n * </div>\n * </ContextMenu>\n * \n * @example\n * // 제어 모드 / Controlled mode\n * const [open, setOpen] = useState(false)\n * <ContextMenu \n * open={open}\n * onOpenChange={setOpen}\n * trigger={<div>우클릭</div>}\n * >\n * <Menu>\n * <MenuItem>복사</MenuItem>\n * <MenuItem>삭제</MenuItem>\n * </Menu>\n * </ContextMenu>\n * \n * @param {ContextMenuProps} props - ContextMenu 컴포넌트의 props / ContextMenu component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} ContextMenu 컴포넌트 / ContextMenu component\n */\nconst ContextMenu = React.forwardRef<HTMLDivElement, ContextMenuProps>(\n ({ \n className, \n children,\n open: controlledOpen,\n onOpenChange,\n trigger,\n placement = \"bottom\",\n align = \"start\",\n offset = 8,\n disabled = false,\n ...props \n }, ref) => {\n const [internalOpen, setInternalOpen] = React.useState(false)\n const [coords, setCoords] = React.useState({ x: 0, y: 0 })\n const triggerRef = React.useRef<HTMLDivElement>(null)\n const menuRef = 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 handleContextMenu = (event: React.MouseEvent) => {\n event.preventDefault()\n if (disabled) return\n\n const rect = event.currentTarget.getBoundingClientRect()\n const x = event.clientX\n const y = event.clientY\n\n setCoords({ x, y })\n handleOpenChange(true)\n }\n\n const updatePosition = React.useCallback(() => {\n if (!menuRef.current) return\n\n const menuRect = menuRef.current.getBoundingClientRect()\n const viewportWidth = window.innerWidth\n const viewportHeight = window.innerHeight\n\n let x = coords.x\n let y = coords.y\n\n // 뷰포트 경계 확인 및 조정\n if (x + menuRect.width > viewportWidth - 8) {\n x = viewportWidth - menuRect.width - 8 // 8px 여백\n }\n if (y + menuRect.height > viewportHeight - 8) {\n y = viewportHeight - menuRect.height - 8 // 8px 여백\n }\n if (x < 8) x = 8 // 8px 여백\n if (y < 8) y = 8 // 8px 여백\n\n setCoords({ x, y })\n }, [coords.x, coords.y])\n\n React.useEffect(() => {\n if (isOpen) {\n updatePosition()\n window.addEventListener('resize', updatePosition)\n window.addEventListener('scroll', updatePosition)\n \n return () => {\n window.removeEventListener('resize', updatePosition)\n window.removeEventListener('scroll', updatePosition)\n }\n }\n }, [isOpen, updatePosition])\n\n React.useEffect(() => {\n const handleClickOutside = (event: MouseEvent) => {\n if (\n triggerRef.current && \n menuRef.current && \n !triggerRef.current.contains(event.target as Node) &&\n !menuRef.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 return (\n <div ref={ref} className={merge(\"relative\", className)} {...props}>\n {/* 트리거 */}\n {trigger && (\n <div\n ref={triggerRef}\n onContextMenu={handleContextMenu}\n className=\"inline-block\"\n >\n {trigger}\n </div>\n )}\n\n {/* 컨텍스트 메뉴 */}\n {isOpen && (\n <div\n ref={menuRef}\n className={merge(\n \"fixed z-50 bg-white dark:bg-gray-800 rounded-lg shadow-xl backdrop-blur-sm\", // 보더 대신 섀도우 사용\n \"min-w-[200px] py-2\", // 16px 패딩\n \"border-0\" // 보더 제거\n )}\n style={{\n left: coords.x,\n top: coords.y,\n boxShadow: \"0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04)\"\n }}\n >\n {children}\n </div>\n )}\n </div>\n )\n }\n)\nContextMenu.displayName = \"ContextMenu\"\n\nexport interface ContextMenuItemProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n icon?: React.ReactNode\n variant?: \"default\" | \"destructive\" | \"disabled\"\n}\n\nconst ContextMenuItem = React.forwardRef<HTMLButtonElement, ContextMenuItemProps>(\n ({ \n className, \n icon,\n variant = \"default\",\n children,\n disabled,\n ...props \n }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"destructive\":\n return \"text-red-600 dark:text-red-400 hover:bg-red-50 dark:hover:bg-red-900/20\"\n case \"disabled\":\n return \"text-gray-400 dark:text-gray-500 cursor-not-allowed\"\n default:\n return \"text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700\"\n }\n }\n\n return (\n <button\n ref={ref}\n className={merge(\n \"w-full flex items-center gap-3 px-4 py-3 text-sm font-medium transition-colors focus:outline-none focus:bg-gray-100 dark:focus:bg-gray-700\", // 16px, 12px 패딩\n getVariantClasses(),\n className\n )}\n disabled={disabled || variant === \"disabled\"}\n {...props}\n >\n {icon && (\n <div className=\"flex-shrink-0 w-4 h-4\">\n {icon}\n </div>\n )}\n <span className=\"flex-1 text-left\">{children}</span>\n </button>\n )\n }\n)\nContextMenuItem.displayName = \"ContextMenuItem\"\n\nexport interface ContextMenuSeparatorProps extends React.HTMLAttributes<HTMLDivElement> {}\n\nconst ContextMenuSeparator = React.forwardRef<HTMLDivElement, ContextMenuSeparatorProps>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"h-px bg-gray-200 dark:bg-gray-700 my-2\", className)} // 8px 여백\n {...props}\n />\n )\n)\nContextMenuSeparator.displayName = \"ContextMenuSeparator\"\n\nexport interface ContextMenuLabelProps extends React.HTMLAttributes<HTMLDivElement> {}\n\nconst ContextMenuLabel = React.forwardRef<HTMLDivElement, ContextMenuLabelProps>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"px-4 py-2 text-xs font-semibold text-gray-500 dark:text-gray-400 uppercase tracking-wide\", className)} // 16px, 8px 패딩\n {...props}\n >\n {children}\n </div>\n )\n)\nContextMenuLabel.displayName = \"ContextMenuLabel\"\n\n// 편의 컴포넌트들\nconst ContextMenuGroup = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"py-1\", className)} // 4px 패딩\n {...props}\n >\n {children}\n </div>\n )\n)\nContextMenuGroup.displayName = \"ContextMenuGroup\"\n\nexport { ContextMenu, ContextMenuItem, ContextMenuSeparator, ContextMenuLabel, ContextMenuGroup } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Command 컴포넌트의 props / Command component props\n * @typedef {Object} CommandProps\n * @property {React.ReactNode} children - CommandList, CommandItem 등 / CommandList, CommandItem, etc.\n * @property {boolean} [open] - 제어 모드에서 열림/닫힘 상태 / Open/close state in controlled mode\n * @property {(open: boolean) => void} [onOpenChange] - 상태 변경 콜백 / State change callback\n * @property {string} [placeholder=\"명령어를 검색하세요...\"] - 검색 입력 플레이스홀더 / Search input placeholder\n * @property {string} [searchValue] - 제어 모드에서 검색 값 / Search value in controlled mode\n * @property {(value: string) => void} [onSearchChange] - 검색 값 변경 콜백 / Search value change callback\n * @property {boolean} [disabled=false] - Command 비활성화 여부 / Disable command\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CommandProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n open?: boolean\n onOpenChange?: (open: boolean) => void\n placeholder?: string\n searchValue?: string\n onSearchChange?: (value: string) => void\n disabled?: boolean\n}\n\n/**\n * Command 컴포넌트 / Command component\n * \n * 명령 팔레트(Command Palette) 컴포넌트입니다.\n * Cmd+K (Mac) 또는 Ctrl+K (Windows)로 열 수 있습니다.\n * 키보드 네비게이션(Arrow keys, Enter, Escape)을 지원합니다.\n * \n * Command Palette component.\n * Can be opened with Cmd+K (Mac) or Ctrl+K (Windows).\n * Supports keyboard navigation (Arrow keys, Enter, Escape).\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Command>\n * <CommandInput placeholder=\"검색...\" />\n * <CommandList>\n * <CommandItem>항목 1</CommandItem>\n * <CommandItem>항목 2</CommandItem>\n * </CommandList>\n * </Command>\n * \n * @example\n * // 제어 모드 / Controlled mode\n * const [open, setOpen] = useState(false)\n * <Command \n * open={open}\n * onOpenChange={setOpen}\n * >\n * <CommandList>\n * <CommandGroup heading=\"파일\">\n * <CommandItem>새 파일</CommandItem>\n * </CommandGroup>\n * </CommandList>\n * </Command>\n * \n * @param {CommandProps} props - Command 컴포넌트의 props / Command component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Command 컴포넌트 / Command component\n */\nconst Command = React.forwardRef<HTMLDivElement, CommandProps>(\n ({ \n className, \n children,\n open: controlledOpen,\n onOpenChange,\n placeholder = \"명령어를 검색하세요...\",\n searchValue: controlledSearchValue,\n onSearchChange,\n disabled = false,\n ...props \n }, ref) => {\n const [internalOpen, setInternalOpen] = React.useState(false)\n const [internalSearchValue, setInternalSearchValue] = React.useState(\"\")\n const [selectedIndex, setSelectedIndex] = React.useState(0)\n const commandRef = React.useRef<HTMLDivElement>(null)\n const inputRef = React.useRef<HTMLInputElement>(null)\n const listRef = React.useRef<HTMLDivElement>(null)\n \n const isControlled = controlledOpen !== undefined\n const isOpen = isControlled ? controlledOpen : internalOpen\n const searchValue = controlledSearchValue !== undefined ? controlledSearchValue : internalSearchValue\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 handleSearchChange = (value: string) => {\n if (!isControlled) {\n setInternalSearchValue(value)\n }\n onSearchChange?.(value)\n setSelectedIndex(0)\n }\n\n const handleKeyDown = (event: React.KeyboardEvent) => {\n if (disabled) return\n\n const items = listRef.current?.querySelectorAll('[data-command-item]')\n const itemCount = items?.length || 0\n\n switch (event.key) {\n case 'ArrowDown':\n event.preventDefault()\n setSelectedIndex((prev) => (prev + 1) % itemCount)\n break\n case 'ArrowUp':\n event.preventDefault()\n setSelectedIndex((prev) => (prev - 1 + itemCount) % itemCount)\n break\n case 'Enter':\n event.preventDefault()\n const selectedItem = items?.[selectedIndex] as HTMLElement\n selectedItem?.click()\n break\n case 'Escape':\n event.preventDefault()\n handleOpenChange(false)\n break\n }\n }\n\n React.useEffect(() => {\n if (isOpen) {\n inputRef.current?.focus()\n setSelectedIndex(0)\n }\n }, [isOpen])\n\n React.useEffect(() => {\n const handleKeyDown = (event: KeyboardEvent) => {\n if (event.key === 'k' && (event.metaKey || event.ctrlKey)) {\n event.preventDefault()\n handleOpenChange(!isOpen)\n }\n }\n\n document.addEventListener('keydown', handleKeyDown)\n return () => {\n document.removeEventListener('keydown', handleKeyDown)\n }\n }, [isOpen])\n\n React.useEffect(() => {\n const selectedItem = listRef.current?.querySelector(`[data-command-item]:nth-child(${selectedIndex + 1})`) as HTMLElement\n selectedItem?.scrollIntoView({ block: 'nearest' })\n }, [selectedIndex])\n\n return (\n <div ref={ref} className={merge(\"relative\", className)} {...props}>\n {isOpen && (\n <div\n ref={commandRef}\n className={merge(\n \"fixed inset-0 z-50 bg-black/50 backdrop-blur-sm\", // 50% 투명도\n \"flex items-start justify-center pt-16\" // 64px 상단 여백\n )}\n onClick={() => handleOpenChange(false)}\n >\n <div\n className={merge(\n \"w-full max-w-2xl mx-4 bg-white dark:bg-gray-800 rounded-lg shadow-2xl\", // 보더 대신 섀도우\n \"border-0 overflow-hidden\" // 보더 제거\n )}\n onClick={(e) => e.stopPropagation()}\n style={{\n boxShadow: \"0 25px 50px -12px rgba(0, 0, 0, 0.25)\"\n }}\n >\n <div className=\"p-4 border-b border-gray-200 dark:border-gray-700\"> {/* 16px 패딩 */}\n <input\n ref={inputRef}\n type=\"text\"\n placeholder={placeholder}\n value={searchValue}\n onChange={(e) => handleSearchChange(e.target.value)}\n onKeyDown={handleKeyDown}\n className={merge(\n \"w-full bg-transparent text-lg font-medium outline-none\", // 18px 텍스트\n \"placeholder:text-gray-500 dark:placeholder:text-gray-400\",\n \"text-gray-900 dark:text-gray-100\"\n )}\n />\n </div>\n \n <div\n ref={listRef}\n className=\"max-h-96 overflow-y-auto py-2\" // 384px 최대 높이, 8px 패딩\n >\n {React.Children.map(children, (child, index) => {\n if (React.isValidElement<CommandItemProps>(child)) {\n return React.cloneElement(child, {\n selected: index === selectedIndex,\n onSelect: () => {\n child.props.onSelect?.()\n handleOpenChange(false)\n }\n })\n }\n return child\n })}\n </div>\n </div>\n </div>\n )}\n </div>\n )\n }\n)\nCommand.displayName = \"Command\"\n\n/**\n * CommandInput 컴포넌트의 props / CommandInput component props\n * @typedef {Object} CommandInputProps\n * @extends {React.InputHTMLAttributes<HTMLInputElement>}\n */\nexport interface CommandInputProps extends React.InputHTMLAttributes<HTMLInputElement> {}\n\nconst CommandInput = React.forwardRef<HTMLInputElement, CommandInputProps>(\n ({ className, ...props }, ref) => (\n <input\n ref={ref}\n className={merge(\n \"flex h-10 w-full rounded-md bg-transparent px-3 py-2 text-sm outline-none\", // 40px 높이, 12px, 8px 패딩\n \"placeholder:text-gray-500 dark:placeholder:text-gray-400\",\n \"disabled:cursor-not-allowed disabled:opacity-50\",\n className\n )}\n {...props}\n />\n )\n)\nCommandInput.displayName = \"CommandInput\"\n\nexport interface CommandListProps extends React.HTMLAttributes<HTMLDivElement> {}\n\nconst CommandList = React.forwardRef<HTMLDivElement, CommandListProps>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"max-h-96 overflow-y-auto py-2\", className)} // 384px 최대 높이, 8px 패딩\n {...props}\n />\n )\n)\nCommandList.displayName = \"CommandList\"\n\n/**\n * CommandItem 컴포넌트의 props / CommandItem component props\n * @typedef {Object} CommandItemProps\n * @property {React.ReactNode} [icon] - 항목 아이콘 / Item icon\n * @property {boolean} [selected=false] - 선택 상태 / Selected state\n * @property {() => void} [onSelect] - 선택 시 콜백 / Selection callback\n * @extends {React.ButtonHTMLAttributes<HTMLButtonElement>}\n */\nexport interface CommandItemProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n icon?: React.ReactNode\n selected?: boolean\n onSelect?: () => void\n}\n\nconst CommandItem = React.forwardRef<HTMLButtonElement, CommandItemProps>(\n ({ \n className, \n icon,\n selected = false,\n onSelect,\n children,\n ...props \n }, ref) => {\n return (\n <button\n ref={ref}\n data-command-item\n className={merge(\n \"relative flex w-full items-center gap-3 rounded-sm px-4 py-3 text-sm\", // 16px, 12px 패딩\n \"text-gray-700 dark:text-gray-300\",\n \"hover:bg-gray-100 dark:hover:bg-gray-700\",\n \"focus:bg-gray-100 dark:focus:bg-gray-700\",\n \"focus:outline-none\",\n selected && \"bg-gray-100 dark:bg-gray-700\",\n \"transition-colors\",\n className\n )}\n onClick={onSelect}\n {...props}\n >\n {icon && (\n <div className=\"flex-shrink-0 w-4 h-4 text-gray-500 dark:text-gray-400\">\n {icon}\n </div>\n )}\n <span className=\"flex-1 text-left\">{children}</span>\n </button>\n )\n }\n)\nCommandItem.displayName = \"CommandItem\"\n\n/**\n * CommandGroup 컴포넌트의 props / CommandGroup component props\n * @typedef {Object} CommandGroupProps\n * @property {React.ReactNode} [heading] - 그룹 제목 / Group heading\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CommandGroupProps extends React.HTMLAttributes<HTMLDivElement> {\n heading?: React.ReactNode\n}\n\nconst CommandGroup = React.forwardRef<HTMLDivElement, CommandGroupProps>(\n ({ className, heading, children, ...props }, ref) => (\n <div ref={ref} className={merge(\"py-2\", className)} {...props}> {/* 8px 패딩 */}\n {heading && (\n <div className=\"px-4 py-2 text-xs font-semibold text-gray-500 dark:text-gray-400 uppercase tracking-wide\"> {/* 16px, 8px 패딩 */}\n {heading}\n </div>\n )}\n <div className=\"space-y-1\"> {/* 4px 간격 */}\n {children}\n </div>\n </div>\n )\n)\nCommandGroup.displayName = \"CommandGroup\"\n\n/**\n * CommandSeparator 컴포넌트의 props / CommandSeparator component props\n * @typedef {Object} CommandSeparatorProps\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CommandSeparatorProps extends React.HTMLAttributes<HTMLDivElement> {}\n\nconst CommandSeparator = React.forwardRef<HTMLDivElement, CommandSeparatorProps>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"h-px bg-gray-200 dark:bg-gray-700 my-2\", className)} // 8px 여백\n {...props}\n />\n )\n)\nCommandSeparator.displayName = \"CommandSeparator\"\n\n/**\n * CommandEmpty 컴포넌트의 props / CommandEmpty component props\n * @typedef {Object} CommandEmptyProps\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CommandEmptyProps extends React.HTMLAttributes<HTMLDivElement> {}\n\nconst CommandEmpty = React.forwardRef<HTMLDivElement, CommandEmptyProps>(\n ({ className, children = \"결과가 없습니다.\", ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\n \"py-8 text-center text-sm text-gray-500 dark:text-gray-400\", // 32px 패딩\n className\n )}\n {...props}\n >\n {children}\n </div>\n )\n)\nCommandEmpty.displayName = \"CommandEmpty\"\n\n// 편의 컴포넌트들\nexport const CommandDialog = React.forwardRef<HTMLDivElement, CommandProps>(\n ({ className, ...props }, ref) => (\n <Command ref={ref} className={className} {...props} />\n )\n)\nCommandDialog.displayName = \"CommandDialog\"\n\nexport { Command, CommandInput, CommandList, CommandItem, CommandGroup, CommandSeparator, CommandEmpty } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * ScrollArea 컴포넌트의 props / ScrollArea component props\n * @typedef {Object} ScrollAreaProps\n * @property {React.ReactNode} children - 스크롤 영역 내용 / Scroll area content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {\"vertical\" | \"horizontal\" | \"both\"} [orientation=\"vertical\"] - 스크롤 방향 / Scroll direction\n * @property {number} [scrollHideDelay=600] - 스크롤바 숨김 지연 시간 (ms) / Scrollbar hide delay (ms)\n * @property {\"auto\" | \"always\" | \"scroll\" | \"hover\"} [type=\"hover\"] - 스크롤바 표시 타입 / Scrollbar display type\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\ninterface ScrollAreaProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n className?: string\n orientation?: \"vertical\" | \"horizontal\" | \"both\"\n scrollHideDelay?: number\n type?: \"auto\" | \"always\" | \"scroll\" | \"hover\"\n}\n\n/**\n * ScrollArea 컴포넌트 / ScrollArea component\n * \n * 커스텀 스크롤바를 가진 스크롤 영역 컴포넌트입니다.\n * 호버 시 스크롤바를 표시하거나 항상 표시할 수 있습니다.\n * \n * Scroll area component with custom scrollbar.\n * Can display scrollbar on hover or always.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <ScrollArea className=\"h-64\">\n * <div>긴 내용...</div>\n * </ScrollArea>\n * \n * @example\n * // 가로 스크롤, 항상 표시 / Horizontal scroll, always visible\n * <ScrollArea orientation=\"horizontal\" type=\"always\">\n * <div className=\"flex space-x-4\">...</div>\n * </ScrollArea>\n * \n * @param {ScrollAreaProps} props - ScrollArea 컴포넌트의 props / ScrollArea component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} ScrollArea 컴포넌트 / ScrollArea component\n */\nconst ScrollArea = React.forwardRef<HTMLDivElement, ScrollAreaProps>(\n ({ \n children, \n className, \n orientation = \"vertical\",\n scrollHideDelay = 600,\n type = \"hover\",\n ...props \n }, ref) => {\n const [showScrollbar, setShowScrollbar] = React.useState(false)\n const timeoutRef = React.useRef<ReturnType<typeof setTimeout> | undefined>(undefined)\n\n const handleMouseEnter = () => {\n if (type === \"hover\" || type === \"always\") {\n setShowScrollbar(true)\n }\n }\n\n const handleMouseLeave = () => {\n if (type === \"hover\") {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current)\n }\n timeoutRef.current = setTimeout(() => {\n setShowScrollbar(false)\n }, scrollHideDelay)\n }\n }\n\n React.useEffect(() => {\n if (type === \"always\") {\n setShowScrollbar(true)\n }\n }, [type])\n\n React.useEffect(() => {\n return () => {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current)\n }\n }\n }, [])\n\n return (\n <div\n ref={ref}\n className={merge(\n \"relative overflow-auto scrollbar-thin\",\n orientation === \"vertical\" && \"overflow-y-auto overflow-x-hidden\",\n orientation === \"horizontal\" && \"overflow-x-auto overflow-y-hidden\",\n orientation === \"both\" && \"overflow-auto\",\n showScrollbar ? \"scrollbar-visible\" : \"scrollbar-hidden\",\n className\n )}\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n {...props}\n >\n {children}\n </div>\n )\n }\n)\n\nScrollArea.displayName = \"ScrollArea\"\n\n/**\n * ScrollBar 컴포넌트의 props / ScrollBar component props\n * @typedef {Object} ScrollBarProps\n * @property {\"vertical\" | \"horizontal\"} [orientation=\"vertical\"] - 스크롤바 방향 / Scrollbar direction\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n */\ninterface ScrollBarProps {\n orientation?: \"vertical\" | \"horizontal\"\n className?: string\n}\n\n/**\n * ScrollBar 컴포넌트 / ScrollBar component\n * 커스텀 스크롤바를 표시합니다.\n * Displays a custom scrollbar.\n * \n * @component\n * @param {ScrollBarProps} props - ScrollBar 컴포넌트의 props / ScrollBar component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} ScrollBar 컴포넌트 / ScrollBar component\n */\nconst ScrollBar = React.forwardRef<HTMLDivElement, ScrollBarProps>(\n ({ orientation = \"vertical\", className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n className={merge(\n \"flex touch-none select-none transition-colors duration-150 ease-out\",\n orientation === \"vertical\" && \"h-full w-2.5 border-l border-l-transparent p-[1px]\",\n orientation === \"horizontal\" && \"h-2.5 flex-col border-t border-t-transparent p-[1px]\",\n className\n )}\n {...props}\n />\n )\n }\n)\n\nScrollBar.displayName = \"ScrollBar\"\n\nexport { ScrollArea, ScrollBar } ","import { useEffect, useState } from \"react\"\n\ninterface ScrollToggleOptions {\n threshold?: number\n showOnMount?: boolean\n smooth?: boolean\n}\n\nexport function useScrollToggle(options: ScrollToggleOptions = {}) {\n const {\n threshold = 400,\n showOnMount = false,\n smooth = true,\n } = options\n\n const [isVisible, setIsVisible] = useState(showOnMount)\n const [mounted, setMounted] = useState(false)\n\n useEffect(() => {\n setMounted(true)\n }, [])\n\n useEffect(() => {\n if (!mounted) return\n\n const toggleVisibility = () => {\n if (typeof window === \"undefined\") return\n setIsVisible(window.pageYOffset > threshold)\n }\n\n toggleVisibility()\n window.addEventListener(\"scroll\", toggleVisibility, { passive: true })\n window.addEventListener(\"resize\", toggleVisibility, { passive: true })\n\n return () => {\n window.removeEventListener(\"scroll\", toggleVisibility)\n window.removeEventListener(\"resize\", toggleVisibility)\n }\n }, [threshold, mounted])\n\n const scrollToTop = () => {\n if (typeof window === \"undefined\") return\n if (smooth) {\n window.scrollTo({ top: 0, behavior: \"smooth\" })\n } else {\n window.scrollTo(0, 0)\n }\n }\n\n return {\n isVisible,\n scrollToTop,\n mounted,\n }\n}\n\n","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\nimport { IconName } from \"../lib/icons\"\nimport { useScrollToggle } from \"../hooks/useScrollToggle\"\n\n/**\n * ScrollToTop 컴포넌트의 props / ScrollToTop component props\n * @typedef {Object} ScrollToTopProps\n * @property {number} [threshold=400] - 표시 임계값 (px, 이 값 이상 스크롤 시 표시) / Display threshold (px, shows when scrolled beyond this value)\n * @property {boolean} [smooth=true] - 부드러운 스크롤 여부 / Smooth scroll\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {IconName} [icon='arrowUp'] - 아이콘 이름 / Icon name\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - 버튼 크기 / Button size\n * @property {\"default\" | \"primary\" | \"secondary\" | \"outline\" | \"ghost\"} [variant=\"default\"] - 버튼 스타일 변형 / Button style variant\n * @property {boolean} [showOnMount=false] - 마운트 시 즉시 표시 여부 / Show immediately on mount\n * @extends {React.HTMLAttributes<HTMLButtonElement>}\n */\nexport interface ScrollToTopProps extends React.HTMLAttributes<HTMLButtonElement> {\n threshold?: number\n smooth?: boolean\n className?: string\n icon?: IconName\n size?: \"sm\" | \"md\" | \"lg\"\n variant?: \"default\" | \"primary\" | \"secondary\" | \"outline\" | \"ghost\"\n showOnMount?: boolean\n}\n\n/**\n * ScrollToTop 컴포넌트 / ScrollToTop component\n * \n * 페이지 상단으로 스크롤하는 버튼 컴포넌트입니다.\n * 지정된 임계값 이상 스크롤 시 자동으로 표시됩니다.\n * \n * Button component that scrolls to top of page.\n * Automatically appears when scrolled beyond specified threshold.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <ScrollToTop />\n * \n * @example\n * // 커스텀 설정 / Custom settings\n * <ScrollToTop \n * threshold={500}\n * variant=\"primary\"\n * size=\"lg\"\n * icon=\"arrowUp\"\n * />\n * \n * @param {ScrollToTopProps} props - ScrollToTop 컴포넌트의 props / ScrollToTop component props\n * @returns {JSX.Element} ScrollToTop 컴포넌트 / ScrollToTop component\n */\nconst ScrollToTop = ({ \n className, \n threshold = 400, \n smooth = true, \n icon = \"arrowUp\",\n size = \"md\",\n variant = \"default\",\n showOnMount = false,\n ...props \n}: ScrollToTopProps) => {\n // HUA Motion의 useScrollToggle 훅 사용\n const { isVisible, scrollToTop, mounted } = useScrollToggle({\n threshold,\n showOnMount,\n smooth\n })\n\n const sizeClasses = {\n sm: \"w-8 h-8 sm:w-10 sm:h-10\",\n md: \"w-10 h-10 sm:w-12 sm:h-12\", \n lg: \"w-12 h-12 sm:w-14 sm:h-14\"\n }\n\n\n\n const variantClasses = {\n default: \"bg-white/20 backdrop-blur-md border border-white/30 text-white hover:bg-white/30 hover:shadow-lg hover:shadow-black/20 dark:bg-slate-800/20 dark:border-slate-700/50 dark:text-slate-100 dark:hover:bg-slate-700/30\",\n primary: \"bg-blue-600/70 backdrop-blur-md border border-blue-500/40 text-white hover:bg-blue-500/80 hover:shadow-xl hover:shadow-blue-500/50 hover:scale-105 transition-all duration-300 dark:bg-blue-500/70 dark:border-blue-400/40 dark:hover:bg-blue-400/80 dark:hover:shadow-blue-400/50\",\n secondary: \"bg-slate-100/60 backdrop-blur-md border border-slate-200/50 text-slate-700 hover:bg-slate-200/70 hover:shadow-lg dark:bg-slate-700/30 dark:border-slate-600/50 dark:text-slate-200 dark:hover:bg-slate-600/40\",\n outline: \"border border-white/40 bg-white/15 backdrop-blur-md text-white hover:bg-white/25 hover:shadow-lg dark:border-slate-600/50 dark:bg-slate-800/15 dark:text-slate-200 dark:hover:bg-slate-700/25\",\n ghost: \"bg-transparent hover:bg-white/15 backdrop-blur-md text-white hover:shadow-lg dark:text-slate-200 dark:hover:bg-slate-700/25\"\n }\n\n return (\n <button\n onClick={scrollToTop}\n className={merge(\n \"fixed z-[9999] rounded-full transition-all duration-500 ease-in-out\",\n \"flex items-center justify-center\",\n \"focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-blue-500\",\n \"transform hover:scale-110 active:scale-95 shadow-lg\",\n // 페이드 애니메이션\n isVisible \n ? \"opacity-100 translate-y-0 pointer-events-auto\" \n : \"opacity-0 translate-y-4 pointer-events-none\",\n className,\n sizeClasses[size],\n variantClasses[variant]\n )}\n aria-label=\"Scroll to top\"\n {...props}\n >\n <Icon name={icon} className=\"w-5 h-5\" />\n </button>\n )\n}\n\nexport { ScrollToTop } ","\"use client\"\n\nimport React, { createContext, useContext, useEffect, useState } from \"react\"\n\ntype Theme = \"light\" | \"dark\" | \"system\"\n\n/**\n * ThemeProvider 컴포넌트의 props / ThemeProvider component props\n * @typedef {Object} ThemeProviderProps\n * @property {React.ReactNode} children - 자식 컴포넌트 / Child components\n * @property {\"light\" | \"dark\" | \"system\"} [defaultTheme=\"light\"] - 기본 테마 / Default theme\n * @property {string} [storageKey=\"hua-ui-theme\"] - localStorage 키 / localStorage key\n * @property {boolean} [enableSystem=true] - 시스템 테마 감지 활성화 / Enable system theme detection\n * @property {boolean} [enableTransition=true] - 테마 전환 애니메이션 활성화 / Enable theme transition animation\n */\ninterface ThemeProviderProps {\n children: React.ReactNode\n defaultTheme?: Theme\n storageKey?: string\n enableSystem?: boolean\n enableTransition?: boolean\n}\n\n/**\n * ThemeProvider의 상태 타입 / ThemeProvider state type\n * @typedef {Object} ThemeProviderState\n * @property {\"light\" | \"dark\" | \"system\"} theme - 현재 테마 / Current theme\n * @property {(theme: \"light\" | \"dark\" | \"system\") => void} setTheme - 테마 설정 함수 / Theme setter function\n * @property {\"light\" | \"dark\"} resolvedTheme - 실제 적용된 테마 (system일 경우 시스템 테마) / Actually applied theme (system theme when system is selected)\n * @property {() => void} toggleTheme - 테마 토글 함수 / Theme toggle function\n */\ninterface ThemeProviderState {\n theme: Theme\n setTheme: (theme: Theme) => void\n resolvedTheme: \"light\" | \"dark\"\n toggleTheme: () => void\n}\n\nconst initialState: ThemeProviderState = {\n theme: \"system\",\n setTheme: () => null,\n resolvedTheme: \"light\",\n toggleTheme: () => null,\n}\n\nconst ThemeProviderContext = createContext<ThemeProviderState>(initialState)\n\n/**\n * ThemeProvider 컴포넌트 / ThemeProvider component\n * \n * 테마 관리를 위한 Context Provider 컴포넌트입니다.\n * localStorage에 테마를 저장하고, 시스템 테마를 감지할 수 있습니다.\n * useTheme 훅을 통해 테마 상태에 접근할 수 있습니다.\n * \n * Context Provider component for theme management.\n * Saves theme to localStorage and can detect system theme.\n * Access theme state through useTheme hook.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <ThemeProvider>\n * <App />\n * </ThemeProvider>\n * \n * @example\n * // 커스텀 설정 / Custom settings\n * <ThemeProvider\n * defaultTheme=\"dark\"\n * storageKey=\"my-app-theme\"\n * enableSystem={true}\n * enableTransition={true}\n * >\n * <App />\n * </ThemeProvider>\n * \n * @param {ThemeProviderProps} props - ThemeProvider 컴포넌트의 props / ThemeProvider component props\n * @returns {JSX.Element} ThemeProvider 컴포넌트 / ThemeProvider component\n */\nexport function ThemeProvider({\n children,\n defaultTheme = \"light\", // system에서 light로 변경\n storageKey = \"hua-ui-theme\",\n enableSystem = true,\n enableTransition = true,\n ...props\n}: ThemeProviderProps): React.ReactElement {\n const [theme, setTheme] = useState<Theme>(defaultTheme)\n const [resolvedTheme, setResolvedTheme] = useState<\"light\" | \"dark\">(\"light\")\n\n useEffect(() => {\n // localStorage에서 테마 가져오기 (클라이언트에서만)\n if (typeof window !== 'undefined') {\n const savedTheme = localStorage.getItem(storageKey) as Theme\n if (savedTheme) {\n setTheme(savedTheme)\n }\n }\n }, [storageKey])\n\n useEffect(() => {\n const root = window.document.documentElement\n\n root.classList.remove(\"light\", \"dark\")\n\n if (theme === \"system\" && enableSystem) {\n const systemTheme = window.matchMedia(\"(prefers-color-scheme: dark)\")\n .matches\n ? \"dark\"\n : \"light\"\n\n root.classList.add(systemTheme)\n setResolvedTheme(systemTheme)\n } else {\n root.classList.add(theme)\n setResolvedTheme(theme as \"light\" | \"dark\")\n }\n\n if (enableTransition) {\n root.classList.add(\"transition-colors\", \"duration-300\")\n }\n }, [theme, enableSystem, enableTransition])\n\n useEffect(() => {\n if (theme === \"system\" && enableSystem) {\n const mediaQuery = window.matchMedia(\"(prefers-color-scheme: dark)\")\n\n const handleChange = () => {\n const systemTheme = mediaQuery.matches ? \"dark\" : \"light\"\n setResolvedTheme(systemTheme)\n document.documentElement.classList.remove(\"light\", \"dark\")\n document.documentElement.classList.add(systemTheme)\n }\n\n mediaQuery.addEventListener(\"change\", handleChange)\n return () => mediaQuery.removeEventListener(\"change\", handleChange)\n }\n }, [theme, enableSystem])\n\n const value = {\n theme,\n setTheme: (theme: Theme) => {\n if (typeof window !== 'undefined') {\n localStorage.setItem(storageKey, theme)\n }\n setTheme(theme)\n },\n resolvedTheme,\n toggleTheme: () => {\n const newTheme = theme === \"light\" ? \"dark\" : \"light\"\n setTheme(newTheme)\n },\n }\n\n return (\n <ThemeProviderContext.Provider {...props} value={value}>\n {children}\n </ThemeProviderContext.Provider>\n )\n}\n\n/**\n * useTheme 훅 / useTheme hook\n * \n * ThemeProvider의 테마 상태에 접근하는 훅입니다.\n * ThemeProvider 내부에서만 사용할 수 있습니다.\n * \n * Hook to access ThemeProvider's theme state.\n * Can only be used inside ThemeProvider.\n * \n * @example\n * const { theme, setTheme, resolvedTheme, toggleTheme } = useTheme()\n * \n * @returns {ThemeProviderState} 테마 상태와 함수들 / Theme state and functions\n * @throws {Error} ThemeProvider 외부에서 사용 시 에러 발생 / Error when used outside ThemeProvider\n */\nexport const useTheme = () => {\n const context = useContext(ThemeProviderContext)\n\n if (context === undefined)\n throw new Error(\"useTheme must be used within a ThemeProvider\")\n\n return context\n} ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\nimport { useTheme } from \"./ThemeProvider\"\n\n/**\n * ThemeToggle 컴포넌트의 props / ThemeToggle component props\n * @typedef {Object} ThemeToggleProps\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Toggle 크기 / Toggle size\n * @property {\"button\" | \"icon\" | \"switch\"} [variant=\"button\"] - Toggle 스타일 변형 / Toggle style variant\n * @property {boolean} [showLabel=false] - 라벨 표시 여부 / Show label\n * @property {Object} [label] - 커스텀 라벨 텍스트 / Custom label text\n * @property {string} [label.light=\"라이트\"] - 라이트 모드 라벨 / Light mode label\n * @property {string} [label.dark=\"다크\"] - 다크 모드 라벨 / Dark mode label\n * @property {string} [label.system=\"시스템\"] - 시스템 모드 라벨 / System mode label\n */\ninterface ThemeToggleProps {\n className?: string\n size?: \"sm\" | \"md\" | \"lg\"\n variant?: \"button\" | \"icon\" | \"switch\"\n showLabel?: boolean\n label?: {\n light?: string\n dark?: string\n system?: string\n }\n}\n\n/**\n * ThemeToggle 컴포넌트 / ThemeToggle component\n * \n * 테마를 전환하는 토글 컴포넌트입니다.\n * ThemeProvider와 함께 사용하며, light/dark/system 테마를 지원합니다.\n * \n * Toggle component for switching themes.\n * Used with ThemeProvider, supports light/dark/system themes.\n * \n * @component\n * @example\n * // 기본 사용 (버튼 스타일) / Basic usage (button style)\n * <ThemeToggle />\n * \n * @example\n * // 아이콘만 표시 / Icon only\n * <ThemeToggle variant=\"icon\" size=\"lg\" />\n * \n * @example\n * // Switch 스타일 / Switch style\n * <ThemeToggle variant=\"switch\" />\n * \n * @example\n * // 라벨과 함께 / With label\n * <ThemeToggle \n * showLabel\n * label={{ light: \"밝게\", dark: \"어둡게\" }}\n * />\n * \n * @param {ThemeToggleProps} props - ThemeToggle 컴포넌트의 props / ThemeToggle component props\n * @returns {JSX.Element} ThemeToggle 컴포넌트 / ThemeToggle component\n */\nexport function ThemeToggle({\n className,\n size = \"md\",\n variant = \"button\",\n showLabel = false,\n label = {\n light: \"라이트\",\n dark: \"다크\",\n system: \"시스템\"\n },\n ...props\n}: ThemeToggleProps) {\n const { theme, setTheme, resolvedTheme } = useTheme()\n\n const sizeClasses = {\n sm: \"h-10 w-10\", // 40px - 더 넉넉한 크기\n md: \"h-12 w-12\", // 48px - 더 넉넉한 크기\n lg: \"h-14 w-14\" // 56px - 더 넉넉한 크기\n }\n\n const iconSizes = {\n sm: 16,\n md: 20,\n lg: 24\n }\n\n const renderIcon = () => {\n if (theme === \"system\") {\n return <Icon name=\"monitor\" size={iconSizes[size]} />\n }\n return resolvedTheme === \"dark\" ? (\n <Icon name=\"moon\" size={iconSizes[size]} />\n ) : (\n <Icon name=\"sun\" size={iconSizes[size]} className=\"text-amber-600\" />\n )\n }\n\n const handleClick = () => {\n if (theme === \"system\") {\n setTheme(\"light\")\n } else if (theme === \"light\") {\n setTheme(\"dark\")\n } else if (theme === \"dark\") {\n setTheme(\"light\") // dark → light로 직접 전환\n }\n }\n\n if (variant === \"icon\") {\n return (\n <button\n onClick={handleClick}\n className={merge(\n \"inline-flex items-center justify-center rounded-lg transition-all duration-300 hover:bg-gray-100 dark:hover:bg-gray-800 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-blue-500/50 focus-visible:ring-offset-2\",\n sizeClasses[size],\n className\n )}\n {...props}\n >\n <div className=\"relative flex items-center justify-center w-full h-full\">\n <div\n className={merge(\n \"absolute inset-0 flex items-center justify-center transition-all duration-300\",\n resolvedTheme === \"dark\" ? \"rotate-0 opacity-100\" : \"rotate-90 opacity-0\"\n )}\n >\n <Icon name=\"moon\" size={iconSizes[size]} className=\"text-blue-500\" />\n </div>\n <div\n className={merge(\n \"absolute inset-0 flex items-center justify-center transition-all duration-300\",\n resolvedTheme === \"dark\" ? \"rotate-90 opacity-0\" : \"rotate-0 opacity-100\"\n )}\n >\n <Icon name=\"sun\" size={iconSizes[size]} className=\"text-amber-600 dark:text-yellow-500\" />\n </div>\n </div>\n </button>\n )\n }\n\n if (variant === \"switch\") {\n return (\n <button\n onClick={handleClick}\n className={merge(\n \"relative inline-flex h-6 w-11 items-center rounded-full transition-colors duration-300 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-blue-500/50 focus-visible:ring-offset-2\",\n resolvedTheme === \"dark\" \n ? \"bg-blue-600\" \n : \"bg-gray-200 dark:bg-gray-700\",\n className\n )}\n {...props}\n >\n <span\n className={merge(\n \"inline-block h-4 w-4 transform rounded-full bg-white transition-transform duration-300 shadow-lg\",\n resolvedTheme === \"dark\" ? \"translate-x-6\" : \"translate-x-1\"\n )}\n />\n <div className=\"absolute inset-0 flex items-center justify-between px-1.5\">\n <Icon name=\"sun\" size={12} className=\"text-amber-600 dark:text-yellow-500 opacity-0\" />\n <Icon name=\"moon\" size={12} className=\"text-blue-500 opacity-0\" />\n </div>\n </button>\n )\n }\n\n return (\n <button\n onClick={handleClick}\n className={merge(\n \"inline-flex items-center gap-3 rounded-lg px-4 py-3 text-sm font-medium transition-all duration-300 hover:bg-gray-100 dark:hover:bg-gray-800 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-blue-500/50 focus-visible:ring-offset-2\", // 12px 간격, 16px, 12px 패딩\n className\n )}\n {...props}\n >\n {renderIcon()}\n {showLabel && (\n <span>\n {theme === \"system\" ? label.system : theme === \"dark\" ? label.dark : label.light}\n </span>\n )}\n </button>\n )\n} ","/**\n * Icon Names - 자동완성 지원\n * \n * 이 파일은 TypeScript 자동완성을 위한 아이콘 이름 목록입니다.\n * 실제 아이콘은 icons.ts와 PROJECT_ICONS에서 관리됩니다.\n */\n\nimport type { IconName } from './icons'\nimport { PROJECT_ICONS } from './icon-providers'\n\n/**\n * PROJECT_ICONS에 정의된 모든 아이콘 이름\n */\nexport type ProjectIconName = keyof typeof PROJECT_ICONS\n\n/**\n * 사용 가능한 모든 아이콘 이름 (icons.ts + PROJECT_ICONS)\n */\nexport type AllIconName = IconName | ProjectIconName\n\n/**\n * 아이콘 이름 목록 (자동완성용)\n */\nexport const iconNames = [\n // Navigation\n 'home', 'menu', 'close', 'search', 'settings', 'user', 'bell',\n 'arrowLeft', 'arrowRight', 'arrowUp', 'arrowDown',\n 'chevronLeft', 'chevronRight', 'chevronUp', 'chevronDown',\n \n // Actions\n 'add', 'edit', 'delete', 'remove', 'check', 'share', 'download', 'upload',\n 'save', 'copy', 'refresh', 'search',\n \n // Status & Feedback\n 'loader', 'success', 'error', 'warning', 'info', 'alertCircle',\n 'heart', 'star', 'bookmark',\n \n // User & Auth\n 'logIn', 'logOut', 'shield', 'key', 'lock', 'unlock',\n 'eye', 'eyeOff', 'users', 'userPlus',\n \n // Data & Analytics\n 'chart', 'barChart', 'pieChart', 'trendingUp', 'trendingDown',\n 'activity', 'database', 'zap', 'circle', 'dollarSign', 'dollar', 'currency',\n \n // Files & Content\n 'fileText', 'file', 'folder', 'book', 'bookOpen',\n 'image', 'video', 'camera',\n \n // Communication\n 'message', 'messageSquare', 'phone', 'mail', 'send',\n \n // Media\n 'play', 'pause', 'mic', 'headphones',\n \n // Emotions\n 'smile', 'frown', 'meh', 'laugh', 'angry',\n 'thumbsUp', 'thumbsDown',\n \n // Time & Date\n 'clock', 'timer', 'calendar', 'calendarDays',\n \n // UI & Theme\n 'monitor', 'sun', 'moon', 'sparkles', 'lightbulb', 'brain',\n \n // Navigation Extended\n 'externalLink', 'link', 'moreHorizontal', 'moreVertical',\n] as const\n\n/**\n * 프로바이더별 아이콘 이름 매핑 (참고용)\n * \n * @example\n * // Lucide 아이콘 사용\n * <Icon name=\"home\" provider=\"lucide\" /> // Lucide: Home\n * \n * // Phosphor 아이콘 사용\n * <Icon name=\"home\" provider=\"phosphor\" /> // Phosphor: House\n * \n * // Untitled 아이콘 사용\n * <Icon name=\"home\" provider=\"untitled\" /> // Untitled: home\n */\nexport const iconProviderMapping: Record<string, {\n lucide: string\n phosphor: string\n untitled: string\n}> = PROJECT_ICONS\n\n/**\n * 아이콘 이름이 유효한지 확인\n */\nexport function isValidIconName(name: string): name is AllIconName {\n return name in PROJECT_ICONS || (iconNames as readonly string[]).includes(name)\n}\n\n/**\n * 프로바이더별 아이콘 이름 가져오기\n */\nexport function getIconNameForProvider(\n iconName: string,\n provider: 'lucide' | 'phosphor' | 'untitled'\n): string | null {\n const mapping = PROJECT_ICONS[iconName as keyof typeof PROJECT_ICONS]\n if (!mapping) return null\n \n return mapping[provider] || null\n}\n\n\n"]}
1
+ {"version":3,"sources":["../src/lib/utils.ts","../src/components/Button.tsx","../src/components/Action.tsx","../src/components/Input.tsx","../src/components/Link.tsx","../src/lib/icons.ts","../src/lib/icon-providers.ts","../src/lib/icon-aliases.ts","../src/components/Icon/icon-store.ts","../src/components/Icon/IconProvider.tsx","../src/components/Icon/Icon.tsx","../src/components/Avatar.tsx","../src/components/Modal.tsx","../src/components/Container.tsx","../src/components/Grid.tsx","../src/components/Stack.tsx","../src/components/Divider.tsx","../src/components/Card.tsx","../src/components/Panel.tsx","../src/components/ActionToolbar.tsx","../src/components/Breadcrumb.tsx","../src/components/ComponentLayout.tsx","../src/components/Navigation.tsx","../src/components/Pagination.tsx","../src/components/PageNavigation.tsx","../src/components/LoadingSpinner.tsx","../src/components/PageTransition.tsx","../src/components/Table.tsx","../src/components/Badge.tsx","../src/components/Progress.tsx","../src/components/Skeleton.tsx","../src/components/Alert.tsx","../src/components/Toast.tsx","../src/components/Tooltip.tsx","../src/components/Popover.tsx","../src/components/Dropdown.tsx","../src/components/Drawer.tsx","../src/components/BottomSheet.tsx","../src/components/ConfirmModal.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","../src/components/Accordion.tsx","../src/components/Tabs.tsx","../src/components/Menu.tsx","../src/components/ContextMenu.tsx","../src/components/Command.tsx","../src/components/ScrollArea.tsx","../src/hooks/useScrollToggle.ts","../src/components/ScrollToTop.tsx","../src/components/ThemeProvider.tsx","../src/components/ThemeToggle.tsx","../src/lib/icon-names.ts"],"names":["merge","inputs","twMerge","clsx","mergeIf","condition","trueClass","falseClass","formatRelativeTime","timestamp","locale","date","diff","minutes","hours","days","mergeMap","classMap","classes","className","cn","isBrowser","useReducedMotion","reduce","setReduce","React","_a","mq","onChange","ButtonInner","variant","size","loading","icon","iconPosition","gradient","customGradient","rounded","shadow","hover","fullWidth","iconOnly","children","disabled","rest","ref","reduced","variantClasses","getGradientClass","sizeClasses","roundedClasses","shadowClasses","hoverClasses","base","content","jsxs","Fragment","jsx","onClick","target","rel","href","ariaLabel","anchorClassName","anchorProps","isDisabled","handleAnchorClick","e","buttonClassName","btnProps","Button","g","Action","actionType","feedback","particleEffect","rippleEffect","soundEffect","hapticFeedback","transparency","blurIntensity","glowIntensity","glowColor","runEffects","event","AudioContextClass","audioContext","oscillator","gainNode","button","rect","x","y","ripple","style","i","particle","angle","velocity","vx","vy","styleVars","cls","anchorRest","btnRest","Input","type","props","ariaInvalid","isInvalid","Link","external","icons","Home","ArrowLeft","ArrowRight","ArrowUp","ArrowDown","Menu","X","Search","Settings","ExternalLink","ChevronLeft","ChevronRight","ChevronDown","ChevronUp","Edit","Trash2","Plus","Minus","Download","Upload","RefreshCw","Save","Copy","Loader2","CheckCircle","XCircle","AlertCircle","Info","Check","Circle","HelpCircle","User","Users","UserPlus","LogIn","LogOut","Eye","EyeOff","BarChart3","TrendingUp","Activity","Database","Zap","FileText","File","Folder","Book","BookOpen","Mail","MessageCircle","Phone","Image","Video","Camera","Smile","Frown","Meh","Lock","Unlock","Shield","Wallet","Key","Clock","Calendar","CalendarPlus","Bell","Heart","Star","Bookmark","Share","Monitor","Sun","Moon","Lightbulb","Brain","Flag","Square","emotionIcons","statusIcons","iconCategories","PhosphorIcons","PROJECT_ICONS","initPhosphorIcons","getIconFromProvider","iconName","provider","iconMapping","getIconDirect","mappedName","LucideIcons","lucideName","camelCaseName","match","p1","phosphorName1","phosphorName2","word","ICON_ALIASES","resolveIconAlias","getIconAliases","_","alias","defaultIconConfig","getDefaultStrokeWidth","set","IconContext","createContext","IconProvider","weight","color","strokeWidth","value","useIconContext","useContext","IconComponent","name","emotion","status","animated","pulse","spin","bounce","ariaHidden","config","iconSet","iconSize","iconWeight","iconColor","iconStrokeWidth","isClient","setIsClient","phosphorReady","setPhosphorReady","iconProps","animationClasses","accessibilityProps","MemoizedIcon","prevProps","nextProps","Icon","EmotionIcon","StatusIcon","LoadingIcon","SuccessIcon","ErrorIcon","Avatar","src","alt","AvatarImage","AvatarFallback","useCombinedRefs","refs","node","Modal","isOpen","onClose","showCloseButton","closeOnOverlayClick","title","description","showBackdrop","backdropClassName","centered","modalRef","combinedRef","handleEscape","scrollbarWidth","handleOverlayClick","titleId","descriptionId","Container","padding","fluid","paddingClasses","Grid","cols","gap","gapX","gapY","responsive","colsClasses","gapClasses","gapXClasses","gapYClasses","Stack","direction","spacing","align","justify","wrap","directionClasses","spacingClasses","alignClasses","justifyClasses","DividerComponent","orientation","orientationClasses","colorClasses","Divider","Card","CardHeader","CardTitle","CardDescription","CardContent","CardFooter","Panel","effect","borderOpacity","shadowOpacity","hoverEffect","animationEffect","customPadding","customRounded","background","gradientColors","patternType","backgroundImage","backgroundVideo","interactive","hoverScale","hoverRotate","hoverGlow","cardProps","styleClasses","baseClasses","effectClasses","patternBackground","backgroundStyles","styles","panelClasses","ActionToolbarComponent","isSelectMode","totalCount","selectedCount","actions","selectModeActions","onToggleSelectMode","onToggleSelectAll","onCancelSelect","getBadgeColor","useCallback","renderButton","action","key","index","ActionToolbar","Breadcrumb","items","maxItems","showHomeIcon","homeLabel","separator","variantStyles","renderedItems","displayItems","firstItem","lastItems","item","isCurrent","BreadcrumbItem","child","itemsCount","ComponentLayout","prevPage","nextPage","breadcrumbItems","Navigation","defaultValue","onValueChange","scale","activeTab","setActiveTab","isControlled","currentValue","NavigationList","getStyleClasses","getScaleClasses","NavigationItem","active","handleClick","NavigationContent","NavigationComponent","Pagination","currentPage","totalPages","onPageChange","showFirstLast","showPrevNext","maxVisiblePages","shape","getVisiblePages","pages","halfVisible","start","end","getSizeClasses","getShapeClasses","getVariantClasses","isActive","handlePageClick","page","visiblePages","PaginationOutlined","PaginationMinimal","PaginationWithInfo","totalItems","itemsPerPage","showInfo","startItem","endItem","PageNavigation","showOnMobile","LoadingSpinner","text","spinnerColors","renderSpinner","PageTransition","duration","loadingVariant","loadingText","showLoading","onTransitionStart","onTransitionEnd","isLoading","setIsLoading","useState","isVisible","setIsVisible","useEffect","timer","transitionClasses","FadeTransition","SlideTransition","ScaleTransition","FlipTransition","Table","TableHeader","TableBody","TableFooter","TableRow","TableHead","TableCell","TableCaption","Badge","Progress","max","showValue","striped","label","percentage","getStripedClasses","ProgressSuccess","ProgressWarning","ProgressError","ProgressInfo","ProgressWrapper","ProgressGroup","Skeleton","width","height","animation","getAnimationClasses","defaultDims","finalWidth","finalHeight","SkeletonText","SkeletonCircle","SkeletonRectangle","SkeletonRounded","SkeletonCard","SkeletonAvatar","SkeletonImage","SkeletonUserProfile","SkeletonList","SkeletonTable","Alert","closable","getIconClasses","getDefaultIcon","AlertSuccess","AlertWarning","AlertError","AlertInfo","ToastContext","useToast","context","ToastProvider","maxToasts","position","toasts","setToasts","removeToast","id","prev","toast","addToast","newToast","clearToasts","ToastContainer","positionClasses","ToastItem","onRemove","handleRemove","getToastStyles","getIconStyles","getToastIcon","Tooltip","delay","coords","setCoords","timeoutRef","tooltipRef","showTooltip","tooltipRect","hideTooltip","getArrowClasses","TooltipLight","TooltipDark","Popover","trigger","controlledOpen","onOpenChange","offset","internalOpen","setInternalOpen","triggerRef","popoverRef","handleOpenChange","newOpen","handleTriggerClick","handleClickOutside","getPositionClasses","getAlignmentClasses","PopoverTrigger","PopoverContent","Dropdown","placement","showArrow","dropdownRef","updatePosition","triggerRect","dropdownRect","viewportWidth","viewportHeight","getPlacementClasses","DropdownItem","DropdownSeparator","DropdownLabel","DropdownMenu","DropdownGroup","Drawer","open","side","closeOnBackdropClick","closeOnEscape","isAnimating","setIsAnimating","sideClasses","transformClasses","DrawerHeader","DrawerContent","DrawerFooter","BottomSheet","showDragHandle","snapPoints","defaultSnap","currentHeight","setCurrentHeight","isDragging","setIsDragging","startY","setStartY","currentY","setCurrentY","heightClasses","handleTouchStart","handleTouchMove","handleTouchEnd","deltaY","threshold","currentIndex","nextIndex","BottomSheetHeader","BottomSheetContent","ConfirmModal","onConfirm","message","warning","confirmText","cancelText","confirmButtonText","showInput","inputValue","onInputChange","inputPlaceholder","inputLabel","requiredInputValue","showCancel","Form","onSubmit","FormField","error","required","errorId","enhancedChildren","childProps","childType","isFormComponent","typeObj","displayName","isNativeFormElement","existingAriaDescribedBy","ariaDescribedBy","FormGroup","inline","Label","Checkbox","success","checkboxId","labelId","iconSizes","stateClasses","isChecked","Radio","radioId","dotSizes","Select","leftIcon","placeholder","selectRef","isFocused","setIsFocused","SelectOption","Switch","switchId","thumbSizes","Slider","showLabel","min","step","isRange","handleChange","newValue","newRange","thumbVariantClasses","thumbSizeClasses","renderSlider","renderValue","val","Textarea","resize","resizeClasses","formatDate","format","year","month","day","getDaysInMonth","getFirstDayOfMonth","DatePicker","minDate","maxDate","dateFormat","setIsOpen","currentMonth","setCurrentMonth","hoveredDate","setHoveredDate","displayDate","handleDateSelect","handlePrevMonth","handleNextMonth","handleToday","today","daysInMonth","firstDay","weekDays","isDateDisabled","isDateSelected","isToday","calendarDays","remainingDays","triggerButton","isCurrentMonth","isSelected","isTodayDate","isHovered","formatFileSize","bytes","k","sizes","getFileIcon","files","multiple","accept","maxSize","maxFiles","dragDrop","fileInputRef","handleFileSelect","selectedFiles","fileArray","validFiles","file","handleDragOver","handleDragLeave","handleDrop","Autocomplete","options","maxHeight","clearable","filterable","onSearch","emptyText","setInputValue","filteredOptions","setFilteredOptions","selectedIndex","setSelectedIndex","isSearching","setIsSearching","inputRef","selectedOption","opt","result","filtered","option","handleInputChange","handleInputFocus","handleInputBlur","handleOptionSelect","handleClear","handleKeyDown","isValueSelected","Accordion","collapsible","openItems","setOpenItems","handleItemToggle","itemValue","newOpenItems","itemValues","values","newIndex","triggerElement","AccordionItem","onToggle","AccordionTrigger","defaultIcon","contentId","triggerId","AccordionContent","dataValue","setHeight","contentRef","TabsContent","Tabs","handleTabChange","TabsList","listRef","tabValues","TabsTrigger","TabsPills","TabsUnderline","TabsCards","MenuItem","MenuSeparator","MenuLabel","MenuHorizontal","MenuVertical","MenuCompact","ContextMenu","menuRef","handleContextMenu","menuRect","ContextMenuItem","ContextMenuSeparator","ContextMenuLabel","ContextMenuGroup","Command","controlledSearchValue","onSearchChange","internalSearchValue","setInternalSearchValue","commandRef","searchValue","handleSearchChange","itemCount","selectedItem","_b","CommandInput","CommandList","CommandItem","selected","onSelect","CommandGroup","heading","CommandSeparator","CommandEmpty","CommandDialog","ScrollArea","scrollHideDelay","showScrollbar","setShowScrollbar","handleMouseEnter","handleMouseLeave","ScrollBar","useScrollToggle","showOnMount","smooth","mounted","setMounted","toggleVisibility","ScrollToTop","scrollToTop","initialState","ThemeProviderContext","ThemeProvider","defaultTheme","storageKey","enableSystem","enableTransition","theme","setTheme","resolvedTheme","setResolvedTheme","savedTheme","root","systemTheme","mediaQuery","useTheme","ThemeToggle","renderIcon","iconNames","iconProviderMapping","isValidIconName","getIconNameForProvider","mapping"],"mappings":"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","file":"index.js","sourcesContent":["import { type ClassValue, clsx } from \"clsx\"\nimport { twMerge } from \"tailwind-merge\"\n\n/**\n * HUA UI의 스마트 클래스 병합 유틸리티\n * clsx와 tailwind-merge를 결합하여 중복 클래스를 자동으로 해결합니다.\n * \n * @param inputs - 병합할 클래스 값들\n * @returns 병합된 클래스 문자열\n * \n * @example\n * ```tsx\n * merge(\"px-2 py-1\", \"px-4\") // \"py-1 px-4\"\n * merge(\"text-red-500\", \"text-blue-500\") // \"text-blue-500\"\n * merge(\"bg-white\", \"dark:bg-slate-900\") // \"bg-white dark:bg-slate-900\"\n * ```\n */\nexport function merge(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs))\n}\n\n/**\n * 조건부 클래스 병합 유틸리티\n * 조건에 따라 클래스를 선택적으로 병합합니다.\n * \n * @param condition - 클래스를 적용할 조건\n * @param trueClass - 조건이 true일 때 적용할 클래스\n * @param falseClass - 조건이 false일 때 적용할 클래스 (선택사항)\n * @returns 병합된 클래스 문자열\n * \n * @example\n * ```tsx\n * mergeIf(isActive, \"bg-blue-500\", \"bg-gray-200\")\n * mergeIf(isLoading, \"opacity-50 cursor-not-allowed\")\n * ```\n */\nexport function mergeIf(\n condition: boolean,\n trueClass: ClassValue,\n falseClass?: ClassValue\n) {\n return merge(condition ? trueClass : falseClass || \"\")\n}\n\n/**\n * 상대 시간 포맷팅 유틸리티\n * \n * 날짜를 상대 시간 형식으로 포맷팅합니다 (예: \"방금 전\", \"5분 전\", \"2시간 전\", \"3일 전\").\n * 7일 이상 경과한 경우 절대 날짜를 반환합니다.\n * \n * Formats a date as relative time (e.g., \"방금 전\", \"5분 전\", \"2시간 전\", \"3일 전\").\n * Returns absolute date for dates older than 7 days.\n * \n * @param timestamp - 포맷팅할 날짜 (Date 객체 또는 ISO 문자열) / Date to format (Date object or ISO string)\n * @param locale - 로케일 (기본값: \"ko-KR\") / Locale (default: \"ko-KR\")\n * @returns 포맷팅된 상대 시간 문자열 / Formatted relative time string\n * \n * @example\n * ```tsx\n * formatRelativeTime(new Date()) // \"방금 전\"\n * formatRelativeTime(new Date(Date.now() - 5 * 60000)) // \"5분 전\"\n * formatRelativeTime(new Date(Date.now() - 2 * 3600000)) // \"2시간 전\"\n * formatRelativeTime(new Date(Date.now() - 3 * 86400000)) // \"3일 전\"\n * formatRelativeTime(new Date(\"2024-01-01\")) // \"2024. 1. 1.\" (7일 이상 경과)\n * ```\n */\nexport function formatRelativeTime(timestamp: Date | string, locale = \"ko-KR\"): string {\n const date = typeof timestamp === \"string\" ? new Date(timestamp) : timestamp;\n const now = new Date();\n const diff = now.getTime() - date.getTime();\n const minutes = Math.floor(diff / 60000);\n const hours = Math.floor(diff / 3600000);\n const days = Math.floor(diff / 86400000);\n\n if (minutes < 1) return locale === \"ko-KR\" ? \"방금 전\" : \"just now\";\n if (minutes < 60) return locale === \"ko-KR\" ? `${minutes}분 전` : `${minutes}m ago`;\n if (hours < 24) return locale === \"ko-KR\" ? `${hours}시간 전` : `${hours}h ago`;\n if (days < 7) return locale === \"ko-KR\" ? `${days}일 전` : `${days}d ago`;\n return date.toLocaleDateString(locale);\n}\n\n/**\n * 객체 기반 클래스 병합 유틸리티\n * 객체의 키-값 쌍을 기반으로 조건부 클래스를 병합합니다.\n * \n * @param classMap - 클래스 맵 객체\n * @returns 병합된 클래스 문자열\n * \n * @example\n * ```tsx\n * mergeMap({\n * \"bg-blue-500\": isPrimary,\n * \"bg-gray-500\": !isPrimary,\n * \"text-white\": true,\n * \"opacity-50\": isDisabled\n * })\n * ```\n */\nexport function mergeMap(classMap: Record<string, boolean | undefined | null>) {\n const classes = Object.entries(classMap)\n .filter(([, condition]) => condition)\n .map(([className]) => className)\n \n return merge(...classes)\n}\n\n// 하위 호환성을 위해 cn도 export (점진적 마이그레이션 지원)\nexport const cn = merge ","\"use client\";\n\nimport React from \"react\";\nimport { merge } from \"../lib/utils\";\n\n/**\n * 버튼 스타일 변형 / Button style variant\n * @typedef {\"default\" | \"destructive\" | \"outline\" | \"secondary\" | \"ghost\" | \"link\" | \"gradient\" | \"neon\" | \"glass\"} Variant\n */\ntype Variant =\n | \"default\" | \"destructive\" | \"outline\" | \"secondary\"\n | \"ghost\" | \"link\" | \"gradient\" | \"neon\" | \"glass\";\n\n/**\n * 버튼 크기 / Button size\n * @typedef {\"sm\" | \"md\" | \"lg\" | \"xl\" | \"icon\"} Size\n */\ntype Size = \"sm\" | \"md\" | \"lg\" | \"xl\" | \"icon\";\n\n/**\n * 버튼 모서리 둥글기 / Button border radius\n * @typedef {\"sm\" | \"md\" | \"lg\" | \"full\"} Rounded\n */\ntype Rounded = \"sm\" | \"md\" | \"lg\" | \"full\";\n\n/**\n * 버튼 그림자 / Button shadow\n * @typedef {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"} Shadow\n */\ntype Shadow = \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\";\n\n/**\n * 버튼 호버 효과 / Button hover effect\n * @typedef {\"scale\" | \"glow\" | \"slide\" | \"none\"} Hover\n */\ntype Hover = \"scale\" | \"glow\" | \"slide\" | \"none\";\n\n/**\n * 그라디언트 색상 이름 / Gradient color name\n * @typedef {\"blue\" | \"purple\" | \"green\" | \"orange\" | \"pink\" | \"custom\"} GradientName\n */\ntype GradientName = \"blue\" | \"purple\" | \"green\" | \"orange\" | \"pink\" | \"custom\";\n\n/**\n * Button 컴포넌트의 공통 props / Common props for Button component\n * @typedef {Object} CommonProps\n * @property {Variant} [variant=\"default\"] - 버튼 스타일 변형 / Button style variant\n * @property {Size} [size=\"md\"] - 버튼 크기 / Button size\n * @property {boolean} [loading=false] - 로딩 상태 (스피너 표시) / Loading state (shows spinner)\n * @property {React.ReactNode} [icon] - 아이콘 요소 / Icon element\n * @property {\"left\" | \"right\"} [iconPosition=\"left\"] - 아이콘 위치 / Icon position\n * @property {GradientName} [gradient=\"blue\"] - 그라디언트 색상 (variant=\"gradient\"일 때) / Gradient color (when variant=\"gradient\")\n * @property {string} [customGradient] - 커스텀 그라디언트 클래스 (variant=\"gradient\"일 때) / Custom gradient class (when variant=\"gradient\")\n * @property {Rounded} [rounded=\"md\"] - 모서리 둥글기 / Border radius\n * @property {Shadow} [shadow=\"md\"] - 그림자 크기 / Shadow size\n * @property {Hover} [hover=\"scale\"] - 호버 효과 / Hover effect\n * @property {boolean} [fullWidth=false] - 전체 너비 사용 / Use full width\n * @property {boolean} [iconOnly=false] - 아이콘만 표시 (aria-label 필수) / Icon only (aria-label required)\n * @property {string} [aria-label] - 접근성을 위한 레이블 (iconOnly일 때 필수) / Accessibility label (required when iconOnly)\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {boolean} [disabled=false] - 비활성화 상태 / Disabled state\n */\ntype CommonProps = {\n variant?: Variant;\n size?: Size;\n loading?: boolean;\n icon?: React.ReactNode;\n iconPosition?: \"left\" | \"right\";\n gradient?: GradientName;\n customGradient?: string;\n rounded?: Rounded;\n shadow?: Shadow;\n hover?: Hover;\n fullWidth?: boolean;\n iconOnly?: boolean;\n \"aria-label\"?: string;\n className?: string;\n disabled?: boolean; // <-- 요놈 추가\n};\n\ntype AnchorProps = CommonProps &\n Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, \"className\"> & {\n href: string;\n };\n\ntype NativeButtonProps = CommonProps &\n Omit<React.ButtonHTMLAttributes<HTMLButtonElement>, \"className\" | \"type\"> & {\n href?: undefined;\n };\n\n/**\n * Button 컴포넌트의 props 타입 / Button component props type\n * href가 제공되면 앵커 태그로, 그렇지 않으면 버튼 태그로 렌더링됩니다.\n * Renders as anchor tag if href is provided, otherwise as button tag.\n * @typedef {AnchorProps | NativeButtonProps} ButtonProps\n */\nexport type ButtonProps = AnchorProps | NativeButtonProps;\n\ntype AnchorOrButton = HTMLAnchorElement | HTMLButtonElement;\n\nconst isBrowser = typeof window !== \"undefined\";\nfunction useReducedMotion() {\n const [reduce, setReduce] = React.useState(false);\n React.useEffect(() => {\n if (!isBrowser || !(\"matchMedia\" in window)) return;\n const mq = window.matchMedia(\"(prefers-reduced-motion: reduce)\");\n const onChange = () => setReduce(!!mq.matches);\n onChange();\n mq.addEventListener?.(\"change\", onChange);\n return () => mq.removeEventListener?.(\"change\", onChange);\n }, []);\n return reduce;\n}\n\n/**\n * Button 컴포넌트 / Button component\n * \n * 다양한 스타일과 크기를 지원하는 범용 버튼 컴포넌트입니다.\n * href prop을 제공하면 앵커 태그로, 그렇지 않으면 버튼 태그로 렌더링됩니다.\n * \n * Universal button component supporting various styles and sizes.\n * Renders as anchor tag if href prop is provided, otherwise as button tag.\n * \n * @component\n * @example\n * // 기본 버튼 / Basic button\n * <Button onClick={() => console.log('클릭')}>클릭하세요</Button>\n * \n * @example\n * // 다양한 변형 / Various variants\n * <Button variant=\"destructive\" size=\"lg\">삭제</Button>\n * <Button variant=\"outline\" size=\"sm\">취소</Button>\n * <Button variant=\"ghost\">보기</Button>\n * \n * @example\n * // 아이콘과 함께 사용 / With icon\n * <Button icon={<Icon name=\"download\" />} iconPosition=\"left\">\n * 다운로드\n * </Button>\n * \n * @example\n * // 로딩 상태 / Loading state\n * <Button loading disabled>저장 중...</Button>\n * \n * @example\n * // 링크 버튼 / Link button\n * <Button href=\"/about\" variant=\"link\">자세히 보기</Button>\n * \n * @example\n * // 아이콘만 표시 (aria-label 필수) / Icon only (aria-label required)\n * <Button iconOnly aria-label=\"닫기\" icon={<Icon name=\"close\" />} />\n * \n * @param {ButtonProps} props - Button 컴포넌트의 props / Button component props\n * @param {React.Ref<HTMLAnchorElement | HTMLButtonElement>} ref - ref 객체 / ref object\n * @returns {JSX.Element} Button 컴포넌트 / Button component\n */\nconst ButtonInner = React.forwardRef<AnchorOrButton, ButtonProps>(function ButtonInner(\n {\n variant = \"default\",\n size = \"md\",\n loading = false,\n icon,\n iconPosition = \"left\",\n gradient = \"blue\",\n customGradient,\n rounded = \"md\",\n shadow = \"md\",\n hover = \"scale\",\n fullWidth,\n iconOnly,\n className,\n children,\n disabled,\n ...rest\n },\n ref\n) {\n const reduced = useReducedMotion();\n\n const variantClasses: Record<Variant, string> = {\n default:\n \"bg-blue-600 text-white hover:bg-blue-700 dark:bg-blue-500 dark:hover:bg-blue-600\",\n destructive:\n \"bg-red-600 text-white hover:bg-red-700 dark:bg-red-500 dark:hover:bg-red-600\",\n outline:\n \"border-2 border-blue-600 bg-transparent text-blue-600 hover:bg-blue-50 dark:border-blue-400 dark:text-blue-400 dark:hover:bg-blue-900/20\",\n secondary:\n \"bg-gray-200 text-gray-900 hover:bg-gray-300 dark:bg-gray-700 dark:text-white dark:hover:bg-gray-600\",\n ghost:\n \"bg-transparent text-gray-700 hover:bg-gray-100 dark:text-gray-300 dark:hover:bg-gray-800\",\n link:\n \"bg-transparent text-blue-600 underline hover:text-blue-700 dark:text-blue-400 dark:hover:text-blue-300\",\n gradient: `bg-gradient-to-r ${customGradient || getGradientClass(gradient)} text-white hover:shadow-lg`,\n neon:\n \"bg-gray-900 text-cyan-400 border border-cyan-400/30 shadow-lg shadow-cyan-400/20 hover:shadow-cyan-400/40\",\n glass:\n \"bg-white/10 backdrop-blur-md border border-white/20 text-white hover:bg-white/20\",\n };\n\n const sizeClasses: Record<Size, string> = {\n sm: \"h-8 px-3 py-1 text-sm\",\n md: \"h-10 px-4 py-2 text-base\",\n lg: \"h-12 px-6 py-3 text-lg\",\n xl: \"h-14 px-8 py-4 text-xl\",\n icon: \"h-10 w-10 p-0\",\n };\n\n const roundedClasses: Record<Rounded, string> = {\n sm: \"rounded\",\n md: \"rounded-md\",\n lg: \"rounded-lg\",\n full: \"rounded-full\",\n };\n\n const shadowClasses: Record<Shadow, string> = {\n none: \"\",\n sm: \"shadow-sm\",\n md: \"shadow-md\",\n lg: \"shadow-lg\",\n xl: \"shadow-xl\",\n };\n\n const hoverClasses: Record<Hover, string> = {\n scale: reduced ? \"\" : \"hover:scale-105 transition-transform duration-200\",\n glow: reduced ? \"\" : \"hover:shadow-2xl hover:shadow-blue-500/25 dark:hover:shadow-cyan-400/25 transition-shadow duration-300\",\n slide: reduced ? \"\" : \"hover:-translate-y-1 transition-transform duration-200\",\n none: \"\",\n };\n\n // variant별 포커스 스타일\n const focusClasses: Record<Variant, string> = {\n default: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-blue-500 focus-visible:ring-offset-1\",\n destructive: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-red-500 focus-visible:ring-offset-1\",\n outline: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-blue-300 dark:focus-visible:ring-blue-600 focus-visible:ring-offset-0\",\n secondary: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-gray-400 focus-visible:ring-offset-1\",\n ghost: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-gray-300 dark:focus-visible:ring-gray-600 focus-visible:ring-offset-0\",\n link: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-blue-400 focus-visible:ring-offset-0\",\n gradient: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-blue-500 focus-visible:ring-offset-1\",\n neon: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-cyan-400 focus-visible:ring-offset-1\",\n glass: \"focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-blue-400/50 focus-visible:ring-offset-0\",\n };\n\n const base = merge(\n \"inline-flex items-center justify-center whitespace-nowrap font-medium transition-all duration-200\",\n focusClasses[variant],\n \"disabled:pointer-events-none disabled:opacity-50 min-w-fit\",\n fullWidth && \"w-full\",\n variantClasses[variant],\n sizeClasses[size],\n roundedClasses[rounded],\n shadowClasses[shadow],\n hoverClasses[hover],\n className\n );\n\n const Spinner = (\n <span role=\"status\" aria-live=\"polite\" className=\"-ml-1 mr-2 inline-flex\">\n <svg className=\"animate-spin h-4 w-4\" viewBox=\"0 0 24 24\" fill=\"none\">\n <circle className=\"opacity-25\" cx=\"12\" cy=\"12\" r=\"10\" stroke=\"currentColor\" strokeWidth=\"4\" />\n <path className=\"opacity-75\" fill=\"currentColor\" d=\"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z\" />\n </svg>\n <span className=\"sr-only\">로딩 중</span>\n </span>\n );\n\n const content = (\n <>\n {loading && Spinner}\n {!loading && icon && iconPosition === \"left\" && <span className=\"mr-2\">{icon}</span>}\n {children}\n {!loading && icon && iconPosition === \"right\" && <span className=\"ml-2\">{icon}</span>}\n </>\n );\n\n if (iconOnly && !(\"aria-label\" in rest) && process.env.NODE_ENV !== \"production\") {\n // eslint-disable-next-line no-console\n console.warn(\"[Button] iconOnly 사용 시 aria-label을 제공하세요.\");\n }\n\n // 앵커 모드\n if (\"href\" in rest && rest.href) {\n const { onClick, target, rel, href, \"aria-label\": ariaLabel, className: anchorClassName, ...anchorProps } = rest as AnchorProps;\n const isDisabled = !!disabled || loading;\n\n const handleAnchorClick: React.MouseEventHandler<HTMLAnchorElement> = (e) => {\n if (isDisabled) { e.preventDefault(); e.stopPropagation(); return; }\n onClick?.(e);\n };\n\n return (\n <a\n ref={ref as React.Ref<HTMLAnchorElement>}\n href={href}\n className={merge(base, anchorClassName)}\n onClick={handleAnchorClick}\n aria-busy={loading || undefined}\n aria-disabled={isDisabled || undefined}\n tabIndex={isDisabled ? -1 : anchorProps.tabIndex}\n target={target}\n rel={target === \"_blank\" ? rel ?? \"noopener noreferrer\" : rel}\n {...anchorProps}\n >\n {content}\n </a>\n );\n }\n\n // 버튼 모드\n const { className: buttonClassName, ...btnProps } = rest as NativeButtonProps;\n const isDisabled = !!disabled || loading;\n return (\n <button\n ref={ref as React.Ref<HTMLButtonElement>}\n className={merge(base, buttonClassName)}\n type=\"button\" // 폼 기본 제출 방지\n disabled={isDisabled}\n aria-busy={loading || undefined}\n aria-disabled={isDisabled || undefined}\n {...btnProps}\n >\n {content}\n </button>\n );\n});\n\nButtonInner.displayName = \"Button\";\n\nexport const Button = ButtonInner;\n\nfunction getGradientClass(gradient: GradientName): string {\n const g: Record<Exclude<GradientName, \"custom\">, string> = {\n blue: \"from-blue-500 to-cyan-500\",\n purple: \"from-purple-500 to-pink-500\",\n green: \"from-green-500 to-emerald-500 dark:from-green-400 dark:to-emerald-400\",\n orange: \"from-orange-500 to-red-500 dark:from-orange-300 dark:to-red-300\",\n pink: \"from-pink-500 to-rose-500\",\n };\n return g[gradient as keyof typeof g] || g.blue;\n}\n","\"use client\";\n\nimport React from \"react\";\nimport { merge } from \"../lib/utils\";\nimport { Button, type ButtonProps } from \"./Button\";\n\n/** Action 전용 옵션(버튼 공통 옵션은 ButtonProps에서 상속) */\ntype ActionKind =\n | \"primary\" | \"secondary\" | \"tertiary\"\n | \"magical\" | \"cyberpunk\" | \"ninja\" | \"wizard\" | \"sniper\";\ntype FeedbackKind = \"ripple\" | \"particle\" | \"sound\" | \"haptic\" | \"glitch\" | \"sparkle\" | \"smoke\";\n\ntype ActionExtras = {\n actionType?: ActionKind;\n feedback?: FeedbackKind;\n\n particleEffect?: boolean;\n rippleEffect?: boolean;\n soundEffect?: boolean;\n hapticFeedback?: boolean;\n\n transparency?: number; // 0~1\n blurIntensity?: number; // px\n glowIntensity?: number; // px\n glowColor?: string; // css color\n};\n\n/**\n * Action 컴포넌트의 props / Action component props\n * @typedef {Object} ActionProps\n * @property {ActionKind} [actionType=\"primary\"] - Action 타입 / Action type\n * @property {FeedbackKind} [feedback=\"ripple\"] - 피드백 타입 / Feedback type\n * @property {boolean} [particleEffect=false] - 파티클 효과 활성화 / Enable particle effect\n * @property {boolean} [rippleEffect=false] - 리플 효과 활성화 / Enable ripple effect\n * @property {boolean} [soundEffect=false] - 사운드 효과 활성화 / Enable sound effect\n * @property {boolean} [hapticFeedback=false] - 햅틱 피드백 활성화 / Enable haptic feedback\n * @property {number} [transparency=1] - 투명도 (0-1) / Transparency (0-1)\n * @property {number} [blurIntensity=0] - blur 강도 (px) / Blur intensity (px)\n * @property {number} [glowIntensity=0] - 글로우 강도 (px) / Glow intensity (px)\n * @property {string} [glowColor=\"rgba(91,140,255,.8)\"] - 글로우 색상 / Glow color\n * @extends {ButtonProps}\n */\nexport type ActionProps = ButtonProps & ActionExtras;\n\ntype AnchorEl = HTMLAnchorElement;\ntype ButtonEl = HTMLButtonElement;\ntype AnchorOrButton = AnchorEl | ButtonEl;\n\nconst isBrowser = typeof window !== \"undefined\";\nfunction useReducedMotion() {\n const [reduce, setReduce] = React.useState(false);\n React.useEffect(() => {\n if (!isBrowser || !(\"matchMedia\" in window)) return;\n const mq = window.matchMedia(\"(prefers-reduced-motion: reduce)\");\n const onChange = () => setReduce(!!mq.matches);\n onChange();\n mq.addEventListener?.(\"change\", onChange);\n return () => mq.removeEventListener?.(\"change\", onChange);\n }, []);\n return reduce;\n}\n\n/**\n * Action 컴포넌트 / Action component\n * \n * 고급 효과를 가진 액션 버튼 컴포넌트입니다.\n * Button 컴포넌트를 기반으로 하며, 파티클, 리플, 사운드, 햅틱 피드백 등을 지원합니다.\n * \n * Action button component with advanced effects.\n * Based on Button component, supports particle, ripple, sound, haptic feedback, etc.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Action>클릭</Action>\n * \n * @example\n * // 고급 효과 / Advanced effects\n * <Action \n * actionType=\"magical\"\n * feedback=\"particle\"\n * particleEffect\n * rippleEffect\n * >\n * 마법 버튼\n * </Action>\n * \n * @param {ActionProps} props - Action 컴포넌트의 props / Action component props\n * @param {React.Ref<AnchorOrButton>} ref - button 또는 anchor 요소 ref / button or anchor element ref\n * @returns {JSX.Element} Action 컴포넌트 / Action component\n */\nexport const Action = React.forwardRef<AnchorOrButton, ActionProps>(\n (\n {\n className,\n children,\n actionType = \"primary\",\n feedback = \"ripple\",\n particleEffect = false,\n rippleEffect = false,\n soundEffect = false,\n hapticFeedback = false,\n transparency = 1,\n blurIntensity = 0,\n glowIntensity = 0,\n glowColor = \"rgba(91,140,255,.8)\",\n loading = false,\n iconOnly = false,\n disabled,\n ...rest\n },\n ref\n ) => {\n const reduced = useReducedMotion();\n\n const runEffects = React.useCallback((event: React.MouseEvent) => {\n if (hapticFeedback && isBrowser && \"vibrate\" in navigator && !reduced) {\n try { navigator.vibrate?.(30); } catch {}\n }\n \n if (soundEffect && !reduced && isBrowser) {\n // 간단한 클릭 사운드 효과 (선택적)\n try {\n const AudioContextClass = window.AudioContext || (window as typeof window & { webkitAudioContext?: typeof AudioContext }).webkitAudioContext;\n if (!AudioContextClass) return;\n const audioContext = new AudioContextClass();\n const oscillator = audioContext.createOscillator();\n const gainNode = audioContext.createGain();\n \n oscillator.connect(gainNode);\n gainNode.connect(audioContext.destination);\n \n oscillator.frequency.value = 800;\n oscillator.type = 'sine';\n gainNode.gain.setValueAtTime(0.1, audioContext.currentTime);\n gainNode.gain.exponentialRampToValueAtTime(0.01, audioContext.currentTime + 0.1);\n \n oscillator.start(audioContext.currentTime);\n oscillator.stop(audioContext.currentTime + 0.1);\n } catch (e) {\n // 오디오 컨텍스트를 지원하지 않는 환경에서는 무시\n }\n }\n \n if (rippleEffect && !reduced && event.currentTarget) {\n // Ripple 효과: 클릭 위치에 원형 애니메이션 생성\n const button = event.currentTarget as HTMLElement;\n const rect = button.getBoundingClientRect();\n const x = event.clientX - rect.left;\n const y = event.clientY - rect.top;\n const size = Math.max(rect.width, rect.height);\n \n const ripple = document.createElement('span');\n ripple.style.cssText = `\n position: absolute;\n border-radius: 50%;\n background: rgba(255, 255, 255, 0.6);\n width: ${size}px;\n height: ${size}px;\n left: ${x - size / 2}px;\n top: ${y - size / 2}px;\n pointer-events: none;\n animation: ripple-animation 0.6s ease-out;\n `;\n \n // CSS 애니메이션 정의 (한 번만)\n if (!document.getElementById('ripple-animation-style')) {\n const style = document.createElement('style');\n style.id = 'ripple-animation-style';\n style.textContent = `\n @keyframes ripple-animation {\n to {\n transform: scale(4);\n opacity: 0;\n }\n }\n `;\n document.head.appendChild(style);\n }\n \n button.style.position = 'relative';\n button.style.overflow = 'hidden';\n button.appendChild(ripple);\n \n setTimeout(() => {\n ripple.remove();\n }, 600);\n }\n \n if (particleEffect && !reduced && event.currentTarget) {\n // 간단한 파티클 효과: 클릭 위치에서 작은 원들이 퍼져나감\n const button = event.currentTarget as HTMLElement;\n const rect = button.getBoundingClientRect();\n const x = event.clientX - rect.left;\n const y = event.clientY - rect.top;\n \n for (let i = 0; i < 5; i++) {\n const particle = document.createElement('span');\n const angle = (Math.PI * 2 * i) / 5;\n const velocity = 30 + Math.random() * 20;\n const vx = Math.cos(angle) * velocity;\n const vy = Math.sin(angle) * velocity;\n \n particle.style.cssText = `\n position: absolute;\n width: 4px;\n height: 4px;\n background: ${glowColor || 'rgba(91,140,255,0.8)'};\n border-radius: 50%;\n left: ${x}px;\n top: ${y}px;\n pointer-events: none;\n animation: particle-animation-${i} 0.5s ease-out forwards;\n `;\n \n // CSS 애니메이션 정의\n if (!document.getElementById(`particle-animation-${i}`)) {\n const style = document.createElement('style');\n style.id = `particle-animation-${i}`;\n style.textContent = `\n @keyframes particle-animation-${i} {\n to {\n transform: translate(${vx}px, ${vy}px) scale(0);\n opacity: 0;\n }\n }\n `;\n document.head.appendChild(style);\n }\n \n button.style.position = 'relative';\n button.appendChild(particle);\n \n setTimeout(() => {\n particle.remove();\n }, 500);\n }\n }\n }, [hapticFeedback, soundEffect, rippleEffect, particleEffect, reduced, glowColor]);\n\n const styleVars = React.useMemo<React.CSSProperties>(() => ({\n \"--action-opacity\": String(transparency),\n \"--action-blur\": `${blurIntensity}px`,\n \"--action-glow-size\": `${glowIntensity}px`,\n \"--action-glow-color\": glowColor,\n }) as React.CSSProperties, [transparency, blurIntensity, glowIntensity, glowColor]);\n\n const cls = React.useMemo(\n () =>\n merge(\n \"hua-action relative inline-flex items-center rounded-xl px-4 py-2 font-medium\",\n \"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary/60\",\n loading && \"cursor-wait opacity-80\",\n iconOnly && \"justify-center\",\n className\n ),\n [className, loading, iconOnly]\n );\n\n /** 분기 1) href가 있으면 앵커 브랜치 */\n if (\"href\" in rest && rest.href) {\n const { onClick, href, ...anchorRest } = rest as Extract<ButtonProps, { href: string }>;\n\n const handleClick: React.MouseEventHandler<AnchorEl> = (e) => {\n if (disabled || loading) { e.preventDefault(); e.stopPropagation(); return; }\n runEffects(e);\n onClick?.(e);\n };\n\n return (\n <Button\n ref={ref as React.Ref<AnchorEl>}\n href={href}\n className={cls}\n style={styleVars}\n onClick={handleClick}\n aria-busy={loading || undefined}\n aria-label={iconOnly ? (anchorRest[\"aria-label\"] as string) : undefined}\n data-action={actionType}\n data-feedback={feedback}\n data-reduced-motion={reduced ? \"true\" : \"false\"}\n disabled={disabled}\n {...anchorRest}\n >\n {children}\n </Button>\n );\n }\n\n /** 분기 2) 기본 버튼 브랜치 */\n const { onClick, ...btnRest } = rest as Extract<ButtonProps, { href?: undefined }>;\n\n const handleClick: React.MouseEventHandler<ButtonEl> = (e) => {\n if (disabled || loading) return;\n runEffects(e);\n onClick?.(e);\n };\n\n return (\n <Button\n ref={ref as React.Ref<ButtonEl>}\n className={cls}\n style={styleVars}\n onClick={handleClick}\n disabled={disabled}\n aria-busy={loading || undefined}\n aria-label={iconOnly ? (btnRest[\"aria-label\"] as string) : undefined}\n data-action={actionType}\n data-feedback={feedback}\n data-reduced-motion={reduced ? \"true\" : \"false\"}\n {...btnRest}\n >\n {children}\n </Button>\n );\n }\n);\n\nAction.displayName = \"Action\";\n","\"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 * Link 컴포넌트의 props / Link component props\n * @typedef {Object} LinkProps\n * @property {string} href - 링크 URL / Link URL\n * @property {React.ReactNode} children - 링크 텍스트 또는 내용 / Link text or content\n * @property {\"default\" | \"primary\" | \"secondary\" | \"ghost\" | \"underline\"} [variant=\"default\"] - Link 스타일 변형 / Link style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Link 크기 / Link size\n * @property {boolean} [external=false] - 외부 링크 여부 (target=\"_blank\" 자동 설정) / External link (auto sets target=\"_blank\")\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {() => void} [onClick] - 클릭 이벤트 핸들러 / Click event handler\n */\nexport interface LinkProps {\n href: string\n children: React.ReactNode\n variant?: \"default\" | \"primary\" | \"secondary\" | \"ghost\" | \"underline\"\n size?: \"sm\" | \"md\" | \"lg\"\n external?: boolean\n className?: string\n onClick?: () => void\n}\n\n/**\n * Link 컴포넌트 / Link component\n * \n * 링크를 표시하는 컴포넌트입니다.\n * 외부 링크의 경우 자동으로 `target=\"_blank\"`와 `rel=\"noopener noreferrer\"`를 설정합니다.\n * \n * Link component for displaying links.\n * Automatically sets `target=\"_blank\"` and `rel=\"noopener noreferrer\"` for external links.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Link href=\"/about\">소개</Link>\n * \n * @example\n * // 외부 링크 / External link\n * <Link href=\"https://example.com\" external>\n * 외부 사이트\n * </Link>\n * \n * @example\n * // Primary 스타일 / Primary style\n * <Link href=\"/contact\" variant=\"primary\" size=\"lg\">\n * 문의하기\n * </Link>\n * \n * @param {LinkProps} props - Link 컴포넌트의 props / Link component props\n * @returns {JSX.Element} Link 컴포넌트 / Link component\n */\nexport function Link({ \n href,\n children,\n className,\n variant = \"default\",\n size = \"md\",\n external = false,\n onClick\n}: LinkProps) {\n const variantClasses = {\n default: \"text-gray-900 dark:text-white hover:text-gray-700 dark:hover:text-gray-300\",\n primary: \"text-blue-600 dark:text-blue-400 hover:text-blue-700 dark:hover:text-blue-300\",\n secondary: \"text-gray-600 dark:text-gray-400 hover:text-gray-800 dark:hover:text-gray-200\",\n ghost: \"text-gray-500 dark:text-gray-400 hover:text-gray-700 dark:hover:bg-gray-800\",\n underline: \"text-blue-600 dark:text-blue-400 hover:text-blue-700 dark:hover:text-blue-300 underline hover:no-underline\"\n }\n\n const sizeClasses = {\n sm: \"text-sm\",\n md: \"text-base\",\n lg: \"text-lg\"\n }\n\n return (\n <a\n href={href}\n className={merge(\n \"transition-colors duration-200\",\n variantClasses[variant],\n sizeClasses[size],\n className\n )}\n target={external ? \"_blank\" : undefined}\n rel={external ? \"noopener noreferrer\" : undefined}\n onClick={onClick}\n >\n {children}\n </a>\n )\n} ","/**\n * Core Icons\n * \n * 핵심 아이콘만 포함하여 번들 크기를 최적화합니다.\n * 나머지 아이콘은 동적 fallback으로 처리됩니다.\n * \n * 포함 기준:\n * 1. sum-diary에서 실제 사용 중인 아이콘\n * 2. UI 컴포넌트에서 자주 사용되는 아이콘\n * 3. 각 카테고리의 대표 아이콘\n * \n * 새로운 아이콘이 필요하면 동적 fallback이 자동으로 처리합니다.\n */\n\nimport {\n // Navigation\n Home,\n ArrowLeft,\n ArrowRight,\n ArrowUp,\n ArrowDown,\n Menu,\n X,\n Search,\n Settings,\n ExternalLink,\n ChevronLeft,\n ChevronRight,\n ChevronDown,\n ChevronUp,\n \n // Actions\n Edit,\n Trash2,\n Plus,\n Minus,\n Download,\n Upload,\n RefreshCw,\n Save,\n Copy,\n \n // Status & Feedback\n Loader2,\n CheckCircle,\n XCircle,\n AlertCircle,\n Info,\n Check,\n Circle,\n HelpCircle,\n \n // User & Auth\n User,\n Users,\n UserPlus,\n LogIn,\n LogOut,\n Eye,\n EyeOff,\n \n // Data & Analytics\n BarChart3,\n TrendingUp,\n Activity,\n Database,\n Zap,\n \n // Files & Content\n FileText,\n File,\n Folder,\n Book,\n BookOpen,\n \n // Communication\n Mail,\n MessageCircle,\n Phone,\n \n // Media\n Image,\n Video,\n Camera,\n \n // Emotions\n Smile,\n Frown,\n Meh,\n \n // Security\n Lock,\n Unlock,\n Shield,\n Wallet,\n Key,\n \n // Time & Date\n Clock,\n Calendar,\n CalendarPlus,\n \n // UI Elements\n Bell,\n Heart,\n Star,\n Bookmark,\n Share,\n \n // Theme\n Monitor,\n Sun,\n Moon,\n \n // Additional\n Lightbulb,\n Brain,\n Flag,\n Square,\n} from 'lucide-react'\n\n// 핵심 아이콘 객체\nexport const icons = {\n // Navigation\n home: Home,\n arrowLeft: ArrowLeft,\n arrowRight: ArrowRight,\n arrowUp: ArrowUp,\n arrowDown: ArrowDown,\n menu: Menu,\n close: X,\n search: Search,\n settings: Settings,\n externalLink: ExternalLink,\n chevronLeft: ChevronLeft,\n chevronRight: ChevronRight,\n chevronDown: ChevronDown,\n chevronUp: ChevronUp,\n \n // Actions\n edit: Edit,\n delete: Trash2,\n add: Plus,\n remove: Minus,\n download: Download,\n upload: Upload,\n refresh: RefreshCw,\n save: Save,\n copy: Copy,\n \n // Status & Feedback\n loader: Loader2,\n success: CheckCircle,\n error: XCircle,\n alertCircle: AlertCircle,\n warning: AlertCircle, // warning은 alertCircle과 동일\n info: Info,\n check: Check,\n circle: Circle,\n helpCircle: HelpCircle,\n \n // User & Auth\n user: User,\n users: Users,\n userPlus: UserPlus,\n logIn: LogIn,\n logOut: LogOut,\n eye: Eye,\n eyeOff: EyeOff,\n \n // Data & Analytics\n chart: BarChart3,\n barChart: BarChart3,\n trendingUp: TrendingUp,\n activity: Activity,\n database: Database,\n zap: Zap,\n \n // Files & Content\n fileText: FileText,\n file: File,\n folder: Folder,\n book: Book,\n bookOpen: BookOpen,\n \n // Communication\n mail: Mail,\n message: MessageCircle,\n phone: Phone,\n \n // Media\n image: Image,\n video: Video,\n camera: Camera,\n \n // Emotions\n smile: Smile,\n frown: Frown,\n meh: Meh,\n \n // Security\n lock: Lock,\n unlock: Unlock,\n shield: Shield,\n wallet: Wallet,\n key: Key,\n \n // Time & Date\n clock: Clock,\n calendar: Calendar,\n calendarPlus: CalendarPlus,\n \n // UI Elements\n bell: Bell,\n heart: Heart,\n star: Star,\n bookmark: Bookmark,\n share: Share,\n \n // Theme\n monitor: Monitor,\n sun: Sun,\n moon: Moon,\n \n // Additional\n lightbulb: Lightbulb,\n brain: Brain,\n flag: Flag,\n square: Square,\n} as const\n\n// 아이콘 이름 타입\nexport type IconName = keyof typeof icons\n\n// 감정별 아이콘 매핑\nexport const emotionIcons = {\n happy: 'smile',\n sad: 'frown',\n neutral: 'meh',\n excited: 'smile', // laugh 대신 smile 사용\n angry: 'frown', // angry 대신 frown 사용\n love: 'heart',\n like: 'heart', // thumbsUp 대신 heart 사용\n dislike: 'frown', // thumbsDown 대신 frown 사용\n} as const\n\n// 상태별 아이콘 매핑\nexport const statusIcons = {\n loading: 'loader',\n success: 'success',\n error: 'error',\n warning: 'warning',\n info: 'info',\n locked: 'lock',\n unlocked: 'unlock',\n visible: 'eye',\n hidden: 'eyeOff',\n} as const\n\n// 아이콘 카테고리별 그룹화 (참고용)\nexport const iconCategories = {\n navigation: ['home', 'arrowLeft', 'arrowRight', 'arrowUp', 'arrowDown', 'menu', 'close', 'search', 'settings', 'externalLink', 'chevronLeft', 'chevronRight', 'chevronDown', 'chevronUp'],\n actions: ['edit', 'delete', 'add', 'remove', 'download', 'upload', 'refresh', 'save', 'copy'],\n status: ['loader', 'success', 'error', 'alertCircle', 'warning', 'info', 'check', 'circle'],\n user: ['user', 'users', 'userPlus', 'logIn', 'logOut', 'eye', 'eyeOff'],\n data: ['chart', 'barChart', 'trendingUp', 'activity', 'database', 'zap'],\n files: ['fileText', 'file', 'folder', 'book'],\n communication: ['mail', 'message', 'phone'],\n media: ['image', 'video', 'camera'],\n emotions: ['smile', 'frown', 'meh'],\n security: ['lock', 'unlock', 'shield'],\n time: ['clock', 'calendar'],\n ui: ['bell', 'heart', 'star', 'bookmark', 'share'],\n theme: ['monitor', 'sun', 'moon'],\n} as const\n","/**\n * Icon Provider System\n * \n * Supports multiple icon libraries:\n * - Lucide Icons (default)\n * - Phosphor Icons\n * - Untitled Icons (SVG-based)\n * \n * Only imports icons that are actually used in the project for optimal bundle size.\n */\n\nimport * as LucideIcons from 'lucide-react'\nimport type { LucideIcon } from 'lucide-react'\n\n// Phosphor Icons - lazy loaded, tree-shakeable\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nlet PhosphorIcons: any = null\n\n// Icon Provider Type\nexport type IconProvider = 'lucide' | 'phosphor' | 'untitled'\n\n// Icon Provider Configuration\nexport interface IconProviderConfig {\n provider: IconProvider\n prefix?: string\n}\n\n/**\n * Project-specific icon list\n * These are the icons actually used in SumUp project\n * Only these icons will be loaded for optimal bundle size\n */\nexport const PROJECT_ICONS = {\n // Navigation & Layout\n 'home': { lucide: 'Home', phosphor: 'House', untitled: 'home' },\n 'layout-dashboard': { lucide: 'LayoutDashboard', phosphor: 'SquaresFour', untitled: 'layout-dashboard' },\n 'folder': { lucide: 'Folder', phosphor: 'Folder', untitled: 'folder' },\n 'alert-circle': { lucide: 'AlertCircle', phosphor: 'WarningCircle', untitled: 'alert-circle' },\n 'alertCircle': { lucide: 'AlertCircle', phosphor: 'WarningCircle', untitled: 'alert-circle' },\n 'columns': { lucide: 'Columns', phosphor: 'Columns', untitled: 'columns' },\n 'users': { lucide: 'Users', phosphor: 'Users', untitled: 'users' },\n 'settings': { lucide: 'Settings', phosphor: 'Gear', untitled: 'settings' },\n 'menu': { lucide: 'Menu', phosphor: 'List', untitled: 'menu' },\n 'close': { lucide: 'X', phosphor: 'X', untitled: 'close' },\n 'chevronLeft': { lucide: 'ChevronLeft', phosphor: 'CaretLeft', untitled: 'chevron-left' },\n 'chevronRight': { lucide: 'ChevronRight', phosphor: 'CaretRight', untitled: 'chevron-right' },\n 'chevronDown': { lucide: 'ChevronDown', phosphor: 'CaretDown', untitled: 'chevron-down' },\n 'chevronUp': { lucide: 'ChevronUp', phosphor: 'CaretUp', untitled: 'chevron-up' },\n 'arrowLeft': { lucide: 'ArrowLeft', phosphor: 'ArrowLeft', untitled: 'arrow-left' },\n 'arrowRight': { lucide: 'ArrowRight', phosphor: 'ArrowRight', untitled: 'arrow-right' },\n 'arrowUp': { lucide: 'ArrowUp', phosphor: 'ArrowUp', untitled: 'arrow-up' },\n 'arrowDown': { lucide: 'ArrowDown', phosphor: 'ArrowDown', untitled: 'arrow-down' },\n\n // Actions\n 'add': { lucide: 'Plus', phosphor: 'Plus', untitled: 'add' },\n 'edit': { lucide: 'Edit', phosphor: 'Pencil', untitled: 'edit' },\n 'pencil': { lucide: 'Pencil', phosphor: 'Pencil', untitled: 'pencil' },\n 'delete': { lucide: 'Trash2', phosphor: 'Trash', untitled: 'trash' },\n 'trash': { lucide: 'Trash2', phosphor: 'Trash', untitled: 'trash' },\n 'upload': { lucide: 'Upload', phosphor: 'Upload', untitled: 'upload' },\n 'download': { lucide: 'Download', phosphor: 'Download', untitled: 'download' },\n 'x': { lucide: 'X', phosphor: 'X', untitled: 'close' },\n 'check': { lucide: 'Check', phosphor: 'Check', untitled: 'check' },\n 'search': { lucide: 'Search', phosphor: 'MagnifyingGlass', untitled: 'search' },\n 'share': { lucide: 'Share', phosphor: 'Share', untitled: 'share' },\n 'copy': { lucide: 'Copy', phosphor: 'Copy', untitled: 'copy' },\n 'save': { lucide: 'Save', phosphor: 'FloppyDisk', untitled: 'save' },\n\n // Status & Feedback\n 'loader': { lucide: 'Loader2', phosphor: 'Spinner', untitled: 'loader' },\n 'loader2': { lucide: 'Loader2', phosphor: 'Spinner', untitled: 'loader' },\n 'check-circle': { lucide: 'CheckCircle', phosphor: 'CheckCircle', untitled: 'check-circle' },\n 'checkCircle': { lucide: 'CheckCircle', phosphor: 'CheckCircle', untitled: 'check-circle' },\n 'success': { lucide: 'CheckCircle', phosphor: 'CheckCircle', untitled: 'check-circle' },\n 'error': { lucide: 'XCircle', phosphor: 'XCircle', untitled: 'error' },\n 'warning': { lucide: 'AlertCircle', phosphor: 'WarningCircle', untitled: 'warning' },\n 'info': { lucide: 'Info', phosphor: 'Info', untitled: 'info' },\n 'refresh': { lucide: 'RefreshCw', phosphor: 'ArrowClockwise', untitled: 'refresh' },\n 'refreshCw': { lucide: 'RefreshCw', phosphor: 'ArrowClockwise', untitled: 'refresh' },\n 'bell': { lucide: 'Bell', phosphor: 'Bell', untitled: 'bell' },\n 'heart': { lucide: 'Heart', phosphor: 'Heart', untitled: 'heart' },\n 'star': { lucide: 'Star', phosphor: 'Star', untitled: 'star' },\n 'bookmark': { lucide: 'Bookmark', phosphor: 'Bookmark', untitled: 'bookmark' },\n\n // User & Auth\n 'user': { lucide: 'User', phosphor: 'User', untitled: 'user' },\n 'userPlus': { lucide: 'UserPlus', phosphor: 'UserPlus', untitled: 'user-plus' },\n 'logIn': { lucide: 'LogIn', phosphor: 'SignIn', untitled: 'log-in' },\n 'logOut': { lucide: 'LogOut', phosphor: 'SignOut', untitled: 'log-out' },\n 'chrome': { lucide: 'Chrome', phosphor: 'ChromeLogo', untitled: 'chrome' },\n 'github': { lucide: 'Github', phosphor: 'GithubLogo', untitled: 'github' },\n 'message': { lucide: 'MessageCircle', phosphor: 'ChatCircle', untitled: 'message' },\n\n // Content\n 'messageSquare': { lucide: 'MessageSquare', phosphor: 'ChatSquare', untitled: 'message-square' },\n 'message-square': { lucide: 'MessageSquare', phosphor: 'ChatSquare', untitled: 'message-square' },\n 'inbox': { lucide: 'Inbox', phosphor: 'Inbox', untitled: 'inbox' },\n 'calendar': { lucide: 'Calendar', phosphor: 'Calendar', untitled: 'calendar' },\n 'calendarPlus': { lucide: 'CalendarPlus', phosphor: 'CalendarPlus', untitled: 'calendar-plus' },\n 'checkSquare': { lucide: 'CheckSquare', phosphor: 'CheckSquare', untitled: 'check-square' },\n 'clock': { lucide: 'Clock', phosphor: 'Clock', untitled: 'clock' },\n 'book': { lucide: 'Book', phosphor: 'Book', untitled: 'book' },\n 'bookOpen': { lucide: 'BookOpen', phosphor: 'BookOpen', untitled: 'book-open' },\n\n // Theme & UI\n 'monitor': { lucide: 'Monitor', phosphor: 'Monitor', untitled: 'monitor' },\n 'sun': { lucide: 'Sun', phosphor: 'Sun', untitled: 'sun' },\n 'moon': { lucide: 'Moon', phosphor: 'Moon', untitled: 'moon' },\n\n // AI & Features\n 'sparkles': { lucide: 'Sparkles', phosphor: 'Sparkle', untitled: 'sparkles' },\n 'lightbulb': { lucide: 'Lightbulb', phosphor: 'Lightbulb', untitled: 'lightbulb' },\n 'brain': { lucide: 'Brain', phosphor: 'Brain', untitled: 'brain' },\n 'zap': { lucide: 'Zap', phosphor: 'Lightning', untitled: 'zap' },\n\n // Data & Analytics\n 'chart': { lucide: 'BarChart3', phosphor: 'ChartBar', untitled: 'chart' },\n 'barChart': { lucide: 'BarChart', phosphor: 'ChartBar', untitled: 'bar-chart' },\n 'trendingUp': { lucide: 'TrendingUp', phosphor: 'TrendUp', untitled: 'trending-up' },\n 'trendingDown': { lucide: 'TrendingDown', phosphor: 'TrendDown', untitled: 'trending-down' },\n 'activity': { lucide: 'Activity', phosphor: 'Activity', untitled: 'activity' },\n 'database': { lucide: 'Database', phosphor: 'Database', untitled: 'database' },\n 'dollarSign': { lucide: 'DollarSign', phosphor: 'CurrencyDollar', untitled: 'dollar-sign' },\n 'dollar': { lucide: 'DollarSign', phosphor: 'CurrencyDollar', untitled: 'dollar-sign' },\n 'currency': { lucide: 'DollarSign', phosphor: 'CurrencyDollar', untitled: 'currency' },\n\n // Security\n 'lock': { lucide: 'Lock', phosphor: 'Lock', untitled: 'lock' },\n 'unlock': { lucide: 'Unlock', phosphor: 'LockOpen', untitled: 'unlock' },\n 'shield': { lucide: 'Shield', phosphor: 'Shield', untitled: 'shield' },\n 'key': { lucide: 'Key', phosphor: 'Key', untitled: 'key' },\n\n // Media\n 'play': { lucide: 'Play', phosphor: 'Play', untitled: 'play' },\n 'pause': { lucide: 'Pause', phosphor: 'Pause', untitled: 'pause' },\n 'image': { lucide: 'Image', phosphor: 'Image', untitled: 'image' },\n 'video': { lucide: 'Video', phosphor: 'Video', untitled: 'video' },\n 'camera': { lucide: 'Camera', phosphor: 'Camera', untitled: 'camera' },\n\n // Files\n 'fileText': { lucide: 'FileText', phosphor: 'FileText', untitled: 'file-text' },\n 'file': { lucide: 'File', phosphor: 'File', untitled: 'file' },\n\n // Navigation\n 'externalLink': { lucide: 'ExternalLink', phosphor: 'ArrowSquareOut', untitled: 'external-link' },\n 'link': { lucide: 'Link', phosphor: 'Link', untitled: 'link' },\n 'moreHorizontal': { lucide: 'MoreHorizontal', phosphor: 'DotsThreeOutline', untitled: 'more-horizontal' },\n 'moreVertical': { lucide: 'MoreVertical', phosphor: 'DotsThreeVertical', untitled: 'more-vertical' },\n\n // Priority\n 'remove': { lucide: 'Minus', phosphor: 'Minus', untitled: 'remove' },\n\n // Eye (password)\n 'eye': { lucide: 'Eye', phosphor: 'Eye', untitled: 'eye' },\n 'eyeOff': { lucide: 'EyeOff', phosphor: 'EyeSlash', untitled: 'eye-off' },\n\n // Emotions\n 'smile': { lucide: 'Smile', phosphor: 'Smiley', untitled: 'smile' },\n 'frown': { lucide: 'Frown', phosphor: 'SmileySad', untitled: 'frown' },\n 'meh': { lucide: 'Meh', phosphor: 'SmileyMeh', untitled: 'meh' },\n\n // Social\n 'mail': { lucide: 'Mail', phosphor: 'Envelope', untitled: 'mail' },\n 'phone': { lucide: 'Phone', phosphor: 'Phone', untitled: 'phone' },\n\n // Additional\n 'flag': { lucide: 'Flag', phosphor: 'Flag', untitled: 'flag' },\n} as const\n\n/**\n * Initialize Phosphor Icons (lazy load)\n * Only loads when Phosphor provider is used\n * Uses tree-shaking to only include used icons\n */\nexport async function initPhosphorIcons() {\n if (typeof window === 'undefined') return null\n\n if (!PhosphorIcons) {\n try {\n // Dynamic import with tree-shaking support\n // Only icons actually used will be included in bundle\n const phosphorModule = await import('@phosphor-icons/react')\n PhosphorIcons = phosphorModule\n } catch (error) {\n console.warn('Phosphor Icons not available. Install @phosphor-icons/react to use.')\n return null\n }\n }\n return PhosphorIcons\n}\n\n/**\n * Get icon from provider\n * Only resolves icons that are in PROJECT_ICONS for optimal bundle size\n * \n * @param iconName - 아이콘 이름 / Icon name\n * @param provider - 아이콘 프로바이더 / Icon provider\n * @returns 아이콘 컴포넌트 또는 null / Icon component or null\n */\nexport function getIconFromProvider(\n iconName: string,\n provider: IconProvider | 'lucide' | 'phosphor' | 'untitled' = 'lucide'\n): LucideIcon | React.ComponentType<Record<string, unknown>> | null {\n // Check if icon is in project icon list\n const iconMapping = PROJECT_ICONS[iconName as keyof typeof PROJECT_ICONS]\n\n if (!iconMapping) {\n // Fallback to direct lookup for backward compatibility\n return getIconDirect(iconName, provider)\n }\n\n const mappedName = iconMapping[provider]\n\n switch (provider) {\n case 'lucide':\n return (LucideIcons as unknown as Record<string, LucideIcon>)[mappedName] || null\n\n case 'phosphor':\n if (!PhosphorIcons) {\n return null\n }\n return PhosphorIcons?.[mappedName] || null\n\n case 'untitled':\n // Untitled Icons are SVG-based, handled separately\n return null\n\n default:\n return null\n }\n}\n\n/**\n * Direct icon lookup (fallback for icons not in PROJECT_ICONS)\n * \n * 동적으로 Lucide 아이콘을 가져옵니다.\n * icons.ts에 없는 아이콘도 사용 가능하도록 합니다.\n * \n * Dynamically loads Lucide icons.\n * Allows using icons not in icons.ts.\n * \n * @param iconName - 아이콘 이름 / Icon name\n * @param provider - 아이콘 프로바이더 / Icon provider\n * @returns 아이콘 컴포넌트 또는 null / Icon component or null\n */\nfunction getIconDirect(\n iconName: string,\n provider: IconProvider | 'lucide' | 'phosphor' | 'untitled'\n): LucideIcon | React.ComponentType<Record<string, unknown>> | null {\n switch (provider) {\n case 'lucide':\n // icons.ts에 없는 아이콘을 동적으로 찾기\n // PascalCase 변환 시도\n const lucideName = iconName.charAt(0).toUpperCase() + iconName.slice(1)\n // camelCase도 시도\n const camelCaseName = iconName.replace(/([A-Z])/g, (match, p1) =>\n match === iconName[0] ? match.toLowerCase() : match\n )\n\n return (LucideIcons as unknown as Record<string, LucideIcon>)[lucideName] ||\n (LucideIcons as unknown as Record<string, LucideIcon>)[iconName] ||\n (LucideIcons as unknown as Record<string, LucideIcon>)[camelCaseName] ||\n null\n\n case 'phosphor':\n if (!PhosphorIcons) {\n return null\n }\n const phosphorName1 = iconName.charAt(0).toUpperCase() + iconName.slice(1)\n const phosphorName2 = iconName\n .split(/(?=[A-Z])/)\n .map(word => word.charAt(0).toUpperCase() + word.slice(1))\n .join('')\n return PhosphorIcons?.[phosphorName1] ||\n PhosphorIcons?.[phosphorName2] ||\n PhosphorIcons?.[iconName] ||\n null\n\n case 'untitled':\n return null\n\n default:\n return null\n }\n}\n\n/**\n * Get icon name for provider\n * \n * 프로바이더별 아이콘 이름을 가져옵니다.\n * Gets icon name for the specified provider.\n * \n * @param iconName - 아이콘 이름 / Icon name\n * @param provider - 아이콘 프로바이더 / Icon provider\n * @returns 프로바이더별 아이콘 이름 / Icon name for provider\n */\nexport function getIconNameForProvider(\n iconName: string,\n provider: IconProvider | 'lucide' | 'phosphor' | 'untitled'\n): string {\n const iconMapping = PROJECT_ICONS[iconName as keyof typeof PROJECT_ICONS]\n if (iconMapping && iconMapping[provider]) {\n return iconMapping[provider]\n }\n return iconName\n}\n\n/**\n * Get all project icon names\n */\nexport function getProjectIconNames(): string[] {\n return Object.keys(PROJECT_ICONS)\n}\n","/**\n * Icon Aliases\n * \n * 여러 이름이 같은 아이콘을 가리키도록 하는 alias 시스템\n * DX 향상을 위해 직관적인 이름들을 지원합니다.\n */\n\nexport const ICON_ALIASES: Record<string, string> = {\n // Navigation aliases\n 'back': 'arrowLeft',\n 'prev': 'arrowLeft',\n 'previous': 'arrowLeft',\n 'forward': 'arrowRight',\n 'next': 'arrowRight',\n \n // Close aliases\n 'close': 'x',\n 'cancel': 'x',\n \n // Delete aliases\n 'remove': 'delete',\n 'trash': 'delete',\n \n // Add aliases\n 'plus': 'add',\n 'new': 'add',\n \n // Edit aliases\n 'pencil': 'edit',\n 'modify': 'edit',\n \n // Save aliases\n 'store': 'save',\n 'floppy': 'save',\n \n // Search aliases\n 'magnify': 'search',\n \n // User aliases\n 'person': 'user',\n 'account': 'user',\n 'profile': 'user',\n \n // Settings aliases\n 'gear': 'settings',\n 'config': 'settings',\n 'preferences': 'settings',\n \n // Home aliases\n 'house': 'home',\n 'main': 'home',\n \n // Check aliases\n 'done': 'check',\n 'complete': 'check',\n 'tick': 'check',\n \n // Info aliases\n 'information': 'info',\n 'help': 'info',\n \n // Warning aliases\n 'alert': 'warning',\n 'caution': 'warning',\n \n // Success aliases\n 'checkmark': 'success',\n 'checkCircle': 'success',\n \n // Error aliases\n 'fail': 'error',\n 'cross': 'error',\n 'xCircle': 'error',\n \n // Loading aliases\n 'spinner': 'loader',\n 'loading': 'loader',\n 'wait': 'loader',\n \n // Refresh aliases\n 'reload': 'refresh',\n 'update': 'refresh',\n 'sync': 'refresh',\n \n // Eye aliases\n 'show': 'eye',\n 'view': 'eye',\n 'hide': 'eyeOff',\n 'hidden': 'eyeOff',\n \n // Lock aliases\n 'secure': 'lock',\n 'locked': 'lock',\n 'unsecure': 'unlock',\n 'unlocked': 'unlock',\n \n // Download aliases\n 'get': 'download',\n 'fetch': 'download',\n \n // Upload aliases\n 'post': 'upload',\n \n // Share aliases\n 'send': 'share',\n 'export': 'share',\n \n // Copy aliases\n 'duplicate': 'copy',\n 'clone': 'copy',\n \n // Mail aliases\n 'email': 'mail',\n 'envelope': 'mail',\n \n // Message aliases\n 'chat': 'message',\n 'comment': 'message',\n 'talk': 'message',\n \n // Calendar aliases\n 'date': 'calendar',\n 'schedule': 'calendar',\n \n // Clock aliases\n 'time': 'clock',\n 'watch': 'clock',\n \n // File aliases\n 'document': 'fileText',\n 'doc': 'fileText',\n 'text': 'fileText',\n \n // Folder aliases\n 'directory': 'folder',\n 'dir': 'folder',\n \n // Image aliases\n 'picture': 'image',\n 'img': 'image',\n \n // Video aliases\n 'movie': 'video',\n 'film': 'video',\n \n // Camera aliases\n 'photo': 'camera',\n 'capture': 'camera',\n \n // Play aliases\n 'start': 'play',\n 'run': 'play',\n \n // Pause aliases\n 'stop': 'pause',\n 'halt': 'pause',\n \n // Heart aliases\n 'like': 'heart',\n 'love': 'heart',\n \n // Star aliases\n 'favorite': 'star',\n \n // Bookmark aliases\n 'saveBookmark': 'bookmark',\n \n // Bell aliases\n 'notification': 'bell',\n 'notify': 'bell',\n 'alarm': 'bell',\n \n // Settings aliases\n 'prefs': 'settings',\n \n // Search aliases (duplicate removed - see line 37)\n 'lookup': 'search',\n \n // More aliases\n 'dots': 'moreHorizontal',\n 'moreMenu': 'moreHorizontal',\n 'moreOptions': 'moreVertical',\n \n // External link aliases\n 'external': 'externalLink',\n 'outbound': 'externalLink',\n 'open': 'externalLink',\n \n // Link aliases\n 'url': 'link',\n 'hyperlink': 'link',\n \n // Chart aliases\n 'graph': 'barChart',\n 'stats': 'barChart',\n 'analytics': 'barChart',\n \n // Database aliases\n 'db': 'database',\n 'storage': 'database',\n \n // Activity aliases\n 'pulse': 'activity',\n 'monitor': 'activity',\n \n // Trending aliases\n 'up': 'trendingUp',\n 'down': 'trendingDown',\n \n // Zap aliases\n 'lightning': 'zap',\n 'bolt': 'zap',\n 'flash': 'zap',\n \n // Shield aliases\n 'security': 'shield',\n 'protect': 'shield',\n \n // Key aliases\n 'password': 'key',\n 'secret': 'key',\n \n // Log in aliases\n 'signin': 'logIn',\n 'login': 'logIn',\n 'enter': 'logIn',\n \n // Log out aliases\n 'signout': 'logOut',\n 'logout': 'logOut',\n 'exit': 'logOut',\n \n // Users aliases\n 'people': 'users',\n 'group': 'users',\n 'team': 'users',\n \n // User plus aliases\n 'addUser': 'userPlus',\n 'invite': 'userPlus',\n \n // Book aliases\n 'read': 'book',\n 'library': 'book',\n \n // Book open aliases\n 'reading': 'bookOpen',\n 'openBook': 'bookOpen',\n \n // Sun aliases\n 'light': 'sun',\n 'day': 'sun',\n \n // Moon aliases\n 'dark': 'moon',\n 'night': 'moon',\n \n // Monitor aliases\n 'screen': 'monitor',\n 'display': 'monitor',\n \n // Brain aliases\n 'ai': 'brain',\n 'intelligence': 'brain',\n 'think': 'brain',\n \n // Lightbulb aliases\n 'idea': 'lightbulb',\n 'bulb': 'lightbulb',\n 'inspiration': 'lightbulb',\n \n // Sparkles aliases\n 'magic': 'sparkles',\n 'stars': 'sparkles',\n 'glitter': 'sparkles',\n} as const\n\n/**\n * Resolve icon alias to actual icon name\n * \n * @param iconName - 아이콘 이름 또는 별칭 / Icon name or alias\n * @returns 실제 아이콘 이름 / Actual icon name\n * @throws {TypeError} iconName이 문자열이 아닌 경우\n */\nexport function resolveIconAlias(iconName: string): string {\n if (typeof iconName !== 'string') {\n throw new TypeError('iconName must be a string');\n }\n return ICON_ALIASES[iconName] || iconName;\n}\n\n/**\n * Get all aliases for an icon name\n * \n * @param iconName - 아이콘 이름 / Icon name\n * @returns 해당 아이콘의 모든 별칭 배열 / Array of all aliases for the icon\n * @throws {TypeError} iconName이 문자열이 아닌 경우\n */\nexport function getIconAliases(iconName: string): string[] {\n if (typeof iconName !== 'string') {\n throw new TypeError('iconName must be a string');\n }\n return Object.entries(ICON_ALIASES)\n .filter(([_, target]) => target === iconName)\n .map(([alias]) => alias);\n}\n\n\n","/**\n * Icon Config Types\n * \n * Icon 시스템의 설정 타입 정의\n * 상태관리는 서비스 레벨에서 관리 (Zustand 등)\n */\n\nexport type IconSet = 'lucide' | 'phosphor' | 'untitled'\n\nexport type PhosphorWeight = 'thin' | 'light' | 'regular' | 'bold' | 'duotone' | 'fill'\n\nexport interface IconConfig {\n set: IconSet\n weight: PhosphorWeight\n size: number\n color: string\n strokeWidth?: number // Lucide/Untitled용\n}\n\nexport const defaultIconConfig: IconConfig = {\n set: 'phosphor',\n weight: 'regular',\n size: 20,\n color: 'currentColor',\n strokeWidth: 1.25,\n}\n\n/**\n * 세트별 기본 strokeWidth\n */\nexport const getDefaultStrokeWidth = (set: IconSet): number => {\n switch (set) {\n case 'lucide':\n return 1.25\n case 'phosphor':\n return 1.25 // Phosphor는 weight 사용\n case 'untitled':\n return 1.5\n default:\n return 1.25\n }\n}\n","'use client'\n\n/**\n * IconProvider - Icon 시스템 전역 설정 Provider\n * \n * React Context를 사용하여 전역 아이콘 설정을 제공합니다.\n * 서비스 레벨에서 Zustand 등으로 상태관리 후 props로 전달 가능합니다.\n * \n * IconProvider - Global Icon Settings Provider\n * \n * Provides global icon settings using React Context API.\n * Can be integrated with state management (e.g., Zustand) at the service level.\n */\n\nimport React, { createContext, useContext } from 'react'\nimport { type IconConfig, type IconSet, type PhosphorWeight, defaultIconConfig } from './icon-store'\n\n/**\n * IconProvider 컴포넌트 Props\n * \n * IconProvider component props interface.\n * \n * @interface IconProviderProps\n */\nexport interface IconProviderProps {\n /** 아이콘 세트 (lucide, phosphor, untitled) / Icon set (lucide, phosphor, untitled) */\n set?: IconSet\n /** Phosphor 아이콘 weight (thin, light, regular, bold, duotone, fill) / Phosphor icon weight */\n weight?: PhosphorWeight\n /** 기본 아이콘 크기 / Default icon size */\n size?: number\n /** 기본 아이콘 색상 / Default icon color */\n color?: string\n /** Lucide/Untitled 아이콘 stroke width / Lucide/Untitled icon stroke width */\n strokeWidth?: number\n /** 자식 컴포넌트 / Child components */\n children: React.ReactNode\n}\n\ninterface IconContextValue extends IconConfig {}\n\nconst IconContext = createContext<IconContextValue>(defaultIconConfig)\n\n/**\n * IconProvider 컴포넌트\n * \n * 전역 아이콘 설정을 Context로 제공합니다.\n * 서비스에서 Zustand로 관리한 값을 props로 전달할 수 있습니다.\n * \n * IconProvider component\n * \n * Provides global icon settings through Context API.\n * Can receive values managed by Zustand at the service level.\n * \n * @component\n * @example\n * ```tsx\n * // 기본 사용 / Basic usage\n * <IconProvider set=\"phosphor\" weight=\"regular\" size={20}>\n * <App />\n * </IconProvider>\n * \n * // Zustand와 함께 사용 / With Zustand\n * const iconConfig = useIconStore(state => state.iconConfig)\n * <IconProvider {...iconConfig}>\n * <App />\n * </IconProvider>\n * \n * // Lucide 아이콘 사용 / Using Lucide icons\n * <IconProvider set=\"lucide\" size={24} strokeWidth={1.5}>\n * <App />\n * </IconProvider>\n * ```\n * \n * @param props - IconProvider 컴포넌트 props / IconProvider component props\n * @returns IconProvider 컴포넌트 / IconProvider component\n */\nexport function IconProvider({\n set = defaultIconConfig.set,\n weight = defaultIconConfig.weight,\n size = defaultIconConfig.size,\n color = defaultIconConfig.color,\n strokeWidth = defaultIconConfig.strokeWidth,\n children,\n}: IconProviderProps) {\n const value: IconContextValue = {\n set,\n weight,\n size,\n color,\n strokeWidth,\n }\n\n return (\n <IconContext.Provider value={value}>\n {children}\n </IconContext.Provider>\n )\n}\n\n/**\n * useIconContext Hook\n * \n * Icon Context를 사용하는 Hook입니다.\n * Icon 컴포넌트 내부에서 사용됩니다.\n * \n * Hook to use Icon Context.\n * Used internally by Icon component.\n * \n * @returns Icon 설정 값 / Icon configuration value\n * \n * @example\n * ```tsx\n * // Icon 컴포넌트 내부에서 사용 / Used inside Icon component\n * const config = useIconContext()\n * const iconSet = config.set\n * const iconSize = config.size\n * ```\n */\nexport function useIconContext(): IconContextValue {\n return useContext(IconContext)\n}\n\n// Re-export types for convenience\nexport type { IconSet, PhosphorWeight, IconConfig } from './icon-store'\nexport { defaultIconConfig, getDefaultStrokeWidth } from './icon-store'\n\n","import React from 'react'\nimport type { LucideProps } from 'lucide-react'\nimport { merge, mergeMap } from '../../lib/utils'\nimport { icons, IconName, emotionIcons, statusIcons } from '../../lib/icons'\nimport { getIconFromProvider, initPhosphorIcons } from '../../lib/icon-providers'\nimport { resolveIconAlias } from '../../lib/icon-aliases'\nimport { useIconContext, type IconSet } from './IconProvider'\nimport { type PhosphorWeight } from './icon-store'\nimport type { AllIconName } from '../../lib/icon-names'\n\n/**\n * Icon 컴포넌트 Props\n * \n * Icon component props interface.\n * \n * @interface IconProps\n */\nexport interface IconProps {\n /** 아이콘 이름 / Icon name */\n name: AllIconName\n /** 아이콘 크기 (숫자 또는 문자열) / Icon size (number or string) */\n size?: number | string\n /** 추가 CSS 클래스 / Additional CSS classes */\n className?: string\n /** 감정 아이콘 타입 / Emotion icon type */\n emotion?: keyof typeof emotionIcons\n /** 상태 아이콘 타입 / Status icon type */\n status?: keyof typeof statusIcons\n /** 아이콘 프로바이더 오버라이드 (전역 설정 무시) / Icon provider override (ignores global config) */\n provider?: IconSet\n /** 부드러운 애니메이션 효과 / Smooth animation effect */\n animated?: boolean\n /** 펄스 애니메이션 / Pulse animation */\n pulse?: boolean\n /** 회전 애니메이션 / Spin animation */\n spin?: boolean\n /** 바운스 애니메이션 / Bounce animation */\n bounce?: boolean\n /** 색상 변형 / Color variant */\n variant?: 'default' | 'primary' | 'secondary' | 'success' | 'warning' | 'error' | 'muted'\n /** Phosphor 아이콘 weight 오버라이드 / Phosphor icon weight override */\n weight?: PhosphorWeight\n /** 스크린 리더용 라벨 (의미 있는 아이콘인 경우) / Screen reader label (for meaningful icons) */\n 'aria-label'?: string\n /** 장식용 아이콘인 경우 true (스크린 리더에서 숨김) / Set to true for decorative icons (hidden from screen readers) */\n 'aria-hidden'?: boolean\n}\n\n/**\n * Icon 컴포넌트\n * \n * 다중 아이콘 라이브러리(Lucide, Phosphor, Untitled)를 지원하는 통합 아이콘 컴포넌트입니다.\n * IconProvider를 통해 전역 설정을 관리할 수 있으며, 개별 아이콘에서도 설정을 오버라이드할 수 있습니다.\n * \n * Icon component that supports multiple icon libraries (Lucide, Phosphor, Untitled).\n * Global settings can be managed through IconProvider, and individual icons can override settings.\n * \n * @component\n * @example\n * ```tsx\n * // 기본 사용 / Basic usage\n * <Icon name=\"heart\" />\n * \n * // 크기 지정 / Specify size\n * <Icon name=\"user\" size={24} />\n * \n * // 색상 변형 / Color variant\n * <Icon name=\"check\" variant=\"success\" />\n * \n * // 애니메이션 / Animation\n * <Icon name=\"loader\" spin />\n * <Icon name=\"heart\" pulse />\n * \n * // 접근성 / Accessibility\n * <Icon name=\"search\" aria-label=\"검색\" />\n * <Icon name=\"decorative-icon\" aria-hidden />\n * \n * // 감정 아이콘 / Emotion icon\n * <Icon emotion=\"happy\" />\n * \n * // 상태 아이콘 / Status icon\n * <Icon status=\"loading\" spin />\n * ```\n * \n * @param props - Icon 컴포넌트 props / Icon component props\n * @returns Icon 컴포넌트 / Icon component\n */\nconst IconComponent = React.forwardRef<HTMLSpanElement, IconProps>(({\n name,\n size,\n className,\n emotion,\n status,\n provider,\n weight,\n animated = false,\n pulse = false,\n spin = false,\n bounce = false,\n variant = 'default',\n 'aria-label': ariaLabel,\n 'aria-hidden': ariaHidden\n}, ref) => {\n // Context에서 전역 설정 가져오기\n const config = useIconContext()\n \n // prop으로 오버라이드 가능, 없으면 Context에서 가져옴\n const iconSet = provider || config.set\n const iconSize = size ?? config.size\n const iconWeight = weight || config.weight\n const iconColor = config.color\n const iconStrokeWidth = config.strokeWidth ?? 1.25\n \n // 클라이언트 사이드에서만 아이콘 렌더링 (hydration 오류 방지)\n const [isClient, setIsClient] = React.useState(false)\n const [phosphorReady, setPhosphorReady] = React.useState(false)\n \n React.useEffect(() => {\n setIsClient(true)\n \n // Phosphor Icons 초기화 (provider가 phosphor일 때만)\n if (iconSet === 'phosphor') {\n initPhosphorIcons().then(() => {\n setPhosphorReady(true)\n })\n } else {\n setPhosphorReady(true)\n }\n }, [iconSet])\n\n // 감정이나 상태가 지정되면 해당 아이콘으로 오버라이드\n let iconName = emotion ? emotionIcons[emotion] : \n status ? statusIcons[status] : \n name\n \n // Alias 해결 (back, prev → arrowLeft 등)\n iconName = resolveIconAlias(iconName) as AllIconName\n \n // 색상 변형 클래스 (먼저 선언 - fallback에서 사용)\n const variantClasses = mergeMap({\n 'text-gray-900 dark:text-white': variant === 'default',\n 'text-blue-600 dark:text-blue-400': variant === 'primary',\n 'text-gray-600 dark:text-gray-400': variant === 'secondary',\n 'text-green-600 dark:text-green-400': variant === 'success',\n 'text-yellow-600 dark:text-yellow-400': variant === 'warning',\n 'text-red-600 dark:text-red-400': variant === 'error',\n 'text-gray-500 dark:text-gray-500': variant === 'muted',\n })\n \n // 서버사이드에서는 빈 span 반환 (hydration 오류 방지)\n // Return empty span on server-side (prevent hydration errors)\n if (!isClient || (iconSet === 'phosphor' && !phosphorReady)) {\n return (\n <span\n style={{ width: iconSize, height: iconSize }}\n className={merge(variantClasses, className)}\n aria-hidden={ariaHidden !== undefined ? ariaHidden : true}\n aria-label={ariaLabel}\n />\n )\n }\n\n // Provider에 따라 아이콘 가져오기\n type IconComponentType = React.ComponentType<LucideProps | React.SVGProps<SVGSVGElement> | Record<string, unknown>>\n let IconComponent: IconComponentType | null = null\n \n if (iconSet === 'lucide') {\n // 1. icons.ts에서 먼저 찾기 (실제 사용되는 아이콘만 포함)\n // 타입 단언: AllIconName에는 있지만 icons 객체에 없는 경우를 위해\n IconComponent = (icons[iconName as IconName] || null) as IconComponentType | null\n \n // 2. 없으면 동적으로 Lucide에서 가져오기 (fallback)\n if (!IconComponent) {\n IconComponent = getIconFromProvider(iconName, iconSet) as IconComponentType | null\n }\n } else {\n // Phosphor나 다른 provider는 getIconFromProvider 사용\n // phosphorReady가 true일 때만 호출됨 (위에서 체크)\n IconComponent = getIconFromProvider(iconName, iconSet) as IconComponentType | null\n }\n \n if (!IconComponent) {\n console.warn(`Icon \"${iconName}\" not found for provider \"${iconSet}\"`)\n // Fallback: 빈 원형 아이콘 표시 (에러 표시)\n // Fallback: display empty circle icon (error indicator)\n return (\n <span\n ref={ref}\n className={merge(\n 'inline-flex items-center justify-center rounded-full border-2 border-dashed border-gray-300 dark:border-gray-600',\n variantClasses,\n className\n )}\n style={{ width: iconSize, height: iconSize }}\n aria-label={ariaLabel || `아이콘을 찾을 수 없음: ${iconName}`}\n title={`Icon not found: ${iconName}`}\n >\n <span className=\"text-xs text-gray-400 dark:text-gray-500\" aria-hidden=\"true\">\n ?\n </span>\n </span>\n )\n }\n \n // 세트별 props 준비\n type IconPropsType = LucideProps & {\n size?: number\n width?: number | string\n height?: number | string\n color?: string\n weight?: PhosphorWeight\n strokeWidth?: number\n }\n \n const iconProps: IconPropsType = {\n size: typeof iconSize === 'number' ? iconSize : undefined,\n width: typeof iconSize === 'string' ? iconSize : iconSize,\n height: typeof iconSize === 'string' ? iconSize : iconSize,\n color: iconColor,\n } as IconPropsType\n \n // Phosphor는 weight 사용\n if (iconSet === 'phosphor') {\n iconProps.weight = iconWeight\n } else {\n // Lucide/Untitled는 strokeWidth 사용\n iconProps.strokeWidth = iconStrokeWidth\n }\n\n // 애니메이션 클래스 생성\n const animationClasses = mergeMap({\n 'animate-pulse': pulse,\n 'animate-spin': spin,\n 'animate-bounce': bounce,\n 'transition-all duration-200 ease-in-out': animated,\n })\n\n // 접근성 속성 결정 / Determine accessibility attributes\n // aria-label이 제공되면 사용, 없으면 aria-hidden이 true인지 확인\n // If aria-label is provided, use it; otherwise check if aria-hidden is true\n const accessibilityProps: React.AriaAttributes = {}\n \n if (ariaLabel) {\n accessibilityProps['aria-label'] = ariaLabel\n accessibilityProps['aria-hidden'] = false\n } else if (ariaHidden !== undefined) {\n accessibilityProps['aria-hidden'] = ariaHidden\n } else {\n // 기본값: 장식용으로 간주 (의미 있는 아이콘은 명시적으로 aria-label 제공 필요)\n // Default: considered decorative (meaningful icons should explicitly provide aria-label)\n accessibilityProps['aria-hidden'] = true\n }\n\n return (\n <span\n ref={ref}\n className={merge(\n 'inline-flex items-center justify-center',\n animationClasses,\n variantClasses,\n className\n )}\n style={{ width: iconSize, height: iconSize }}\n {...accessibilityProps}\n >\n {IconComponent && React.createElement(IconComponent, { \n ...iconProps,\n className: variantClasses,\n 'aria-hidden': true // SVG 내부 요소는 항상 숨김 (외부 span이 접근성 담당)\n } as React.ComponentProps<typeof IconComponent>)}\n </span>\n )\n})\n\nIconComponent.displayName = 'Icon'\n\n// 성능 최적화: React.memo 적용\n// Performance optimization: Apply React.memo\n// forwardRef와 함께 사용할 때는 React.memo로 감싸기\n// When using with forwardRef, wrap with React.memo\nconst MemoizedIcon = React.memo(IconComponent, (prevProps, nextProps) => {\n // props 비교 함수: 변경된 props만 체크\n // Props comparison function: only check changed props\n return (\n prevProps.name === nextProps.name &&\n prevProps.size === nextProps.size &&\n prevProps.className === nextProps.className &&\n prevProps.emotion === nextProps.emotion &&\n prevProps.status === nextProps.status &&\n prevProps.provider === nextProps.provider &&\n prevProps.animated === nextProps.animated &&\n prevProps.pulse === nextProps.pulse &&\n prevProps.spin === nextProps.spin &&\n prevProps.bounce === nextProps.bounce &&\n prevProps.variant === nextProps.variant &&\n prevProps.weight === nextProps.weight &&\n prevProps['aria-label'] === nextProps['aria-label'] &&\n prevProps['aria-hidden'] === nextProps['aria-hidden']\n )\n})\n\n// 타입 안전성을 위해 export\n// Export for type safety\nexport const Icon = MemoizedIcon as typeof IconComponent\n\nIcon.displayName = 'Icon'\n\n/**\n * EmotionIcon 컴포넌트\n * \n * 감정을 표현하는 아이콘 컴포넌트입니다.\n * Icon component for expressing emotions.\n * \n * @component\n * @example\n * ```tsx\n * <EmotionIcon emotion=\"happy\" />\n * <EmotionIcon emotion=\"sad\" size={24} />\n * ```\n */\nexport const EmotionIcon = React.forwardRef<HTMLSpanElement, Omit<IconProps, 'name'> & { emotion: keyof typeof emotionIcons }>(\n (props, ref) => <Icon ref={ref} name=\"smile\" {...props} />\n)\n\nEmotionIcon.displayName = 'EmotionIcon'\n\n/**\n * StatusIcon 컴포넌트\n * \n * 상태를 표현하는 아이콘 컴포넌트입니다.\n * Icon component for expressing status.\n * \n * @component\n * @example\n * ```tsx\n * <StatusIcon status=\"loading\" spin />\n * <StatusIcon status=\"success\" variant=\"success\" />\n * ```\n */\nexport const StatusIcon = React.forwardRef<HTMLSpanElement, Omit<IconProps, 'name'> & { status: keyof typeof statusIcons }>(\n (props, ref) => <Icon ref={ref} name=\"info\" {...props} />\n)\n\nStatusIcon.displayName = 'StatusIcon'\n\n/**\n * LoadingIcon 컴포넌트\n * \n * 로딩 상태를 표시하는 전용 아이콘 컴포넌트입니다.\n * Dedicated icon component for displaying loading status.\n * \n * @component\n * @example\n * ```tsx\n * <LoadingIcon />\n * <LoadingIcon size={32} />\n * ```\n */\nexport const LoadingIcon = React.forwardRef<HTMLDivElement, Omit<IconProps, 'name' | 'status'>>(\n (props, ref) => (\n <Icon ref={ref} name=\"loader\" status=\"loading\" spin aria-label=\"로딩 중\" {...props} />\n )\n)\n\nLoadingIcon.displayName = 'LoadingIcon'\n\n/**\n * SuccessIcon 컴포넌트\n * \n * 성공 상태를 표시하는 전용 아이콘 컴포넌트입니다.\n * Dedicated icon component for displaying success status.\n * \n * @component\n * @example\n * ```tsx\n * <SuccessIcon />\n * <SuccessIcon size={24} />\n * ```\n */\nexport const SuccessIcon = React.forwardRef<HTMLDivElement, Omit<IconProps, 'name' | 'status'>>(\n (props, ref) => (\n <Icon ref={ref} name=\"check\" status=\"success\" variant=\"success\" aria-label=\"성공\" {...props} />\n )\n)\n\nSuccessIcon.displayName = 'SuccessIcon'\n\n/**\n * ErrorIcon 컴포넌트\n * \n * 에러 상태를 표시하는 전용 아이콘 컴포넌트입니다.\n * Dedicated icon component for displaying error status.\n * \n * @component\n * @example\n * ```tsx\n * <ErrorIcon />\n * <ErrorIcon size={24} />\n * ```\n */\nexport const ErrorIcon = React.forwardRef<HTMLDivElement, Omit<IconProps, 'name' | 'status'>>(\n (props, ref) => (\n <Icon ref={ref} name=\"alertCircle\" status=\"error\" variant=\"error\" aria-label=\"오류\" {...props} />\n )\n)\n\nErrorIcon.displayName = 'ErrorIcon'\n\n","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Avatar 컴포넌트의 props / Avatar component props\n * @typedef {Object} AvatarProps\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - 아바타 크기 / Avatar size\n * @property {\"default\" | \"glass\"} [variant=\"default\"] - 아바타 스타일 변형 / Avatar style variant\n * @property {string} [src] - 이미지 URL / Image URL\n * @property {string} [alt] - 이미지 대체 텍스트 / Image alt text\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface AvatarProps extends React.HTMLAttributes<HTMLDivElement> {\n size?: \"sm\" | \"md\" | \"lg\"\n variant?: \"default\" | \"glass\"\n src?: string\n alt?: string\n}\n\n/**\n * AvatarImage 컴포넌트의 props\n * @typedef {Object} AvatarImageProps\n * @extends {React.ImgHTMLAttributes<HTMLImageElement>}\n */\nexport interface AvatarImageProps extends React.ImgHTMLAttributes<HTMLImageElement> {}\n\n/**\n * AvatarFallback 컴포넌트의 props\n * @typedef {Object} AvatarFallbackProps\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface AvatarFallbackProps extends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Avatar 컴포넌트 / Avatar component\n * \n * 사용자 프로필 이미지를 표시하는 컴포넌트입니다.\n * 이미지가 없을 경우 대체 텍스트나 초기 문자를 표시합니다.\n * \n * Component for displaying user profile images.\n * Shows fallback text or initials when image is not available.\n * \n * @component\n * @example\n * // 기본 사용 (이미지) / Basic usage (with image)\n * <Avatar src=\"/user.jpg\" alt=\"사용자\" />\n * \n * @example\n * // 대체 텍스트 / Fallback text\n * <Avatar alt=\"홍길동\">홍</Avatar>\n * \n * @example\n * // Glass 스타일 / Glass style\n * <Avatar variant=\"glass\" size=\"lg\" src=\"/user.jpg\" alt=\"사용자\" />\n * \n * @param {AvatarProps} props - Avatar 컴포넌트의 props / Avatar component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Avatar 컴포넌트 / Avatar component\n */\nconst Avatar = React.forwardRef<HTMLDivElement, AvatarProps>(\n ({ className, size = \"md\", variant = \"default\", src, alt, children, ...props }, ref) => {\n const sizeClasses = {\n sm: \"w-8 h-8\",\n md: \"w-10 h-10\", \n lg: \"w-12 h-12\"\n }\n\n const variantClasses = {\n default: \"\",\n glass: \"ring-2 ring-white/30 backdrop-blur-sm\"\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n \"relative flex shrink-0 overflow-hidden rounded-full\",\n sizeClasses[size],\n variantClasses[variant],\n className\n )}\n {...props}\n >\n {src ? (\n <AvatarImage src={src} alt={alt || \"avatar\"} />\n ) : (\n <AvatarFallback>\n {children || (alt ? alt.charAt(0).toUpperCase() : \"U\")}\n </AvatarFallback>\n )}\n </div>\n )\n }\n)\nAvatar.displayName = \"Avatar\"\n\n/**\n * AvatarImage 컴포넌트 / AvatarImage component\n * \n * 아바타 이미지를 표시하는 컴포넌트입니다.\n * Displays the avatar image.\n * \n * @component\n * @param {AvatarImageProps} props - AvatarImage 컴포넌트의 props / AvatarImage component props\n * @param {React.Ref<HTMLImageElement>} ref - img 요소 ref / img element ref\n * @returns {JSX.Element} AvatarImage 컴포넌트 / AvatarImage component\n */\nconst AvatarImage = React.forwardRef<HTMLImageElement, AvatarImageProps>(\n ({ className, ...props }, ref) => (\n <img\n ref={ref}\n className={merge(\"aspect-square h-full w-full object-cover object-center\", className)}\n {...props}\n />\n )\n)\nAvatarImage.displayName = \"AvatarImage\"\n\n/**\n * AvatarFallback 컴포넌트 / AvatarFallback component\n * \n * 아바타 이미지가 없을 때 표시되는 대체 컴포넌트입니다.\n * Fallback component displayed when avatar image is not available.\n * \n * @component\n * @param {AvatarFallbackProps} props - AvatarFallback 컴포넌트의 props / AvatarFallback component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} AvatarFallback 컴포넌트 / AvatarFallback component\n */\nconst AvatarFallback = React.forwardRef<HTMLDivElement, AvatarFallbackProps>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\n \"flex h-full w-full items-center justify-center rounded-full bg-gray-100 dark:bg-gray-800 text-gray-600 dark:text-gray-400 font-medium\",\n className\n )}\n {...props}\n />\n )\n)\nAvatarFallback.displayName = \"AvatarFallback\"\n\nexport { Avatar, AvatarImage, AvatarFallback } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Modal 컴포넌트의 props / Modal component props\n * @typedef {Object} ModalProps\n * @property {boolean} isOpen - 모달 열림/닫힘 상태 / Modal open/close state\n * @property {() => void} onClose - 모달 닫기 콜백 함수 / Modal close callback function\n * @property {React.ReactNode} children - 모달 내용 / Modal content\n * @property {\"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\" | \"3xl\"} [size=\"md\"] - 모달 크기 / Modal size\n * @property {boolean} [showCloseButton=true] - 닫기 버튼 표시 여부 / Show close button\n * @property {boolean} [closeOnOverlayClick=true] - 오버레이 클릭 시 닫기 여부 / Close on overlay click\n * @property {string} [title] - 모달 제목 / Modal title\n * @property {string} [description] - 모달 설명 / Modal description\n * @property {boolean} [showBackdrop=true] - 배경 오버레이 표시 여부 / Show backdrop overlay\n * @property {string} [backdropClassName] - 배경 오버레이 추가 CSS 클래스 / Additional CSS class for backdrop\n * @property {boolean} [centered=true] - 모달을 화면 중앙에 배치할지 여부 / Center modal on screen\n * @property {string} [className] - 모달 컨테이너 추가 CSS 클래스 / Additional CSS class for modal container\n */\nexport interface ModalProps {\n isOpen: boolean\n onClose: () => void\n children: React.ReactNode\n size?: \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\" | \"3xl\"\n showCloseButton?: boolean\n closeOnOverlayClick?: boolean\n title?: string\n description?: string\n showBackdrop?: boolean\n backdropClassName?: string\n centered?: boolean\n className?: string\n}\n\n// Ref 병합 유틸리티\nfunction useCombinedRefs<T>(...refs: (React.Ref<T> | undefined)[]): React.RefCallback<T> {\n return React.useCallback(\n (node: T) => {\n refs.forEach((ref) => {\n if (!ref) return;\n if (typeof ref === \"function\") {\n ref(node);\n } else {\n (ref as React.MutableRefObject<T | null>).current = node;\n }\n });\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n refs\n );\n}\n\n/**\n * Modal 컴포넌트 / Modal component\n * \n * 오버레이와 함께 표시되는 모달 다이얼로그 컴포넌트입니다.\n * ESC 키로 닫기, 오버레이 클릭으로 닫기, 접근성 속성(ARIA)을 지원합니다.\n * \n * Modal dialog component displayed with overlay.\n * Supports closing with ESC key, overlay click, and ARIA accessibility attributes.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * const [isOpen, setIsOpen] = useState(false)\n * \n * <Modal isOpen={isOpen} onClose={() => setIsOpen(false)}>\n * <p>모달 내용</p>\n * </Modal>\n * \n * @example\n * // 제목과 설명 포함 / With title and description\n * <Modal\n * isOpen={isOpen}\n * onClose={() => setIsOpen(false)}\n * title=\"확인\"\n * description=\"이 작업을 계속하시겠습니까?\"\n * >\n * <Button onClick={handleConfirm}>확인</Button>\n * </Modal>\n * \n * @example\n * // 큰 크기 모달 / Large size modal\n * <Modal\n * isOpen={isOpen}\n * onClose={() => setIsOpen(false)}\n * size=\"xl\"\n * closeOnOverlayClick={false}\n * >\n * <div>큰 모달 내용</div>\n * </Modal>\n * \n * @param {ModalProps} props - Modal 컴포넌트의 props / Modal component props\n * @param {React.Ref<HTMLDivElement>} ref - 모달 컨테이너 ref / Modal container ref\n * @returns {JSX.Element} Modal 컴포넌트 / Modal component\n */\nexport const Modal = React.forwardRef<HTMLDivElement, ModalProps>(\n ({ \n className,\n isOpen,\n onClose,\n children,\n size = \"md\",\n showCloseButton = true,\n closeOnOverlayClick = true,\n title,\n description,\n showBackdrop = true,\n backdropClassName,\n centered = true\n }, ref) => {\n const modalRef = React.useRef<HTMLDivElement>(null)\n const combinedRef = useCombinedRefs(ref, modalRef)\n\n // ESC 키로 모달 닫기 및 스크롤 잠금 (화면 흔들림 방지)\n React.useEffect(() => {\n const handleEscape = (e: KeyboardEvent) => {\n if (e.key === \"Escape\") {\n onClose()\n }\n }\n\n if (isOpen) {\n document.addEventListener(\"keydown\", handleEscape)\n // 스크롤바 너비 계산하여 padding 추가 (화면 흔들림 방지)\n const scrollbarWidth = window.innerWidth - document.documentElement.clientWidth\n document.body.style.overflow = \"hidden\"\n document.body.style.paddingRight = `${scrollbarWidth}px`\n }\n\n return () => {\n document.removeEventListener(\"keydown\", handleEscape)\n document.body.style.overflow = \"unset\"\n document.body.style.paddingRight = \"unset\"\n }\n }, [isOpen, onClose])\n\n // 모달 외부 클릭으로 닫기\n const handleOverlayClick = (e: React.MouseEvent) => {\n if (closeOnOverlayClick && e.target === e.currentTarget) {\n onClose()\n }\n }\n\n // 모달 크기 클래스 (반응형 포함)\n const sizeClasses = {\n sm: \"md:w-80\", // 20rem = 320px\n md: \"md:w-96\", // 24rem = 384px\n lg: \"md:w-[32rem]\", // 32rem = 512px\n xl: \"md:w-[38rem]\", // 38rem = 608px\n \"2xl\": \"md:w-[50rem]\", // 50rem = 800px\n \"3xl\": \"md:w-[72rem]\" // 72rem = 1152px (더 넓게)\n }\n\n // 접근성을 위한 ID 생성\n const titleId = title ? `modal-title-${React.useId()}` : undefined;\n const descriptionId = description ? `modal-description-${React.useId()}` : undefined;\n\n if (!isOpen) return null\n\n return (\n <div\n className={merge(\n \"fixed top-0 left-0 right-0 bottom-0 z-50 flex justify-center p-4 overflow-hidden\", // PWA 호환성 개선\n centered ? \"items-center\" : \"items-start pt-16\", // 64px 상단 여백\n className\n )}\n style={{\n width: '100vw',\n height: '100vh',\n minHeight: '100vh'\n }}\n onClick={handleOverlayClick}\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby={titleId}\n aria-describedby={descriptionId}\n >\n {/* 배경 오버레이 */}\n {showBackdrop && (\n <div className={merge(\n \"absolute inset-0 bg-black/60 backdrop-blur-md transition-opacity duration-300\",\n backdropClassName\n )} />\n )}\n \n {/* 모달 컨테이너 */}\n <div\n ref={combinedRef}\n className={merge(\n \"relative bg-white dark:bg-gray-800 rounded-lg shadow-2xl border border-gray-200/50 dark:border-gray-700/50 transform transition-all duration-300 ease-out overflow-hidden\",\n // 반응형: 모바일 전체, 데스크톱 고정\n \"w-[calc(100vw-2rem)]\", // 모바일: 화면 너비 - 패딩\n sizeClasses[size], // 데스크톱: md:w-[72rem]\n \"max-w-[calc(100vw-2rem)] md:max-w-none\", // 모바일: 최대 너비 제한, 데스크톱: 제한 없음\n \"flex-none\" // flex 컨테이너에서 크기 유지\n )}\n style={{\n animation: \"modalSlideIn 0.3s cubic-bezier(0.16, 1, 0.3, 1)\",\n maxHeight: \"90vh\",\n marginTop: centered ? 'auto' : '0',\n marginBottom: centered ? 'auto' : '0'\n }}\n >\n \n {/* 헤더 */}\n {title && (\n <div className=\"relative z-10 px-6 pt-6 pb-4 border-b border-gray-200/50 dark:border-gray-700/50\">\n {/* 타이틀과 닫기 버튼 - 같은 줄, 양쪽 끝 */}\n <div className=\"flex items-center justify-between gap-4 mb-2\">\n <h2 id={titleId} className=\"text-xl font-semibold text-gray-900 dark:text-white flex-1 min-w-0\">{title}</h2>\n {/* 닫기 버튼 - 타이틀과 같은 계층의 오른쪽 끝 */}\n {showCloseButton && (\n <button\n onClick={onClose}\n className=\"flex-shrink-0 p-2 text-gray-400 hover:text-gray-600 dark:hover:text-gray-300 transition-all duration-200 rounded-full hover:bg-gray-100 dark:hover:bg-gray-700 hover:scale-110 z-20\"\n aria-label=\"닫기\"\n >\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n </button>\n )}\n </div>\n {/* 설명 - 아래 줄 */}\n {description && (\n <p id={descriptionId} className=\"text-sm text-gray-600 dark:text-gray-400\">{description}</p>\n )}\n </div>\n )}\n \n {/* 타이틀이 없을 때만 별도 닫기 버튼 */}\n {!title && showCloseButton && (\n <button\n onClick={onClose}\n className=\"absolute top-4 right-4 p-2 text-gray-400 hover:text-gray-600 dark:hover:text-gray-300 transition-all duration-200 rounded-full hover:bg-gray-100 dark:hover:bg-gray-700 hover:scale-110 z-20\"\n aria-label=\"닫기\"\n >\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n </button>\n )}\n \n {/* 모달 내용 */}\n <div className={`relative z-10 ${title ? 'px-6 mb-6' : 'p-6'}`}>\n {children}\n </div>\n </div>\n </div>\n )\n})\n\nModal.displayName = \"Modal\" ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Container 컴포넌트의 props\n * @typedef {Object} ContainerProps\n * @property {\"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\"} [size=\"lg\"] - 컨테이너 최대 너비\n * @property {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"} [padding=\"md\"] - 내부 패딩 크기\n * @property {boolean} [centered=true] - 컨테이너를 중앙 정렬할지 여부\n * @property {boolean} [fluid=false] - 최대 너비 제한 없이 전체 너비 사용\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface ContainerProps extends React.HTMLAttributes<HTMLDivElement> {\n size?: \"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\"\n padding?: \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"\n centered?: boolean\n fluid?: boolean\n}\n\n/**\n * Container 컴포넌트\n * \n * 콘텐츠를 감싸는 컨테이너 컴포넌트입니다.\n * 반응형 최대 너비와 패딩을 제공하여 일관된 레이아웃을 구성합니다.\n * \n * @component\n * @example\n * // 기본 사용\n * <Container>\n * <h1>제목</h1>\n * <p>내용</p>\n * </Container>\n * \n * @example\n * // 작은 크기, 패딩 없음\n * <Container size=\"sm\" padding=\"none\">\n * <div>콘텐츠</div>\n * </Container>\n * \n * @example\n * // 전체 너비 사용\n * <Container fluid padding=\"xl\">\n * <div>전체 너비 콘텐츠</div>\n * </Container>\n * \n * @param {ContainerProps} props - Container 컴포넌트의 props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref\n * @returns {JSX.Element} Container 컴포넌트\n */\nconst Container = React.forwardRef<HTMLDivElement, ContainerProps>(\n ({ \n className, \n size = \"lg\",\n padding = \"md\",\n centered = true,\n fluid = false,\n ...props \n }, ref) => {\n const sizeClasses = {\n sm: \"max-w-2xl\", // 672px\n md: \"max-w-4xl\", // 896px\n lg: \"max-w-6xl\", // 1152px\n xl: \"max-w-7xl\", // 1280px\n full: \"max-w-full\"\n }\n\n const paddingClasses = {\n none: \"\",\n sm: \"px-4 py-8\", // 16px 좌우, 32px 상하\n md: \"px-6 py-12\", // 24px 좌우, 48px 상하\n lg: \"px-8 py-16\", // 32px 좌우, 64px 상하\n xl: \"px-12 py-20\" // 48px 좌우, 80px 상하\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n \"w-full\",\n !fluid && sizeClasses[size],\n paddingClasses[padding],\n centered && \"mx-auto\",\n \"bg-white/5 backdrop-blur-sm rounded-xl shadow-xl\",\n \"dark:bg-slate-900/5\",\n className\n )}\n {...props}\n />\n )\n }\n)\nContainer.displayName = \"Container\"\n\nexport { Container } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Grid 컴포넌트의 props\n * @typedef {Object} GridProps\n * @property {1|2|3|4|5|6|7|8|9|10|11|12} [cols=1] - 그리드 열 개수\n * @property {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"} [gap=\"md\"] - 그리드 아이템 간 간격\n * @property {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"} [gapX] - 가로 간격 (gap보다 우선)\n * @property {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"} [gapY] - 세로 간격\n * @property {boolean} [responsive=true] - 반응형 그리드 활성화 (모바일: 1열, 태블릿: 2열, 데스크톱: 지정 열)\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface GridProps extends React.HTMLAttributes<HTMLDivElement> {\n cols?: 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12\n gap?: \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"\n gapX?: \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"\n gapY?: \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"\n responsive?: boolean\n}\n\n/**\n * Grid 컴포넌트\n * \n * CSS Grid를 사용한 그리드 레이아웃 컴포넌트입니다.\n * 반응형 그리드를 지원하여 모바일부터 데스크톱까지 최적화된 레이아웃을 제공합니다.\n * \n * @component\n * @example\n * // 기본 3열 그리드\n * <Grid cols={3} gap=\"md\">\n * <div>아이템 1</div>\n * <div>아이템 2</div>\n * <div>아이템 3</div>\n * </Grid>\n * \n * @example\n * // 가로/세로 간격 분리\n * <Grid cols={4} gapX=\"lg\" gapY=\"sm\">\n * {items.map(item => <div key={item.id}>{item.content}</div>)}\n * </Grid>\n * \n * @example\n * // 반응형 비활성화 (고정 그리드)\n * <Grid cols={6} responsive={false} gap=\"lg\">\n * <div>고정 6열</div>\n * </Grid>\n * \n * @param {GridProps} props - Grid 컴포넌트의 props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref\n * @returns {JSX.Element} Grid 컴포넌트\n */\nconst Grid = React.forwardRef<HTMLDivElement, GridProps>(\n ({ \n className, \n cols = 1,\n gap = \"md\",\n gapX,\n gapY,\n responsive = true,\n ...props \n }, ref) => {\n const colsClasses = {\n 1: \"grid-cols-1\",\n 2: \"grid-cols-1 sm:grid-cols-2\",\n 3: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-3\",\n 4: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-4\",\n 5: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-5\",\n 6: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-6\",\n 7: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-7\",\n 8: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-8\",\n 9: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-9\",\n 10: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-10\",\n 11: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-11\",\n 12: \"grid-cols-1 sm:grid-cols-2 lg:grid-cols-12\"\n }\n\n const gapClasses = {\n none: \"gap-0\",\n sm: \"gap-4\", // 16px\n md: \"gap-6\", // 24px\n lg: \"gap-8\", // 32px\n xl: \"gap-12\" // 48px\n }\n\n const gapXClasses = {\n none: \"gap-x-0\",\n sm: \"gap-x-4\", // 16px\n md: \"gap-x-6\", // 24px\n lg: \"gap-x-8\", // 32px\n xl: \"gap-x-12\" // 48px\n }\n\n const gapYClasses = {\n none: \"gap-y-0\",\n sm: \"gap-y-4\", // 16px\n md: \"gap-y-6\", // 24px\n lg: \"gap-y-8\", // 32px\n xl: \"gap-y-12\" // 48px\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n \"grid\",\n responsive ? colsClasses[cols] : `grid-cols-${cols}`,\n gapX ? gapXClasses[gapX] : gapClasses[gap],\n gapY && gapYClasses[gapY],\n className\n )}\n {...props}\n />\n )\n }\n)\nGrid.displayName = \"Grid\"\n\nexport { Grid } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Stack 컴포넌트의 props\n * @typedef {Object} StackProps\n * @property {\"vertical\" | \"horizontal\"} [direction=\"vertical\"] - 스택 방향\n * @property {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"} [spacing=\"md\"] - 아이템 간 간격\n * @property {\"start\" | \"center\" | \"end\" | \"stretch\"} [align=\"start\"] - 교차축 정렬\n * @property {\"start\" | \"center\" | \"end\" | \"between\" | \"around\" | \"evenly\"} [justify=\"start\"] - 주축 정렬\n * @property {boolean} [wrap=false] - 아이템 줄바꿈 허용\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface StackProps extends React.HTMLAttributes<HTMLDivElement> {\n direction?: \"vertical\" | \"horizontal\"\n spacing?: \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"\n align?: \"start\" | \"center\" | \"end\" | \"stretch\"\n justify?: \"start\" | \"center\" | \"end\" | \"between\" | \"around\" | \"evenly\"\n wrap?: boolean\n}\n\n/**\n * Stack 컴포넌트\n * \n * Flexbox를 사용한 스택 레이아웃 컴포넌트입니다.\n * 수직 또는 수평 방향으로 아이템을 배치하고 정렬할 수 있습니다.\n * \n * @component\n * @example\n * // 기본 수직 스택\n * <Stack spacing=\"md\">\n * <div>아이템 1</div>\n * <div>아이템 2</div>\n * </Stack>\n * \n * @example\n * // 수평 스택, 중앙 정렬\n * <Stack direction=\"horizontal\" spacing=\"lg\" align=\"center\" justify=\"between\">\n * <Button>왼쪽</Button>\n * <Button>오른쪽</Button>\n * </Stack>\n * \n * @example\n * // 줄바꿈 허용\n * <Stack direction=\"horizontal\" wrap spacing=\"sm\">\n * {tags.map(tag => <Badge key={tag}>{tag}</Badge>)}\n * </Stack>\n * \n * @param {StackProps} props - Stack 컴포넌트의 props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref\n * @returns {JSX.Element} Stack 컴포넌트\n */\nconst Stack = React.forwardRef<HTMLDivElement, StackProps>(\n ({ \n className, \n direction = \"vertical\",\n spacing = \"md\",\n align = \"start\",\n justify = \"start\",\n wrap = false,\n ...props \n }, ref) => {\n const directionClasses = {\n vertical: \"flex flex-col\",\n horizontal: \"flex flex-row\"\n }\n\n const spacingClasses = {\n none: \"\",\n sm: direction === \"vertical\" ? \"space-y-4\" : \"space-x-4\", // 16px\n md: direction === \"vertical\" ? \"space-y-6\" : \"space-x-6\", // 24px\n lg: direction === \"vertical\" ? \"space-y-8\" : \"space-x-8\", // 32px\n xl: direction === \"vertical\" ? \"space-y-12\" : \"space-x-12\" // 48px\n }\n\n const alignClasses = {\n start: \"items-start\",\n center: \"items-center\",\n end: \"items-end\",\n stretch: \"items-stretch\"\n }\n\n const justifyClasses = {\n start: \"justify-start\",\n center: \"justify-center\",\n end: \"justify-end\",\n between: \"justify-between\",\n around: \"justify-around\",\n evenly: \"justify-evenly\"\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n directionClasses[direction],\n spacingClasses[spacing],\n alignClasses[align],\n justifyClasses[justify],\n wrap && \"flex-wrap\",\n className\n )}\n {...props}\n />\n )\n }\n)\nStack.displayName = \"Stack\"\n\nexport { Stack } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Divider 컴포넌트의 props / Divider component props\n * @typedef {Object} DividerProps\n * @property {\"horizontal\" | \"vertical\"} [orientation=\"horizontal\"] - Divider 방향 / Divider orientation\n * @property {\"solid\" | \"dashed\" | \"dotted\" | \"gradient\" | \"glass\"} [variant=\"solid\"] - Divider 스타일 변형 / Divider style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Divider 크기 / Divider size\n * @property {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"} [spacing=\"md\"] - Divider 주변 여백 / Divider spacing\n * @property {\"default\" | \"muted\" | \"primary\" | \"secondary\"} [color=\"default\"] - Divider 색상 / Divider color\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface DividerProps extends React.HTMLAttributes<HTMLDivElement> {\n orientation?: \"horizontal\" | \"vertical\"\n variant?: \"solid\" | \"dashed\" | \"dotted\" | \"gradient\" | \"glass\"\n size?: \"sm\" | \"md\" | \"lg\"\n spacing?: \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\"\n color?: \"default\" | \"muted\" | \"primary\" | \"secondary\"\n}\n\n/**\n * Divider 컴포넌트 / Divider component\n * \n * 콘텐츠를 구분하는 구분선 컴포넌트입니다.\n * 가로/세로 방향, 다양한 스타일과 색상을 지원합니다.\n * \n * Divider component for separating content.\n * Supports horizontal/vertical orientation, various styles and colors.\n * \n * @component\n * @example\n * // 기본 사용 (가로) / Basic usage (horizontal)\n * <Divider />\n * \n * @example\n * // 세로 구분선 / Vertical divider\n * <div className=\"flex\">\n * <div>왼쪽</div>\n * <Divider orientation=\"vertical\" />\n * <div>오른쪽</div>\n * </div>\n * \n * @example\n * // 다양한 스타일 / Various styles\n * <Divider variant=\"dashed\" spacing=\"lg\" />\n * <Divider variant=\"gradient\" color=\"primary\" />\n * \n * @param {DividerProps} props - Divider 컴포넌트의 props / Divider component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Divider 컴포넌트 / Divider component\n */\nconst DividerComponent = React.forwardRef<HTMLDivElement, DividerProps>(\n ({ \n className, \n orientation = \"horizontal\",\n variant = \"solid\",\n size = \"md\",\n spacing = \"md\",\n color = \"default\",\n ...props \n }, ref) => {\n const orientationClasses = React.useMemo(() => ({\n horizontal: \"w-full\",\n vertical: \"h-full w-px\"\n }), [])\n\n const sizeClasses = React.useMemo(() => ({\n sm: orientation === \"horizontal\" ? \"h-px\" : \"w-px\",\n md: orientation === \"horizontal\" ? \"h-0.5\" : \"w-0.5\", // 2px\n lg: orientation === \"horizontal\" ? \"h-1\" : \"w-1\" // 4px\n }), [orientation])\n\n const variantClasses = React.useMemo(() => ({\n solid: \"\",\n dashed: \"border-dashed\",\n dotted: \"border-dotted\",\n gradient: orientation === \"horizontal\" \n ? \"bg-gradient-to-r from-transparent via-gray-300 to-transparent dark:via-gray-600\"\n : \"bg-gradient-to-b from-transparent via-gray-300 to-transparent dark:via-gray-600\",\n glass: orientation === \"horizontal\"\n ? \"bg-gradient-to-r from-transparent via-white/30 to-transparent\"\n : \"bg-gradient-to-b from-transparent via-white/30 to-transparent\"\n }), [orientation])\n\n const colorClasses = React.useMemo(() => ({\n default: \"bg-gray-200 dark:bg-gray-700\",\n muted: \"bg-gray-100 dark:bg-gray-800\",\n primary: \"bg-blue-200 dark:bg-blue-700\",\n secondary: \"bg-gray-300 dark:bg-gray-600\"\n }), [])\n\n const spacingClasses = React.useMemo(() => ({\n none: \"\",\n sm: orientation === \"horizontal\" ? \"my-4\" : \"mx-4\", // 16px\n md: orientation === \"horizontal\" ? \"my-6\" : \"mx-6\", // 24px\n lg: orientation === \"horizontal\" ? \"my-8\" : \"mx-8\", // 32px\n xl: orientation === \"horizontal\" ? \"my-12\" : \"mx-12\" // 48px\n }), [orientation])\n\n return (\n <div\n ref={ref}\n className={merge(\n \"flex-shrink-0\",\n orientationClasses[orientation],\n sizeClasses[size],\n variant === \"gradient\" ? variantClasses[variant] : colorClasses[color],\n variant !== \"gradient\" && variantClasses[variant],\n spacingClasses[spacing],\n className\n )}\n {...props}\n />\n )\n }\n)\n\nDividerComponent.displayName = \"Divider\"\n\nconst Divider = React.memo(DividerComponent)\n\nexport { Divider } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Card 컴포넌트의 props / Card component props\n * @typedef {Object} CardProps\n * @property {\"default\" | \"outline\" | \"elevated\"} [variant=\"default\"] - 카드 스타일 변형 / Card style variant\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CardProps extends React.HTMLAttributes<HTMLDivElement> {\n variant?: \"default\" | \"outline\" | \"elevated\"\n}\n\n/**\n * Card 컴포넌트 / Card component\n * \n * 콘텐츠를 카드 형태로 표시하는 컴포넌트입니다.\n * CardHeader, CardTitle, CardDescription, CardContent, CardFooter와 함께 사용합니다.\n * \n * Component that displays content in card format.\n * Used with CardHeader, CardTitle, CardDescription, CardContent, and CardFooter.\n * \n * @component\n * @example\n * // 기본 카드 / Basic card\n * <Card>\n * <CardHeader>\n * <CardTitle>카드 제목</CardTitle>\n * <CardDescription>카드 설명</CardDescription>\n * </CardHeader>\n * <CardContent>\n * <p>카드 내용</p>\n * </CardContent>\n * <CardFooter>\n * <Button>액션</Button>\n * </CardFooter>\n * </Card>\n * \n * @example\n * // Elevated 스타일 / Elevated style\n * <Card variant=\"elevated\">\n * <CardContent>강조된 카드</CardContent>\n * </Card>\n * \n * @param {CardProps} props - Card 컴포넌트의 props / Card component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Card 컴포넌트 / Card component\n */\nconst Card = React.forwardRef<HTMLDivElement, CardProps>(\n ({ className, variant = \"default\", ...props }, ref) => {\n const variantClasses = {\n default: \"bg-white dark:bg-slate-800 border border-slate-200 dark:border-slate-700\",\n outline: \"bg-transparent border-2 border-slate-300 dark:border-slate-600\",\n elevated: \"bg-white dark:bg-slate-800 shadow-lg border border-slate-200 dark:border-slate-700\"\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n \"rounded-lg p-6\",\n variantClasses[variant],\n className\n )}\n {...props}\n />\n )\n }\n)\n\nCard.displayName = \"Card\"\n\n/**\n * CardHeader 컴포넌트의 props / CardHeader component props\n * @typedef {Object} CardHeaderProps\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CardHeaderProps extends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * CardHeader 컴포넌트 / CardHeader component\n * 카드의 헤더 영역을 표시합니다. CardTitle과 CardDescription을 포함합니다.\n * Displays the header area of a card. Contains CardTitle and CardDescription.\n * \n * @component\n * @param {CardHeaderProps} props - CardHeader 컴포넌트의 props / CardHeader component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} CardHeader 컴포넌트 / CardHeader component\n */\nconst CardHeader = React.forwardRef<HTMLDivElement, CardHeaderProps>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"flex flex-col space-y-1.5 p-6\", className)}\n {...props}\n />\n )\n)\n\nCardHeader.displayName = \"CardHeader\"\n\n/**\n * CardTitle 컴포넌트의 props / CardTitle component props\n * @typedef {Object} CardTitleProps\n * @extends {React.HTMLAttributes<HTMLHeadingElement>}\n */\nexport interface CardTitleProps extends React.HTMLAttributes<HTMLHeadingElement> {}\n\n/**\n * CardTitle 컴포넌트 / CardTitle component\n * 카드의 제목을 표시합니다. h3 태그로 렌더링됩니다.\n * Displays the card title. Renders as h3 tag.\n * \n * @component\n * @param {CardTitleProps} props - CardTitle 컴포넌트의 props / CardTitle component props\n * @param {React.Ref<HTMLParagraphElement>} ref - h3 요소 ref / h3 element ref\n * @returns {JSX.Element} CardTitle 컴포넌트 / CardTitle component\n */\nconst CardTitle = React.forwardRef<HTMLParagraphElement, CardTitleProps>(\n ({ className, ...props }, ref) => (\n <h3\n ref={ref}\n className={merge(\n \"text-2xl font-semibold leading-none tracking-tight\",\n className\n )}\n {...props}\n />\n )\n)\n\nCardTitle.displayName = \"CardTitle\"\n\n/**\n * CardDescription 컴포넌트의 props / CardDescription component props\n * @typedef {Object} CardDescriptionProps\n * @extends {React.HTMLAttributes<HTMLParagraphElement>}\n */\nexport interface CardDescriptionProps extends React.HTMLAttributes<HTMLParagraphElement> {}\n\n/**\n * CardDescription 컴포넌트 / CardDescription component\n * 카드의 설명 텍스트를 표시합니다.\n * Displays the card description text.\n * \n * @component\n * @param {CardDescriptionProps} props - CardDescription 컴포넌트의 props / CardDescription component props\n * @param {React.Ref<HTMLParagraphElement>} ref - p 요소 ref / p element ref\n * @returns {JSX.Element} CardDescription 컴포넌트 / CardDescription component\n */\nconst CardDescription = React.forwardRef<HTMLParagraphElement, CardDescriptionProps>(\n ({ className, ...props }, ref) => (\n <p\n ref={ref}\n className={merge(\"text-sm text-slate-500 dark:text-slate-400\", className)}\n {...props}\n />\n )\n)\n\nCardDescription.displayName = \"CardDescription\"\n\n/**\n * CardContent 컴포넌트의 props / CardContent component props\n * @typedef {Object} CardContentProps\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CardContentProps extends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * CardContent 컴포넌트 / CardContent component\n * 카드의 메인 콘텐츠 영역을 표시합니다.\n * Displays the main content area of a card.\n * \n * @component\n * @param {CardContentProps} props - CardContent 컴포넌트의 props / CardContent component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} CardContent 컴포넌트 / CardContent component\n */\nconst CardContent = React.forwardRef<HTMLDivElement, CardContentProps>(\n ({ className, ...props }, ref) => (\n <div ref={ref} className={merge(\"p-6 pt-0\", className)} {...props} />\n )\n)\n\nCardContent.displayName = \"CardContent\"\n\n/**\n * CardFooter 컴포넌트의 props / CardFooter component props\n * @typedef {Object} CardFooterProps\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CardFooterProps extends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * CardFooter 컴포넌트 / CardFooter component\n * 카드의 푸터 영역을 표시합니다. 주로 액션 버튼을 배치합니다.\n * Displays the footer area of a card. Typically used for action buttons.\n * \n * @component\n * @param {CardFooterProps} props - CardFooter 컴포넌트의 props / CardFooter component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} CardFooter 컴포넌트 / CardFooter component\n */\nconst CardFooter = React.forwardRef<HTMLDivElement, CardFooterProps>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"flex items-center p-6 pt-0\", className)}\n {...props}\n />\n )\n)\n\nCardFooter.displayName = \"CardFooter\"\n\nexport { Card, CardHeader, CardFooter, CardTitle, CardDescription, CardContent } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Card, CardProps } from \"./Card\"\n\n/**\n * Panel 컴포넌트의 props / Panel component props\n * @typedef {Object} PanelProps\n * @property {\"default\" | \"solid\" | \"glass\" | \"outline\" | \"elevated\" | \"neon\" | \"holographic\" | \"cyberpunk\" | \"minimal\" | \"luxury\"} [style=\"default\"] - Panel 스타일 / Panel style\n * @property {\"none\" | \"glow\" | \"shadow\" | \"gradient\" | \"animated\"} [effect=\"none\"] - Panel 효과 / Panel effect\n * @property {number} [transparency=1] - 투명도 (0-1) / Transparency (0-1)\n * @property {number} [blurIntensity=0] - backdrop-blur 강도 (px) / Backdrop blur intensity (px)\n * @property {number} [borderOpacity=1] - 보더 투명도 (0-1) / Border opacity (0-1)\n * @property {number} [shadowOpacity=1] - 그림자 투명도 (0-1) / Shadow opacity (0-1)\n * @property {number} [glowIntensity=0] - 글로우 강도 (px) / Glow intensity (px)\n * @property {string} [glowColor=\"blue\"] - 글로우 색상 / Glow color\n * @property {boolean} [particleEffect=false] - 파티클 효과 활성화 / Enable particle effect\n * @property {boolean} [hoverEffect=false] - 호버 효과 활성화 / Enable hover effect\n * @property {boolean} [animationEffect=false] - 애니메이션 효과 활성화 / Enable animation effect\n * @property {\"none\" | \"small\" | \"sm\" | \"medium\" | \"md\" | \"large\" | \"lg\" | \"xl\" | \"custom\"} [padding=\"md\"] - 패딩 크기 / Padding size\n * @property {string} [customPadding] - 커스텀 패딩 / Custom padding\n * @property {\"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\" | \"custom\"} [rounded=\"lg\"] - 둥근 모서리 크기 / Rounded corner size\n * @property {string} [customRounded] - 커스텀 둥근 모서리 / Custom rounded corners\n * @property {\"solid\" | \"gradient\" | \"pattern\" | \"image\" | \"video\"} [background=\"solid\"] - 배경 타입 / Background type\n * @property {string[]} [gradientColors] - 그라디언트 색상 배열 / Gradient color array\n * @property {\"dots\" | \"lines\" | \"grid\" | \"waves\" | \"custom\"} [patternType=\"dots\"] - 패턴 타입 / Pattern type\n * @property {string} [backgroundImage] - 배경 이미지 URL / Background image URL\n * @property {string} [backgroundVideo] - 배경 비디오 URL / Background video URL\n * @property {boolean} [interactive=false] - 인터랙티브 모드 활성화 / Enable interactive mode\n * @property {number} [hoverScale=1.05] - 호버 시 스케일 / Scale on hover\n * @property {number} [hoverRotate=0] - 호버 시 회전 각도 / Rotation angle on hover\n * @property {boolean} [hoverGlow=false] - 호버 시 글로우 효과 / Glow effect on hover\n * @extends {Omit<CardProps, 'variant' | 'style'>}\n */\nexport interface PanelProps extends Omit<CardProps, 'variant' | 'style'> {\n // 🆕 Panel 전용 고급 속성들\n style?: \"default\" | \"solid\" | \"glass\" | \"outline\" | \"elevated\" | \"neon\" | \"holographic\" | \"cyberpunk\" | \"minimal\" | \"luxury\"\n effect?: \"none\" | \"glow\" | \"shadow\" | \"gradient\" | \"animated\"\n \n // 고급 스타일링\n transparency?: number // 0-1 사이 투명도\n blurIntensity?: number // backdrop-blur 강도\n borderOpacity?: number // 보더 투명도\n shadowOpacity?: number // 그림자 투명도\n glowIntensity?: number // 글로우 강도\n glowColor?: string // 글로우 색상\n \n // 고급 효과\n particleEffect?: boolean\n hoverEffect?: boolean\n animationEffect?: boolean\n \n // 레이아웃 옵션\n padding?: \"none\" | \"small\" | \"sm\" | \"medium\" | \"md\" | \"large\" | \"lg\" | \"xl\" | \"custom\"\n customPadding?: string\n rounded?: \"none\" | \"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\" | \"custom\"\n customRounded?: string\n \n // 배경 옵션\n background?: \"solid\" | \"gradient\" | \"pattern\" | \"image\" | \"video\"\n gradientColors?: string[]\n patternType?: \"dots\" | \"lines\" | \"grid\" | \"waves\" | \"custom\"\n backgroundImage?: string\n backgroundVideo?: string\n \n // 인터랙션\n interactive?: boolean\n hoverScale?: number\n hoverRotate?: number\n hoverGlow?: boolean\n}\n\n/**\n * Panel 컴포넌트 / Panel component\n * \n * 고급 스타일링 옵션을 가진 패널 컴포넌트입니다.\n * 다양한 스타일, 효과, 배경 옵션을 지원합니다.\n * Card 컴포넌트를 기반으로 하며, 추가적인 고급 기능을 제공합니다.\n * \n * Panel component with advanced styling options.\n * Supports various styles, effects, and background options.\n * Based on Card component with additional advanced features.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Panel>\n * <div>내용</div>\n * </Panel>\n * \n * @example\n * // Glass 스타일 / Glass style\n * <Panel style=\"glass\" effect=\"glow\">\n * <div>Glass 패널</div>\n * </Panel>\n * \n * @example\n * // 인터랙티브 패널 / Interactive panel\n * <Panel \n * style=\"neon\"\n * interactive\n * hoverScale={1.1}\n * hoverGlow\n * >\n * <div>호버 효과</div>\n * </Panel>\n * \n * @param {PanelProps} props - Panel 컴포넌트의 props / Panel component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Panel 컴포넌트 / Panel component\n */\nconst Panel = React.forwardRef<HTMLDivElement, PanelProps>(\n ({ \n className,\n style = \"default\",\n effect = \"none\",\n transparency = 1,\n blurIntensity = 0,\n borderOpacity = 1,\n shadowOpacity = 1,\n glowIntensity = 0,\n glowColor = \"blue\",\n particleEffect = false,\n hoverEffect = false,\n animationEffect = false,\n padding = \"md\",\n customPadding,\n rounded = \"lg\",\n customRounded,\n background = \"solid\",\n gradientColors = [\"#3B82F6\", \"#8B5CF6\"],\n patternType = \"dots\",\n backgroundImage,\n backgroundVideo,\n interactive = false,\n hoverScale = 1.05,\n hoverRotate = 0,\n hoverGlow = false,\n children,\n ...cardProps \n }, ref): React.ReactElement => {\n \n // 스타일별 클래스 생성 - useMemo로 메모이제이션\n const styleClasses = React.useMemo(() => {\n const baseClasses = \"transition-all duration-300\"\n \n switch (style) {\n case \"solid\":\n return merge(baseClasses, \"bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700\")\n case \"glass\":\n return merge(baseClasses, \"bg-white/10 backdrop-blur-md border border-white/20\")\n case \"outline\":\n return merge(baseClasses, \"bg-transparent border border-gray-300 dark:border-gray-600\")\n case \"elevated\":\n return merge(baseClasses, \"bg-white dark:bg-gray-800 shadow-lg border border-gray-100 dark:border-gray-700\")\n case \"neon\":\n return merge(baseClasses, \"bg-gray-900 border border-cyan-400/30 shadow-lg shadow-cyan-400/20\")\n case \"holographic\":\n return merge(baseClasses, \"bg-gradient-to-br from-white/20 via-purple-500/20 to-cyan-500/20 backdrop-blur-sm border border-white/30\")\n case \"cyberpunk\":\n return merge(baseClasses, \"bg-gray-900 border-2 border-pink-500 shadow-lg shadow-pink-500/30\")\n case \"minimal\":\n return merge(baseClasses, \"bg-white border border-gray-200 shadow-sm\")\n case \"luxury\":\n return merge(baseClasses, \"bg-gradient-to-br from-amber-50 to-yellow-100 border border-amber-200 shadow-xl\")\n default:\n return merge(baseClasses, \"bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700\")\n }\n }, [style])\n \n // 효과별 클래스 생성 - useMemo로 메모이제이션\n const effectClasses = React.useMemo(() => {\n switch (effect) {\n case \"glow\":\n return \"shadow-2xl shadow-blue-500/20 dark:shadow-cyan-400/20\"\n case \"shadow\":\n return \"shadow-xl\"\n case \"gradient\":\n return \"bg-gradient-to-r from-blue-500/10 via-purple-500/10 to-cyan-500/10\"\n case \"animated\":\n return \"animate-pulse\"\n default:\n return \"\"\n }\n }, [effect])\n \n // 패딩 클래스 생성 - useMemo로 메모이제이션\n const paddingClasses = React.useMemo(() => {\n if (customPadding) return customPadding\n \n switch (padding) {\n case \"none\": return \"p-0\"\n case \"small\":\n case \"sm\": return \"p-3\"\n case \"medium\":\n case \"md\": return \"p-6\"\n case \"large\":\n case \"lg\": return \"p-8\"\n case \"xl\": return \"p-12\"\n default: return \"p-6\"\n }\n }, [padding, customPadding])\n \n // 둥근 모서리 클래스 생성 - useMemo로 메모이제이션\n const roundedClasses = React.useMemo(() => {\n if (customRounded) return customRounded\n \n switch (rounded) {\n case \"none\": return \"rounded-none\"\n case \"sm\": return \"rounded-sm\"\n case \"md\": return \"rounded-md\"\n case \"lg\": return \"rounded-lg\"\n case \"xl\": return \"rounded-xl\"\n case \"full\": return \"rounded-full\"\n default: return \"rounded-lg\"\n }\n }, [rounded, customRounded])\n \n // 패턴 배경 생성 - useMemo로 메모이제이션\n const patternBackground = React.useMemo(() => {\n switch (patternType) {\n case \"dots\":\n return \"radial-gradient(circle, #000 1px, transparent 1px)\"\n case \"lines\":\n return \"linear-gradient(45deg, #000 1px, transparent 1px)\"\n case \"grid\":\n return \"linear-gradient(#000 1px, transparent 1px), linear-gradient(90deg, #000 1px, transparent 1px)\"\n case \"waves\":\n return \"repeating-linear-gradient(45deg, transparent, transparent 10px, rgba(0,0,0,0.1) 10px, rgba(0,0,0,0.1) 20px)\"\n default:\n return \"\"\n }\n }, [patternType])\n \n // 배경 스타일 생성 - useMemo로 메모이제이션\n const backgroundStyles = React.useMemo((): React.CSSProperties => {\n const styles: React.CSSProperties = {\n opacity: transparency,\n }\n \n if (blurIntensity > 0) {\n styles.backdropFilter = `blur(${blurIntensity}px)`\n }\n \n if (borderOpacity < 1) {\n styles.borderColor = `rgba(0, 0, 0, ${borderOpacity})`\n }\n \n if (shadowOpacity < 1) {\n styles.boxShadow = `0 4px 6px -1px rgba(0, 0, 0, ${shadowOpacity * 0.1})`\n }\n \n if (glowIntensity > 0) {\n styles.boxShadow = `${styles.boxShadow || ''}, 0 0 ${glowIntensity * 10}px ${glowColor}`\n }\n \n switch (background) {\n case \"gradient\":\n styles.background = `linear-gradient(135deg, ${gradientColors.join(', ')})`\n break\n case \"pattern\":\n styles.backgroundImage = patternBackground\n break\n case \"image\":\n if (backgroundImage) {\n styles.backgroundImage = `url(${backgroundImage})`\n styles.backgroundSize = 'cover'\n styles.backgroundPosition = 'center'\n }\n break\n case \"video\":\n // 비디오 배경은 별도 요소로 처리\n break\n }\n \n return styles\n }, [transparency, blurIntensity, borderOpacity, shadowOpacity, glowIntensity, glowColor, background, gradientColors, patternBackground, backgroundImage])\n \n // 호버 효과 클래스 생성 - useMemo로 메모이제이션\n const hoverClasses = React.useMemo(() => {\n if (!interactive) return \"\"\n \n const classes = []\n \n if (hoverScale !== 1) {\n classes.push(`hover:scale-${hoverScale}`)\n }\n \n if (hoverRotate !== 0) {\n classes.push(`hover:rotate-${hoverRotate}`)\n }\n \n if (hoverGlow) {\n classes.push(\"hover:shadow-2xl hover:shadow-blue-500/30\")\n }\n \n return classes.join(\" \")\n }, [interactive, hoverScale, hoverRotate, hoverGlow])\n \n // Panel 전용 클래스들 - useMemo로 메모이제이션\n const panelClasses = React.useMemo(() => merge(\n \"panel-component\",\n `panel-${style}`,\n `panel-effect-${effect}`,\n styleClasses,\n effectClasses,\n paddingClasses,\n roundedClasses,\n hoverClasses,\n className\n ), [style, effect, styleClasses, effectClasses, paddingClasses, roundedClasses, hoverClasses, className])\n \n return (\n <div className=\"relative\">\n {/* 비디오 배경 */}\n {background === \"video\" && backgroundVideo && (\n <video\n className=\"absolute inset-0 w-full h-full object-cover rounded-lg\"\n autoPlay\n muted\n loop\n playsInline\n >\n <source src={backgroundVideo} type=\"video/mp4\" />\n </video>\n )}\n \n {/* 파티클 효과 */}\n {particleEffect && (\n <div className=\"absolute inset-0 pointer-events-none\">\n {/* 파티클 효과 렌더링 */}\n </div>\n )}\n \n {/* 메인 Panel */}\n <Card\n ref={ref}\n className={panelClasses}\n style={backgroundStyles}\n {...cardProps}\n >\n {children}\n </Card>\n \n {/* 애니메이션 효과 */}\n {animationEffect && (\n <div className=\"absolute inset-0 pointer-events-none\">\n {/* 애니메이션 효과 렌더링 */}\n </div>\n )}\n </div>\n )\n }\n)\n\nPanel.displayName = \"Panel\"\n\nexport { Panel } ","\"use client\";\n\nimport React, { useMemo, useCallback } from 'react';\nimport { Button } from './Button';\nimport { Icon } from './Icon';\nimport type { IconName } from '../lib/icons';\nimport { merge } from '../lib/utils';\n\n/**\n * ActionButton 인터페이스\n * @typedef {Object} ActionButton\n * @property {string} label - 버튼 라벨 (데스크톱)\n * @property {string} [labelMobile] - 버튼 라벨 (모바일, 없으면 label 사용)\n * @property {IconName} [icon] - 버튼 아이콘\n * @property {() => void} onClick - 클릭 핸들러\n * @property {boolean} [disabled] - 비활성화 여부\n * @property {'default' | 'outline' | 'destructive' | 'ghost'} [variant='outline'] - 버튼 스타일\n * @property {Object} [badge] - 배지 정보\n * @property {number} badge.count - 배지 숫자\n * @property {'blue' | 'red' | 'gray' | 'green'} [badge.color='gray'] - 배지 색상\n * @property {string} [className] - 추가 CSS 클래스\n */\nexport interface ActionButton {\n label: string;\n labelMobile?: string; // 모바일에서 표시할 짧은 텍스트\n icon?: IconName;\n onClick: () => void;\n disabled?: boolean;\n variant?: 'default' | 'outline' | 'destructive' | 'ghost';\n badge?: {\n count: number;\n color?: 'blue' | 'red' | 'gray' | 'green';\n };\n className?: string;\n}\n\n/**\n * ActionToolbar 컴포넌트의 props / ActionToolbar component props\n * @typedef {Object} ActionToolbarProps\n * @property {boolean} [isSelectMode=false] - 선택 모드 활성화 여부 / Enable select mode\n * @property {number} [totalCount=0] - 전체 항목 개수 / Total item count\n * @property {number} [selectedCount=0] - 선택된 항목 개수 / Selected item count\n * @property {ActionButton[]} [actions=[]] - 일반 모드 액션 버튼들 / Normal mode action buttons\n * @property {ActionButton[]} [selectModeActions=[]] - 선택 모드 액션 버튼들 / Select mode action buttons\n * @property {() => void} [onToggleSelectMode] - 선택 모드 토글 함수 / Toggle select mode function\n * @property {() => void} [onToggleSelectAll] - 전체 선택/해제 함수 / Toggle select all function\n * @property {() => void} [onCancelSelect] - 선택 모드 취소 함수 / Cancel select mode function\n * @property {boolean} [loading=false] - 로딩 상태 / Loading state\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface ActionToolbarProps extends React.HTMLAttributes<HTMLDivElement> {\n /** 선택 모드 활성화 여부 */\n isSelectMode?: boolean;\n /** 전체 항목 개수 */\n totalCount?: number;\n /** 선택된 항목 개수 */\n selectedCount?: number;\n /** 일반 모드 액션 버튼들 */\n actions?: ActionButton[];\n /** 선택 모드 액션 버튼들 */\n selectModeActions?: ActionButton[];\n /** 선택 모드 토글 함수 */\n onToggleSelectMode?: () => void;\n /** 전체 선택/해제 함수 */\n onToggleSelectAll?: () => void;\n /** 선택 모드 취소 함수 */\n onCancelSelect?: () => void;\n /** 로딩 상태 */\n loading?: boolean;\n}\n\n/**\n * ActionToolbar 컴포넌트 / ActionToolbar component\n * \n * 범용 액션 툴바 컴포넌트입니다.\n * 알림, 로그 관리, 대시보드 등에서 재사용 가능한 액션 버튼 영역을 제공합니다.\n * 선택 모드, 일괄 액션, 반응형 레이아웃을 지원합니다.\n * \n * Universal action toolbar component.\n * Provides reusable action button area for notifications, log management, dashboard, etc.\n * Supports select mode, batch actions, and responsive layout.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * ```tsx\n * <ActionToolbar\n * isSelectMode={isSelectMode}\n * totalCount={notifications.length}\n * selectedCount={selectedIds.size}\n * actions={[\n * {\n * label: \"모두 읽음\",\n * labelMobile: \"읽음\",\n * icon: \"check\",\n * onClick: handleMarkAllAsRead,\n * disabled: unreadCount === 0,\n * badge: { count: unreadCount, color: 'blue' }\n * }\n * ]}\n * selectModeActions={[\n * {\n * label: \"선택 삭제\",\n * labelMobile: \"삭제\",\n * icon: \"delete\",\n * onClick: handleDeleteSelected,\n * disabled: selectedIds.size === 0,\n * badge: { count: selectedIds.size, color: 'red' }\n * }\n * ]}\n * onToggleSelectMode={() => setIsSelectMode(true)}\n * onToggleSelectAll={handleToggleSelectAll}\n * onCancelSelect={() => {\n * setIsSelectMode(false);\n * setSelectedIds(new Set());\n * }}\n * />\n * ```\n * \n * @param {ActionToolbarProps} props - ActionToolbar 컴포넌트의 props / ActionToolbar component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} ActionToolbar 컴포넌트 / ActionToolbar component\n */\nconst ActionToolbarComponent = React.forwardRef<HTMLDivElement, ActionToolbarProps>(\n (\n {\n isSelectMode = false,\n totalCount = 0,\n selectedCount = 0,\n actions = [],\n selectModeActions = [],\n onToggleSelectMode,\n onToggleSelectAll,\n onCancelSelect,\n loading = false,\n className,\n ...props\n },\n ref\n ) => {\n const getBadgeColor = useCallback((color?: string) => {\n switch (color) {\n case 'red':\n return 'bg-red-100 dark:bg-red-900 text-red-700 dark:text-red-300';\n case 'blue':\n return 'bg-blue-100 dark:bg-blue-900 text-blue-700 dark:text-blue-300';\n case 'green':\n return 'bg-green-100 dark:bg-green-900 text-green-700 dark:text-green-300';\n case 'gray':\n default:\n return 'bg-gray-100 dark:bg-gray-700 text-gray-700 dark:text-gray-300';\n }\n }, []);\n\n const renderButton = useCallback((action: ActionButton, key: string) => (\n <Button\n key={key}\n variant={action.variant || 'outline'}\n size=\"sm\"\n onClick={action.onClick}\n disabled={action.disabled || loading}\n className={merge('flex-1 sm:flex-initial', action.className)}\n >\n {action.icon && <Icon name={action.icon} className=\"h-4 w-4 sm:h-3.5 sm:w-3.5 mr-1 sm:mr-1.5\" />}\n <span className=\"hidden sm:inline\">{action.label}</span>\n <span className=\"sm:hidden\">{action.labelMobile || action.label}</span>\n {action.badge && action.badge.count > 0 && (\n <span className={merge('ml-1.5', getBadgeColor(action.badge.color), 'px-1.5 py-0.5 rounded-full text-xs font-semibold')}>\n {action.badge.count}\n </span>\n )}\n </Button>\n ), [getBadgeColor, loading]);\n\n return (\n <div\n ref={ref}\n className={merge(\n 'mb-4 bg-white dark:bg-gray-800 rounded-lg shadow-sm border border-gray-200 dark:border-gray-700 p-3 sm:p-4',\n className\n )}\n {...props}\n >\n {isSelectMode ? (\n <div className=\"flex flex-wrap items-center gap-2\">\n {/* 전체 선택/해제 버튼 */}\n {onToggleSelectAll && (\n <Button\n variant=\"outline\"\n size=\"sm\"\n onClick={onToggleSelectAll}\n className=\"flex-1 sm:flex-initial min-w-[100px]\"\n >\n <Icon name={selectedCount === totalCount ? \"square\" : \"check\"} className=\"h-4 w-4 sm:h-3.5 sm:w-3.5 mr-1 sm:mr-1.5\" />\n <span className=\"hidden sm:inline\">{selectedCount === totalCount ? '전체 해제' : '전체 선택'}</span>\n <span className=\"sm:hidden\">{selectedCount === totalCount ? '해제' : '전체'}</span>\n </Button>\n )}\n \n {/* 선택 모드 액션 버튼들 */}\n {selectModeActions.map((action, index) => (\n <div key={`select-action-${index}`} className={merge('flex-1 sm:flex-initial min-w-[100px]', action.className)}>\n {renderButton(action, `select-${index}`)}\n </div>\n ))}\n \n {/* 취소 버튼 */}\n {onCancelSelect && (\n <Button\n variant=\"outline\"\n size=\"sm\"\n onClick={onCancelSelect}\n className=\"flex-1 sm:flex-initial min-w-[80px]\"\n >\n 취소\n </Button>\n )}\n </div>\n ) : (\n <div className=\"flex flex-wrap items-center gap-2\">\n {/* 선택 모드 진입 버튼 */}\n {onToggleSelectMode && (\n <Button\n variant=\"outline\"\n size=\"sm\"\n onClick={onToggleSelectMode}\n disabled={totalCount === 0}\n className=\"flex-1 sm:flex-initial min-w-[80px] sm:min-w-[auto] px-2 sm:px-3\"\n title={totalCount === 0 ? \"항목이 없습니다\" : \"여러 항목 선택\"}\n >\n <Icon name=\"check\" className=\"h-4 w-4 sm:h-3.5 sm:w-3.5\" />\n <span className=\"hidden sm:inline ml-1.5 sm:ml-2\">선택</span>\n </Button>\n )}\n \n {/* 일반 모드 액션 버튼들 */}\n {actions.map((action, index) => (\n <div key={`action-${index}`} className={merge('flex-1 sm:flex-initial min-w-[100px]', action.className)}>\n {renderButton(action, `action-${index}`)}\n </div>\n ))}\n </div>\n )}\n </div>\n );\n }\n);\n\nActionToolbarComponent.displayName = 'ActionToolbar';\n\nexport const ActionToolbar = React.memo(ActionToolbarComponent);\n\n","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\n\n/**\n * Breadcrumb 항목 타입 / Breadcrumb item type\n */\nexport interface BreadcrumbItemData {\n label: string\n href?: string\n icon?: string\n}\n\n/**\n * Breadcrumb 컴포넌트의 props / Breadcrumb component props\n * @typedef {Object} BreadcrumbProps\n * @property {React.ReactNode} [children] - BreadcrumbItem 컴포넌트들 / BreadcrumbItem components\n * @property {BreadcrumbItemData[]} [items] - Breadcrumb 항목 배열 (children 대신 사용 가능) / Breadcrumb items array (alternative to children)\n * @property {number} [maxItems] - 최대 표시할 항목 수 (긴 경로 처리) / Maximum number of items to display (for long paths)\n * @property {boolean} [showHomeIcon] - 홈 아이콘 표시 여부 / Show home icon\n * @property {string} [homeLabel] - 홈 라벨 (기본: \"Home\") / Home label (default: \"Home\")\n * @property {React.ReactNode} [separator] - 항목 사이 구분자 (기본: chevronRight 아이콘) / Separator between items (default: chevronRight icon)\n * @property {'default' | 'subtle' | 'transparent' | 'glass'} [variant='default'] - Breadcrumb 스타일 변형 / Breadcrumb style variant\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface BreadcrumbProps extends React.HTMLAttributes<HTMLDivElement> {\n children?: React.ReactNode\n items?: BreadcrumbItemData[]\n maxItems?: number\n showHomeIcon?: boolean\n homeLabel?: string\n separator?: React.ReactNode\n variant?: 'default' | 'subtle' | 'transparent' | 'glass'\n}\n\n/**\n * BreadcrumbItem 컴포넌트의 props / BreadcrumbItem component props\n * @typedef {Object} BreadcrumbItemProps\n * @property {string} [href] - 링크 URL (없으면 일반 텍스트) / Link URL (plain text if not provided)\n * @property {boolean} [isCurrent=false] - 현재 페이지 여부 / Current page indicator\n * @property {React.ReactNode} children - 항목 텍스트 / Item text\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n */\nexport interface BreadcrumbItemProps {\n href?: string\n isCurrent?: boolean\n children: React.ReactNode\n className?: string\n}\n\n/**\n * Breadcrumb 컴포넌트 / Breadcrumb component\n * \n * 네비게이션 경로를 표시하는 breadcrumb 컴포넌트입니다.\n * 현재 위치와 경로를 시각적으로 표현합니다.\n * \n * Breadcrumb component for displaying navigation paths.\n * Visually represents current location and path.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Breadcrumb>\n * <BreadcrumbItem href=\"/\">홈</BreadcrumbItem>\n * <BreadcrumbItem href=\"/products\">상품</BreadcrumbItem>\n * <BreadcrumbItem isCurrent>상세</BreadcrumbItem>\n * </Breadcrumb>\n * \n * @example\n * // 커스텀 구분자 / Custom separator\n * <Breadcrumb separator={<span>/</span>}>\n * <BreadcrumbItem href=\"/\">홈</BreadcrumbItem>\n * <BreadcrumbItem isCurrent>현재</BreadcrumbItem>\n * </Breadcrumb>\n * \n * @param {BreadcrumbProps} props - Breadcrumb 컴포넌트의 props / Breadcrumb component props\n * @param {React.Ref<HTMLDivElement>} ref - nav 요소 ref / nav element ref\n * @returns {JSX.Element} Breadcrumb 컴포넌트 / Breadcrumb component\n */\nconst Breadcrumb = React.forwardRef<HTMLDivElement, BreadcrumbProps>(\n ({ \n className, \n children, \n items,\n maxItems,\n showHomeIcon,\n homeLabel = \"Home\",\n separator = <Icon name=\"chevronRight\" className=\"w-3 h-3 text-slate-400 dark:text-slate-500 flex-shrink-0\" />, \n variant = 'default', \n ...props \n }, ref) => {\n const variantStyles = {\n default: \"inline-flex items-center text-sm w-fit\",\n subtle: \"inline-flex items-center text-xs bg-white/40 dark:bg-slate-800/40 backdrop-blur-md rounded-md px-3 py-2 border border-slate-200/30 dark:border-white/20 w-fit shadow-sm\",\n transparent: \"inline-flex items-center text-xs w-fit\",\n glass: \"inline-flex items-center text-xs bg-white/30 dark:bg-slate-800/30 backdrop-blur-lg rounded-lg px-4 py-2 border border-slate-200/25 dark:border-white/15 w-fit shadow-lg\"\n }\n \n // items prop이 있으면 BreadcrumbItem으로 변환\n const renderItems = () => {\n if (items) {\n let displayItems = [...items]\n \n // maxItems 처리\n if (maxItems && displayItems.length > maxItems) {\n const firstItem = displayItems[0]\n const lastItems = displayItems.slice(-(maxItems - 1))\n displayItems = [firstItem, { label: '...', href: undefined }, ...lastItems]\n }\n \n // 마지막 항목은 isCurrent로 표시\n return displayItems.map((item, index) => {\n const isLast = index === displayItems.length - 1\n const isCurrent = isLast && !item.href\n \n return (\n <BreadcrumbItem\n key={index}\n href={item.href}\n isCurrent={isCurrent}\n >\n {item.icon && (\n <Icon name={item.icon as any} className=\"w-4 h-4 mr-1\" />\n )}\n {item.label}\n </BreadcrumbItem>\n )\n })\n }\n \n // children이 있으면 그대로 사용\n if (children) {\n return React.Children.map(children, (child, index) => {\n if (React.isValidElement(child)) {\n return (\n <li key={index} className=\"flex items-center\">\n {child}\n {index < React.Children.count(children) - 1 && (\n <span className=\"mx-3 text-slate-400 dark:text-slate-500 flex items-center justify-center\" aria-hidden=\"true\">\n {separator}\n </span>\n )}\n </li>\n )\n }\n return child\n })\n }\n \n return null\n }\n \n const renderedItems = renderItems()\n const itemsCount = items ? items.length : (children ? React.Children.count(children) : 0)\n \n return (\n <nav\n ref={ref}\n aria-label=\"Breadcrumb\"\n className={merge(variantStyles[variant], className)}\n {...props}\n >\n <ol className=\"inline-flex items-center\">\n {showHomeIcon && (\n <li className=\"flex items-center\">\n <BreadcrumbItem href=\"/\">\n <Icon name=\"home\" className=\"w-4 h-4 mr-1\" />\n {homeLabel}\n </BreadcrumbItem>\n {itemsCount > 0 && (\n <span className=\"mx-3 text-slate-400 dark:text-slate-500 flex items-center justify-center\" aria-hidden=\"true\">\n {separator}\n </span>\n )}\n </li>\n )}\n {items ? (\n renderedItems?.map((item, index) => (\n <li key={index} className=\"flex items-center\">\n {item}\n {index < (renderedItems?.length || 0) - 1 && (\n <span className=\"mx-3 text-slate-400 dark:text-slate-500 flex items-center justify-center\" aria-hidden=\"true\">\n {separator}\n </span>\n )}\n </li>\n ))\n ) : (\n renderedItems\n )}\n </ol>\n </nav>\n )\n }\n)\nBreadcrumb.displayName = \"Breadcrumb\"\n\n/**\n * BreadcrumbItem 컴포넌트\n * Breadcrumb의 개별 항목을 표시합니다.\n * \n * @component\n * @param {BreadcrumbItemProps} props - BreadcrumbItem 컴포넌트의 props\n * @param {React.Ref<HTMLLIElement>} ref - li 요소 ref\n * @returns {JSX.Element} BreadcrumbItem 컴포넌트\n */\nconst BreadcrumbItem = React.forwardRef<HTMLLIElement, BreadcrumbItemProps>(\n ({ className, href, isCurrent = false, children, ...props }, ref) => {\n if (isCurrent) {\n return (\n <span\n ref={ref}\n aria-current=\"page\"\n className={merge(\n \"text-slate-500 dark:text-slate-400 font-medium\",\n className\n )}\n {...props}\n >\n {children}\n </span>\n )\n }\n\n if (href) {\n return (\n <a\n href={href}\n className={merge(\n \"text-slate-400 hover:text-slate-600 dark:text-slate-500 dark:hover:text-slate-300 transition-colors\",\n className\n )}\n {...props}\n >\n {children}\n </a>\n )\n }\n\n return (\n <span\n ref={ref}\n className={merge(\n \"text-slate-400 dark:text-slate-500\",\n className\n )}\n {...props}\n >\n {children}\n </span>\n )\n }\n)\nBreadcrumbItem.displayName = \"BreadcrumbItem\"\n\nexport { Breadcrumb, BreadcrumbItem } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Breadcrumb, BreadcrumbItem } from \"./Breadcrumb\"\n\n/**\n * ComponentLayout 컴포넌트의 props / ComponentLayout component props\n * @typedef {Object} ComponentLayoutProps\n * @property {string} title - 페이지 제목 / Page title\n * @property {string} description - 페이지 설명 / Page description\n * @property {React.ReactNode} children - 페이지 내용 / Page content\n * @property {Object} [prevPage] - 이전 페이지 정보 / Previous page information\n * @property {string} prevPage.title - 이전 페이지 제목 / Previous page title\n * @property {string} prevPage.href - 이전 페이지 링크 / Previous page link\n * @property {Object} [nextPage] - 다음 페이지 정보 / Next page information\n * @property {string} nextPage.title - 다음 페이지 제목 / Next page title\n * @property {string} nextPage.href - 다음 페이지 링크 / Next page link\n * @property {Array<Object>} [breadcrumbItems] - Breadcrumb 항목들 / Breadcrumb items\n * @property {string} breadcrumbItems[].label - Breadcrumb 라벨 / Breadcrumb label\n * @property {string} [breadcrumbItems[].href] - Breadcrumb 링크 / Breadcrumb link\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface ComponentLayoutProps extends React.HTMLAttributes<HTMLDivElement> {\n title: string\n description: string\n children: React.ReactNode\n prevPage?: {\n title: string\n href: string\n }\n nextPage?: {\n title: string\n href: string\n }\n breadcrumbItems?: Array<{\n label: string\n href?: string\n }>\n}\n\n/**\n * ComponentLayout 컴포넌트 / ComponentLayout component\n * \n * 컴포넌트 문서 페이지 레이아웃을 제공하는 컴포넌트입니다.\n * 제목, 설명, Breadcrumb, 이전/다음 페이지 네비게이션을 포함합니다.\n * \n * Component that provides layout for component documentation pages.\n * Includes title, description, Breadcrumb, and previous/next page navigation.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <ComponentLayout\n * title=\"Button 컴포넌트\"\n * description=\"버튼 컴포넌트 사용법\"\n * >\n * <Button>예제</Button>\n * </ComponentLayout>\n * \n * @example\n * // 이전/다음 페이지 네비게이션 포함 / With previous/next page navigation\n * <ComponentLayout\n * title=\"Input 컴포넌트\"\n * description=\"입력 컴포넌트 사용법\"\n * prevPage={{ title: \"Button\", href: \"/components/button\" }}\n * nextPage={{ title: \"Select\", href: \"/components/select\" }}\n * >\n * <Input placeholder=\"입력하세요\" />\n * </ComponentLayout>\n * \n * @param {ComponentLayoutProps} props - ComponentLayout 컴포넌트의 props / ComponentLayout component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} ComponentLayout 컴포넌트 / ComponentLayout component\n */\nconst ComponentLayout = React.forwardRef<HTMLDivElement, ComponentLayoutProps>(\n ({ \n className, \n title, \n description, \n children, \n prevPage, \n nextPage,\n breadcrumbItems = [\n { label: \"Components\", href: \"/components\" }\n ],\n ...props \n }, ref) => {\n return (\n <div className=\"relative min-h-screen\">\n {/* 고정된 페이지 네비게이션 - 위쪽 */}\n <div className=\"fixed right-4 top-4 z-50 hidden lg:block\">\n <div className=\"flex flex-col space-y-4\">\n {prevPage && (\n <a\n href={prevPage.href}\n className=\"group p-3 bg-white/80 backdrop-blur-sm border border-slate-200 rounded-full shadow-lg hover:shadow-2xl hover:bg-white/90 active:scale-95 transition-all duration-200\"\n title={`이전: ${prevPage.title}`}\n >\n <svg \n className=\"w-5 h-5 text-slate-600 group-hover:text-blue-600 group-active:text-blue-800 transition-colors\" \n fill=\"none\" \n stroke=\"currentColor\" \n viewBox=\"0 0 24 24\"\n >\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M5 15l7-7 7 7\" />\n </svg>\n </a>\n )}\n </div>\n </div>\n\n {/* 고정된 페이지 네비게이션 - 아래쪽 */}\n <div className=\"fixed right-4 bottom-4 z-50 hidden lg:block\">\n <div className=\"flex flex-col space-y-4\">\n {nextPage && (\n <a\n href={nextPage.href}\n className=\"group p-3 bg-white/80 backdrop-blur-sm border border-slate-200 rounded-full shadow-lg hover:shadow-2xl hover:bg-white/90 active:scale-95 transition-all duration-200\"\n title={`다음: ${nextPage.title}`}\n >\n <svg \n className=\"w-5 h-5 text-slate-600 group-hover:text-blue-600 group-active:text-blue-800 transition-colors\" \n fill=\"none\" \n stroke=\"currentColor\" \n viewBox=\"0 0 24 24\"\n >\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M19 9l-7 7-7-7\" />\n </svg>\n </a>\n )}\n </div>\n </div>\n\n {/* 메인 콘텐츠 */}\n <div\n ref={ref}\n className={merge(\"container mx-auto px-4 py-8\", className)}\n {...props}\n >\n <div className=\"max-w-4xl mx-auto\">\n {/* 브레드크럼 */}\n <Breadcrumb className=\"mb-6\">\n {breadcrumbItems.map((item, index) => (\n <BreadcrumbItem \n key={index}\n href={item.href}\n isCurrent={index === breadcrumbItems.length - 1}\n >\n {item.label}\n </BreadcrumbItem>\n ))}\n </Breadcrumb>\n\n {/* 페이지 헤더 */}\n <div className=\"mb-8\">\n <h1 className=\"text-4xl font-bold mb-4\">{title}</h1>\n <p className=\"text-lg text-slate-600 dark:text-slate-400\">\n {description}\n </p>\n </div>\n\n {/* 페이지 콘텐츠 */}\n <div className=\"space-y-8\">\n {children}\n </div>\n\n {/* 모바일 페이지 네비게이션 */}\n <div className=\"mt-12 lg:hidden\">\n <div className=\"flex items-center justify-between py-4 border-t border-slate-200 dark:border-slate-700\">\n {prevPage && (\n <a\n href={prevPage.href}\n className=\"flex items-center text-sm text-slate-600 hover:text-slate-900 dark:text-slate-400 dark:hover:text-slate-100 transition-colors\"\n >\n <svg className=\"w-4 h-4 mr-2\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M15 19l-7-7 7-7\" />\n </svg>\n {prevPage.title}\n </a>\n )}\n {nextPage && (\n <a\n href={nextPage.href}\n className=\"flex items-center text-sm text-slate-600 hover:text-slate-900 dark:text-slate-400 dark:hover:text-slate-100 transition-colors\"\n >\n {nextPage.title}\n <svg className=\"w-4 h-4 ml-2\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M9 5l7 7-7 7\" />\n </svg>\n </a>\n )}\n </div>\n </div>\n </div>\n </div>\n </div>\n )\n }\n)\nComponentLayout.displayName = \"ComponentLayout\"\n\nexport { ComponentLayout } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Navigation 컴포넌트의 props / Navigation component props\n * @typedef {Object} NavigationProps\n * @property {string} [value] - 제어 모드에서 활성 탭 값 / Active tab value in controlled mode\n * @property {string} [defaultValue] - 비제어 모드에서 기본 활성 탭 값 / Default active tab value in uncontrolled mode\n * @property {(value: string) => void} [onValueChange] - 탭 변경 콜백 / Tab change callback\n * @property {\"pills\" | \"underline\" | \"cards\"} [variant=\"pills\"] - Navigation 스타일 변형 / Navigation style variant\n * @property {\"small\" | \"medium\" | \"large\"} [scale=\"medium\"] - Navigation 크기 / Navigation size\n * @extends {Omit<React.HTMLAttributes<HTMLDivElement>, 'style'>}\n */\nexport interface NavigationProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'style'> {\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n variant?: \"pills\" | \"underline\" | \"cards\"\n scale?: \"small\" | \"medium\" | \"large\"\n}\n\n/**\n * Navigation 컴포넌트 / Navigation component\n * \n * 탭 네비게이션 컴포넌트입니다.\n * NavigationList, NavigationItem, NavigationContent와 함께 사용합니다.\n * \n * Tab navigation component.\n * Used with NavigationList, NavigationItem, and NavigationContent.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Navigation>\n * <Navigation.List>\n * <Navigation.Item value=\"tab1\">탭 1</Navigation.Item>\n * <Navigation.Item value=\"tab2\">탭 2</Navigation.Item>\n * </Navigation.List>\n * <Navigation.Content value=\"tab1\">내용 1</Navigation.Content>\n * </Navigation>\n * \n * @param {NavigationProps} props - Navigation 컴포넌트의 props / Navigation component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Navigation 컴포넌트 / Navigation component\n */\nconst Navigation = React.forwardRef<HTMLDivElement, NavigationProps>(\n ({ \n className, \n value,\n defaultValue,\n onValueChange,\n variant = \"pills\",\n scale = \"medium\",\n children,\n ...props \n }, ref) => {\n const [activeTab, setActiveTab] = React.useState(value || defaultValue || \"\")\n const isControlled = value !== undefined\n const currentValue = isControlled ? value : activeTab\n\n const handleTabChange = (newValue: string) => {\n if (!isControlled) {\n setActiveTab(newValue)\n }\n onValueChange?.(newValue)\n }\n\n React.useEffect(() => {\n if (value !== undefined) {\n setActiveTab(value)\n }\n }, [value])\n\n return (\n <div\n ref={ref}\n className={merge(\n \"w-full\",\n className\n )}\n {...props}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return React.cloneElement(child, {\n value: currentValue,\n variant,\n scale\n } as Partial<NavigationListProps | NavigationItemProps>)\n }\n return child\n })}\n </div>\n )\n }\n)\nNavigation.displayName = \"Navigation\"\n\n/**\n * NavigationList 컴포넌트의 props / NavigationList component props\n * @typedef {Object} NavigationListProps\n * @property {string} [value] - 활성 탭 값 / Active tab value\n * @property {(value: string) => void} [onValueChange] - 탭 변경 콜백 / Tab change callback\n * @property {\"pills\" | \"underline\" | \"cards\"} [variant=\"pills\"] - Navigation 스타일 변형 / Navigation style variant\n * @property {\"small\" | \"medium\" | \"large\"} [scale=\"medium\"] - Navigation 크기 / Navigation size\n * @extends {Omit<React.HTMLAttributes<HTMLDivElement>, 'style'>}\n */\nexport interface NavigationListProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'style'> {\n value?: string\n onValueChange?: (value: string) => void\n variant?: \"pills\" | \"underline\" | \"cards\"\n scale?: \"small\" | \"medium\" | \"large\"\n}\n\nconst NavigationList = React.forwardRef<HTMLDivElement, NavigationListProps>(\n ({ \n className, \n value,\n onValueChange,\n variant = \"pills\",\n scale = \"medium\",\n children,\n ...props \n }, ref) => {\n const getStyleClasses = () => {\n switch (variant) {\n case \"pills\":\n return \"bg-slate-100 dark:bg-slate-800 p-1 rounded-xl\"\n case \"underline\":\n return \"border-b border-slate-200 dark:border-slate-700\"\n case \"cards\":\n return \"bg-slate-50 dark:bg-slate-900 p-1 rounded-xl\"\n default:\n return \"bg-slate-100 dark:bg-slate-800 p-1 rounded-xl\"\n }\n }\n\n const getScaleClasses = () => {\n switch (scale) {\n case \"small\":\n return \"gap-1\"\n case \"large\":\n return \"gap-3\"\n default:\n return \"gap-2\"\n }\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n \"flex\",\n getStyleClasses(),\n getScaleClasses(),\n className\n )}\n {...props}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return React.cloneElement(child, {\n value,\n variant,\n scale\n } as Partial<NavigationItemProps>)\n }\n return child\n })}\n </div>\n )\n }\n)\nNavigationList.displayName = \"NavigationList\"\n\n/**\n * NavigationItem 컴포넌트의 props / NavigationItem component props\n * @typedef {Object} NavigationItemProps\n * @property {string} value - 탭 값 / Tab value\n * @property {(value: string) => void} [onValueChange] - 탭 변경 콜백 / Tab change callback\n * @property {\"pills\" | \"underline\" | \"cards\"} [variant] - Navigation 스타일 변형 (자동으로 설정됨) / Navigation style variant (auto-set)\n * @property {\"small\" | \"medium\" | \"large\"} [scale] - Navigation 크기 (자동으로 설정됨) / Navigation size (auto-set)\n * @property {boolean} [active] - 활성 상태 (자동으로 설정됨) / Active state (auto-set)\n * @extends {Omit<React.ButtonHTMLAttributes<HTMLButtonElement>, 'style'>}\n */\nexport interface NavigationItemProps extends Omit<React.ButtonHTMLAttributes<HTMLButtonElement>, 'style'> {\n value: string\n onValueChange?: (value: string) => void\n variant?: \"pills\" | \"underline\" | \"cards\"\n scale?: \"small\" | \"medium\" | \"large\"\n active?: boolean\n}\n\nconst NavigationItem = React.forwardRef<HTMLButtonElement, NavigationItemProps>(\n ({ \n className, \n value,\n onValueChange,\n variant = \"pills\",\n scale = \"medium\",\n active = false,\n children,\n ...props \n }, ref) => {\n const getStyleClasses = () => {\n switch (variant) {\n case \"pills\":\n return merge(\n \"rounded-lg px-3 py-2 text-sm font-medium transition-all\",\n active \n ? \"bg-white dark:bg-slate-700 text-slate-900 dark:text-slate-100 shadow-sm\" \n : \"text-slate-600 dark:text-slate-400 hover:text-slate-900 dark:hover:text-slate-100\"\n )\n case \"underline\":\n return merge(\n \"border-b-2 px-3 py-2 text-sm font-medium transition-all\",\n active \n ? \"border-blue-500 text-blue-600 dark:text-blue-400\" \n : \"border-transparent text-slate-600 dark:text-slate-400 hover:text-slate-900 dark:hover:text-slate-100\"\n )\n case \"cards\":\n return merge(\n \"rounded-lg px-3 py-2 text-sm font-medium transition-all\",\n active \n ? \"bg-white dark:bg-slate-800 text-slate-900 dark:text-slate-100 shadow-sm border border-slate-200 dark:border-slate-700\" \n : \"text-slate-600 dark:text-slate-400 hover:text-slate-900 dark:hover:text-slate-100\"\n )\n default:\n return merge(\n \"rounded-lg px-3 py-2 text-sm font-medium transition-all\",\n active \n ? \"bg-white dark:bg-slate-700 text-slate-900 dark:text-slate-100 shadow-sm\" \n : \"text-slate-600 dark:text-slate-400 hover:text-slate-900 dark:hover:text-slate-100\"\n )\n }\n }\n\n const getScaleClasses = () => {\n switch (scale) {\n case \"small\":\n return \"text-xs px-2 py-1\"\n case \"large\":\n return \"text-base px-4 py-3\"\n default:\n return \"text-sm px-3 py-2\"\n }\n }\n\n const handleClick = () => {\n onValueChange?.(value)\n }\n\n return (\n <button\n ref={ref}\n className={merge(\n getStyleClasses(),\n getScaleClasses(),\n \"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-blue-400 focus-visible:ring-offset-2\",\n className\n )}\n onClick={handleClick}\n {...props}\n >\n {children}\n </button>\n )\n }\n)\nNavigationItem.displayName = \"NavigationItem\"\n\n/**\n * NavigationContent 컴포넌트의 props / NavigationContent component props\n * @typedef {Object} NavigationContentProps\n * @property {string} value - 탭 값 / Tab value\n * @property {boolean} [active] - 활성 상태 (자동으로 설정됨) / Active state (auto-set)\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface NavigationContentProps extends React.HTMLAttributes<HTMLDivElement> {\n value: string\n active?: boolean\n}\n\nconst NavigationContent = React.forwardRef<HTMLDivElement, NavigationContentProps>(\n ({ className, active = false, ...props }, ref) => {\n if (!active) return null\n\n return (\n <div\n ref={ref}\n className={merge(\"mt-4\", className)}\n {...props}\n />\n )\n }\n)\nNavigationContent.displayName = \"NavigationContent\"\n\n// 서브컴포넌트 타입 정의\nexport interface NavigationComponent extends React.ForwardRefExoticComponent<NavigationProps & React.RefAttributes<HTMLDivElement>> {\n List: typeof NavigationList\n Item: typeof NavigationItem\n Content: typeof NavigationContent\n}\n\nconst NavigationComponent = Navigation as NavigationComponent\nNavigationComponent.List = NavigationList\nNavigationComponent.Item = NavigationItem\nNavigationComponent.Content = NavigationContent\n\nexport { NavigationComponent as Navigation, NavigationList, NavigationItem, NavigationContent } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Pagination 컴포넌트의 props / Pagination component props\n * @typedef {Object} PaginationProps\n * @property {number} currentPage - 현재 페이지 번호 / Current page number\n * @property {number} totalPages - 전체 페이지 수 / Total number of pages\n * @property {(page: number) => void} onPageChange - 페이지 변경 콜백 / Page change callback\n * @property {boolean} [showFirstLast=true] - 첫/마지막 페이지 버튼 표시 여부 / Show first/last page buttons\n * @property {boolean} [showPrevNext=true] - 이전/다음 페이지 버튼 표시 여부 / Show previous/next page buttons\n * @property {number} [maxVisiblePages=5] - 최대 표시 페이지 수 / Maximum visible page numbers\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Pagination 크기 / Pagination size\n * @property {\"default\" | \"outlined\" | \"minimal\"} [variant=\"default\"] - Pagination 스타일 변형 / Pagination style variant\n * @property {\"square\" | \"circle\"} [shape=\"square\"] - 버튼 모양 / Button shape\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface PaginationProps extends React.HTMLAttributes<HTMLDivElement> {\n currentPage: number\n totalPages: number\n onPageChange: (page: number) => void\n showFirstLast?: boolean\n showPrevNext?: boolean\n maxVisiblePages?: number\n size?: \"sm\" | \"md\" | \"lg\"\n variant?: \"default\" | \"outlined\" | \"minimal\"\n shape?: \"square\" | \"circle\"\n}\n\n/**\n * Pagination 컴포넌트 / Pagination component\n * \n * 페이지네이션 컨트롤을 제공하는 컴포넌트입니다.\n * 첫/마지막 페이지, 이전/다음 페이지 버튼을 지원하며,\n * 많은 페이지가 있을 경우 자동으로 생략 표시(...)를 합니다.\n * \n * Component that provides pagination controls.\n * Supports first/last page and previous/next page buttons,\n * and automatically shows ellipsis (...) when there are many pages.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * const [page, setPage] = useState(1)\n * \n * <Pagination\n * currentPage={page}\n * totalPages={10}\n * onPageChange={setPage}\n * />\n * \n * @example\n * // Outlined 스타일, 원형 버튼 / Outlined style, circular buttons\n * <Pagination\n * currentPage={page}\n * totalPages={20}\n * onPageChange={setPage}\n * variant=\"outlined\"\n * shape=\"circle\"\n * />\n * \n * @param {PaginationProps} props - Pagination 컴포넌트의 props / Pagination component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Pagination 컴포넌트 / Pagination component\n */\nconst Pagination = React.forwardRef<HTMLDivElement, PaginationProps>(\n ({ \n className, \n currentPage,\n totalPages,\n onPageChange,\n showFirstLast = true,\n showPrevNext = true,\n maxVisiblePages = 5,\n size = \"md\",\n variant = \"default\",\n shape = \"square\",\n ...props \n }, ref) => {\n const getVisiblePages = () => {\n const pages: (number | string)[] = []\n const halfVisible = Math.floor(maxVisiblePages / 2)\n \n let start = Math.max(1, currentPage - halfVisible)\n let end = Math.min(totalPages, currentPage + halfVisible)\n \n // 조정\n if (end - start + 1 < maxVisiblePages) {\n if (start === 1) {\n end = Math.min(totalPages, start + maxVisiblePages - 1)\n } else {\n start = Math.max(1, end - maxVisiblePages + 1)\n }\n }\n \n // 첫 페이지\n if (start > 1) {\n pages.push(1)\n if (start > 2) {\n pages.push(\"...\")\n }\n }\n \n // 중간 페이지들\n for (let i = start; i <= end; i++) {\n pages.push(i)\n }\n \n // 마지막 페이지\n if (end < totalPages) {\n if (end < totalPages - 1) {\n pages.push(\"...\")\n }\n pages.push(totalPages)\n }\n \n return pages\n }\n\n const getSizeClasses = () => {\n switch (size) {\n case \"sm\":\n return \"h-8 px-2 text-sm\" // 32px 높이, 8px 패딩\n case \"lg\":\n return \"h-12 px-4 text-base\" // 48px 높이, 16px 패딩\n default:\n return \"h-10 px-3 text-sm\" // 40px 높이, 12px 패딩\n }\n }\n\n const getShapeClasses = () => {\n switch (shape) {\n case \"circle\":\n return \"rounded-full aspect-square flex items-center justify-center\"\n default:\n return \"rounded-md\"\n }\n }\n\n const getVariantClasses = (isActive: boolean = false) => {\n switch (variant) {\n case \"outlined\":\n return merge(\n \"border border-gray-300 dark:border-gray-600\",\n isActive \n ? \"bg-blue-500 border-blue-500 text-white\" \n : \"bg-white dark:bg-gray-800 text-gray-700 dark:text-gray-300 hover:bg-gray-50 dark:hover:bg-gray-700\"\n )\n case \"minimal\":\n return merge(\n \"border-0\",\n isActive \n ? \"bg-blue-100 dark:bg-blue-900 text-blue-700 dark:text-blue-300\" \n : \"bg-transparent text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700\"\n )\n default:\n return merge(\n \"border-0\",\n isActive \n ? \"bg-blue-500 text-white\" \n : \"bg-white dark:bg-gray-800 text-gray-700 dark:text-gray-300 hover:bg-gray-50 dark:hover:bg-gray-700\"\n )\n }\n }\n\n const handlePageClick = (page: number) => {\n if (page >= 1 && page <= totalPages && page !== currentPage) {\n onPageChange(page)\n }\n }\n\n const visiblePages = getVisiblePages()\n\n return (\n <div\n ref={ref}\n className={merge(\n \"flex items-center justify-center gap-1\",\n className\n )}\n {...props}\n >\n {/* 첫 페이지 버튼 */}\n {showFirstLast && currentPage > 1 && (\n <button\n onClick={() => handlePageClick(1)}\n className={merge(\n \"inline-flex items-center justify-center font-medium transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n getSizeClasses(),\n getShapeClasses(),\n getVariantClasses()\n )}\n aria-label=\"첫 페이지로 이동\"\n >\n <svg className=\"w-4 h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M11 19l-7-7 7-7M19 19l-7-7 7-7\" />\n </svg>\n </button>\n )}\n\n {/* 이전 페이지 버튼 */}\n {showPrevNext && currentPage > 1 && (\n <button\n onClick={() => handlePageClick(currentPage - 1)}\n className={merge(\n \"inline-flex items-center justify-center font-medium transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n getSizeClasses(),\n getShapeClasses(),\n getVariantClasses()\n )}\n aria-label=\"이전 페이지로 이동\"\n >\n <svg className=\"w-4 h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M15 19l-7-7 7-7\" />\n </svg>\n </button>\n )}\n\n {/* 페이지 번호들 */}\n {visiblePages.map((page, index) => (\n <React.Fragment key={index}>\n {page === \"...\" ? (\n <span className={merge(\n \"inline-flex items-center justify-center px-3 py-2 text-sm font-medium text-gray-500 dark:text-gray-400\",\n getSizeClasses()\n )}>\n ...\n </span>\n ) : (\n <button\n onClick={() => handlePageClick(page as number)}\n className={merge(\n \"inline-flex items-center justify-center font-medium transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n getSizeClasses(),\n getShapeClasses(),\n getVariantClasses(page === currentPage)\n )}\n aria-label={`${page}페이지로 이동`}\n aria-current={page === currentPage ? \"page\" : undefined}\n >\n {page}\n </button>\n )}\n </React.Fragment>\n ))}\n\n {/* 다음 페이지 버튼 */}\n {showPrevNext && currentPage < totalPages && (\n <button\n onClick={() => handlePageClick(currentPage + 1)}\n className={merge(\n \"inline-flex items-center justify-center font-medium transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n getSizeClasses(),\n getShapeClasses(),\n getVariantClasses()\n )}\n aria-label=\"다음 페이지로 이동\"\n >\n <svg className=\"w-4 h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M9 5l7 7-7 7\" />\n </svg>\n </button>\n )}\n\n {/* 마지막 페이지 버튼 */}\n {showFirstLast && currentPage < totalPages && (\n <button\n onClick={() => handlePageClick(totalPages)}\n className={merge(\n \"inline-flex items-center justify-center font-medium transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n getSizeClasses(),\n getShapeClasses(),\n getVariantClasses()\n )}\n aria-label=\"마지막 페이지로 이동\"\n >\n <svg className=\"w-4 h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M13 5l7 7-7 7M5 5l7 7-7 7\" />\n </svg>\n </button>\n )}\n </div>\n )\n }\n)\nPagination.displayName = \"Pagination\"\n\n// 편의 컴포넌트들\nexport const PaginationOutlined = React.forwardRef<HTMLDivElement, Omit<PaginationProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Pagination ref={ref} variant=\"outlined\" className={className} {...props} />\n )\n)\nPaginationOutlined.displayName = \"PaginationOutlined\"\n\nexport const PaginationMinimal = React.forwardRef<HTMLDivElement, Omit<PaginationProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Pagination ref={ref} variant=\"minimal\" className={className} {...props} />\n )\n)\nPaginationMinimal.displayName = \"PaginationMinimal\"\n\n// 복합 컴포넌트들\nexport const PaginationWithInfo = React.forwardRef<HTMLDivElement, PaginationProps & { \n totalItems?: number\n itemsPerPage?: number\n showInfo?: boolean\n}>(\n ({ \n totalItems = 0, \n itemsPerPage = 10, \n showInfo = true, \n className, \n ...props \n }, ref) => {\n const startItem = (props.currentPage - 1) * itemsPerPage + 1\n const endItem = Math.min(props.currentPage * itemsPerPage, totalItems)\n \n return (\n <div className={merge(\"flex flex-col sm:flex-row items-center justify-between gap-4\", className)}>\n {showInfo && (\n <div className=\"text-sm text-gray-700 dark:text-gray-300\">\n {totalItems > 0 ? (\n <>\n <span className=\"font-medium\">{startItem}</span>\n {\" - \"}\n <span className=\"font-medium\">{endItem}</span>\n {\" of \"}\n <span className=\"font-medium\">{totalItems}</span>\n {\" results\"}\n </>\n ) : (\n \"No results\"\n )}\n </div>\n )}\n <Pagination ref={ref} {...props} />\n </div>\n )\n }\n)\nPaginationWithInfo.displayName = \"PaginationWithInfo\"\n\nexport { Pagination } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\n\n/**\n * PageNavigation 컴포넌트의 props / PageNavigation component props\n * @typedef {Object} PageNavigationProps\n * @property {Object} [prevPage] - 이전 페이지 정보 / Previous page information\n * @property {string} prevPage.title - 이전 페이지 제목 / Previous page title\n * @property {string} prevPage.href - 이전 페이지 링크 / Previous page link\n * @property {Object} [nextPage] - 다음 페이지 정보 / Next page information\n * @property {string} nextPage.title - 다음 페이지 제목 / Next page title\n * @property {string} nextPage.href - 다음 페이지 링크 / Next page link\n * @property {boolean} [showOnMobile=false] - 모바일에서 표시 여부 / Show on mobile\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface PageNavigationProps extends React.HTMLAttributes<HTMLDivElement> {\n prevPage?: {\n title: string\n href: string\n }\n nextPage?: {\n title: string\n href: string\n }\n showOnMobile?: boolean\n}\n\n/**\n * PageNavigation 컴포넌트 / PageNavigation component\n * \n * 이전/다음 페이지로 이동하는 네비게이션 컴포넌트입니다.\n * 문서 페이지나 가이드 페이지에서 사용하기 적합합니다.\n * \n * Navigation component for moving to previous/next pages.\n * Suitable for documentation or guide pages.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <PageNavigation\n * prevPage={{ title: \"이전 페이지\", href: \"/prev\" }}\n * nextPage={{ title: \"다음 페이지\", href: \"/next\" }}\n * />\n * \n * @param {PageNavigationProps} props - PageNavigation 컴포넌트의 props / PageNavigation component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} PageNavigation 컴포넌트 / PageNavigation component\n */\nconst PageNavigation = React.forwardRef<HTMLDivElement, PageNavigationProps>(\n ({ \n className, \n prevPage, \n nextPage, \n showOnMobile = false,\n ...props \n }, ref) => {\n if (!prevPage && !nextPage) {\n return null\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n \"flex items-center justify-between py-4\",\n !showOnMobile && \"hidden md:flex\",\n className\n )}\n {...props}\n >\n {/* 이전 페이지 */}\n <div className=\"flex-1\">\n {prevPage && (\n <a\n href={prevPage.href}\n className=\"group inline-flex items-center text-sm text-slate-600 hover:text-slate-900 dark:text-slate-400 dark:hover:text-slate-100 transition-colors\"\n >\n <Icon \n name=\"chevronLeft\" \n className=\"w-4 h-4 mr-2 transition-transform group-hover:-translate-x-1\" \n />\n <span className=\"hidden sm:inline\">{prevPage.title}</span>\n </a>\n )}\n </div>\n\n {/* 다음 페이지 */}\n <div className=\"flex-1 flex justify-end\">\n {nextPage && (\n <a\n href={nextPage.href}\n className=\"group inline-flex items-center text-sm text-slate-600 hover:text-slate-900 dark:text-slate-400 dark:hover:text-slate-100 transition-colors\"\n >\n <span className=\"hidden sm:inline mr-2\">{nextPage.title}</span>\n <Icon \n name=\"chevronRight\" \n className=\"w-4 h-4 transition-transform group-hover:translate-x-1\" \n />\n </a>\n )}\n </div>\n </div>\n )\n }\n)\nPageNavigation.displayName = \"PageNavigation\"\n\nexport { PageNavigation } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * LoadingSpinner 컴포넌트의 props / LoadingSpinner component props\n * @typedef {Object} LoadingSpinnerProps\n * @property {\"sm\" | \"md\" | \"lg\" | \"xl\"} [size=\"md\"] - Spinner 크기 / Spinner size\n * @property {\"default\" | \"dots\" | \"bars\" | \"ring\" | \"ripple\"} [variant=\"default\"] - Spinner 애니메이션 타입 / Spinner animation type\n * @property {string} [text] - Spinner 아래 표시할 텍스트 / Text to display below spinner\n * @property {\"default\" | \"primary\" | \"secondary\" | \"success\" | \"warning\" | \"error\" | \"glass\"} [color=\"default\"] - Spinner 색상 / Spinner color\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n */\nexport interface LoadingSpinnerProps {\n size?: \"sm\" | \"md\" | \"lg\" | \"xl\"\n variant?: \"default\" | \"dots\" | \"bars\" | \"ring\" | \"ripple\"\n text?: string\n color?: \"default\" | \"primary\" | \"secondary\" | \"success\" | \"warning\" | \"error\" | \"glass\"\n className?: string\n}\n\n/**\n * LoadingSpinner 컴포넌트 / LoadingSpinner component\n * \n * 로딩 상태를 표시하는 스피너 컴포넌트입니다.\n * 다양한 애니메이션 타입과 크기를 지원합니다.\n * \n * Spinner component that displays loading state.\n * Supports various animation types and sizes.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <LoadingSpinner />\n * \n * @example\n * // 텍스트와 함께 / With text\n * <LoadingSpinner \n * text=\"로딩 중...\"\n * size=\"lg\"\n * color=\"primary\"\n * />\n * \n * @example\n * // 다양한 애니메이션 / Various animations\n * <LoadingSpinner variant=\"dots\" />\n * <LoadingSpinner variant=\"bars\" color=\"success\" />\n * <LoadingSpinner variant=\"ripple\" size=\"xl\" />\n * \n * @param {LoadingSpinnerProps} props - LoadingSpinner 컴포넌트의 props / LoadingSpinner component props\n * @returns {JSX.Element} LoadingSpinner 컴포넌트 / LoadingSpinner component\n */\nexport function LoadingSpinner({ \n className, \n size = \"md\", \n variant = \"default\", \n text, \n color = \"default\" \n}: LoadingSpinnerProps) {\n const sizeClasses = {\n sm: \"w-6 h-6\", // 24px - 더 넉넉한 크기\n md: \"w-8 h-8\", // 32px - 더 넉넉한 크기\n lg: \"w-12 h-12\", // 48px - 더 넉넉한 크기\n xl: \"w-16 h-16\" // 64px - 더 넉넉한 크기\n }\n\n // LoadingSpinner는 border 색상을 사용하므로 특화 색상 시스템 사용\n const spinnerColors: Record<string, string> = {\n default: \"border-gray-300 border-t-gray-600 dark:border-gray-600 dark:border-t-gray-300\",\n primary: \"border-blue-300 border-t-blue-600 dark:border-blue-600 dark:border-t-blue-300\",\n secondary: \"border-gray-300 border-t-gray-600 dark:border-gray-600 dark:border-t-gray-300\",\n success: \"border-green-300 border-t-green-600 dark:border-green-600 dark:border-t-green-300\",\n warning: \"border-yellow-300 border-t-yellow-600 dark:border-yellow-600 dark:border-t-yellow-300\",\n error: \"border-red-300 border-t-red-600 dark:border-red-600 dark:border-t-red-300\",\n glass: \"border-white/30 border-t-white/50 dark:border-slate-600/50 dark:border-t-slate-400/50\"\n }\n\n const renderSpinner = () => {\n switch (variant) {\n case \"dots\":\n return (\n <div className=\"flex space-x-1\">\n <div className=\"w-2 h-2 bg-current rounded-full animate-bounce\" />\n <div className=\"w-2 h-2 bg-current rounded-full animate-bounce delay-100\" />\n <div className=\"w-2 h-2 bg-current rounded-full animate-bounce delay-200\" />\n </div>\n )\n case \"bars\":\n return (\n <div className=\"flex space-x-1 h-full items-end\">\n <div className=\"w-1 bg-current animate-pulse\" style={{ height: '60%' }} />\n <div className=\"w-1 bg-current animate-pulse delay-100\" style={{ height: '80%' }} />\n <div className=\"w-1 bg-current animate-pulse delay-200\" style={{ height: '40%' }} />\n <div className=\"w-1 bg-current animate-pulse delay-300\" style={{ height: '100%' }} />\n <div className=\"w-1 bg-current animate-pulse delay-500\" style={{ height: '70%' }} />\n </div>\n )\n case \"ring\":\n return (\n <div className={merge(\n \"animate-spin rounded-full border-2\",\n spinnerColors[color] || spinnerColors.default\n )} />\n )\n case \"ripple\":\n return (\n <div className=\"relative\">\n <div className={merge(\n \"absolute inset-0 rounded-full border-2 animate-ping\",\n spinnerColors[color] || spinnerColors.default\n )} />\n <div className={merge(\n \"rounded-full border-2\",\n spinnerColors[color] || spinnerColors.default\n )} />\n </div>\n )\n default:\n return (\n <div className={merge(\n \"animate-spin rounded-full border-2\",\n spinnerColors[color] || spinnerColors.default\n )} />\n )\n }\n }\n\n return (\n <div className={merge(\"flex flex-col items-center justify-center\", className)}>\n <div className={merge(sizeClasses[size], \"text-gray-600 dark:text-gray-400\")}>\n {renderSpinner()}\n </div>\n {text && (\n <p className=\"mt-3 text-sm text-gray-600 dark:text-gray-400 text-center\">\n {text}\n </p>\n )}\n </div>\n )\n} ","'use client'\n\nimport React, { useState, useEffect } from 'react'\nimport { merge } from '../lib/utils'\nimport { LoadingSpinner } from './LoadingSpinner'\n\n/**\n * PageTransition 컴포넌트의 props / PageTransition component props\n * @typedef {Object} PageTransitionProps\n * @property {React.ReactNode} children - 페이지 내용 / Page content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {number} [duration=300] - 전환 지속 시간 (ms) / Transition duration (ms)\n * @property {'fade' | 'slide' | 'scale' | 'flip'} [variant='fade'] - 전환 애니메이션 타입 / Transition animation type\n * @property {'default' | 'dots' | 'bars' | 'ring' | 'ripple'} [loadingVariant='ripple'] - 로딩 스피너 타입 / Loading spinner type\n * @property {string} [loadingText='페이지 로딩 중...'] - 로딩 텍스트 / Loading text\n * @property {boolean} [showLoading=true] - 로딩 표시 여부 / Show loading\n * @property {() => void} [onTransitionStart] - 전환 시작 콜백 / Transition start callback\n * @property {() => void} [onTransitionEnd] - 전환 종료 콜백 / Transition end callback\n */\nexport interface PageTransitionProps {\n children: React.ReactNode\n className?: string\n duration?: number\n variant?: 'fade' | 'slide' | 'scale' | 'flip'\n loadingVariant?: 'default' | 'dots' | 'bars' | 'ring' | 'ripple'\n loadingText?: string\n showLoading?: boolean\n onTransitionStart?: () => void\n onTransitionEnd?: () => void\n}\n\n/**\n * PageTransition 컴포넌트 / PageTransition component\n * \n * 페이지 전환 애니메이션을 제공하는 컴포넌트입니다.\n * 다양한 전환 효과와 로딩 스피너를 지원합니다.\n * \n * Component that provides page transition animations.\n * Supports various transition effects and loading spinners.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <PageTransition>\n * <div>페이지 내용</div>\n * </PageTransition>\n * \n * @example\n * // Slide 전환 / Slide transition\n * <PageTransition\n * variant=\"slide\"\n * duration={500}\n * loadingVariant=\"dots\"\n * >\n * <div>페이지 내용</div>\n * </PageTransition>\n * \n * @param {PageTransitionProps} props - PageTransition 컴포넌트의 props / PageTransition component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} PageTransition 컴포넌트 / PageTransition component\n */\nexport const PageTransition = React.forwardRef<HTMLDivElement, PageTransitionProps>(({\n children,\n className,\n duration = 300,\n variant = 'fade',\n loadingVariant = 'ripple',\n loadingText = '페이지 로딩 중...',\n showLoading = true,\n onTransitionStart,\n onTransitionEnd\n}, ref) => {\n const [isLoading, setIsLoading] = useState(true)\n const [isVisible, setIsVisible] = useState(false)\n\n useEffect(() => {\n const timer = setTimeout(() => {\n setIsLoading(false)\n setIsVisible(true)\n onTransitionEnd?.()\n }, duration)\n\n onTransitionStart?.()\n\n return () => clearTimeout(timer)\n }, [duration, onTransitionStart, onTransitionEnd])\n\n const transitionClasses = {\n fade: merge(\n 'transition-opacity duration-300 ease-in-out',\n isVisible ? 'opacity-100' : 'opacity-0'\n ),\n slide: merge(\n 'transition-transform duration-300 ease-in-out',\n isVisible ? 'translate-x-0' : 'translate-x-full'\n ),\n scale: merge(\n 'transition-all duration-300 ease-in-out',\n isVisible ? 'scale-100 opacity-100' : 'scale-95 opacity-0'\n ),\n flip: merge(\n 'transition-all duration-500 ease-in-out',\n isVisible ? 'rotate-y-0 opacity-100' : 'rotate-y-90 opacity-0'\n )\n }\n\n if (isLoading && showLoading) {\n return (\n <div className={merge('flex flex-col items-center justify-center min-h-screen bg-gradient-to-br from-blue-50 to-purple-50 dark:from-slate-900 dark:to-slate-800', className)}>\n <LoadingSpinner\n size=\"lg\"\n variant={loadingVariant}\n text={loadingText}\n />\n </div>\n )\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n 'w-full',\n transitionClasses[variant],\n className\n )}\n style={{ transitionDuration: `${duration}ms` }}\n >\n {children}\n </div>\n )\n})\n\nPageTransition.displayName = 'PageTransition'\n\n// Convenience components for different transition types\nexport const FadeTransition = React.forwardRef<HTMLDivElement, Omit<PageTransitionProps, 'variant'>>((props, ref) => (\n <PageTransition ref={ref} variant=\"fade\" {...props} />\n))\n\nexport const SlideTransition = React.forwardRef<HTMLDivElement, Omit<PageTransitionProps, 'variant'>>((props, ref) => (\n <PageTransition ref={ref} variant=\"slide\" {...props} />\n))\n\nexport const ScaleTransition = React.forwardRef<HTMLDivElement, Omit<PageTransitionProps, 'variant'>>((props, ref) => (\n <PageTransition ref={ref} variant=\"scale\" {...props} />\n))\n\nexport const FlipTransition = React.forwardRef<HTMLDivElement, Omit<PageTransitionProps, 'variant'>>((props, ref) => (\n <PageTransition ref={ref} variant=\"flip\" {...props} />\n))\n\n// Add displayName for convenience components\nFadeTransition.displayName = 'FadeTransition'\nSlideTransition.displayName = 'SlideTransition'\nScaleTransition.displayName = 'ScaleTransition'\nFlipTransition.displayName = 'FlipTransition' ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Table 컴포넌트의 props / Table component props\n * @typedef {Object} TableProps\n * @property {React.ReactNode} children - TableHeader, TableBody, TableFooter 등 / TableHeader, TableBody, TableFooter, etc.\n * @property {\"default\" | \"bordered\" | \"striped\"} [variant=\"default\"] - Table 스타일 변형 / Table style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Table 크기 / Table size\n * @extends {React.HTMLAttributes<HTMLTableElement>}\n */\nexport interface TableProps extends React.HTMLAttributes<HTMLTableElement> {\n children: React.ReactNode\n variant?: \"default\" | \"bordered\" | \"striped\"\n size?: \"sm\" | \"md\" | \"lg\"\n}\n\n/**\n * TableHeader 컴포넌트의 props / TableHeader component props\n * @typedef {Object} TableHeaderProps\n * @property {React.ReactNode} children - TableHead 컴포넌트들 / TableHead components\n * @extends {React.HTMLAttributes<HTMLTableSectionElement>}\n */\nexport interface TableHeaderProps extends React.HTMLAttributes<HTMLTableSectionElement> {\n children: React.ReactNode\n}\n\n/**\n * TableBody 컴포넌트의 props / TableBody component props\n * @typedef {Object} TableBodyProps\n * @property {React.ReactNode} children - TableRow 컴포넌트들 / TableRow components\n * @extends {React.HTMLAttributes<HTMLTableSectionElement>}\n */\nexport interface TableBodyProps extends React.HTMLAttributes<HTMLTableSectionElement> {\n children: React.ReactNode\n}\n\n/**\n * TableFooter 컴포넌트의 props / TableFooter component props\n * @typedef {Object} TableFooterProps\n * @property {React.ReactNode} children - TableRow 컴포넌트들 / TableRow components\n * @extends {React.HTMLAttributes<HTMLTableSectionElement>}\n */\nexport interface TableFooterProps extends React.HTMLAttributes<HTMLTableSectionElement> {\n children: React.ReactNode\n}\n\n/**\n * TableRow 컴포넌트의 props / TableRow component props\n * @typedef {Object} TableRowProps\n * @property {React.ReactNode} children - TableHead 또는 TableCell 컴포넌트들 / TableHead or TableCell components\n * @property {\"default\" | \"hover\"} [variant=\"default\"] - Row 스타일 변형 / Row style variant\n * @extends {React.HTMLAttributes<HTMLTableRowElement>}\n */\nexport interface TableRowProps extends React.HTMLAttributes<HTMLTableRowElement> {\n children: React.ReactNode\n variant?: \"default\" | \"hover\"\n}\n\n/**\n * TableHead 컴포넌트의 props / TableHead component props\n * @typedef {Object} TableHeadProps\n * @property {React.ReactNode} children - 헤더 셀 내용 / Header cell content\n * @extends {React.ThHTMLAttributes<HTMLTableCellElement>}\n */\nexport interface TableHeadProps extends React.ThHTMLAttributes<HTMLTableCellElement> {\n children: React.ReactNode\n}\n\n/**\n * TableCell 컴포넌트의 props / TableCell component props\n * @typedef {Object} TableCellProps\n * @property {React.ReactNode} children - 셀 내용 / Cell content\n * @extends {React.TdHTMLAttributes<HTMLTableCellElement>}\n */\nexport interface TableCellProps extends React.TdHTMLAttributes<HTMLTableCellElement> {\n children: React.ReactNode\n}\n\n/**\n * Table 컴포넌트 / Table component\n * \n * 데이터를 표 형태로 표시하는 테이블 컴포넌트입니다.\n * TableHeader, TableBody, TableFooter, TableRow, TableHead, TableCell과 함께 사용합니다.\n * \n * Table component that displays data in tabular format.\n * Used with TableHeader, TableBody, TableFooter, TableRow, TableHead, and TableCell.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Table>\n * <TableHeader>\n * <TableRow>\n * <TableHead>이름</TableHead>\n * <TableHead>나이</TableHead>\n * </TableRow>\n * </TableHeader>\n * <TableBody>\n * <TableRow>\n * <TableCell>홍길동</TableCell>\n * <TableCell>30</TableCell>\n * </TableRow>\n * </TableBody>\n * </Table>\n * \n * @example\n * // Bordered 스타일 / Bordered style\n * <Table variant=\"bordered\">\n * <TableHeader>\n * <TableRow>\n * <TableHead>항목</TableHead>\n * </TableRow>\n * </TableHeader>\n * <TableBody>\n * <TableRow>\n * <TableCell>값</TableCell>\n * </TableRow>\n * </TableBody>\n * </Table>\n * \n * @example\n * // Striped 스타일, 호버 효과 / Striped style with hover effect\n * <Table variant=\"striped\">\n * <TableBody>\n * <TableRow variant=\"hover\">\n * <TableCell>데이터</TableCell>\n * </TableRow>\n * </TableBody>\n * </Table>\n * \n * @param {TableProps} props - Table 컴포넌트의 props / Table component props\n * @param {React.Ref<HTMLTableElement>} ref - table 요소 ref / table element ref\n * @returns {JSX.Element} Table 컴포넌트 / Table component\n */\nconst Table = React.forwardRef<HTMLTableElement, TableProps>(\n ({ className, variant = \"default\", size = \"md\", ...props }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"bordered\":\n return \"border border-slate-200 dark:border-slate-700 divide-x divide-slate-200 dark:divide-slate-700\"\n case \"striped\":\n return \"divide-y divide-slate-200 dark:divide-slate-700\"\n default:\n return \"\"\n }\n }\n\n const getSizeClasses = () => {\n switch (size) {\n case \"sm\":\n return \"text-sm\"\n case \"lg\":\n return \"text-base\"\n default:\n return \"text-sm\"\n }\n }\n\n return (\n <div className=\"w-full overflow-auto\">\n <table\n ref={ref}\n className={merge(\n \"w-full caption-bottom\",\n getVariantClasses(),\n getSizeClasses(),\n className\n )}\n {...props}\n />\n </div>\n )\n }\n)\nTable.displayName = \"Table\"\n\n/**\n * TableHeader 컴포넌트 / TableHeader component\n * 테이블의 헤더 영역을 표시합니다.\n * Displays the header area of a table.\n * \n * @component\n * @param {TableHeaderProps} props - TableHeader 컴포넌트의 props / TableHeader component props\n * @param {React.Ref<HTMLTableSectionElement>} ref - thead 요소 ref / thead element ref\n * @returns {JSX.Element} TableHeader 컴포넌트 / TableHeader component\n */\nconst TableHeader = React.forwardRef<HTMLTableSectionElement, TableHeaderProps>(\n ({ className, ...props }, ref) => (\n <thead ref={ref} className={merge(\"[&_tr]:border-b\", className)} {...props} />\n )\n)\nTableHeader.displayName = \"TableHeader\"\n\n/**\n * TableBody 컴포넌트 / TableBody component\n * 테이블의 본문 영역을 표시합니다.\n * Displays the body area of a table.\n * \n * @component\n * @param {TableBodyProps} props - TableBody 컴포넌트의 props / TableBody component props\n * @param {React.Ref<HTMLTableSectionElement>} ref - tbody 요소 ref / tbody element ref\n * @returns {JSX.Element} TableBody 컴포넌트 / TableBody component\n */\nconst TableBody = React.forwardRef<HTMLTableSectionElement, TableBodyProps>(\n ({ className, ...props }, ref) => (\n <tbody\n ref={ref}\n className={merge(\"[&_tr:last-child]:border-0\", className)}\n {...props}\n />\n )\n)\nTableBody.displayName = \"TableBody\"\n\n/**\n * TableFooter 컴포넌트 / TableFooter component\n * 테이블의 푸터 영역을 표시합니다.\n * Displays the footer area of a table.\n * \n * @component\n * @param {TableFooterProps} props - TableFooter 컴포넌트의 props / TableFooter component props\n * @param {React.Ref<HTMLTableSectionElement>} ref - tfoot 요소 ref / tfoot element ref\n * @returns {JSX.Element} TableFooter 컴포넌트 / TableFooter component\n */\nconst TableFooter = React.forwardRef<HTMLTableSectionElement, TableFooterProps>(\n ({ className, ...props }, ref) => (\n <tfoot\n ref={ref}\n className={merge(\n \"border-t bg-slate-50 dark:bg-slate-800/50 font-medium [&>tr]:last:border-b-0\",\n className\n )}\n {...props}\n />\n )\n)\nTableFooter.displayName = \"TableFooter\"\n\n/**\n * TableRow 컴포넌트 / TableRow component\n * 테이블의 행을 표시합니다.\n * Displays a table row.\n * \n * @component\n * @param {TableRowProps} props - TableRow 컴포넌트의 props / TableRow component props\n * @param {React.Ref<HTMLTableRowElement>} ref - tr 요소 ref / tr element ref\n * @returns {JSX.Element} TableRow 컴포넌트 / TableRow component\n */\nconst TableRow = React.forwardRef<HTMLTableRowElement, TableRowProps>(\n ({ className, variant = \"default\", ...props }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"hover\":\n return \"hover:bg-slate-50 dark:hover:bg-slate-800/50\"\n default:\n return \"\"\n }\n }\n\n return (\n <tr\n ref={ref}\n className={merge(\n \"border-b transition-colors data-[state=selected]:bg-slate-50 dark:data-[state=selected]:bg-slate-800/50\",\n getVariantClasses(),\n className\n )}\n {...props}\n />\n )\n }\n)\nTableRow.displayName = \"TableRow\"\n\n/**\n * TableHead 컴포넌트 / TableHead component\n * 테이블의 헤더 셀을 표시합니다.\n * Displays a table header cell.\n * \n * @component\n * @param {TableHeadProps} props - TableHead 컴포넌트의 props / TableHead component props\n * @param {React.Ref<HTMLTableCellElement>} ref - th 요소 ref / th element ref\n * @returns {JSX.Element} TableHead 컴포넌트 / TableHead component\n */\nconst TableHead = React.forwardRef<HTMLTableCellElement, TableHeadProps>(\n ({ className, ...props }, ref) => (\n <th\n ref={ref}\n className={merge(\n \"h-12 px-4 text-left align-middle font-medium text-slate-500 dark:text-slate-400 [&:has([role=checkbox])]:pr-0\",\n className\n )}\n {...props}\n />\n )\n)\nTableHead.displayName = \"TableHead\"\n\n/**\n * TableCell 컴포넌트 / TableCell component\n * 테이블의 데이터 셀을 표시합니다.\n * Displays a table data cell.\n * \n * @component\n * @param {TableCellProps} props - TableCell 컴포넌트의 props / TableCell component props\n * @param {React.Ref<HTMLTableCellElement>} ref - td 요소 ref / td element ref\n * @returns {JSX.Element} TableCell 컴포넌트 / TableCell component\n */\nconst TableCell = React.forwardRef<HTMLTableCellElement, TableCellProps>(\n ({ className, ...props }, ref) => (\n <td\n ref={ref}\n className={merge(\"p-4 align-middle [&:has([role=checkbox])]:pr-0\", className)}\n {...props}\n />\n )\n)\nTableCell.displayName = \"TableCell\"\n\n/**\n * TableCaption 컴포넌트 / TableCaption component\n * 테이블의 캡션을 표시합니다.\n * Displays a table caption.\n * \n * @component\n * @param {React.HTMLAttributes<HTMLTableCaptionElement>} props - TableCaption 컴포넌트의 props / TableCaption component props\n * @param {React.Ref<HTMLTableCaptionElement>} ref - caption 요소 ref / caption element ref\n * @returns {JSX.Element} TableCaption 컴포넌트 / TableCaption component\n */\nconst TableCaption = React.forwardRef<HTMLTableCaptionElement, React.HTMLAttributes<HTMLTableCaptionElement>>(\n ({ className, ...props }, ref) => (\n <caption\n ref={ref}\n className={merge(\"mt-4 text-sm text-slate-500 dark:text-slate-400\", className)}\n {...props}\n />\n )\n)\nTableCaption.displayName = \"TableCaption\"\n\nexport {\n Table,\n TableHeader,\n TableBody,\n TableFooter,\n TableHead,\n TableRow,\n TableCell,\n TableCaption,\n} ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Badge 컴포넌트의 props / Badge component props\n * @typedef {Object} BadgeProps\n * @property {\"default\" | \"secondary\" | \"destructive\" | \"error\" | \"outline\" | \"glass\"} [variant=\"default\"] - Badge 스타일 변형 / Badge style variant\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface BadgeProps extends React.HTMLAttributes<HTMLDivElement> {\n variant?: \"default\" | \"secondary\" | \"destructive\" | \"error\" | \"outline\" | \"glass\"\n}\n\n/**\n * Badge 컴포넌트 / Badge component\n * \n * 상태나 카테고리를 표시하는 작은 배지 컴포넌트입니다.\n * React.memo로 최적화되어 있어 불필요한 리렌더링을 방지합니다.\n * \n * Small badge component for displaying status or category.\n * Optimized with React.memo to prevent unnecessary re-renders.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Badge>New</Badge>\n * \n * @example\n * // 다양한 변형 / Various variants\n * <Badge variant=\"destructive\">완료</Badge>\n * <Badge variant=\"error\">오류</Badge>\n * <Badge variant=\"outline\">대기</Badge>\n * \n * @param {BadgeProps} props - Badge 컴포넌트의 props / Badge component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Badge 컴포넌트 / Badge component\n */\nconst Badge = React.memo(React.forwardRef<HTMLDivElement, BadgeProps>(\n ({ className, variant = \"default\", ...props }, ref) => {\n const variantClasses = React.useMemo(() => ({\n default: \"bg-slate-900 text-slate-50 hover:bg-slate-900/80 dark:bg-slate-50 dark:text-slate-900 dark:hover:bg-slate-50/80\",\n secondary: \"bg-slate-100 text-slate-900 hover:bg-slate-100/80 dark:bg-slate-800 dark:text-slate-50 dark:hover:bg-slate-800/80\",\n destructive: \"bg-red-500 text-slate-50 hover:bg-red-500/80 dark:bg-red-900 dark:text-slate-50 dark:hover:bg-red-900/80\",\n error: \"bg-red-500 text-slate-50 hover:bg-red-500/80 dark:bg-red-900 dark:text-slate-50 dark:hover:bg-red-900/80\", // error는 destructive와 동일\n outline: \"text-slate-950 border border-slate-200 hover:bg-slate-100 hover:text-slate-900 dark:border-slate-800 dark:text-slate-50 dark:hover:bg-slate-800 dark:hover:text-slate-50\",\n glass: \"bg-white/20 backdrop-blur-sm border border-white/30 text-white hover:bg-white/30 dark:bg-slate-800/20 dark:border-slate-700/50 dark:text-slate-200 dark:hover:bg-slate-700/30\"\n }), [])\n\n return (\n <div\n ref={ref}\n className={merge(\n \"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-gray-400 focus:ring-offset-2\",\n variantClasses[variant],\n className\n )}\n {...props}\n />\n )\n }\n))\nBadge.displayName = \"Badge\"\n\nexport { Badge } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Progress 컴포넌트의 props\n * @typedef {Object} ProgressProps\n * @property {number} [value=0] - 진행률 값\n * @property {number} [max=100] - 최대값\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Progress 바 크기\n * @property {\"default\" | \"success\" | \"warning\" | \"error\" | \"info\" | \"glass\"} [variant=\"default\"] - Progress 스타일 변형\n * @property {boolean} [showValue=false] - 진행률 퍼센트 표시 여부\n * @property {boolean} [animated=true] - 애니메이션 활성화 여부\n * @property {boolean} [striped=false] - 줄무늬 패턴 표시 여부\n * @property {string} [label] - Progress 라벨 텍스트\n * @property {string} [description] - Progress 설명 텍스트\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface ProgressProps extends React.HTMLAttributes<HTMLDivElement> {\n value?: number\n max?: number\n size?: \"sm\" | \"md\" | \"lg\"\n variant?: \"default\" | \"success\" | \"warning\" | \"error\" | \"info\" | \"glass\"\n showValue?: boolean\n animated?: boolean\n striped?: boolean\n label?: string\n description?: string\n}\n\n/**\n * Progress 컴포넌트 / Progress component\n * \n * 진행률을 표시하는 프로그레스 바 컴포넌트입니다.\n * 다양한 스타일과 애니메이션을 지원합니다.\n * \n * Progress bar component that displays progress.\n * Supports various styles and animations.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Progress value={50} />\n * \n * @example\n * // 라벨과 값 표시 / Show label and value\n * <Progress \n * value={75} \n * label=\"업로드 진행률\"\n * showValue\n * />\n * \n * @example\n * // Success 스타일, 줄무늬 패턴 / Success style, striped pattern\n * <Progress \n * value={90}\n * variant=\"success\"\n * striped\n * animated\n * />\n * \n * @param {ProgressProps} props - Progress 컴포넌트의 props / Progress component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Progress 컴포넌트 / Progress component\n */\nconst Progress = React.forwardRef<HTMLDivElement, ProgressProps>(\n ({ \n className, \n value = 0,\n max = 100,\n size = \"md\",\n variant = \"default\",\n showValue = false,\n animated = true,\n striped = false,\n label,\n description,\n ...props \n }, ref) => {\n const percentage = Math.min(Math.max((value / max) * 100, 0), 100)\n\n const sizeClasses = {\n sm: \"h-2\", // 8px 높이\n md: \"h-3\", // 12px 높이\n lg: \"h-4\" // 16px 높이\n }\n\n const getVariantClasses = () => {\n switch (variant) {\n case \"success\":\n return \"bg-green-500 dark:bg-green-400\"\n case \"warning\":\n return \"bg-yellow-500 dark:bg-yellow-400\"\n case \"error\":\n return \"bg-red-500 dark:bg-red-400\"\n case \"info\":\n return \"bg-blue-500 dark:bg-blue-400\"\n case \"glass\":\n return \"bg-white/50 backdrop-blur-sm\"\n default:\n return \"bg-gray-900 dark:bg-gray-100\"\n }\n }\n\n const getStripedClasses = () => {\n if (!striped) return \"\"\n return \"bg-gradient-to-r from-transparent via-white/20 to-transparent bg-[length:20px_100%] animate-pulse\"\n }\n\n return (\n <div className={merge(\"w-full\", className)} {...props}>\n {/* 라벨과 값 */}\n {(label || showValue) && (\n <div className=\"flex items-center justify-between mb-2\"> {/* 8px 여백 */}\n {label && (\n <span className=\"text-sm font-medium text-gray-700 dark:text-gray-300\">\n {label}\n </span>\n )}\n {showValue && (\n <span className=\"text-sm text-gray-600 dark:text-gray-400\">\n {Math.round(percentage)}%\n </span>\n )}\n </div>\n )}\n\n {/* 프로그레스 바 */}\n <div\n ref={ref}\n className={merge(\n \"relative w-full overflow-hidden rounded-full\",\n variant === \"glass\" \n ? \"bg-white/10 backdrop-blur-sm border border-white/20 dark:bg-slate-800/10 dark:border-slate-700/50\"\n : \"bg-gray-200 dark:bg-gray-700\",\n sizeClasses[size]\n )}\n >\n <div\n className={merge(\n \"h-full rounded-full transition-all duration-300 ease-out\",\n getVariantClasses(),\n getStripedClasses(),\n animated && \"animate-pulse\"\n )}\n style={{\n width: `${percentage}%`,\n transition: animated ? \"width 0.3s ease-out\" : \"none\"\n }}\n />\n </div>\n\n {/* 설명 */}\n {description && (\n <p className=\"mt-2 text-xs text-gray-500 dark:text-gray-400\"> {/* 8px 여백 */}\n {description}\n </p>\n )}\n </div>\n )\n }\n)\nProgress.displayName = \"Progress\"\n\n// 편의 컴포넌트들\nexport const ProgressSuccess = React.forwardRef<HTMLDivElement, Omit<ProgressProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Progress ref={ref} variant=\"success\" className={className} {...props} />\n )\n)\nProgressSuccess.displayName = \"ProgressSuccess\"\n\nexport const ProgressWarning = React.forwardRef<HTMLDivElement, Omit<ProgressProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Progress ref={ref} variant=\"warning\" className={className} {...props} />\n )\n)\nProgressWarning.displayName = \"ProgressWarning\"\n\nexport const ProgressError = React.forwardRef<HTMLDivElement, Omit<ProgressProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Progress ref={ref} variant=\"error\" className={className} {...props} />\n )\n)\nProgressError.displayName = \"ProgressError\"\n\nexport const ProgressInfo = React.forwardRef<HTMLDivElement, Omit<ProgressProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Progress ref={ref} variant=\"info\" className={className} {...props} />\n )\n)\nProgressInfo.displayName = \"ProgressInfo\"\n\n// 복합 Progress 컴포넌트들\nexport const ProgressWrapper = React.forwardRef<HTMLDivElement, ProgressProps & { title?: string }>(\n ({ title, className, ...props }, ref) => (\n <div className={merge(\"p-4 bg-white dark:bg-gray-800 rounded-lg border border-gray-200 dark:border-gray-700\", className)}>\n {title && (\n <h3 className=\"text-sm font-semibold text-gray-900 dark:text-white mb-3\"> {/* 12px 여백 */}\n {title}\n </h3>\n )}\n <Progress ref={ref} {...props} />\n </div>\n )\n)\nProgressWrapper.displayName = \"ProgressWrapper\"\n\nexport const ProgressGroup = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"space-y-4\", className)} // 16px 간격\n {...props}\n >\n {children}\n </div>\n )\n)\nProgressGroup.displayName = \"ProgressGroup\"\n\nexport { Progress } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Skeleton 컴포넌트의 props\n * @typedef {Object} SkeletonProps\n * @property {\"text\" | \"circular\" | \"rectangular\" | \"rounded\"} [variant=\"text\"] - Skeleton 모양\n * @property {string | number} [width] - 너비 (기본값: variant에 따라 다름)\n * @property {string | number} [height] - 높이 (기본값: variant에 따라 다름)\n * @property {\"pulse\" | \"wave\" | \"shimmer\"} [animation=\"pulse\"] - 애니메이션 타입\n * @property {string} [className] - 추가 CSS 클래스\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface SkeletonProps extends React.HTMLAttributes<HTMLDivElement> {\n variant?: \"text\" | \"circular\" | \"rectangular\" | \"rounded\"\n width?: string | number\n height?: string | number\n animation?: \"pulse\" | \"wave\" | \"shimmer\"\n className?: string\n}\n\n/**\n * Skeleton 컴포넌트 / Skeleton component\n * \n * 로딩 중 콘텐츠의 플레이스홀더를 표시하는 스켈레톤 컴포넌트입니다.\n * 다양한 모양과 애니메이션을 지원합니다.\n * \n * Skeleton component that displays placeholders for content while loading.\n * Supports various shapes and animations.\n * \n * @component\n * @example\n * // 기본 사용 (텍스트) / Basic usage (text)\n * <Skeleton />\n * \n * @example\n * // 원형 아바타 / Circular avatar\n * <Skeleton variant=\"circular\" width={40} height={40} />\n * \n * @example\n * // Wave 애니메이션 / Wave animation\n * <Skeleton \n * variant=\"rounded\" \n * width=\"100%\" \n * height={200}\n * animation=\"wave\"\n * />\n * \n * @param {SkeletonProps} props - Skeleton 컴포넌트의 props / Skeleton component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Skeleton 컴포넌트 / Skeleton component\n */\nconst Skeleton = React.forwardRef<HTMLDivElement, SkeletonProps>(\n ({ \n className, \n variant = \"text\",\n width,\n height,\n animation = \"pulse\",\n ...props \n }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"circular\":\n return \"rounded-full\"\n case \"rounded\":\n return \"rounded-lg\"\n case \"rectangular\":\n return \"rounded-none\"\n case \"text\":\n default:\n return \"rounded\"\n }\n }\n\n const getAnimationClasses = () => {\n switch (animation) {\n case \"wave\":\n return \"animate-pulse bg-gradient-to-r from-gray-200 via-gray-300 to-gray-200 bg-[length:200%_100%] animate-shimmer\"\n case \"shimmer\":\n return \"bg-gradient-to-r from-gray-200 via-gray-300 to-gray-200 bg-[length:200%_100%] animate-shimmer\"\n case \"pulse\":\n default:\n return \"animate-pulse bg-gray-200 dark:bg-gray-700\"\n }\n }\n\n const getDefaultDimensions = () => {\n switch (variant) {\n case \"circular\":\n return { width: \"40px\", height: \"40px\" }\n case \"text\":\n return { width: \"100%\", height: \"1em\" }\n case \"rounded\":\n return { width: \"100%\", height: \"200px\" }\n case \"rectangular\":\n return { width: \"100%\", height: \"200px\" }\n default:\n return { width: \"100%\", height: \"1em\" }\n }\n }\n\n const defaultDims = getDefaultDimensions()\n const finalWidth = width || defaultDims.width\n const finalHeight = height || defaultDims.height\n\n return (\n <div\n ref={ref}\n className={merge(\n \"block\",\n getVariantClasses(),\n getAnimationClasses(),\n className\n )}\n style={{\n width: typeof finalWidth === \"number\" ? `${finalWidth}px` : finalWidth,\n height: typeof finalHeight === \"number\" ? `${finalHeight}px` : finalHeight,\n }}\n {...props}\n />\n )\n }\n)\nSkeleton.displayName = \"Skeleton\"\n\n// 편의 컴포넌트들\nexport const SkeletonText = React.forwardRef<HTMLDivElement, Omit<SkeletonProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Skeleton ref={ref} variant=\"text\" className={className} {...props} />\n )\n)\nSkeletonText.displayName = \"SkeletonText\"\n\nexport const SkeletonCircle = React.forwardRef<HTMLDivElement, Omit<SkeletonProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Skeleton ref={ref} variant=\"circular\" className={className} {...props} />\n )\n)\nSkeletonCircle.displayName = \"SkeletonCircle\"\n\nexport const SkeletonRectangle = React.forwardRef<HTMLDivElement, Omit<SkeletonProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Skeleton ref={ref} variant=\"rectangular\" className={className} {...props} />\n )\n)\nSkeletonRectangle.displayName = \"SkeletonRectangle\"\n\nexport const SkeletonRounded = React.forwardRef<HTMLDivElement, Omit<SkeletonProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Skeleton ref={ref} variant=\"rounded\" className={className} {...props} />\n )\n)\nSkeletonRounded.displayName = \"SkeletonRounded\"\n\n// 복합 스켈레톤 컴포넌트들\nexport const SkeletonCard = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"space-y-4 p-6\", className)} // 16px 간격, 24px 패딩\n {...props}\n >\n <div className=\"flex items-center space-x-4\"> {/* 16px 간격 */}\n <SkeletonCircle className=\"w-12 h-12\" /> {/* 48px 크기 */}\n <div className=\"space-y-2 flex-1\"> {/* 8px 간격 */}\n <SkeletonText className=\"h-4 w-3/4\" /> {/* 16px 높이, 75% 너비 */}\n <SkeletonText className=\"h-3 w-1/2\" /> {/* 12px 높이, 50% 너비 */}\n </div>\n </div>\n <SkeletonRounded className=\"w-full h-32\" /> {/* 128px 높이 */}\n <div className=\"space-y-2\"> {/* 8px 간격 */}\n <SkeletonText className=\"h-4 w-full\" />\n <SkeletonText className=\"h-4 w-5/6\" />\n <SkeletonText className=\"h-4 w-4/6\" />\n </div>\n </div>\n )\n)\nSkeletonCard.displayName = \"SkeletonCard\"\n\nexport const SkeletonAvatar = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"flex items-center space-x-4\", className)} // 16px 간격\n {...props}\n >\n <SkeletonCircle className=\"w-12 h-12\" /> {/* 48px 크기 */}\n <div className=\"space-y-2 flex-1\"> {/* 8px 간격 */}\n <SkeletonText className=\"h-4 w-3/4\" />\n <SkeletonText className=\"h-3 w-1/2\" />\n </div>\n </div>\n )\n)\nSkeletonAvatar.displayName = \"SkeletonAvatar\"\n\nexport const SkeletonImage = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"space-y-2\", className)} // 8px 간격\n {...props}\n >\n <SkeletonRounded className=\"w-full h-48\" /> {/* 192px 높이 */}\n <SkeletonText className=\"h-4 w-1/2\" />\n </div>\n )\n)\nSkeletonImage.displayName = \"SkeletonImage\"\n\nexport const SkeletonUserProfile = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"space-y-4\", className)} // 16px 간격\n {...props}\n >\n <div className=\"flex items-center space-x-4\"> {/* 16px 간격 */}\n <SkeletonCircle className=\"w-16 h-16\" /> {/* 64px 크기 */}\n <div className=\"space-y-2 flex-1\"> {/* 8px 간격 */}\n <SkeletonText className=\"h-5 w-1/2\" />\n <SkeletonText className=\"h-3 w-1/3\" />\n </div>\n </div>\n <div className=\"space-y-2\"> {/* 8px 간격 */}\n <SkeletonText className=\"h-4 w-full\" />\n <SkeletonText className=\"h-4 w-5/6\" />\n </div>\n </div>\n )\n)\nSkeletonUserProfile.displayName = \"SkeletonUserProfile\"\n\nexport const SkeletonList = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"space-y-4\", className)} // 16px 간격\n {...props}\n >\n {Array.from({ length: 3 }).map((_, index) => (\n <div key={index} className=\"flex items-center space-x-4\"> {/* 16px 간격 */}\n <SkeletonCircle className=\"w-10 h-10\" /> {/* 40px 크기 */}\n <div className=\"space-y-2 flex-1\"> {/* 8px 간격 */}\n <SkeletonText className=\"h-4 w-3/4\" />\n <SkeletonText className=\"h-3 w-1/2\" />\n </div>\n </div>\n ))}\n </div>\n )\n)\nSkeletonList.displayName = \"SkeletonList\"\n\nexport const SkeletonTable = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"space-y-4\", className)} // 16px 간격\n {...props}\n >\n {/* 헤더 */}\n <div className=\"flex space-x-4\"> {/* 16px 간격 */}\n <SkeletonText className=\"h-4 w-1/4\" />\n <SkeletonText className=\"h-4 w-1/4\" />\n <SkeletonText className=\"h-4 w-1/4\" />\n <SkeletonText className=\"h-4 w-1/4\" />\n </div>\n {/* 행들 */}\n {Array.from({ length: 5 }).map((_, index) => (\n <div key={index} className=\"flex space-x-4\"> {/* 16px 간격 */}\n <SkeletonText className=\"h-4 w-1/4\" />\n <SkeletonText className=\"h-4 w-1/4\" />\n <SkeletonText className=\"h-4 w-1/4\" />\n <SkeletonText className=\"h-4 w-1/4\" />\n </div>\n ))}\n </div>\n )\n)\nSkeletonTable.displayName = \"SkeletonTable\"\n\nexport { Skeleton } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Alert 컴포넌트의 props\n * @typedef {Object} AlertProps\n * @property {\"default\" | \"success\" | \"warning\" | \"error\" | \"info\"} [variant=\"default\"] - Alert 스타일 변형\n * @property {string} [title] - Alert 제목\n * @property {string} [description] - Alert 설명\n * @property {React.ReactNode} [icon] - 커스텀 아이콘\n * @property {React.ReactNode} [action] - 액션 버튼/요소\n * @property {boolean} [closable=false] - 닫기 버튼 표시 여부\n * @property {() => void} [onClose] - 닫기 버튼 클릭 시 호출되는 콜백\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface AlertProps extends React.HTMLAttributes<HTMLDivElement> {\n variant?: \"default\" | \"success\" | \"warning\" | \"error\" | \"info\"\n title?: string\n description?: string\n icon?: React.ReactNode\n action?: React.ReactNode\n closable?: boolean\n onClose?: () => void\n}\n\n/**\n * Alert 컴포넌트 / Alert component\n * \n * 사용자에게 중요한 정보나 경고를 표시하는 컴포넌트입니다.\n * 다양한 변형(variant)을 지원하며, 아이콘, 제목, 설명, 액션 버튼을 포함할 수 있습니다.\n * \n * Component for displaying important information or warnings to users.\n * Supports various variants and can include icons, titles, descriptions, and action buttons.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Alert variant=\"info\" title=\"정보\" description=\"이것은 정보 메시지입니다.\" />\n * \n * @example\n * // 닫기 버튼 포함 / With close button\n * <Alert \n * variant=\"warning\" \n * title=\"경고\" \n * closable \n * onClose={() => console.log('닫기')}\n * />\n * \n * @example\n * // 커스텀 아이콘과 액션 / Custom icon and action\n * <Alert \n * variant=\"success\"\n * icon={<Icon name=\"check\" />}\n * action={<Button size=\"sm\">확인</Button>}\n * >\n * 작업이 완료되었습니다.\n * </Alert>\n * \n * @param {AlertProps} props - Alert 컴포넌트의 props / Alert component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Alert 컴포넌트 / Alert component\n */\nconst Alert = React.forwardRef<HTMLDivElement, AlertProps>(\n ({ \n className, \n variant = \"default\",\n title,\n description,\n icon,\n action,\n closable = false,\n onClose,\n children,\n ...props \n }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"success\":\n return \"bg-green-500/10 backdrop-blur-sm border-green-400/30 text-green-200 dark:bg-green-500/10 dark:border-green-400/30 dark:text-green-200\"\n case \"warning\":\n return \"bg-yellow-500/10 backdrop-blur-sm border-yellow-400/30 text-yellow-200 dark:bg-yellow-500/10 dark:border-yellow-400/30 dark:text-yellow-200\"\n case \"error\":\n return \"bg-red-500/10 backdrop-blur-sm border-red-400/30 text-red-200 dark:bg-red-500/10 dark:border-red-400/30 dark:text-red-200\"\n case \"info\":\n return \"bg-blue-500/10 backdrop-blur-sm border-blue-400/30 text-blue-200 dark:bg-blue-500/10 dark:border-blue-400/30 dark:text-blue-200\"\n default:\n return \"bg-white/10 backdrop-blur-sm border-white/30 text-white dark:bg-slate-800/20 dark:border-slate-700/50 dark:text-slate-200\"\n }\n }\n\n const getIconClasses = () => {\n switch (variant) {\n case \"success\":\n return \"text-green-500 dark:text-green-400\"\n case \"warning\":\n return \"text-yellow-500 dark:text-yellow-400\"\n case \"error\":\n return \"text-red-500 dark:text-red-400\"\n case \"info\":\n return \"text-blue-500 dark:text-blue-400\"\n default:\n return \"text-gray-500 dark:text-gray-400\"\n }\n }\n\n const getDefaultIcon = () => {\n switch (variant) {\n case \"success\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M5 13l4 4L19 7\" />\n </svg>\n )\n case \"warning\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-2.5L13.732 4c-.77-.833-1.964-.833-2.732 0L3.732 16.5c-.77.833.192 2.5 1.732 2.5z\" />\n </svg>\n )\n case \"error\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n )\n case \"info\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z\" />\n </svg>\n )\n default:\n return null\n }\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n \"relative rounded-lg border p-4\", // 16px 패딩\n getVariantClasses(),\n className\n )}\n {...props}\n >\n <div className=\"flex items-start gap-3\"> {/* 12px 간격 */}\n {/* 아이콘 */}\n {(icon || getDefaultIcon()) && (\n <div className={merge(\"flex-shrink-0 mt-0.5\", getIconClasses())}>\n {icon || getDefaultIcon()}\n </div>\n )}\n\n {/* 내용 */}\n <div className=\"flex-1 min-w-0\">\n {title && (\n <h4 className=\"text-sm font-semibold mb-1\"> {/* 4px 여백 */}\n {title}\n </h4>\n )}\n {description && (\n <p className=\"text-sm leading-relaxed\">\n {description}\n </p>\n )}\n {children && (\n <div className=\"mt-2\"> {/* 8px 여백 */}\n {children}\n </div>\n )}\n </div>\n\n {/* 액션 */}\n {(action || closable) && (\n <div className=\"flex-shrink-0 flex items-center gap-2\"> {/* 8px 간격 */}\n {action}\n {closable && (\n <button\n onClick={onClose}\n className={merge(\n \"inline-flex rounded-md p-1.5 focus:outline-none focus:ring-2 focus:ring-offset-2 transition-all duration-200 hover:bg-black/5 dark:hover:bg-white/5\",\n getIconClasses()\n )}\n aria-label=\"닫기\"\n >\n <svg className=\"w-4 h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n </button>\n )}\n </div>\n )}\n </div>\n </div>\n )\n }\n)\nAlert.displayName = \"Alert\"\n\n// 편의 컴포넌트들\nexport const AlertSuccess = React.forwardRef<HTMLDivElement, Omit<AlertProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Alert ref={ref} variant=\"success\" className={className} {...props} />\n )\n)\nAlertSuccess.displayName = \"AlertSuccess\"\n\nexport const AlertWarning = React.forwardRef<HTMLDivElement, Omit<AlertProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Alert ref={ref} variant=\"warning\" className={className} {...props} />\n )\n)\nAlertWarning.displayName = \"AlertWarning\"\n\nexport const AlertError = React.forwardRef<HTMLDivElement, Omit<AlertProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Alert ref={ref} variant=\"error\" className={className} {...props} />\n )\n)\nAlertError.displayName = \"AlertError\"\n\nexport const AlertInfo = React.forwardRef<HTMLDivElement, Omit<AlertProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Alert ref={ref} variant=\"info\" className={className} {...props} />\n )\n)\nAlertInfo.displayName = \"AlertInfo\"\n\nexport { Alert } ","\"use client\"\n\nimport React from \"react\"\nimport { createContext, useContext, useState, useCallback } from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Toast 메시지 타입 / Toast message type\n * @typedef {Object} Toast\n * @property {string} id - Toast 고유 ID / Toast unique ID\n * @property {\"success\" | \"error\" | \"warning\" | \"info\"} type - Toast 타입 / Toast type\n * @property {string} [title] - Toast 제목 / Toast title\n * @property {string} message - Toast 메시지 / Toast message\n * @property {number} [duration] - 표시 시간(ms), 0이면 자동 제거 안 함 / Display duration (ms), 0 means no auto-remove\n * @property {Object} [action] - 액션 버튼 / Action button\n * @property {string} action.label - 액션 버튼 레이블 / Action button label\n * @property {() => void} action.onClick - 액션 버튼 클릭 핸들러 / Action button click handler\n */\nexport interface Toast {\n id: string\n type: \"success\" | \"error\" | \"warning\" | \"info\"\n title?: string\n message: string\n duration?: number\n action?: {\n label: string\n onClick: () => void\n }\n}\n\n// Toast Context 타입\ninterface ToastContextType {\n toasts: Toast[]\n addToast: (toast: Omit<Toast, \"id\">) => void\n removeToast: (id: string) => void\n clearToasts: () => void\n}\n\n// Toast Context 생성\nconst ToastContext = createContext<ToastContextType | undefined>(undefined)\n\n/**\n * useToast Hook\n * \n * Toast를 추가, 제거, 초기화하는 훅입니다.\n * ToastProvider 내부에서만 사용 가능합니다.\n * \n * Hook for adding, removing, and clearing toasts.\n * Can only be used within ToastProvider.\n * \n * @example\n * const { addToast, removeToast, clearToasts } = useToast()\n * \n * addToast({\n * type: \"success\",\n * message: \"저장되었습니다\",\n * duration: 3000\n * })\n * \n * @returns {ToastContextType} Toast 컨텍스트 값 / Toast context value\n * @throws {Error} ToastProvider 외부에서 사용 시 에러 발생 / Error when used outside ToastProvider\n */\nexport function useToast(): ToastContextType {\n const context = useContext(ToastContext)\n if (!context) {\n throw new Error(\"useToast must be used within a ToastProvider\")\n }\n return context\n}\n\n/**\n * ToastProvider 컴포넌트의 props / ToastProvider component props\n * @typedef {Object} ToastProviderProps\n * @property {React.ReactNode} children - 자식 컴포넌트 / Child components\n * @property {number} [maxToasts=5] - 최대 Toast 개수 / Maximum number of toasts\n * @property {\"top-right\" | \"top-left\" | \"bottom-right\" | \"bottom-left\" | \"top-center\" | \"bottom-center\"} [position=\"top-right\"] - Toast 표시 위치 / Toast display position\n */\ninterface ToastProviderProps {\n children: React.ReactNode\n maxToasts?: number\n position?: \"top-right\" | \"top-left\" | \"bottom-right\" | \"bottom-left\" | \"top-center\" | \"bottom-center\"\n}\n\n/**\n * ToastProvider 컴포넌트 / ToastProvider component\n * \n * Toast 시스템의 컨텍스트를 제공하는 Provider 컴포넌트입니다.\n * 앱의 루트 레벨에서 사용하여 전역 Toast 기능을 활성화합니다.\n * \n * Provider component that provides context for the Toast system.\n * Use at the root level of your app to enable global Toast functionality.\n * \n * @component\n * @example\n * // App.tsx\n * <ToastProvider position=\"top-center\" maxToasts={3}>\n * <App />\n * </ToastProvider>\n * \n * @example\n * // 컴포넌트에서 사용 / Usage in component\n * const { addToast } = useToast()\n * \n * const handleSave = () => {\n * addToast({\n * type: \"success\",\n * message: \"저장되었습니다\",\n * title: \"성공\"\n * })\n * }\n * \n * @param {ToastProviderProps} props - ToastProvider 컴포넌트의 props / ToastProvider component props\n * @returns {JSX.Element} ToastProvider 컴포넌트 / ToastProvider component\n * \n * @todo 접근성 개선: ToastItem에 role=\"alert\" 또는 role=\"status\" 추가 필요 / Accessibility: Add role=\"alert\" or role=\"status\" to ToastItem\n * @todo 접근성 개선: aria-live=\"polite\" 또는 aria-live=\"assertive\" 추가 필요 / Accessibility: Add aria-live=\"polite\" or aria-live=\"assertive\"\n */\nexport function ToastProvider({\n children,\n maxToasts = 5,\n position = \"top-right\"\n}: ToastProviderProps) {\n const [toasts, setToasts] = useState<Toast[]>([])\n\n const removeToast = useCallback((id: string) => {\n setToasts(prev => prev.filter(toast => toast.id !== id))\n }, [])\n\n const addToast = useCallback((toast: Omit<Toast, \"id\">) => {\n const id = Math.random().toString(36).substr(2, 9)\n const newToast: Toast = { ...toast, id }\n\n setToasts(prev => {\n const updatedToasts = [...prev, newToast]\n return updatedToasts.slice(-maxToasts) // 최대 개수 제한\n })\n\n // 자동 제거\n if (toast.duration !== 0) {\n setTimeout(() => {\n removeToast(id)\n }, toast.duration || 5000)\n }\n }, [maxToasts, removeToast])\n\n const clearToasts = useCallback(() => {\n setToasts([])\n }, [])\n\n return (\n <ToastContext.Provider value={{ toasts, addToast, removeToast, clearToasts }}>\n {children}\n <ToastContainer toasts={toasts} removeToast={removeToast} position={position} />\n </ToastContext.Provider>\n )\n}\n\n// Toast Container Props\ninterface ToastContainerProps {\n toasts: Toast[]\n removeToast: (id: string) => void\n position: string\n}\n\n// Toast Container\nfunction ToastContainer({ toasts, removeToast, position }: ToastContainerProps) {\n const positionClasses = {\n \"top-right\": \"top-4 right-4\",\n \"top-left\": \"top-4 left-4\",\n \"bottom-right\": \"bottom-4 right-4\",\n \"bottom-left\": \"bottom-4 left-4\",\n \"top-center\": \"top-4 left-1/2 transform -translate-x-1/2\",\n \"bottom-center\": \"bottom-4 left-1/2 transform -translate-x-1/2\"\n }\n\n if (toasts.length === 0) return null\n\n return (\n <div className={merge(\n \"fixed z-50 space-y-3 max-w-sm\", // 12px 간격\n positionClasses[position as keyof typeof positionClasses]\n )}>\n {toasts.map((toast) => (\n <ToastItem key={toast.id} toast={toast} onRemove={removeToast} />\n ))}\n </div>\n )\n}\n\n// Toast Item Props\ninterface ToastItemProps {\n toast: Toast\n onRemove: (id: string) => void\n}\n\n// Toast Item\nfunction ToastItem({ toast, onRemove }: ToastItemProps) {\n const [isVisible, setIsVisible] = useState(false)\n\n React.useEffect(() => {\n setIsVisible(true)\n }, [])\n\n const handleRemove = () => {\n setIsVisible(false)\n setTimeout(() => onRemove(toast.id), 300)\n }\n\n const getToastStyles = (type: Toast[\"type\"]) => {\n switch (type) {\n case \"success\":\n return \"bg-green-50 dark:bg-green-900/20 border-green-200 dark:border-green-800 text-green-800 dark:text-green-200\"\n case \"error\":\n return \"bg-red-50 dark:bg-red-900/20 border-red-200 dark:border-red-800 text-red-800 dark:text-red-200\"\n case \"warning\":\n return \"bg-yellow-50 dark:bg-yellow-900/20 border-yellow-200 dark:border-yellow-800 text-yellow-800 dark:text-yellow-200\"\n case \"info\":\n return \"bg-blue-50 dark:bg-blue-900/20 border-blue-200 dark:border-blue-800 text-blue-800 dark:text-blue-200\"\n }\n }\n\n const getIconStyles = (type: Toast[\"type\"]) => {\n switch (type) {\n case \"success\":\n return \"text-green-500 dark:text-green-400\"\n case \"error\":\n return \"text-red-500 dark:text-red-400\"\n case \"warning\":\n return \"text-yellow-500 dark:text-yellow-400\"\n case \"info\":\n return \"text-blue-500 dark:text-blue-400\"\n }\n }\n\n const getToastIcon = (type: Toast[\"type\"]) => {\n switch (type) {\n case \"success\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M5 13l4 4L19 7\" />\n </svg>\n )\n case \"error\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n )\n case \"warning\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-2.5L13.732 4c-.77-.833-1.964-.833-2.732 0L3.732 16.5c-.77.833.192 2.5 1.732 2.5z\" />\n </svg>\n )\n case \"info\":\n return (\n <svg className=\"w-5 h-5\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z\" />\n </svg>\n )\n }\n }\n\n return (\n <div\n className={merge(\n \"flex items-start p-4 rounded-xl border shadow-lg backdrop-blur-sm transition-all duration-300 transform\",\n getToastStyles(toast.type),\n isVisible\n ? \"translate-x-0 opacity-100 scale-100\"\n : \"translate-x-full opacity-0 scale-95\"\n )}\n style={{\n animation: isVisible ? \"slideInRight 0.3s cubic-bezier(0.16, 1, 0.3, 1)\" : undefined\n }}\n >\n {/* 아이콘 */}\n <div className={merge(\"flex-shrink-0 mr-3\", getIconStyles(toast.type))}> {/* 12px 여백 */}\n {getToastIcon(toast.type)}\n </div>\n\n {/* 내용 */}\n <div className=\"flex-1 min-w-0\">\n {toast.title && (\n <h4 className=\"text-sm font-semibold mb-1\"> {/* 4px 여백 */}\n {toast.title}\n </h4>\n )}\n <p className=\"text-sm leading-relaxed\">\n {toast.message}\n </p>\n\n {/* 액션 버튼 */}\n {toast.action && (\n <button\n onClick={toast.action.onClick}\n className=\"mt-3 text-sm font-medium underline hover:no-underline transition-all duration-200\" // 12px 여백\n >\n {toast.action.label}\n </button>\n )}\n </div>\n\n {/* 닫기 버튼 */}\n <div className=\"flex-shrink-0 ml-4\"> {/* 16px 여백 */}\n <button\n onClick={handleRemove}\n className={merge(\n \"inline-flex rounded-md p-1.5 focus:outline-none focus:ring-2 focus:ring-offset-2 transition-all duration-200 hover:bg-black/5 dark:hover:bg-white/5\",\n getIconStyles(toast.type)\n )}\n aria-label=\"닫기\"\n >\n <svg className=\"w-4 h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n </button>\n </div>\n </div>\n )\n}\n\n// 편의 함수들\nexport const showToast = (toast: Omit<Toast, \"id\">) => {\n // 이 함수는 ToastProvider 내부에서만 사용 가능\n\n}\n\nexport const showSuccessToast = (message: string, title?: string, duration?: number) => {\n\n}\n\nexport const showErrorToast = (message: string, title?: string, duration?: number) => {\n\n}\n\nexport const showWarningToast = (message: string, title?: string, duration?: number) => {\n\n}\n\nexport const showInfoToast = (message: string, title?: string, duration?: number) => {\n\n} ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Tooltip 컴포넌트의 props / Tooltip component props\n * @typedef {Object} TooltipProps\n * @property {string} content - Tooltip 내용 / Tooltip content\n * @property {React.ReactNode} children - Tooltip이 연결될 요소 / Element to attach tooltip to\n * @property {\"top\" | \"bottom\" | \"left\" | \"right\"} [position=\"top\"] - Tooltip 표시 위치 / Tooltip display position\n * @property {\"default\" | \"light\" | \"dark\"} [variant=\"default\"] - Tooltip 스타일 변형 / Tooltip style variant\n * @property {number} [delay=300] - Tooltip 표시 지연 시간(ms) / Tooltip display delay (ms)\n * @property {boolean} [disabled=false] - Tooltip 비활성화 여부 / Disable tooltip\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface TooltipProps extends React.HTMLAttributes<HTMLDivElement> {\n content: string\n children: React.ReactNode\n position?: \"top\" | \"bottom\" | \"left\" | \"right\"\n variant?: \"default\" | \"light\" | \"dark\"\n delay?: number\n disabled?: boolean\n}\n\n/**\n * Tooltip 컴포넌트 / Tooltip component\n * \n * 호버 시 추가 정보를 표시하는 툴팁 컴포넌트입니다.\n * 마우스 호버 시 지연 시간 후 표시됩니다.\n * \n * Tooltip component that displays additional information on hover.\n * Appears after a delay when the mouse hovers over the element.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Tooltip content=\"이것은 도움말입니다\">\n * <Button>호버하세요</Button>\n * </Tooltip>\n * \n * @example\n * // 다양한 위치 / Different positions\n * <Tooltip content=\"위치 변경\" position=\"bottom\">\n * <Icon name=\"info\" />\n * </Tooltip>\n * \n * @example\n * // 커스텀 스타일 / Custom styles\n * <Tooltip content=\"라이트 스타일\" variant=\"light\" delay={500}>\n * <span>호버</span>\n * </Tooltip>\n * \n * @param {TooltipProps} props - Tooltip 컴포넌트의 props / Tooltip component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Tooltip 컴포넌트 / Tooltip component\n * \n * @todo 접근성 개선: role=\"tooltip\" 추가 필요 / Accessibility: Add role=\"tooltip\"\n * @todo 접근성 개선: aria-describedby 연결 필요 / Accessibility: Connect aria-describedby\n * @todo 접근성 개선: 키보드 포커스 시 Tooltip 표시 필요 / Accessibility: Show tooltip on keyboard focus\n */\nconst Tooltip = React.forwardRef<HTMLDivElement, TooltipProps>(\n ({ \n className, \n content,\n children,\n position = \"top\",\n variant = \"default\",\n delay = 300,\n disabled = false,\n ...props \n }, ref) => {\n const [isVisible, setIsVisible] = React.useState(false)\n const [coords, setCoords] = React.useState({ x: 0, y: 0 })\n const timeoutRef = React.useRef<number | undefined>(undefined)\n const tooltipRef = React.useRef<HTMLDivElement>(null)\n\n const showTooltip = (e: React.MouseEvent) => {\n if (disabled) return\n \n const rect = e.currentTarget.getBoundingClientRect()\n const tooltipRect = tooltipRef.current?.getBoundingClientRect()\n \n let x = 0\n let y = 0\n \n switch (position) {\n case \"top\":\n x = rect.left + rect.width / 2\n y = rect.top - 8 // 8px 간격\n break\n case \"bottom\":\n x = rect.left + rect.width / 2\n y = rect.bottom + 8 // 8px 간격\n break\n case \"left\":\n x = rect.left - 8 // 8px 간격\n y = rect.top + rect.height / 2\n break\n case \"right\":\n x = rect.right + 8 // 8px 간격\n y = rect.top + rect.height / 2\n break\n }\n \n setCoords({ x, y })\n \n timeoutRef.current = window.setTimeout(() => {\n setIsVisible(true)\n }, delay)\n }\n\n const hideTooltip = () => {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current)\n }\n setIsVisible(false)\n }\n\n React.useEffect(() => {\n return () => {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current)\n }\n }\n }, [])\n\n const getVariantClasses = () => {\n switch (variant) {\n case \"light\":\n return \"bg-white text-gray-900 border border-gray-200 shadow-lg\"\n case \"dark\":\n return \"bg-gray-900 text-white shadow-lg\"\n default:\n return \"bg-gray-800 text-white shadow-lg\"\n }\n }\n\n const getPositionClasses = () => {\n switch (position) {\n case \"top\":\n return \"bottom-full left-1/2 -translate-x-1/2 mb-2\" // 8px 간격\n case \"bottom\":\n return \"top-full left-1/2 -translate-x-1/2 mt-2\" // 8px 간격\n case \"left\":\n return \"right-full top-1/2 -translate-y-1/2 mr-2\" // 8px 간격\n case \"right\":\n return \"left-full top-1/2 -translate-y-1/2 ml-2\" // 8px 간격\n default:\n return \"bottom-full left-1/2 -translate-x-1/2 mb-2\"\n }\n }\n\n const getArrowClasses = () => {\n switch (position) {\n case \"top\":\n return \"top-full left-1/2 -translate-x-1/2 border-t-gray-800 dark:border-t-gray-800\"\n case \"bottom\":\n return \"bottom-full left-1/2 -translate-x-1/2 border-b-gray-800 dark:border-b-gray-800\"\n case \"left\":\n return \"left-full top-1/2 -translate-y-1/2 border-l-gray-800 dark:border-l-gray-800\"\n case \"right\":\n return \"right-full top-1/2 -translate-y-1/2 border-r-gray-800 dark:border-r-gray-800\"\n default:\n return \"top-full left-1/2 -translate-x-1/2 border-t-gray-800 dark:border-t-gray-800\"\n }\n }\n\n return (\n <div\n ref={ref}\n className={merge(\"relative inline-block\", className)}\n onMouseEnter={showTooltip}\n onMouseLeave={hideTooltip}\n {...props}\n >\n {children}\n \n {isVisible && (\n <div\n ref={tooltipRef}\n className={merge(\n \"fixed z-50 px-3 py-2 text-sm rounded-lg whitespace-nowrap pointer-events-none\", // 12px, 8px 패딩\n getVariantClasses()\n )}\n style={{\n left: `${coords.x}px`,\n top: `${coords.y}px`,\n transform: 'translate(-50%, -50%)'\n }}\n >\n {content}\n {/* 화살표 */}\n <div\n className={merge(\n \"absolute w-0 h-0 border-4 border-transparent\",\n getArrowClasses()\n )}\n />\n </div>\n )}\n </div>\n )\n }\n)\nTooltip.displayName = \"Tooltip\"\n\n// 편의 컴포넌트들\nexport const TooltipLight = React.forwardRef<HTMLDivElement, Omit<TooltipProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Tooltip ref={ref} variant=\"light\" className={className} {...props} />\n )\n)\nTooltipLight.displayName = \"TooltipLight\"\n\nexport const TooltipDark = React.forwardRef<HTMLDivElement, Omit<TooltipProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Tooltip ref={ref} variant=\"dark\" className={className} {...props} />\n )\n)\nTooltipDark.displayName = \"TooltipDark\"\n\nexport { Tooltip } ","\"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 * Dropdown 컴포넌트의 props / Dropdown component props\n * @typedef {Object} DropdownProps\n * @property {React.ReactNode} trigger - Dropdown을 열기 위한 트리거 요소 / Trigger element to open dropdown\n * @property {React.ReactNode} children - Dropdown 내용 / Dropdown content\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\"} [placement=\"bottom\"] - Dropdown 표시 위치 / Dropdown display position\n * @property {\"start\" | \"center\" | \"end\"} [align=\"start\"] - Dropdown 정렬 / Dropdown alignment\n * @property {number} [offset=8] - 트리거와 Dropdown 사이 간격 (px) / Spacing between trigger and dropdown (px)\n * @property {boolean} [disabled=false] - Dropdown 비활성화 여부 / Disable dropdown\n * @property {boolean} [showArrow=true] - 화살표 표시 여부 / Show arrow\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface DropdownProps extends React.HTMLAttributes<HTMLDivElement> {\n trigger: React.ReactNode\n children: React.ReactNode\n open?: boolean\n onOpenChange?: (open: boolean) => void\n placement?: \"top\" | \"bottom\" | \"left\" | \"right\"\n align?: \"start\" | \"center\" | \"end\"\n offset?: number\n disabled?: boolean\n showArrow?: boolean\n}\n\n/**\n * Dropdown 컴포넌트 / Dropdown component\n * \n * 트리거 요소를 클릭하면 표시되는 드롭다운 메뉴 컴포넌트입니다.\n * 외부 클릭 시 자동으로 닫히며, 뷰포트 경계를 자동으로 감지하여 위치를 조정합니다.\n * \n * Dropdown menu component that appears when the trigger element is clicked.\n * Automatically closes on outside click and adjusts position by detecting viewport boundaries.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Dropdown trigger={<Button>메뉴</Button>}>\n * <Menu>\n * <MenuItem>항목 1</MenuItem>\n * <MenuItem>항목 2</MenuItem>\n * </Menu>\n * </Dropdown>\n * \n * @example\n * // 제어 모드, 화살표 없음 / Controlled mode, no arrow\n * const [open, setOpen] = useState(false)\n * <Dropdown \n * open={open}\n * onOpenChange={setOpen}\n * trigger={<Button>제어 모드</Button>}\n * placement=\"top\"\n * showArrow={false}\n * >\n * <div className=\"p-4\">내용</div>\n * </Dropdown>\n * \n * @param {DropdownProps} props - Dropdown 컴포넌트의 props / Dropdown component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Dropdown 컴포넌트 / Dropdown component\n */\nconst Dropdown = React.forwardRef<HTMLDivElement, DropdownProps>(\n ({ \n className, \n trigger,\n children,\n open: controlledOpen,\n onOpenChange,\n placement = \"bottom\",\n align = \"start\",\n offset = 8,\n disabled = false,\n showArrow = true,\n ...props \n }, ref) => {\n const [internalOpen, setInternalOpen] = React.useState(false)\n const [coords, setCoords] = React.useState({ x: 0, y: 0 })\n const triggerRef = React.useRef<HTMLDivElement>(null)\n const dropdownRef = 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 const updatePosition = React.useCallback(() => {\n if (!triggerRef.current || !dropdownRef.current) return\n\n const triggerRect = triggerRef.current.getBoundingClientRect()\n const dropdownRect = dropdownRef.current.getBoundingClientRect()\n const viewportWidth = window.innerWidth\n const viewportHeight = window.innerHeight\n\n let x = 0\n let y = 0\n\n // 기본 위치 계산\n switch (placement) {\n case \"top\":\n x = triggerRect.left\n y = triggerRect.top - offset\n break\n case \"bottom\":\n x = triggerRect.left\n y = triggerRect.bottom + offset\n break\n case \"left\":\n x = triggerRect.left - offset\n y = triggerRect.top\n break\n case \"right\":\n x = triggerRect.right + offset\n y = triggerRect.top\n break\n }\n\n // 정렬 조정\n switch (align) {\n case \"center\":\n if (placement === \"top\" || placement === \"bottom\") {\n x = triggerRect.left + triggerRect.width / 2 - dropdownRect.width / 2\n } else {\n y = triggerRect.top + triggerRect.height / 2 - dropdownRect.height / 2\n }\n break\n case \"end\":\n if (placement === \"top\" || placement === \"bottom\") {\n x = triggerRect.right - dropdownRect.width\n } else {\n y = triggerRect.bottom - dropdownRect.height\n }\n break\n case \"start\":\n default:\n // 기본값은 이미 start 정렬\n break\n }\n\n // 뷰포트 경계 확인 및 조정\n if (x < 8) x = 8 // 8px 여백\n if (x + dropdownRect.width > viewportWidth - 8) {\n x = viewportWidth - dropdownRect.width - 8 // 8px 여백\n }\n if (y < 8) y = 8 // 8px 여백\n if (y + dropdownRect.height > viewportHeight - 8) {\n y = viewportHeight - dropdownRect.height - 8 // 8px 여백\n }\n\n setCoords({ x, y })\n }, [placement, align, offset])\n\n React.useEffect(() => {\n if (isOpen) {\n updatePosition()\n window.addEventListener('resize', updatePosition)\n window.addEventListener('scroll', updatePosition)\n \n return () => {\n window.removeEventListener('resize', updatePosition)\n window.removeEventListener('scroll', updatePosition)\n }\n }\n }, [isOpen, updatePosition])\n\n React.useEffect(() => {\n const handleClickOutside = (event: MouseEvent) => {\n if (\n triggerRef.current && \n dropdownRef.current && \n !triggerRef.current.contains(event.target as Node) &&\n !dropdownRef.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 getPlacementClasses = () => {\n switch (placement) {\n case \"top\":\n return \"bottom-full left-0 mb-2\" // 8px 간격\n case \"bottom\":\n return \"top-full left-0 mt-2\" // 8px 간격\n case \"left\":\n return \"right-full top-0 mr-2\" // 8px 간격\n case \"right\":\n return \"left-full top-0 ml-2\" // 8px 간격\n default:\n return \"top-full left-0 mt-2\"\n }\n }\n\n const getArrowClasses = () => {\n switch (placement) {\n case \"top\":\n return \"top-full left-4 -translate-x-1/2 border-t-gray-100 dark:border-t-gray-800\"\n case \"bottom\":\n return \"bottom-full left-4 -translate-x-1/2 border-b-gray-100 dark:border-b-gray-800\"\n case \"left\":\n return \"left-full top-4 -translate-y-1/2 border-l-gray-100 dark:border-l-gray-800\"\n case \"right\":\n return \"right-full top-4 -translate-y-1/2 border-r-gray-100 dark:border-r-gray-800\"\n default:\n return \"bottom-full left-4 -translate-x-1/2 border-b-gray-100 dark:border-b-gray-800\"\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={dropdownRef}\n className={merge(\n \"absolute z-50 bg-white dark:bg-gray-800 rounded-lg shadow-xl backdrop-blur-sm\", // 보더 대신 섀도우 사용\n \"min-w-[200px] py-2\", // 16px 패딩\n getPlacementClasses()\n )}\n style={{\n transform: `translate(${coords.x}px, ${coords.y}px)`,\n boxShadow: \"0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04)\"\n }}\n >\n {/* 화살표 */}\n {showArrow && (\n <div\n className={merge(\n \"absolute w-0 h-0 border-4 border-transparent\",\n getArrowClasses()\n )}\n />\n )}\n \n {/* 내용 */}\n <div className=\"relative z-10\">\n {children}\n </div>\n </div>\n )}\n </div>\n )\n }\n)\nDropdown.displayName = \"Dropdown\"\n\n// 드롭다운 아이템 컴포넌트들\nexport interface DropdownItemProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n icon?: React.ReactNode\n variant?: \"default\" | \"destructive\" | \"disabled\"\n}\n\nconst DropdownItem = React.forwardRef<HTMLButtonElement, DropdownItemProps>(\n ({ \n className, \n icon,\n variant = \"default\",\n children,\n disabled,\n ...props \n }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"destructive\":\n return \"text-red-600 dark:text-red-400 hover:bg-red-50 dark:hover:bg-red-900/20\"\n case \"disabled\":\n return \"text-gray-400 dark:text-gray-500 cursor-not-allowed\"\n default:\n return \"text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700\"\n }\n }\n\n return (\n <button\n ref={ref}\n className={merge(\n \"w-full flex items-center gap-3 px-4 py-3 text-sm font-medium transition-colors focus:outline-none focus:bg-gray-100 dark:focus:bg-gray-700\", // 16px, 12px 패딩\n getVariantClasses(),\n className\n )}\n disabled={disabled || variant === \"disabled\"}\n {...props}\n >\n {icon && (\n <div className=\"flex-shrink-0 w-4 h-4\">\n {icon}\n </div>\n )}\n <span className=\"flex-1 text-left\">{children}</span>\n </button>\n )\n }\n)\nDropdownItem.displayName = \"DropdownItem\"\n\nexport interface DropdownSeparatorProps extends React.HTMLAttributes<HTMLDivElement> {}\n\nconst DropdownSeparator = React.forwardRef<HTMLDivElement, DropdownSeparatorProps>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"h-px bg-gray-200 dark:bg-gray-700 my-2\", className)} // 8px 여백\n {...props}\n />\n )\n)\nDropdownSeparator.displayName = \"DropdownSeparator\"\n\nexport interface DropdownLabelProps extends React.HTMLAttributes<HTMLDivElement> {}\n\nconst DropdownLabel = React.forwardRef<HTMLDivElement, DropdownLabelProps>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"px-4 py-2 text-xs font-semibold text-gray-500 dark:text-gray-400 uppercase tracking-wide\", className)} // 16px, 8px 패딩\n {...props}\n >\n {children}\n </div>\n )\n)\nDropdownLabel.displayName = \"DropdownLabel\"\n\n// 편의 컴포넌트들\nconst DropdownMenu = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"py-1\", className)} // 4px 패딩\n {...props}\n >\n {children}\n </div>\n )\n)\nDropdownMenu.displayName = \"DropdownMenu\"\n\nconst DropdownGroup = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"space-y-1\", className)} // 4px 간격\n {...props}\n >\n {children}\n </div>\n )\n)\nDropdownGroup.displayName = \"DropdownGroup\"\n\nexport { Dropdown, DropdownItem, DropdownSeparator, DropdownLabel, DropdownMenu, DropdownGroup } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\n\n/**\n * Drawer 컴포넌트의 props / Drawer component props\n * @typedef {Object} DrawerProps\n * @property {boolean} open - Drawer 열림/닫힘 상태 / Drawer open/close state\n * @property {(open: boolean) => void} onOpenChange - 상태 변경 콜백 / State change callback\n * @property {React.ReactNode} children - Drawer 내용 / Drawer content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {\"left\" | \"right\" | \"top\" | \"bottom\"} [side=\"right\"] - Drawer 표시 위치 / Drawer display position\n * @property {\"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\"} [size=\"md\"] - Drawer 크기 / Drawer size\n * @property {boolean} [showBackdrop=true] - 배경 오버레이 표시 여부 / Show backdrop overlay\n * @property {string} [backdropClassName] - 배경 오버레이 추가 CSS 클래스 / Backdrop overlay additional CSS class\n * @property {boolean} [closeOnBackdropClick=true] - 배경 클릭 시 닫기 여부 / Close on backdrop click\n * @property {boolean} [closeOnEscape=true] - ESC 키로 닫기 여부 / Close on ESC key\n */\ninterface DrawerProps {\n open: boolean\n onOpenChange: (open: boolean) => void\n children: React.ReactNode\n className?: string\n side?: \"left\" | \"right\" | \"top\" | \"bottom\"\n size?: \"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\"\n showBackdrop?: boolean\n backdropClassName?: string\n closeOnBackdropClick?: boolean\n closeOnEscape?: boolean\n}\n\n/**\n * Drawer 컴포넌트 / Drawer component\n * \n * 사이드에서 슬라이드되는 패널 컴포넌트입니다.\n * Modal과 유사하지만 특정 방향에서 슬라이드되는 애니메이션을 제공합니다.\n * ESC 키로 닫기, 배경 클릭으로 닫기 기능을 지원합니다.\n * \n * Panel component that slides from the side.\n * Similar to Modal but provides slide animation from a specific direction.\n * Supports closing with ESC key and backdrop click.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * const [open, setOpen] = useState(false)\n * \n * <Drawer open={open} onOpenChange={setOpen}>\n * <DrawerHeader>제목</DrawerHeader>\n * <DrawerContent>내용</DrawerContent>\n * <DrawerFooter>\n * <Button onClick={() => setOpen(false)}>닫기</Button>\n * </DrawerFooter>\n * </Drawer>\n * \n * @example\n * // 왼쪽에서 열기 / Open from left\n * <Drawer open={open} onOpenChange={setOpen} side=\"left\" size=\"lg\">\n * <DrawerContent>사이드바 내용</DrawerContent>\n * </Drawer>\n * \n * @param {DrawerProps} props - Drawer 컴포넌트의 props / Drawer component props\n * @param {React.Ref<HTMLDivElement>} ref - Drawer 컨테이너 ref / Drawer container ref\n * @returns {JSX.Element} Drawer 컴포넌트 / Drawer component\n * \n * @todo 접근성 개선: role=\"dialog\", aria-modal=\"true\" 추가 필요 / Accessibility: Add role=\"dialog\", aria-modal=\"true\"\n * @todo 접근성 개선: aria-labelledby, aria-describedby 연결 필요 / Accessibility: Connect aria-labelledby, aria-describedby\n */\nconst Drawer = React.forwardRef<HTMLDivElement, DrawerProps>(\n ({ \n open, \n onOpenChange, \n children, \n className,\n side = \"right\",\n size = \"md\",\n showBackdrop = true,\n backdropClassName,\n closeOnBackdropClick = true,\n closeOnEscape = true,\n ...props \n }, ref) => {\n const [isVisible, setIsVisible] = React.useState(false)\n const [isAnimating, setIsAnimating] = React.useState(false)\n\n React.useEffect(() => {\n if (open) {\n setIsVisible(true)\n setIsAnimating(true)\n // 애니메이션 시작을 위한 지연\n const timer = setTimeout(() => setIsAnimating(false), 50)\n return () => clearTimeout(timer)\n } else {\n setIsAnimating(true)\n const timer = setTimeout(() => {\n setIsVisible(false)\n setIsAnimating(false)\n }, 300) // 애니메이션 완료 후 숨김\n return () => clearTimeout(timer)\n }\n }, [open])\n\n React.useEffect(() => {\n if (!closeOnEscape) return\n\n const handleEscape = (e: KeyboardEvent) => {\n if (e.key === \"Escape\" && open) {\n onOpenChange(false)\n }\n }\n\n if (open) {\n document.addEventListener(\"keydown\", handleEscape)\n document.body.style.overflow = \"hidden\"\n }\n\n return () => {\n document.removeEventListener(\"keydown\", handleEscape)\n document.body.style.overflow = \"\"\n }\n }, [open, closeOnEscape, onOpenChange])\n\n if (!isVisible) return null\n\n const sizeClasses = {\n sm: side === \"left\" || side === \"right\" ? \"w-80\" : \"h-64\",\n md: side === \"left\" || side === \"right\" ? \"w-96\" : \"h-96\",\n lg: side === \"left\" || side === \"right\" ? \"w-[28rem]\" : \"h-[32rem]\",\n xl: side === \"left\" || side === \"right\" ? \"w-[32rem]\" : \"h-[40rem]\",\n full: side === \"left\" || side === \"right\" ? \"w-full\" : \"h-full\"\n }\n\n const sideClasses = {\n left: \"left-0 top-0 h-full translate-x-0\",\n right: \"right-0 top-0 h-full translate-x-0\",\n top: \"top-0 left-0 w-full translate-y-0\",\n bottom: \"bottom-0 left-0 w-full translate-y-0\"\n }\n\n const transformClasses = {\n left: isAnimating ? (open ? \"translate-x-0\" : \"-translate-x-full\") : \"\",\n right: isAnimating ? (open ? \"translate-x-0\" : \"translate-x-full\") : \"\",\n top: isAnimating ? (open ? \"translate-y-0\" : \"-translate-y-full\") : \"\",\n bottom: isAnimating ? (open ? \"translate-y-0\" : \"translate-y-full\") : \"\"\n }\n\n return (\n <div className=\"fixed inset-0 z-50\">\n {/* Backdrop */}\n {showBackdrop && (\n <div\n className={merge(\n \"absolute inset-0 bg-black/60 backdrop-blur-md transition-opacity duration-300\",\n isAnimating ? (open ? \"opacity-100\" : \"opacity-0\") : \"\",\n backdropClassName\n )}\n onClick={closeOnBackdropClick ? () => onOpenChange(false) : undefined}\n />\n )}\n\n {/* Drawer Content */}\n <div\n ref={ref}\n className={merge(\n \"absolute bg-white/95 dark:!bg-gray-800/95 backdrop-blur-xl border border-gray-200/50 dark:!border-gray-600/50 shadow-2xl transition-transform duration-300 ease-out\",\n sizeClasses[size],\n sideClasses[side],\n transformClasses[side],\n className\n )}\n {...props}\n >\n {children}\n </div>\n </div>\n )\n }\n)\nDrawer.displayName = \"Drawer\"\n\n/**\n * DrawerHeader 컴포넌트의 props / DrawerHeader component props\n * @typedef {Object} DrawerHeaderProps\n * @property {React.ReactNode} children - 헤더 내용 / Header content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {boolean} [showCloseButton=true] - 닫기 버튼 표시 여부 / Show close button\n * @property {() => void} [onClose] - 닫기 버튼 클릭 콜백 / Close button click callback\n */\ninterface DrawerHeaderProps {\n children: React.ReactNode\n className?: string\n showCloseButton?: boolean\n onClose?: () => void\n}\n\n/**\n * DrawerHeader 컴포넌트 / DrawerHeader component\n * Drawer의 헤더 영역을 표시합니다.\n * Displays the header area of a Drawer.\n * \n * @component\n * @param {DrawerHeaderProps} props - DrawerHeader 컴포넌트의 props / DrawerHeader component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} DrawerHeader 컴포넌트 / DrawerHeader component\n */\nconst DrawerHeader = React.forwardRef<HTMLDivElement, DrawerHeaderProps>(\n ({ children, className, showCloseButton = true, onClose, ...props }, ref) => {\n return (\n <div\n ref={ref}\n className={merge(\"flex items-center justify-between p-6 border-b border-gray-200/50 dark:border-gray-700/50\", className)}\n {...props}\n >\n <div className=\"flex-1\">{children}</div>\n {showCloseButton && (\n <button\n onClick={onClose}\n className=\"p-2 rounded-lg hover:bg-gray-100/80 dark:hover:bg-gray-800/80 transition-colors\"\n >\n <Icon name=\"close\" size={20} />\n </button>\n )}\n </div>\n )\n }\n)\nDrawerHeader.displayName = \"DrawerHeader\"\n\n/**\n * DrawerContent 컴포넌트의 props / DrawerContent component props\n * @typedef {Object} DrawerContentProps\n * @property {React.ReactNode} children - 콘텐츠 / Content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n */\ninterface DrawerContentProps {\n children: React.ReactNode\n className?: string\n}\n\n/**\n * DrawerContent 컴포넌트 / DrawerContent component\n * Drawer의 메인 콘텐츠 영역을 표시합니다.\n * Displays the main content area of a Drawer.\n * \n * @component\n * @param {DrawerContentProps} props - DrawerContent 컴포넌트의 props / DrawerContent component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} DrawerContent 컴포넌트 / DrawerContent component\n */\nconst DrawerContent = React.forwardRef<HTMLDivElement, DrawerContentProps>(\n ({ children, className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n className={merge(\"flex-1 p-6 overflow-y-auto\", className)}\n {...props}\n >\n {children}\n </div>\n )\n }\n)\nDrawerContent.displayName = \"DrawerContent\"\n\n/**\n * DrawerFooter 컴포넌트의 props / DrawerFooter component props\n * @typedef {Object} DrawerFooterProps\n * @property {React.ReactNode} children - 푸터 내용 / Footer content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n */\ninterface DrawerFooterProps {\n children: React.ReactNode\n className?: string\n}\n\n/**\n * DrawerFooter 컴포넌트 / DrawerFooter component\n * Drawer의 푸터 영역을 표시합니다. 주로 액션 버튼을 배치합니다.\n * Displays the footer area of a Drawer. Typically used for action buttons.\n * \n * @component\n * @param {DrawerFooterProps} props - DrawerFooter 컴포넌트의 props / DrawerFooter component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} DrawerFooter 컴포넌트 / DrawerFooter component\n */\nconst DrawerFooter = React.forwardRef<HTMLDivElement, DrawerFooterProps>(\n ({ children, className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n className={merge(\"flex items-center justify-end gap-3 p-6 border-t border-gray-200/50 dark:border-gray-700/50\", className)}\n {...props}\n >\n {children}\n </div>\n )\n }\n)\nDrawerFooter.displayName = \"DrawerFooter\"\n\nexport { Drawer, DrawerHeader, DrawerContent, DrawerFooter } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\n\n/**\n * BottomSheet 컴포넌트의 props / BottomSheet component props\n * @typedef {Object} BottomSheetProps\n * @property {boolean} open - BottomSheet 열림/닫힘 상태 / BottomSheet open/close state\n * @property {(open: boolean) => void} onOpenChange - 상태 변경 콜백 / State change callback\n * @property {React.ReactNode} children - BottomSheet 내용 / BottomSheet content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {\"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\"} [height=\"md\"] - BottomSheet 높이 / BottomSheet height\n * @property {boolean} [showBackdrop=true] - 배경 오버레이 표시 여부 / Show backdrop overlay\n * @property {string} [backdropClassName] - 배경 오버레이 추가 CSS 클래스 / Backdrop overlay additional CSS class\n * @property {boolean} [closeOnBackdropClick=true] - 배경 클릭 시 닫기 여부 / Close on backdrop click\n * @property {boolean} [closeOnEscape=true] - ESC 키로 닫기 여부 / Close on ESC key\n * @property {boolean} [showDragHandle=true] - 드래그 핸들 표시 여부 / Show drag handle\n * @property {number[]} [snapPoints=[25, 50, 75, 100]] - 스냅 포인트 (퍼센트) / Snap points (percentage)\n * @property {number} [defaultSnap=50] - 기본 스냅 포인트 (퍼센트) / Default snap point (percentage)\n */\ninterface BottomSheetProps {\n open: boolean\n onOpenChange: (open: boolean) => void\n children: React.ReactNode\n className?: string\n height?: \"sm\" | \"md\" | \"lg\" | \"xl\" | \"full\"\n showBackdrop?: boolean\n backdropClassName?: string\n closeOnBackdropClick?: boolean\n closeOnEscape?: boolean\n showDragHandle?: boolean\n snapPoints?: number[]\n defaultSnap?: number\n}\n\n/**\n * BottomSheet 컴포넌트 / BottomSheet component\n * \n * 화면 하단에서 올라오는 시트 컴포넌트입니다.\n * 모바일 친화적인 UI를 제공하며, 드래그로 높이를 조절할 수 있습니다.\n * 스냅 포인트를 지원하여 특정 높이에서 멈출 수 있습니다.\n * \n * Sheet component that slides up from the bottom of the screen.\n * Provides mobile-friendly UI and allows height adjustment by dragging.\n * Supports snap points to stop at specific heights.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * const [open, setOpen] = useState(false)\n * \n * <BottomSheet open={open} onOpenChange={setOpen}>\n * <BottomSheetHeader>제목</BottomSheetHeader>\n * <BottomSheetContent>내용</BottomSheetContent>\n * </BottomSheet>\n * \n * @example\n * // 커스텀 스냅 포인트 / Custom snap points\n * <BottomSheet \n * open={open} \n * onOpenChange={setOpen}\n * snapPoints={[30, 60, 90]}\n * defaultSnap={30}\n * >\n * <BottomSheetContent>내용</BottomSheetContent>\n * </BottomSheet>\n * \n * @param {BottomSheetProps} props - BottomSheet 컴포넌트의 props / BottomSheet component props\n * @param {React.Ref<HTMLDivElement>} ref - BottomSheet 컨테이너 ref / BottomSheet container ref\n * @returns {JSX.Element} BottomSheet 컴포넌트 / BottomSheet component\n * \n * @todo 접근성 개선: role=\"dialog\", aria-modal=\"true\" 추가 필요 / Accessibility: Add role=\"dialog\", aria-modal=\"true\"\n * @todo 접근성 개선: aria-labelledby, aria-describedby 연결 필요 / Accessibility: Connect aria-labelledby, aria-describedby\n */\nconst BottomSheet = React.forwardRef<HTMLDivElement, BottomSheetProps>(\n ({ \n open, \n onOpenChange, \n children, \n className,\n height = \"md\",\n showBackdrop = true,\n backdropClassName,\n closeOnBackdropClick = true,\n closeOnEscape = true,\n showDragHandle = true,\n snapPoints = [25, 50, 75, 100],\n defaultSnap = 50,\n ...props \n }, ref) => {\n const [isVisible, setIsVisible] = React.useState(false)\n const [isAnimating, setIsAnimating] = React.useState(false)\n const [currentHeight, setCurrentHeight] = React.useState(defaultSnap)\n const [isDragging, setIsDragging] = React.useState(false)\n const [startY, setStartY] = React.useState(0)\n const [currentY, setCurrentY] = React.useState(0)\n\n const heightClasses = {\n sm: \"h-64\",\n md: \"h-96\",\n lg: \"h-[32rem]\",\n xl: \"h-[40rem]\",\n full: \"h-full\"\n }\n\n React.useEffect(() => {\n if (open) {\n setIsVisible(true)\n setIsAnimating(true)\n const timer = setTimeout(() => setIsAnimating(false), 50)\n return () => clearTimeout(timer)\n } else {\n setIsAnimating(true)\n const timer = setTimeout(() => {\n setIsVisible(false)\n setIsAnimating(false)\n }, 300)\n return () => clearTimeout(timer)\n }\n }, [open])\n\n React.useEffect(() => {\n if (!closeOnEscape) return\n\n const handleEscape = (e: KeyboardEvent) => {\n if (e.key === \"Escape\" && open) {\n onOpenChange(false)\n }\n }\n\n if (open) {\n document.addEventListener(\"keydown\", handleEscape)\n document.body.style.overflow = \"hidden\"\n }\n\n return () => {\n document.removeEventListener(\"keydown\", handleEscape)\n document.body.style.overflow = \"\"\n }\n }, [open, closeOnEscape, onOpenChange])\n\n const handleTouchStart = (e: React.TouchEvent) => {\n setIsDragging(true)\n setStartY(e.touches[0].clientY)\n setCurrentY(e.touches[0].clientY)\n }\n\n const handleTouchMove = (e: React.TouchEvent) => {\n if (!isDragging) return\n setCurrentY(e.touches[0].clientY)\n }\n\n const handleTouchEnd = () => {\n if (!isDragging) return\n setIsDragging(false)\n\n const deltaY = currentY - startY\n const threshold = 100\n\n if (deltaY > threshold) {\n // 아래로 드래그 - 닫기\n onOpenChange(false)\n } else if (deltaY < -threshold) {\n // 위로 드래그 - 다음 스냅 포인트\n const currentIndex = snapPoints.indexOf(currentHeight)\n const nextIndex = Math.min(currentIndex + 1, snapPoints.length - 1)\n setCurrentHeight(snapPoints[nextIndex])\n }\n }\n\n if (!isVisible) return null\n\n return (\n <div className=\"fixed inset-0 z-50\">\n {/* Backdrop */}\n {showBackdrop && (\n <div\n className={merge(\n \"absolute inset-0 bg-black/60 backdrop-blur-md transition-opacity duration-300\",\n isAnimating ? (open ? \"opacity-100\" : \"opacity-0\") : \"\",\n backdropClassName\n )}\n onClick={closeOnBackdropClick ? () => onOpenChange(false) : undefined}\n />\n )}\n\n {/* Bottom Sheet */}\n <div\n ref={ref}\n className={merge(\n \"absolute bottom-0 left-0 right-0 bg-white/95 dark:!bg-gray-800/95 backdrop-blur-xl border-t border-gray-200/50 dark:!border-gray-600/50 shadow-2xl rounded-t-lg transition-transform duration-300 ease-out pb-safe\",\n heightClasses[height],\n isAnimating ? (open ? \"translate-y-0\" : \"translate-y-full\") : \"\",\n className\n )}\n style={{\n height: `${currentHeight}%`,\n transform: isDragging ? `translateY(${currentY - startY}px)` : undefined\n }}\n onTouchStart={handleTouchStart}\n onTouchMove={handleTouchMove}\n onTouchEnd={handleTouchEnd}\n {...props}\n >\n {/* Drag Handle */}\n {showDragHandle && (\n <div className=\"flex justify-center pt-3 pb-2\">\n <div className=\"w-12 h-1.5 bg-gray-300 dark:bg-gray-600 rounded-full\" />\n </div>\n )}\n\n {children}\n </div>\n </div>\n )\n }\n)\nBottomSheet.displayName = \"BottomSheet\"\n\n/**\n * BottomSheetHeader 컴포넌트의 props / BottomSheetHeader component props\n * @typedef {Object} BottomSheetHeaderProps\n * @property {React.ReactNode} children - 헤더 내용 / Header content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {boolean} [showCloseButton=true] - 닫기 버튼 표시 여부 / Show close button\n * @property {() => void} [onClose] - 닫기 버튼 클릭 콜백 / Close button click callback\n */\ninterface BottomSheetHeaderProps {\n children: React.ReactNode\n className?: string\n showCloseButton?: boolean\n onClose?: () => void\n}\n\n/**\n * BottomSheetHeader 컴포넌트 / BottomSheetHeader component\n * BottomSheet의 헤더 영역을 표시합니다.\n * Displays the header area of a BottomSheet.\n * \n * @component\n * @param {BottomSheetHeaderProps} props - BottomSheetHeader 컴포넌트의 props / BottomSheetHeader component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} BottomSheetHeader 컴포넌트 / BottomSheetHeader component\n */\nconst BottomSheetHeader = React.forwardRef<HTMLDivElement, BottomSheetHeaderProps>(\n ({ children, className, showCloseButton = true, onClose, ...props }, ref) => {\n return (\n <div\n ref={ref}\n className={merge(\"flex items-center justify-between px-6 py-4\", className)}\n {...props}\n >\n <div className=\"flex-1\">{children}</div>\n {showCloseButton && (\n <button\n onClick={onClose}\n className=\"p-2 rounded-lg hover:bg-gray-100/80 dark:hover:bg-gray-800/80 transition-colors\"\n >\n <Icon name=\"close\" size={20} />\n </button>\n )}\n </div>\n )\n }\n)\nBottomSheetHeader.displayName = \"BottomSheetHeader\"\n\n/**\n * BottomSheetContent 컴포넌트의 props / BottomSheetContent component props\n * @typedef {Object} BottomSheetContentProps\n * @property {React.ReactNode} children - 콘텐츠 / Content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n */\ninterface BottomSheetContentProps {\n children: React.ReactNode\n className?: string\n}\n\n/**\n * BottomSheetContent 컴포넌트 / BottomSheetContent component\n * BottomSheet의 메인 콘텐츠 영역을 표시합니다.\n * Displays the main content area of a BottomSheet.\n * \n * @component\n * @param {BottomSheetContentProps} props - BottomSheetContent 컴포넌트의 props / BottomSheetContent component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} BottomSheetContent 컴포넌트 / BottomSheetContent component\n */\nconst BottomSheetContent = React.forwardRef<HTMLDivElement, BottomSheetContentProps>(\n ({ children, className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n className={merge(\"flex-1 px-6 pb-6 overflow-y-auto\", className)}\n {...props}\n >\n {children}\n </div>\n )\n }\n)\nBottomSheetContent.displayName = \"BottomSheetContent\"\n\nexport { BottomSheet, BottomSheetHeader, BottomSheetContent } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Modal } from \"./Modal\"\nimport { Button } from \"./Button\"\n\n/**\n * ConfirmModal 컴포넌트의 props / ConfirmModal component props\n * @typedef {Object} ConfirmModalProps\n * @property {boolean} isOpen - 모달 열림/닫힘 상태 / Modal open/close state\n * @property {() => void} onClose - 닫기 콜백 / Close callback\n * @property {() => void} onConfirm - 확인 콜백 / Confirm callback\n * @property {string} title - 모달 제목 / Modal title\n * @property {string} message - 모달 메시지 / Modal message\n * @property {string} [warning] - 경고 메시지 / Warning message\n * @property {string} [confirmText=\"확인\"] - 확인 버튼 텍스트 / Confirm button text\n * @property {string} [cancelText=\"취소\"] - 취소 버튼 텍스트 / Cancel button text\n * @property {string} [confirmButtonText] - 확인 버튼 커스텀 텍스트 / Custom confirm button text\n * @property {\"danger\" | \"warning\" | \"info\" | \"success\" | \"error\"} [type=\"danger\"] - 모달 타입 / Modal type\n * @property {boolean} [loading=false] - 로딩 상태 / Loading state\n * @property {boolean} [disabled=false] - 비활성화 여부 / Disabled state\n * @property {boolean} [showInput=false] - 입력 필드 표시 여부 / Show input field\n * @property {string} [inputValue=\"\"] - 입력 필드 값 / Input field value\n * @property {(value: string) => void} [onInputChange] - 입력 값 변경 콜백 / Input value change callback\n * @property {string} [inputPlaceholder] - 입력 필드 플레이스홀더 / Input field placeholder\n * @property {string} [inputLabel] - 입력 필드 라벨 / Input field label\n * @property {string} [requiredInputValue] - 필수 입력 값 (확인 버튼 활성화 조건) / Required input value (confirm button activation condition)\n * @property {boolean} [showCancel=true] - 취소 버튼 표시 여부 / Show cancel button\n * @property {\"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\"} [size=\"md\"] - 모달 크기 / Modal size\n */\nexport interface ConfirmModalProps {\n isOpen: boolean\n onClose: () => void\n onConfirm: () => void\n title: string\n message: string\n warning?: string\n confirmText?: string\n cancelText?: string\n confirmButtonText?: string\n type?: \"danger\" | \"warning\" | \"info\" | \"success\" | \"error\"\n loading?: boolean\n disabled?: boolean\n showInput?: boolean\n inputValue?: string\n onInputChange?: (value: string) => void\n inputPlaceholder?: string\n inputLabel?: string\n requiredInputValue?: string\n showCancel?: boolean\n size?: \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\"\n}\n\n/**\n * ConfirmModal 컴포넌트 / ConfirmModal component\n * \n * 확인/취소가 필요한 모달 컴포넌트입니다.\n * 다양한 타입(danger, warning, info, success, error)을 지원하며,\n * 입력 필드와 필수 입력 값 검증을 지원합니다.\n * \n * Modal component that requires confirmation/cancellation.\n * Supports various types (danger, warning, info, success, error),\n * and supports input fields and required input value validation.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <ConfirmModal\n * isOpen={isOpen}\n * onClose={() => setIsOpen(false)}\n * onConfirm={handleConfirm}\n * title=\"삭제 확인\"\n * message=\"정말 삭제하시겠습니까?\"\n * />\n * \n * @example\n * // 입력 필드와 함께 / With input field\n * <ConfirmModal\n * isOpen={isOpen}\n * onClose={() => setIsOpen(false)}\n * onConfirm={handleDelete}\n * title=\"삭제 확인\"\n * message=\"삭제하려면 'DELETE'를 입력하세요\"\n * showInput\n * inputLabel=\"확인 입력\"\n * requiredInputValue=\"DELETE\"\n * inputValue={inputValue}\n * onInputChange={setInputValue}\n * />\n * \n * @param {ConfirmModalProps} props - ConfirmModal 컴포넌트의 props / ConfirmModal component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} ConfirmModal 컴포넌트 / ConfirmModal component\n */\nconst ConfirmModal = React.forwardRef<HTMLDivElement, ConfirmModalProps>(\n ({\n isOpen,\n onClose,\n onConfirm,\n title,\n message,\n warning,\n confirmText = \"확인\",\n cancelText = \"취소\",\n confirmButtonText,\n type = \"danger\",\n loading = false,\n disabled = false,\n showInput = false,\n inputValue = \"\",\n onInputChange,\n inputPlaceholder,\n inputLabel,\n requiredInputValue,\n showCancel = true,\n size = \"md\"\n }, ref) => {\n // 타입별 아이콘과 색상\n const typeConfig = {\n danger: {\n icon: (\n <svg className=\"h-6 w-6 text-red-600 dark:text-red-400\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-2.5L13.732 4c-.77-.833-1.964-.833-2.732 0L3.732 16.5c-.77.833.192 2.5 1.732 2.5z\" />\n </svg>\n ),\n bgColor: \"bg-red-100 dark:bg-red-900/20\",\n buttonColor: \"bg-red-600 hover:bg-red-700 focus:ring-red-500\",\n textColor: \"text-red-600 dark:text-red-400\"\n },\n warning: {\n icon: (\n <svg className=\"h-6 w-6 text-yellow-600 dark:text-yellow-400\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-2.5L13.732 4c-.77-.833-1.964-.833-2.732 0L3.732 16.5c-.77.833.192 2.5 1.732 2.5z\" />\n </svg>\n ),\n bgColor: \"bg-yellow-100 dark:bg-yellow-900/20\",\n buttonColor: \"bg-yellow-600 hover:bg-yellow-700 focus:ring-yellow-500\",\n textColor: \"text-yellow-600 dark:text-yellow-400\"\n },\n info: {\n icon: (\n <svg className=\"h-6 w-6 text-blue-600 dark:text-blue-400\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z\" />\n </svg>\n ),\n bgColor: \"bg-blue-100 dark:bg-blue-900/20\",\n buttonColor: \"bg-blue-600 hover:bg-blue-700 focus:ring-blue-500\",\n textColor: \"text-blue-600 dark:text-blue-400\"\n },\n success: {\n icon: (\n <svg className=\"h-6 w-6 text-green-600 dark:text-green-400\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M5 13l4 4L19 7\" />\n </svg>\n ),\n bgColor: \"bg-green-100 dark:bg-green-900/20\",\n buttonColor: \"bg-green-600 hover:bg-green-700 focus:ring-green-500\",\n textColor: \"text-green-600 dark:text-green-400\"\n },\n error: {\n icon: (\n <svg className=\"h-6 w-6 text-red-600 dark:text-red-400\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n ),\n bgColor: \"bg-red-100 dark:bg-red-900/20\",\n buttonColor: \"bg-red-600 hover:bg-red-700 focus:ring-red-500\",\n textColor: \"text-red-600 dark:text-red-400\"\n }\n }\n\n const config = typeConfig[type]\n const isInputValid = !showInput || !requiredInputValue || inputValue === requiredInputValue\n const isDisabled = disabled || loading || !isInputValid\n\n return (\n <Modal \n isOpen={isOpen} \n onClose={onClose} \n showCloseButton={false}\n size={size}\n >\n <div className=\"text-center\">\n {/* 아이콘 */}\n <div className={merge(\n \"mx-auto flex items-center justify-center h-16 w-16 rounded-full mb-6\", // 64px 아이콘, 24px 여백\n config.bgColor\n )}>\n {config.icon}\n </div>\n\n {/* 제목 */}\n <h3 className=\"text-xl font-semibold text-gray-900 dark:text-white mb-4\"> {/* 16px 여백 */}\n {title}\n </h3>\n\n {/* 메시지 */}\n <div className=\"mb-6\"> {/* 24px 여백 */}\n <p className=\"text-sm text-gray-600 dark:text-gray-400\">\n {message}\n </p>\n \n {/* 경고 메시지 */}\n {warning && (\n <p className={merge(\n \"text-sm mt-3 font-medium\", // 12px 여백\n config.textColor\n )}>\n {warning}\n </p>\n )}\n </div>\n\n {/* 입력 필드 */}\n {showInput && (\n <div className=\"mb-6\"> {/* 24px 여백 */}\n <label htmlFor=\"confirmInput\" className=\"block text-sm font-medium text-gray-700 dark:text-gray-300 mb-3 text-left\"> {/* 12px 여백 */}\n {inputLabel}\n </label>\n <input\n type=\"text\"\n id=\"confirmInput\"\n value={inputValue}\n onChange={(e) => onInputChange?.(e.target.value)}\n placeholder={inputPlaceholder}\n className=\"w-full px-4 py-3 border border-gray-300 dark:border-gray-600 rounded-lg focus:outline-none focus:ring-2 focus:ring-red-500 focus:border-transparent dark:bg-gray-700 dark:text-white transition-colors\" // 16px, 12px 패딩\n />\n </div>\n )}\n\n {/* 버튼 */}\n <div className={merge(\n \"flex gap-3\", // 12px 간격\n showCancel ? \"justify-center\" : \"justify-center\"\n )}>\n {showCancel && (\n <Button\n variant=\"outline\"\n onClick={onClose}\n disabled={loading}\n className=\"px-6 py-3\" // 24px, 12px 패딩\n >\n {cancelText}\n </Button>\n )}\n <Button\n variant=\"default\"\n onClick={onConfirm}\n disabled={isDisabled}\n className={merge(\n \"px-6 py-3\", // 24px, 12px 패딩\n config.buttonColor\n )}\n >\n {loading ? (\n <div className=\"flex items-center\">\n <svg className=\"animate-spin -ml-1 mr-2 h-4 w-4 text-white\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\">\n <circle className=\"opacity-25\" cx=\"12\" cy=\"12\" r=\"10\" stroke=\"currentColor\" strokeWidth=\"4\"></circle>\n <path className=\"opacity-75\" fill=\"currentColor\" d=\"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z\"></path>\n </svg>\n 처리 중...\n </div>\n ) : (\n confirmButtonText || confirmText\n )}\n </Button>\n </div>\n </div>\n </Modal>\n )\n }\n)\nConfirmModal.displayName = \"ConfirmModal\"\n\nexport { ConfirmModal } ","\"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","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\n\n/**\n * Accordion 컴포넌트의 props / Accordion component props\n * @typedef {Object} AccordionProps\n * @property {React.ReactNode} children - AccordionItem 컴포넌트들 / AccordionItem components\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {\"single\" | \"multiple\"} [type=\"single\"] - 단일 또는 다중 아이템 열기 허용 / Allow single or multiple items to be open\n * @property {string | string[]} [defaultValue] - 초기 열린 아이템 값 (비제어 컴포넌트) / Initial open item value (uncontrolled component)\n * @property {string | string[]} [value] - 현재 열린 아이템 값 (제어 컴포넌트) / Current open item value (controlled component)\n * @property {(value: string | string[]) => void} [onValueChange] - 아이템 열림/닫힘 콜백 / Item open/close callback\n * @property {boolean} [collapsible=false] - 단일 모드에서 열린 아이템을 닫을 수 있는지 여부 / Whether open item can be closed in single mode\n */\ninterface AccordionProps {\n children: React.ReactNode\n className?: string\n type?: \"single\" | \"multiple\"\n defaultValue?: string | string[]\n value?: string | string[]\n onValueChange?: (value: string | string[]) => void\n collapsible?: boolean\n}\n\n/**\n * Accordion 컴포넌트 / Accordion component\n * \n * 접을 수 있는 콘텐츠 섹션을 제공하는 컴포넌트입니다.\n * 키보드 네비게이션(Arrow keys, Home/End)을 지원하며, ARIA 속성을 자동으로 설정합니다.\n * \n * Component that provides collapsible content sections.\n * Supports keyboard navigation (Arrow keys, Home/End) and automatically sets ARIA attributes.\n * \n * @component\n * @example\n * // 기본 사용 (단일 열기) / Basic usage (single open)\n * <Accordion type=\"single\">\n * <AccordionItem value=\"item1\">\n * <AccordionTrigger>제목 1</AccordionTrigger>\n * <AccordionContent>내용 1</AccordionContent>\n * </AccordionItem>\n * <AccordionItem value=\"item2\">\n * <AccordionTrigger>제목 2</AccordionTrigger>\n * <AccordionContent>내용 2</AccordionContent>\n * </AccordionItem>\n * </Accordion>\n * \n * @example\n * // 다중 열기 / Multiple open\n * <Accordion type=\"multiple\" defaultValue={[\"item1\", \"item2\"]}>\n * <AccordionItem value=\"item1\">\n * <AccordionTrigger>제목 1</AccordionTrigger>\n * <AccordionContent>내용 1</AccordionContent>\n * </AccordionItem>\n * </Accordion>\n * \n * @example\n * // 제어 컴포넌트 / Controlled component\n * const [openItems, setOpenItems] = useState<string[]>([])\n * <Accordion type=\"multiple\" value={openItems} onValueChange={setOpenItems}>\n * <AccordionItem value=\"item1\">\n * <AccordionTrigger>제목</AccordionTrigger>\n * <AccordionContent>내용</AccordionContent>\n * </AccordionItem>\n * </Accordion>\n * \n * @param {AccordionProps} props - Accordion 컴포넌트의 props / Accordion component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Accordion 컴포넌트 / Accordion component\n */\nconst Accordion = React.forwardRef<HTMLDivElement, AccordionProps>(\n ({ \n children, \n className,\n type = \"single\",\n defaultValue,\n value,\n onValueChange,\n collapsible = false,\n ...props \n }, ref) => {\n const [openItems, setOpenItems] = React.useState<string[]>(\n value ? (Array.isArray(value) ? value : [value]) : \n defaultValue ? (Array.isArray(defaultValue) ? defaultValue : [defaultValue]) : []\n )\n\n React.useEffect(() => {\n if (value !== undefined) {\n setOpenItems(Array.isArray(value) ? value : [value])\n }\n }, [value])\n\n const handleItemToggle = (itemValue: string) => {\n let newOpenItems: string[]\n\n if (type === \"single\") {\n if (openItems.includes(itemValue)) {\n newOpenItems = collapsible ? [] : openItems\n } else {\n newOpenItems = [itemValue]\n }\n } else {\n if (openItems.includes(itemValue)) {\n newOpenItems = openItems.filter(item => item !== itemValue)\n } else {\n newOpenItems = [...openItems, itemValue]\n }\n }\n\n setOpenItems(newOpenItems)\n onValueChange?.(type === \"single\" ? newOpenItems[0] || \"\" : newOpenItems)\n }\n\n // 모든 아이템의 value를 수집\n const itemValues = React.useMemo(() => {\n const values: string[] = []\n React.Children.forEach(children, (child) => {\n if (React.isValidElement(child)) {\n const childProps = child.props as { value?: string }\n if (childProps.value) {\n values.push(childProps.value)\n }\n }\n })\n return values\n }, [children])\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLDivElement>) => {\n const target = e.target as HTMLElement\n if (!target.hasAttribute('data-accordion-trigger')) return\n\n const currentValue = target.getAttribute('data-accordion-value')\n if (!currentValue) return\n\n const currentIndex = itemValues.indexOf(currentValue)\n if (currentIndex === -1) return\n\n let newIndex = currentIndex\n\n if (e.key === \"ArrowDown\") {\n e.preventDefault()\n newIndex = currentIndex < itemValues.length - 1 ? currentIndex + 1 : 0\n } else if (e.key === \"ArrowUp\") {\n e.preventDefault()\n newIndex = currentIndex > 0 ? currentIndex - 1 : itemValues.length - 1\n } else if (e.key === \"Home\") {\n e.preventDefault()\n newIndex = 0\n } else if (e.key === \"End\") {\n e.preventDefault()\n newIndex = itemValues.length - 1\n }\n\n if (newIndex !== currentIndex && itemValues[newIndex]) {\n const triggerElement = target.closest('[data-accordion-item]')?.querySelector(\n `[data-accordion-value=\"${itemValues[newIndex]}\"]`\n ) as HTMLElement\n triggerElement?.focus()\n }\n }\n\n return (\n <div\n ref={ref}\n className={merge(\"space-y-2\", className)}\n onKeyDown={handleKeyDown}\n {...props}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return React.cloneElement(child, {\n openItems,\n onToggle: handleItemToggle\n } as Partial<AccordionItemProps>)\n }\n return child\n })}\n </div>\n )\n }\n)\nAccordion.displayName = \"Accordion\"\n\n/**\n * AccordionItem 컴포넌트의 props / AccordionItem component props\n * @typedef {Object} AccordionItemProps\n * @property {string} value - 아이템의 고유 값 / Item unique value\n * @property {React.ReactNode} children - AccordionTrigger와 AccordionContent / AccordionTrigger and AccordionContent\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {boolean} [disabled=false] - 아이템 비활성화 여부 / Item disabled state\n * @property {string[]} [openItems] - 열린 아이템 목록 (Accordion에서 자동 전달) / Open items list (auto-passed from Accordion)\n * @property {(value: string) => void} [onToggle] - 토글 콜백 (Accordion에서 자동 전달) / Toggle callback (auto-passed from Accordion)\n */\ninterface AccordionItemProps {\n value: string\n children: React.ReactNode\n className?: string\n disabled?: boolean\n openItems?: string[]\n onToggle?: (value: string) => void\n}\n\n/**\n * AccordionItem 컴포넌트 / AccordionItem component\n * 아코디언의 개별 아이템을 감싸는 컨테이너입니다.\n * Container that wraps an individual accordion item.\n * \n * @component\n * @param {AccordionItemProps} props - AccordionItem 컴포넌트의 props / AccordionItem component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} AccordionItem 컴포넌트 / AccordionItem component\n */\nconst AccordionItem = React.forwardRef<HTMLDivElement, AccordionItemProps>(\n ({ \n value, \n children, \n className,\n disabled = false,\n openItems = [],\n onToggle,\n ...props \n }, ref) => {\n const isOpen = openItems.includes(value)\n\n return (\n <div\n ref={ref}\n data-accordion-item\n className={merge(\n \"border border-gray-200/50 dark:border-gray-700/50 rounded-lg overflow-hidden\",\n disabled && \"opacity-50 pointer-events-none\",\n className\n )}\n {...props}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return React.cloneElement(child, {\n value,\n isOpen,\n disabled,\n onToggle: () => onToggle?.(value),\n 'data-accordion-value': value\n } as Partial<AccordionTriggerProps | AccordionContentProps>)\n }\n return child\n })}\n </div>\n )\n }\n)\nAccordionItem.displayName = \"AccordionItem\"\n\ninterface AccordionTriggerProps {\n children: React.ReactNode\n className?: string\n icon?: React.ReactNode\n iconPosition?: \"left\" | \"right\"\n value?: string // Optional: AccordionItem에서 자동으로 전달됨 / Optional: Auto-passed from AccordionItem\n isOpen?: boolean\n disabled?: boolean\n onToggle?: () => void\n}\n\nconst AccordionTrigger = React.forwardRef<HTMLButtonElement, AccordionTriggerProps>(\n ({ \n children, \n className,\n icon,\n iconPosition = \"right\",\n value,\n isOpen = false,\n disabled = false,\n onToggle,\n ...props \n }, ref) => {\n const defaultIcon = (\n <Icon \n name=\"chevronDown\" \n size={20} \n className={merge(\n \"transition-transform duration-300 ease-out text-gray-500 dark:text-gray-400\",\n isOpen && \"rotate-180\"\n )} \n />\n )\n\n const contentId = `accordion-content-${value}`\n const triggerId = `accordion-trigger-${value}`\n\n return (\n <button\n ref={ref}\n id={triggerId}\n data-accordion-trigger\n data-accordion-value={value}\n aria-expanded={isOpen}\n aria-controls={contentId}\n onClick={onToggle}\n disabled={disabled}\n className={merge(\n \"flex w-full items-center justify-between px-6 py-4 text-left font-medium transition-all hover:bg-gray-50/80 dark:hover:bg-gray-800/80 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-blue-500/50 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n className\n )}\n {...props}\n >\n <div className=\"flex items-center gap-3 flex-1\">\n {iconPosition === \"left\" && (icon || defaultIcon)}\n <span className=\"flex-1\">{children}</span>\n </div>\n {iconPosition === \"right\" && (icon || defaultIcon)}\n </button>\n )\n }\n)\nAccordionTrigger.displayName = \"AccordionTrigger\"\n\n/**\n * AccordionTrigger 컴포넌트 / AccordionTrigger component\n * 아코디언 아이템을 열고 닫는 트리거 버튼입니다.\n * Button that opens and closes an accordion item.\n * \n * @component\n * @param {AccordionTriggerProps} props - AccordionTrigger 컴포넌트의 props / AccordionTrigger component props\n * @param {React.Ref<HTMLButtonElement>} ref - button 요소 ref / button element ref\n * @returns {JSX.Element} AccordionTrigger 컴포넌트 / AccordionTrigger component\n */\n\n/**\n * AccordionContent 컴포넌트의 props\n * @typedef {Object} AccordionContentProps\n * @property {React.ReactNode} children - 콘텐츠\n * @property {string} [className] - 추가 CSS 클래스\n * @property {boolean} [isOpen] - 열림 상태 (AccordionItem에서 자동 전달)\n * @property {string} [value] - 아이템 값 (AccordionItem에서 자동 전달)\n * @property {string} ['data-accordion-value'] - 아이템 값 (내부 사용)\n */\ninterface AccordionContentProps {\n children: React.ReactNode\n className?: string\n isOpen?: boolean\n value?: string\n 'data-accordion-value'?: string\n}\n\n/**\n * AccordionContent 컴포넌트 / AccordionContent component\n * 아코디언 아이템의 콘텐츠를 표시합니다.\n * Displays the content of an accordion item.\n * \n * @component\n * @param {AccordionContentProps} props - AccordionContent 컴포넌트의 props / AccordionContent component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} AccordionContent 컴포넌트 / AccordionContent component\n */\nconst AccordionContent = React.forwardRef<HTMLDivElement, AccordionContentProps>(\n ({ children, className, isOpen = false, value, 'data-accordion-value': dataValue, ...props }, ref) => {\n const [height, setHeight] = React.useState(0)\n const contentRef = React.useRef<HTMLDivElement>(null)\n const itemValue = value || dataValue || 'unknown'\n\n React.useEffect(() => {\n if (contentRef.current) {\n if (isOpen) {\n setHeight(contentRef.current.scrollHeight)\n } else {\n setHeight(0)\n }\n }\n }, [isOpen, children])\n\n const triggerId = `accordion-trigger-${itemValue}`\n const contentId = `accordion-content-${itemValue}`\n\n return (\n <div\n ref={ref}\n id={contentId}\n role=\"region\"\n aria-labelledby={triggerId}\n hidden={!isOpen}\n className=\"overflow-hidden transition-all duration-300 ease-out\"\n style={{ height: `${height}px` }}\n {...props}\n >\n <div\n ref={contentRef}\n className={merge(\"px-6 pt-2 pb-4\", className)}\n >\n {children}\n </div>\n </div>\n )\n }\n)\nAccordionContent.displayName = \"AccordionContent\"\n\nexport { Accordion, AccordionItem, AccordionTrigger, AccordionContent } ","\"use client\"\n\nimport React from 'react'\nimport { merge } from '../lib/utils'\n\n/**\n * TabsContent 컴포넌트의 props / TabsContent component props\n * @typedef {Object} TabsContentProps\n * @property {string} value - 탭 패널의 고유 값 (TabsTrigger의 value와 일치해야 함) / Unique value for tab panel (must match TabsTrigger value)\n * @property {boolean} [active] - 탭 패널 활성화 상태 (자동 설정됨) / Tab panel active state (auto-set)\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface TabsContentProps extends React.HTMLAttributes<HTMLDivElement> {\n value: string\n active?: boolean\n}\n\n/**\n * TabsContent 컴포넌트 / TabsContent component\n * 탭의 콘텐츠 패널을 표시합니다. Tabs 컴포넌트 내부에서 사용됩니다.\n * Displays the tab content panel. Used inside Tabs component.\n * \n * @component\n * @param {TabsContentProps} props - TabsContent 컴포넌트의 props / TabsContent component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} TabsContent 컴포넌트 / TabsContent component\n */\nconst TabsContent = React.forwardRef<HTMLDivElement, TabsContentProps>(\n ({ className, value, active, children, ...props }, ref) => {\n // active prop이 명시적으로 false로 설정된 경우에만 숨김\n if (active === false) return null\n\n return (\n <div\n ref={ref}\n role=\"tabpanel\"\n id={`tabpanel-${value}`}\n aria-labelledby={`tab-${value}`}\n hidden={!active}\n className={merge(\n \"mt-2 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2\",\n className\n )}\n {...props}\n >\n {children}\n </div>\n )\n }\n)\nTabsContent.displayName = \"TabsContent\"\n\n/**\n * Tabs 컴포넌트의 props / Tabs component props\n * @typedef {Object} TabsProps\n * @property {string} [value] - 현재 활성화된 탭 값 (제어 컴포넌트) / Currently active tab value (controlled component)\n * @property {string} [defaultValue] - 초기 활성화된 탭 값 (비제어 컴포넌트) / Initial active tab value (uncontrolled component)\n * @property {(value: string) => void} [onValueChange] - 탭 변경 시 호출되는 콜백 / Callback when tab changes\n * @property {\"horizontal\" | \"vertical\"} [orientation=\"horizontal\"] - 탭 방향 / Tab orientation\n * @property {\"default\" | \"pills\" | \"underline\" | \"cards\"} [variant=\"default\"] - 탭 스타일 변형 / Tab style variant\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - 탭 크기 / Tab size\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface TabsProps extends React.HTMLAttributes<HTMLDivElement> {\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n orientation?: \"horizontal\" | \"vertical\"\n variant?: \"default\" | \"pills\" | \"underline\" | \"cards\"\n size?: \"sm\" | \"md\" | \"lg\"\n}\n\n/**\n * Tabs 컴포넌트 / Tabs component\n * \n * 탭 네비게이션을 제공하는 컴포넌트입니다.\n * 키보드 네비게이션(Arrow keys, Home/End)을 지원하며, ARIA 속성을 자동으로 설정합니다.\n * \n * Component that provides tab navigation.\n * Supports keyboard navigation (Arrow keys, Home/End) and automatically sets ARIA attributes.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Tabs defaultValue=\"tab1\">\n * <TabsList>\n * <TabsTrigger value=\"tab1\">탭 1</TabsTrigger>\n * <TabsTrigger value=\"tab2\">탭 2</TabsTrigger>\n * </TabsList>\n * <TabsContent value=\"tab1\">탭 1 내용</TabsContent>\n * <TabsContent value=\"tab2\">탭 2 내용</TabsContent>\n * </Tabs>\n * \n * @example\n * // 제어 컴포넌트 / Controlled component\n * const [activeTab, setActiveTab] = useState(\"tab1\")\n * <Tabs value={activeTab} onValueChange={setActiveTab}>\n * <TabsList>\n * <TabsTrigger value=\"tab1\">탭 1</TabsTrigger>\n * </TabsList>\n * <TabsContent value=\"tab1\">내용</TabsContent>\n * </Tabs>\n * \n * @example\n * // 다양한 변형 / Various variants\n * <Tabs variant=\"pills\" size=\"lg\">\n * <TabsList>\n * <TabsTrigger value=\"tab1\">Pills 스타일</TabsTrigger>\n * </TabsList>\n * </Tabs>\n * \n * @param {TabsProps} props - Tabs 컴포넌트의 props / Tabs component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Tabs 컴포넌트 / Tabs component\n */\nconst Tabs = React.forwardRef<HTMLDivElement, TabsProps>(\n ({ \n className, \n value,\n defaultValue,\n onValueChange,\n orientation = \"horizontal\",\n variant = \"default\",\n size = \"md\",\n children,\n ...props \n }, ref) => {\n const [activeTab, setActiveTab] = React.useState(value || defaultValue || \"\")\n const isControlled = value !== undefined\n const currentValue = isControlled ? value : activeTab\n\n const handleTabChange = (newValue: string) => {\n if (!isControlled) {\n setActiveTab(newValue)\n }\n onValueChange?.(newValue)\n }\n\n React.useEffect(() => {\n if (value !== undefined) {\n setActiveTab(value)\n }\n }, [value])\n\n return (\n <div\n ref={ref}\n className={merge(\n \"w-full\",\n orientation === \"vertical\" && \"flex\",\n className\n )}\n {...props}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n // TabsContent인 경우 active prop을 자동으로 설정\n if (child.type === TabsContent) {\n const childProps = child.props as TabsContentProps\n return React.cloneElement(child, {\n value: currentValue,\n onValueChange: handleTabChange,\n orientation,\n variant,\n size,\n active: childProps.value === currentValue\n } as Partial<TabsContentProps>)\n }\n // 다른 컴포넌트들\n return React.cloneElement(child, {\n value: currentValue,\n onValueChange: handleTabChange,\n orientation,\n variant,\n size\n } as Partial<TabsTriggerProps | TabsListProps>)\n }\n return child\n })}\n </div>\n )\n }\n)\nTabs.displayName = \"Tabs\"\n\n/**\n * TabsList 컴포넌트의 props / TabsList component props\n * @typedef {Object} TabsListProps\n * @property {string} [value] - 현재 활성화된 탭 값 (Tabs에서 자동 전달) / Currently active tab value (auto-passed from Tabs)\n * @property {(value: string) => void} [onValueChange] - 탭 변경 콜백 (Tabs에서 자동 전달) / Tab change callback (auto-passed from Tabs)\n * @property {\"horizontal\" | \"vertical\"} [orientation] - 탭 방향 (Tabs에서 자동 전달) / Tab orientation (auto-passed from Tabs)\n * @property {\"default\" | \"pills\" | \"underline\" | \"cards\"} [variant] - 탭 스타일 (Tabs에서 자동 전달) / Tab style (auto-passed from Tabs)\n * @property {\"sm\" | \"md\" | \"lg\"} [size] - 탭 크기 (Tabs에서 자동 전달) / Tab size (auto-passed from Tabs)\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface TabsListProps extends React.HTMLAttributes<HTMLDivElement> {\n value?: string\n onValueChange?: (value: string) => void\n orientation?: \"horizontal\" | \"vertical\"\n variant?: \"default\" | \"pills\" | \"underline\" | \"cards\"\n size?: \"sm\" | \"md\" | \"lg\"\n}\n\n/**\n * TabsList 컴포넌트 / TabsList component\n * 탭 트리거 목록을 표시합니다. Tabs 컴포넌트 내부에서 사용됩니다.\n * Displays the list of tab triggers. Used inside Tabs component.\n * \n * @component\n * @param {TabsListProps} props - TabsList 컴포넌트의 props / TabsList component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} TabsList 컴포넌트 / TabsList component\n */\nconst TabsList = React.forwardRef<HTMLDivElement, TabsListProps>(\n ({ \n className, \n value,\n onValueChange,\n orientation = \"horizontal\",\n variant = \"default\",\n size = \"md\",\n children,\n ...props \n }, ref) => {\n const listRef = React.useRef<HTMLDivElement>(null)\n React.useImperativeHandle(ref, () => listRef.current as HTMLDivElement)\n \n // 모든 탭 트리거의 value를 수집\n const tabValues = React.useMemo(() => {\n const values: string[] = []\n React.Children.forEach(children, (child) => {\n if (React.isValidElement(child)) {\n const childProps = child.props as { value?: string }\n if (childProps.value) {\n values.push(childProps.value)\n }\n }\n })\n return values\n }, [children])\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLDivElement>) => {\n if (!value || tabValues.length === 0) return\n\n const currentIndex = tabValues.indexOf(value)\n if (currentIndex === -1) return\n\n let newIndex = currentIndex\n\n if (orientation === \"horizontal\") {\n if (e.key === \"ArrowLeft\") {\n e.preventDefault()\n newIndex = currentIndex > 0 ? currentIndex - 1 : tabValues.length - 1\n } else if (e.key === \"ArrowRight\") {\n e.preventDefault()\n newIndex = currentIndex < tabValues.length - 1 ? currentIndex + 1 : 0\n } else if (e.key === \"Home\") {\n e.preventDefault()\n newIndex = 0\n } else if (e.key === \"End\") {\n e.preventDefault()\n newIndex = tabValues.length - 1\n }\n } else {\n if (e.key === \"ArrowUp\") {\n e.preventDefault()\n newIndex = currentIndex > 0 ? currentIndex - 1 : tabValues.length - 1\n } else if (e.key === \"ArrowDown\") {\n e.preventDefault()\n newIndex = currentIndex < tabValues.length - 1 ? currentIndex + 1 : 0\n } else if (e.key === \"Home\") {\n e.preventDefault()\n newIndex = 0\n } else if (e.key === \"End\") {\n e.preventDefault()\n newIndex = tabValues.length - 1\n }\n }\n\n if (newIndex !== currentIndex && tabValues[newIndex]) {\n onValueChange?.(tabValues[newIndex])\n // 포커스 이동\n const triggerElement = listRef.current?.querySelector(\n `[data-tab-value=\"${tabValues[newIndex]}\"]`\n ) as HTMLElement\n triggerElement?.focus()\n }\n }\n const getVariantClasses = () => {\n switch (variant) {\n case \"pills\":\n return \"bg-gray-50 dark:bg-gray-800/80 p-3 rounded-xl border border-gray-200/50 dark:border-gray-700/50\"\n case \"underline\":\n return \"border-b border-gray-200 dark:border-gray-700\"\n case \"cards\":\n return \"bg-gray-50/80 dark:bg-gray-900/80 p-3 rounded-xl border border-gray-200/50 dark:border-gray-700/50\"\n default:\n return \"bg-gray-50 dark:bg-gray-800/80 p-3 rounded-xl border border-gray-200/50 dark:border-gray-700/50\"\n }\n }\n\n const getSizeClasses = () => {\n switch (size) {\n case \"sm\":\n return \"h-12\"\n case \"lg\":\n return \"h-16\"\n default:\n return \"h-14\"\n }\n }\n\n return (\n <div\n ref={listRef}\n role=\"tablist\"\n aria-orientation={orientation}\n onKeyDown={handleKeyDown}\n className={merge(\n \"flex items-center justify-center\",\n orientation === \"vertical\" && \"flex-col\",\n getVariantClasses(),\n getSizeClasses(),\n className\n )}\n {...props}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return React.cloneElement(child, {\n value,\n onValueChange,\n orientation,\n variant,\n size\n } as Partial<TabsTriggerProps>)\n }\n return child\n })}\n </div>\n )\n }\n)\nTabsList.displayName = \"TabsList\"\n\n/**\n * TabsTrigger 컴포넌트의 props\n * @typedef {Object} TabsTriggerProps\n * @property {string} value - 탭 트리거의 고유 값 (TabsContent의 value와 일치해야 함)\n * @property {(value: string) => void} [onValueChange] - 탭 변경 콜백 (TabsList에서 자동 전달)\n * @property {\"horizontal\" | \"vertical\"} [orientation] - 탭 방향 (TabsList에서 자동 전달)\n * @property {\"default\" | \"pills\" | \"underline\" | \"cards\"} [variant] - 탭 스타일 (TabsList에서 자동 전달)\n * @property {\"sm\" | \"md\" | \"lg\"} [size] - 탭 크기 (TabsList에서 자동 전달)\n * @property {boolean} [active] - 탭 활성화 상태 (자동 설정됨)\n * @extends {React.ButtonHTMLAttributes<HTMLButtonElement>}\n */\nexport interface TabsTriggerProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n value: string\n onValueChange?: (value: string) => void\n orientation?: \"horizontal\" | \"vertical\"\n variant?: \"default\" | \"pills\" | \"underline\" | \"cards\"\n size?: \"sm\" | \"md\" | \"lg\"\n active?: boolean\n}\n\n/**\n * TabsTrigger 컴포넌트 / TabsTrigger component\n * 탭을 활성화하는 버튼입니다. TabsList 컴포넌트 내부에서 사용됩니다.\n * Button that activates a tab. Used inside TabsList component.\n * \n * @component\n * @param {TabsTriggerProps} props - TabsTrigger 컴포넌트의 props / TabsTrigger component props\n * @param {React.Ref<HTMLButtonElement>} ref - button 요소 ref / button element ref\n * @returns {JSX.Element} TabsTrigger 컴포넌트 / TabsTrigger component\n */\nconst TabsTrigger = React.forwardRef<HTMLButtonElement, TabsTriggerProps>(\n ({ \n className, \n value,\n onValueChange,\n orientation = \"horizontal\",\n variant = \"default\",\n size = \"md\",\n active = false,\n children,\n ...props \n }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"pills\":\n return merge(\n \"inline-flex items-center justify-center whitespace-nowrap rounded-lg px-4 py-2.5 text-sm font-medium ring-offset-background transition-all duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n active \n ? \"bg-white dark:bg-gray-900 text-gray-900 dark:text-white shadow-md\" \n : \"text-gray-600 dark:text-gray-400 hover:text-gray-900 dark:hover:text-white hover:bg-gray-100 dark:hover:bg-gray-800\"\n )\n case \"underline\":\n return merge(\n \"inline-flex items-center justify-center whitespace-nowrap border-b-2 px-4 py-2.5 text-sm font-medium ring-offset-background transition-all duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n active \n ? \"border-blue-500 text-blue-600 dark:text-blue-400\" \n : \"border-transparent text-gray-600 dark:text-gray-400 hover:text-gray-900 dark:hover:text-white\"\n )\n case \"cards\":\n return merge(\n \"inline-flex items-center justify-center whitespace-nowrap rounded-lg px-4 py-2.5 text-sm font-medium ring-offset-background transition-all duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n active \n ? \"bg-white dark:bg-gray-900 text-gray-900 dark:text-white shadow-md\" \n : \"text-gray-600 dark:text-gray-400 hover:text-gray-900 dark:hover:text-white hover:bg-gray-100 dark:hover:bg-gray-800\"\n )\n default:\n return merge(\n \"inline-flex items-center justify-center whitespace-nowrap rounded-lg px-4 py-2.5 text-sm font-medium ring-offset-background transition-all duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\",\n active \n ? \"bg-white dark:bg-gray-900 text-gray-900 dark:text-white shadow-md\" \n : \"text-gray-600 dark:text-gray-400 hover:text-gray-900 dark:hover:text-white hover:bg-gray-100 dark:hover:bg-gray-800\"\n )\n }\n }\n\n const getSizeClasses = () => {\n switch (size) {\n case \"sm\":\n return \"h-10 px-4 py-2 text-xs\"\n case \"lg\":\n return \"h-14 px-6 py-3 text-base\"\n default:\n return \"h-12 px-5 py-2.5 text-sm\"\n }\n }\n\n const handleClick = () => {\n console.log('TabsTrigger clicked:', value, 'onValueChange:', !!onValueChange)\n if (onValueChange) {\n onValueChange(value)\n }\n }\n\n return (\n <button\n ref={ref}\n role=\"tab\"\n aria-selected={active}\n aria-controls={`tabpanel-${value}`}\n id={`tab-${value}`}\n data-tab-value={value}\n tabIndex={active ? 0 : -1}\n className={merge(\n getVariantClasses(),\n getSizeClasses(),\n className\n )}\n onClick={handleClick}\n type=\"button\"\n {...props}\n >\n {children}\n </button>\n )\n }\n)\nTabsTrigger.displayName = \"TabsTrigger\"\n\n// 편의 컴포넌트들\nconst TabsPills = React.forwardRef<HTMLDivElement, TabsProps>(\n (props, ref) => <Tabs ref={ref} variant=\"pills\" {...props} />\n)\nTabsPills.displayName = \"TabsPills\"\n\nconst TabsUnderline = React.forwardRef<HTMLDivElement, TabsProps>(\n (props, ref) => <Tabs ref={ref} variant=\"underline\" {...props} />\n)\nTabsUnderline.displayName = \"TabsUnderline\"\n\nconst TabsCards = React.forwardRef<HTMLDivElement, TabsProps>(\n (props, ref) => <Tabs ref={ref} variant=\"cards\" {...props} />\n)\nTabsCards.displayName = \"TabsCards\"\n\nexport { Tabs, TabsList, TabsTrigger, TabsContent, TabsPills, TabsUnderline, TabsCards } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Menu 컴포넌트의 props / Menu component props\n * @typedef {Object} MenuProps\n * @property {React.ReactNode} children - MenuItem, MenuSeparator, MenuLabel 컴포넌트들 / MenuItem, MenuSeparator, MenuLabel components\n * @property {\"default\" | \"horizontal\" | \"vertical\" | \"compact\"} [variant=\"default\"] - 메뉴 방향 및 스타일 / Menu direction and style\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - 메뉴 아이템 크기 / Menu item size\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface MenuProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n variant?: \"default\" | \"horizontal\" | \"vertical\" | \"compact\"\n size?: \"sm\" | \"md\" | \"lg\"\n}\n\n/**\n * Menu 컴포넌트 / Menu component\n * \n * 메뉴 리스트를 제공하는 컴포넌트입니다.\n * MenuItem, MenuSeparator, MenuLabel과 함께 사용합니다.\n * \n * Component that provides menu lists.\n * Used with MenuItem, MenuSeparator, and MenuLabel.\n * \n * @component\n * @example\n * // 기본 수직 메뉴 / Basic vertical menu\n * <Menu>\n * <MenuItem icon={<Icon name=\"home\" />}>홈</MenuItem>\n * <MenuItem icon={<Icon name=\"settings\" />}>설정</MenuItem>\n * <MenuSeparator />\n * <MenuItem>로그아웃</MenuItem>\n * </Menu>\n * \n * @example\n * // 수평 메뉴 / Horizontal menu\n * <Menu variant=\"horizontal\">\n * <MenuItem>메뉴 1</MenuItem>\n * <MenuItem>메뉴 2</MenuItem>\n * </Menu>\n * \n * @param {MenuProps} props - Menu 컴포넌트의 props / Menu component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Menu 컴포넌트 / Menu component\n */\nconst Menu = React.forwardRef<HTMLDivElement, MenuProps>(\n ({ \n className, \n children,\n variant = \"default\",\n size = \"md\",\n ...props \n }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"horizontal\":\n return \"flex items-center space-x-1\" // 4px 간격\n case \"vertical\":\n return \"flex flex-col space-y-1\" // 4px 간격\n case \"compact\":\n return \"flex flex-col space-y-0.5\" // 2px 간격\n default:\n return \"flex flex-col space-y-1\" // 4px 간격\n }\n }\n\n const getSizeClasses = () => {\n switch (size) {\n case \"sm\":\n return \"text-sm\"\n case \"lg\":\n return \"text-base\"\n default:\n return \"text-sm\"\n }\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n getVariantClasses(),\n getSizeClasses(),\n className\n )}\n {...props}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return React.cloneElement(child, {\n variant,\n size\n } as Partial<MenuItemProps | MenuSeparatorProps | MenuLabelProps>)\n }\n return child\n })}\n </div>\n )\n }\n)\nMenu.displayName = \"Menu\"\n\n/**\n * MenuItem 컴포넌트의 props / MenuItem component props\n * @typedef {Object} MenuItemProps\n * @property {React.ReactNode} [icon] - 메뉴 아이템 아이콘 / Menu item icon\n * @property {\"default\" | \"horizontal\" | \"vertical\" | \"compact\"} [variant] - 메뉴 변형 (Menu에서 자동 전달) / Menu variant (auto-passed from Menu)\n * @property {\"sm\" | \"md\" | \"lg\"} [size] - 메뉴 크기 (Menu에서 자동 전달) / Menu size (auto-passed from Menu)\n * @property {boolean} [active=false] - 활성화 상태 / Active state\n * @property {boolean} [disabled=false] - 비활성화 상태 / Disabled state\n * @extends {React.ButtonHTMLAttributes<HTMLButtonElement>}\n */\nexport interface MenuItemProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n icon?: React.ReactNode\n variant?: \"default\" | \"horizontal\" | \"vertical\" | \"compact\"\n size?: \"sm\" | \"md\" | \"lg\"\n active?: boolean\n disabled?: boolean\n}\n\n/**\n * MenuItem 컴포넌트 / MenuItem component\n * 메뉴의 개별 아이템을 표시합니다.\n * Displays an individual menu item.\n * \n * @component\n * @param {MenuItemProps} props - MenuItem 컴포넌트의 props / MenuItem component props\n * @param {React.Ref<HTMLButtonElement>} ref - button 요소 ref / button element ref\n * @returns {JSX.Element} MenuItem 컴포넌트 / MenuItem component\n */\nconst MenuItem = React.forwardRef<HTMLButtonElement, MenuItemProps>(\n ({ \n className, \n icon,\n variant = \"default\",\n size = \"md\",\n active = false,\n disabled = false,\n children,\n ...props \n }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"horizontal\":\n return merge(\n \"flex items-center gap-2 px-3 py-2 rounded-md text-sm font-medium transition-colors\", // 12px, 8px 패딩\n active \n ? \"bg-blue-100 dark:bg-blue-900 text-blue-700 dark:text-blue-300\" \n : \"text-gray-700 dark:text-gray-300 hover:text-gray-900 dark:hover:text-gray-100 hover:bg-gray-100 dark:hover:bg-gray-700\"\n )\n case \"vertical\":\n return merge(\n \"flex items-center gap-3 px-4 py-3 rounded-md text-sm font-medium transition-colors\", // 16px, 12px 패딩\n active \n ? \"bg-blue-100 dark:bg-blue-900 text-blue-700 dark:text-blue-300\" \n : \"text-gray-700 dark:text-gray-300 hover:text-gray-900 dark:hover:text-gray-100 hover:bg-gray-100 dark:hover:bg-gray-700\"\n )\n case \"compact\":\n return merge(\n \"flex items-center gap-2 px-2 py-1.5 rounded text-sm font-medium transition-colors\", // 8px, 6px 패딩\n active \n ? \"bg-blue-100 dark:bg-blue-900 text-blue-700 dark:text-blue-300\" \n : \"text-gray-700 dark:text-gray-300 hover:text-gray-900 dark:hover:text-gray-100 hover:bg-gray-100 dark:hover:bg-gray-700\"\n )\n default:\n return merge(\n \"flex items-center gap-3 px-4 py-3 rounded-md text-sm font-medium transition-colors\", // 16px, 12px 패딩\n active \n ? \"bg-blue-100 dark:bg-blue-900 text-blue-700 dark:text-blue-300\" \n : \"text-gray-700 dark:text-gray-300 hover:text-gray-900 dark:hover:text-gray-100 hover:bg-gray-100 dark:hover:bg-gray-700\"\n )\n }\n }\n\n const getSizeClasses = () => {\n switch (size) {\n case \"sm\":\n return \"text-xs\"\n case \"lg\":\n return \"text-base\"\n default:\n return \"text-sm\"\n }\n }\n\n return (\n <button\n ref={ref}\n className={merge(\n getVariantClasses(),\n getSizeClasses(),\n disabled && \"opacity-50 cursor-not-allowed\",\n className\n )}\n disabled={disabled}\n {...props}\n >\n {icon && (\n <div className=\"flex-shrink-0 w-4 h-4\">\n {icon}\n </div>\n )}\n <span className=\"flex-1 text-left\">{children}</span>\n </button>\n )\n }\n)\nMenuItem.displayName = \"MenuItem\"\n\n/**\n * MenuSeparator 컴포넌트의 props / MenuSeparator component props\n * @typedef {Object} MenuSeparatorProps\n * @property {\"default\" | \"horizontal\" | \"vertical\" | \"compact\"} [variant] - 메뉴 변형 (Menu에서 자동 전달) / Menu variant (auto-passed from Menu)\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface MenuSeparatorProps extends React.HTMLAttributes<HTMLDivElement> {\n variant?: \"default\" | \"horizontal\" | \"vertical\" | \"compact\"\n}\n\n/**\n * MenuSeparator 컴포넌트 / MenuSeparator component\n * 메뉴 아이템들을 구분하는 구분선을 표시합니다.\n * Displays a separator line between menu items.\n * \n * @component\n * @param {MenuSeparatorProps} props - MenuSeparator 컴포넌트의 props / MenuSeparator component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} MenuSeparator 컴포넌트 / MenuSeparator component\n */\nconst MenuSeparator = React.forwardRef<HTMLDivElement, MenuSeparatorProps>(\n ({ className, variant = \"default\", ...props }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"horizontal\":\n return \"w-px h-4 bg-gray-200 dark:bg-gray-700 mx-1\" // 4px 여백\n case \"vertical\":\n case \"compact\":\n default:\n return \"h-px bg-gray-200 dark:bg-gray-700 my-2\" // 8px 여백\n }\n }\n\n return (\n <div\n ref={ref}\n className={merge(getVariantClasses(), className)}\n {...props}\n />\n )\n }\n)\nMenuSeparator.displayName = \"MenuSeparator\"\n\n/**\n * MenuLabel 컴포넌트의 props / MenuLabel component props\n * @typedef {Object} MenuLabelProps\n * @property {\"default\" | \"horizontal\" | \"vertical\" | \"compact\"} [variant] - 메뉴 변형 (Menu에서 자동 전달) / Menu variant (auto-passed from Menu)\n * @property {\"sm\" | \"md\" | \"lg\"} [size] - 메뉴 크기 (Menu에서 자동 전달) / Menu size (auto-passed from Menu)\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface MenuLabelProps extends React.HTMLAttributes<HTMLDivElement> {\n variant?: \"default\" | \"horizontal\" | \"vertical\" | \"compact\"\n size?: \"sm\" | \"md\" | \"lg\"\n}\n\n/**\n * MenuLabel 컴포넌트 / MenuLabel component\n * 메뉴 섹션의 레이블을 표시합니다.\n * Displays a label for a menu section.\n * \n * @component\n * @param {MenuLabelProps} props - MenuLabel 컴포넌트의 props / MenuLabel component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} MenuLabel 컴포넌트 / MenuLabel component\n */\nconst MenuLabel = React.forwardRef<HTMLDivElement, MenuLabelProps>(\n ({ className, variant = \"default\", size = \"md\", children, ...props }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"horizontal\":\n return \"px-3 py-1 text-xs font-semibold text-gray-500 dark:text-gray-400 uppercase tracking-wide\" // 12px, 4px 패딩\n case \"vertical\":\n case \"compact\":\n default:\n return \"px-4 py-2 text-xs font-semibold text-gray-500 dark:text-gray-400 uppercase tracking-wide\" // 16px, 8px 패딩\n }\n }\n\n const getSizeClasses = () => {\n switch (size) {\n case \"sm\":\n return \"text-xs\"\n case \"lg\":\n return \"text-sm\"\n default:\n return \"text-xs\"\n }\n }\n\n return (\n <div\n ref={ref}\n className={merge(\n getVariantClasses(),\n getSizeClasses(),\n className\n )}\n {...props}\n >\n {children}\n </div>\n )\n }\n)\nMenuLabel.displayName = \"MenuLabel\"\n\n// 편의 컴포넌트들\nexport const MenuHorizontal = React.forwardRef<HTMLDivElement, Omit<MenuProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Menu ref={ref} variant=\"horizontal\" className={className} {...props} />\n )\n)\nMenuHorizontal.displayName = \"MenuHorizontal\"\n\nexport const MenuVertical = React.forwardRef<HTMLDivElement, Omit<MenuProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Menu ref={ref} variant=\"vertical\" className={className} {...props} />\n )\n)\nMenuVertical.displayName = \"MenuVertical\"\n\nexport const MenuCompact = React.forwardRef<HTMLDivElement, Omit<MenuProps, \"variant\">>(\n ({ className, ...props }, ref) => (\n <Menu ref={ref} variant=\"compact\" className={className} {...props} />\n )\n)\nMenuCompact.displayName = \"MenuCompact\"\n\nexport { Menu, MenuItem, MenuSeparator, MenuLabel } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * ContextMenu 컴포넌트의 props / ContextMenu component props\n * @typedef {Object} ContextMenuProps\n * @property {React.ReactNode} children - ContextMenu 내용 / ContextMenu content\n * @property {boolean} [open] - 제어 모드에서 열림/닫힘 상태 / Open/close state in controlled mode\n * @property {(open: boolean) => void} [onOpenChange] - 상태 변경 콜백 / State change callback\n * @property {React.ReactNode} [trigger] - ContextMenu를 열기 위한 트리거 요소 (우클릭 이벤트) / Trigger element to open context menu (right-click event)\n * @property {\"top\" | \"bottom\" | \"left\" | \"right\"} [placement=\"bottom\"] - ContextMenu 표시 위치 / ContextMenu display position\n * @property {\"start\" | \"center\" | \"end\"} [align=\"start\"] - ContextMenu 정렬 / ContextMenu alignment\n * @property {number} [offset=8] - 트리거와 ContextMenu 사이 간격 (px) / Spacing between trigger and context menu (px)\n * @property {boolean} [disabled=false] - ContextMenu 비활성화 여부 / Disable context menu\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface ContextMenuProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n open?: boolean\n onOpenChange?: (open: boolean) => void\n trigger?: React.ReactNode\n placement?: \"top\" | \"bottom\" | \"left\" | \"right\"\n align?: \"start\" | \"center\" | \"end\"\n offset?: number\n disabled?: boolean\n}\n\n/**\n * ContextMenu 컴포넌트 / ContextMenu component\n * \n * 우클릭 시 표시되는 컨텍스트 메뉴 컴포넌트입니다.\n * 트리거 요소에 우클릭 이벤트를 자동으로 연결합니다.\n * \n * Context menu component that appears on right-click.\n * Automatically connects right-click events to the trigger element.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <ContextMenu trigger={<div>우클릭하세요</div>}>\n * <div className=\"p-2\">\n * <button>항목 1</button>\n * <button>항목 2</button>\n * </div>\n * </ContextMenu>\n * \n * @example\n * // 제어 모드 / Controlled mode\n * const [open, setOpen] = useState(false)\n * <ContextMenu \n * open={open}\n * onOpenChange={setOpen}\n * trigger={<div>우클릭</div>}\n * >\n * <Menu>\n * <MenuItem>복사</MenuItem>\n * <MenuItem>삭제</MenuItem>\n * </Menu>\n * </ContextMenu>\n * \n * @param {ContextMenuProps} props - ContextMenu 컴포넌트의 props / ContextMenu component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} ContextMenu 컴포넌트 / ContextMenu component\n */\nconst ContextMenu = React.forwardRef<HTMLDivElement, ContextMenuProps>(\n ({ \n className, \n children,\n open: controlledOpen,\n onOpenChange,\n trigger,\n placement = \"bottom\",\n align = \"start\",\n offset = 8,\n disabled = false,\n ...props \n }, ref) => {\n const [internalOpen, setInternalOpen] = React.useState(false)\n const [coords, setCoords] = React.useState({ x: 0, y: 0 })\n const triggerRef = React.useRef<HTMLDivElement>(null)\n const menuRef = 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 handleContextMenu = (event: React.MouseEvent) => {\n event.preventDefault()\n if (disabled) return\n\n const rect = event.currentTarget.getBoundingClientRect()\n const x = event.clientX\n const y = event.clientY\n\n setCoords({ x, y })\n handleOpenChange(true)\n }\n\n const updatePosition = React.useCallback(() => {\n if (!menuRef.current) return\n\n const menuRect = menuRef.current.getBoundingClientRect()\n const viewportWidth = window.innerWidth\n const viewportHeight = window.innerHeight\n\n let x = coords.x\n let y = coords.y\n\n // 뷰포트 경계 확인 및 조정\n if (x + menuRect.width > viewportWidth - 8) {\n x = viewportWidth - menuRect.width - 8 // 8px 여백\n }\n if (y + menuRect.height > viewportHeight - 8) {\n y = viewportHeight - menuRect.height - 8 // 8px 여백\n }\n if (x < 8) x = 8 // 8px 여백\n if (y < 8) y = 8 // 8px 여백\n\n setCoords({ x, y })\n }, [coords.x, coords.y])\n\n React.useEffect(() => {\n if (isOpen) {\n updatePosition()\n window.addEventListener('resize', updatePosition)\n window.addEventListener('scroll', updatePosition)\n \n return () => {\n window.removeEventListener('resize', updatePosition)\n window.removeEventListener('scroll', updatePosition)\n }\n }\n }, [isOpen, updatePosition])\n\n React.useEffect(() => {\n const handleClickOutside = (event: MouseEvent) => {\n if (\n triggerRef.current && \n menuRef.current && \n !triggerRef.current.contains(event.target as Node) &&\n !menuRef.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 return (\n <div ref={ref} className={merge(\"relative\", className)} {...props}>\n {/* 트리거 */}\n {trigger && (\n <div\n ref={triggerRef}\n onContextMenu={handleContextMenu}\n className=\"inline-block\"\n >\n {trigger}\n </div>\n )}\n\n {/* 컨텍스트 메뉴 */}\n {isOpen && (\n <div\n ref={menuRef}\n className={merge(\n \"fixed z-50 bg-white dark:bg-gray-800 rounded-lg shadow-xl backdrop-blur-sm\", // 보더 대신 섀도우 사용\n \"min-w-[200px] py-2\", // 16px 패딩\n \"border-0\" // 보더 제거\n )}\n style={{\n left: coords.x,\n top: coords.y,\n boxShadow: \"0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04)\"\n }}\n >\n {children}\n </div>\n )}\n </div>\n )\n }\n)\nContextMenu.displayName = \"ContextMenu\"\n\nexport interface ContextMenuItemProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n icon?: React.ReactNode\n variant?: \"default\" | \"destructive\" | \"disabled\"\n}\n\nconst ContextMenuItem = React.forwardRef<HTMLButtonElement, ContextMenuItemProps>(\n ({ \n className, \n icon,\n variant = \"default\",\n children,\n disabled,\n ...props \n }, ref) => {\n const getVariantClasses = () => {\n switch (variant) {\n case \"destructive\":\n return \"text-red-600 dark:text-red-400 hover:bg-red-50 dark:hover:bg-red-900/20\"\n case \"disabled\":\n return \"text-gray-400 dark:text-gray-500 cursor-not-allowed\"\n default:\n return \"text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700\"\n }\n }\n\n return (\n <button\n ref={ref}\n className={merge(\n \"w-full flex items-center gap-3 px-4 py-3 text-sm font-medium transition-colors focus:outline-none focus:bg-gray-100 dark:focus:bg-gray-700\", // 16px, 12px 패딩\n getVariantClasses(),\n className\n )}\n disabled={disabled || variant === \"disabled\"}\n {...props}\n >\n {icon && (\n <div className=\"flex-shrink-0 w-4 h-4\">\n {icon}\n </div>\n )}\n <span className=\"flex-1 text-left\">{children}</span>\n </button>\n )\n }\n)\nContextMenuItem.displayName = \"ContextMenuItem\"\n\nexport interface ContextMenuSeparatorProps extends React.HTMLAttributes<HTMLDivElement> {}\n\nconst ContextMenuSeparator = React.forwardRef<HTMLDivElement, ContextMenuSeparatorProps>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"h-px bg-gray-200 dark:bg-gray-700 my-2\", className)} // 8px 여백\n {...props}\n />\n )\n)\nContextMenuSeparator.displayName = \"ContextMenuSeparator\"\n\nexport interface ContextMenuLabelProps extends React.HTMLAttributes<HTMLDivElement> {}\n\nconst ContextMenuLabel = React.forwardRef<HTMLDivElement, ContextMenuLabelProps>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"px-4 py-2 text-xs font-semibold text-gray-500 dark:text-gray-400 uppercase tracking-wide\", className)} // 16px, 8px 패딩\n {...props}\n >\n {children}\n </div>\n )\n)\nContextMenuLabel.displayName = \"ContextMenuLabel\"\n\n// 편의 컴포넌트들\nconst ContextMenuGroup = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, children, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"py-1\", className)} // 4px 패딩\n {...props}\n >\n {children}\n </div>\n )\n)\nContextMenuGroup.displayName = \"ContextMenuGroup\"\n\nexport { ContextMenu, ContextMenuItem, ContextMenuSeparator, ContextMenuLabel, ContextMenuGroup } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * Command 컴포넌트의 props / Command component props\n * @typedef {Object} CommandProps\n * @property {React.ReactNode} children - CommandList, CommandItem 등 / CommandList, CommandItem, etc.\n * @property {boolean} [open] - 제어 모드에서 열림/닫힘 상태 / Open/close state in controlled mode\n * @property {(open: boolean) => void} [onOpenChange] - 상태 변경 콜백 / State change callback\n * @property {string} [placeholder=\"명령어를 검색하세요...\"] - 검색 입력 플레이스홀더 / Search input placeholder\n * @property {string} [searchValue] - 제어 모드에서 검색 값 / Search value in controlled mode\n * @property {(value: string) => void} [onSearchChange] - 검색 값 변경 콜백 / Search value change callback\n * @property {boolean} [disabled=false] - Command 비활성화 여부 / Disable command\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CommandProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n open?: boolean\n onOpenChange?: (open: boolean) => void\n placeholder?: string\n searchValue?: string\n onSearchChange?: (value: string) => void\n disabled?: boolean\n}\n\n/**\n * Command 컴포넌트 / Command component\n * \n * 명령 팔레트(Command Palette) 컴포넌트입니다.\n * Cmd+K (Mac) 또는 Ctrl+K (Windows)로 열 수 있습니다.\n * 키보드 네비게이션(Arrow keys, Enter, Escape)을 지원합니다.\n * \n * Command Palette component.\n * Can be opened with Cmd+K (Mac) or Ctrl+K (Windows).\n * Supports keyboard navigation (Arrow keys, Enter, Escape).\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <Command>\n * <CommandInput placeholder=\"검색...\" />\n * <CommandList>\n * <CommandItem>항목 1</CommandItem>\n * <CommandItem>항목 2</CommandItem>\n * </CommandList>\n * </Command>\n * \n * @example\n * // 제어 모드 / Controlled mode\n * const [open, setOpen] = useState(false)\n * <Command \n * open={open}\n * onOpenChange={setOpen}\n * >\n * <CommandList>\n * <CommandGroup heading=\"파일\">\n * <CommandItem>새 파일</CommandItem>\n * </CommandGroup>\n * </CommandList>\n * </Command>\n * \n * @param {CommandProps} props - Command 컴포넌트의 props / Command component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} Command 컴포넌트 / Command component\n */\nconst Command = React.forwardRef<HTMLDivElement, CommandProps>(\n ({ \n className, \n children,\n open: controlledOpen,\n onOpenChange,\n placeholder = \"명령어를 검색하세요...\",\n searchValue: controlledSearchValue,\n onSearchChange,\n disabled = false,\n ...props \n }, ref) => {\n const [internalOpen, setInternalOpen] = React.useState(false)\n const [internalSearchValue, setInternalSearchValue] = React.useState(\"\")\n const [selectedIndex, setSelectedIndex] = React.useState(0)\n const commandRef = React.useRef<HTMLDivElement>(null)\n const inputRef = React.useRef<HTMLInputElement>(null)\n const listRef = React.useRef<HTMLDivElement>(null)\n \n const isControlled = controlledOpen !== undefined\n const isOpen = isControlled ? controlledOpen : internalOpen\n const searchValue = controlledSearchValue !== undefined ? controlledSearchValue : internalSearchValue\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 handleSearchChange = (value: string) => {\n if (!isControlled) {\n setInternalSearchValue(value)\n }\n onSearchChange?.(value)\n setSelectedIndex(0)\n }\n\n const handleKeyDown = (event: React.KeyboardEvent) => {\n if (disabled) return\n\n const items = listRef.current?.querySelectorAll('[data-command-item]')\n const itemCount = items?.length || 0\n\n switch (event.key) {\n case 'ArrowDown':\n event.preventDefault()\n setSelectedIndex((prev) => (prev + 1) % itemCount)\n break\n case 'ArrowUp':\n event.preventDefault()\n setSelectedIndex((prev) => (prev - 1 + itemCount) % itemCount)\n break\n case 'Enter':\n event.preventDefault()\n const selectedItem = items?.[selectedIndex] as HTMLElement\n selectedItem?.click()\n break\n case 'Escape':\n event.preventDefault()\n handleOpenChange(false)\n break\n }\n }\n\n React.useEffect(() => {\n if (isOpen) {\n inputRef.current?.focus()\n setSelectedIndex(0)\n }\n }, [isOpen])\n\n React.useEffect(() => {\n const handleKeyDown = (event: KeyboardEvent) => {\n if (event.key === 'k' && (event.metaKey || event.ctrlKey)) {\n event.preventDefault()\n handleOpenChange(!isOpen)\n }\n }\n\n document.addEventListener('keydown', handleKeyDown)\n return () => {\n document.removeEventListener('keydown', handleKeyDown)\n }\n }, [isOpen])\n\n React.useEffect(() => {\n const selectedItem = listRef.current?.querySelector(`[data-command-item]:nth-child(${selectedIndex + 1})`) as HTMLElement\n selectedItem?.scrollIntoView({ block: 'nearest' })\n }, [selectedIndex])\n\n return (\n <div ref={ref} className={merge(\"relative\", className)} {...props}>\n {isOpen && (\n <div\n ref={commandRef}\n className={merge(\n \"fixed inset-0 z-50 bg-black/50 backdrop-blur-sm\", // 50% 투명도\n \"flex items-start justify-center pt-16\" // 64px 상단 여백\n )}\n onClick={() => handleOpenChange(false)}\n >\n <div\n className={merge(\n \"w-full max-w-2xl mx-4 bg-white dark:bg-gray-800 rounded-lg shadow-2xl\", // 보더 대신 섀도우\n \"border-0 overflow-hidden\" // 보더 제거\n )}\n onClick={(e) => e.stopPropagation()}\n style={{\n boxShadow: \"0 25px 50px -12px rgba(0, 0, 0, 0.25)\"\n }}\n >\n <div className=\"p-4 border-b border-gray-200 dark:border-gray-700\"> {/* 16px 패딩 */}\n <input\n ref={inputRef}\n type=\"text\"\n placeholder={placeholder}\n value={searchValue}\n onChange={(e) => handleSearchChange(e.target.value)}\n onKeyDown={handleKeyDown}\n className={merge(\n \"w-full bg-transparent text-lg font-medium outline-none\", // 18px 텍스트\n \"placeholder:text-gray-500 dark:placeholder:text-gray-400\",\n \"text-gray-900 dark:text-gray-100\"\n )}\n />\n </div>\n \n <div\n ref={listRef}\n className=\"max-h-96 overflow-y-auto py-2\" // 384px 최대 높이, 8px 패딩\n >\n {React.Children.map(children, (child, index) => {\n if (React.isValidElement<CommandItemProps>(child)) {\n return React.cloneElement(child, {\n selected: index === selectedIndex,\n onSelect: () => {\n child.props.onSelect?.()\n handleOpenChange(false)\n }\n })\n }\n return child\n })}\n </div>\n </div>\n </div>\n )}\n </div>\n )\n }\n)\nCommand.displayName = \"Command\"\n\n/**\n * CommandInput 컴포넌트의 props / CommandInput component props\n * @typedef {Object} CommandInputProps\n * @extends {React.InputHTMLAttributes<HTMLInputElement>}\n */\nexport interface CommandInputProps extends React.InputHTMLAttributes<HTMLInputElement> {}\n\nconst CommandInput = React.forwardRef<HTMLInputElement, CommandInputProps>(\n ({ className, ...props }, ref) => (\n <input\n ref={ref}\n className={merge(\n \"flex h-10 w-full rounded-md bg-transparent px-3 py-2 text-sm outline-none\", // 40px 높이, 12px, 8px 패딩\n \"placeholder:text-gray-500 dark:placeholder:text-gray-400\",\n \"disabled:cursor-not-allowed disabled:opacity-50\",\n className\n )}\n {...props}\n />\n )\n)\nCommandInput.displayName = \"CommandInput\"\n\nexport interface CommandListProps extends React.HTMLAttributes<HTMLDivElement> {}\n\nconst CommandList = React.forwardRef<HTMLDivElement, CommandListProps>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"max-h-96 overflow-y-auto py-2\", className)} // 384px 최대 높이, 8px 패딩\n {...props}\n />\n )\n)\nCommandList.displayName = \"CommandList\"\n\n/**\n * CommandItem 컴포넌트의 props / CommandItem component props\n * @typedef {Object} CommandItemProps\n * @property {React.ReactNode} [icon] - 항목 아이콘 / Item icon\n * @property {boolean} [selected=false] - 선택 상태 / Selected state\n * @property {() => void} [onSelect] - 선택 시 콜백 / Selection callback\n * @extends {React.ButtonHTMLAttributes<HTMLButtonElement>}\n */\nexport interface CommandItemProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n icon?: React.ReactNode\n selected?: boolean\n onSelect?: () => void\n}\n\nconst CommandItem = React.forwardRef<HTMLButtonElement, CommandItemProps>(\n ({ \n className, \n icon,\n selected = false,\n onSelect,\n children,\n ...props \n }, ref) => {\n return (\n <button\n ref={ref}\n data-command-item\n className={merge(\n \"relative flex w-full items-center gap-3 rounded-sm px-4 py-3 text-sm\", // 16px, 12px 패딩\n \"text-gray-700 dark:text-gray-300\",\n \"hover:bg-gray-100 dark:hover:bg-gray-700\",\n \"focus:bg-gray-100 dark:focus:bg-gray-700\",\n \"focus:outline-none\",\n selected && \"bg-gray-100 dark:bg-gray-700\",\n \"transition-colors\",\n className\n )}\n onClick={onSelect}\n {...props}\n >\n {icon && (\n <div className=\"flex-shrink-0 w-4 h-4 text-gray-500 dark:text-gray-400\">\n {icon}\n </div>\n )}\n <span className=\"flex-1 text-left\">{children}</span>\n </button>\n )\n }\n)\nCommandItem.displayName = \"CommandItem\"\n\n/**\n * CommandGroup 컴포넌트의 props / CommandGroup component props\n * @typedef {Object} CommandGroupProps\n * @property {React.ReactNode} [heading] - 그룹 제목 / Group heading\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CommandGroupProps extends React.HTMLAttributes<HTMLDivElement> {\n heading?: React.ReactNode\n}\n\nconst CommandGroup = React.forwardRef<HTMLDivElement, CommandGroupProps>(\n ({ className, heading, children, ...props }, ref) => (\n <div ref={ref} className={merge(\"py-2\", className)} {...props}> {/* 8px 패딩 */}\n {heading && (\n <div className=\"px-4 py-2 text-xs font-semibold text-gray-500 dark:text-gray-400 uppercase tracking-wide\"> {/* 16px, 8px 패딩 */}\n {heading}\n </div>\n )}\n <div className=\"space-y-1\"> {/* 4px 간격 */}\n {children}\n </div>\n </div>\n )\n)\nCommandGroup.displayName = \"CommandGroup\"\n\n/**\n * CommandSeparator 컴포넌트의 props / CommandSeparator component props\n * @typedef {Object} CommandSeparatorProps\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CommandSeparatorProps extends React.HTMLAttributes<HTMLDivElement> {}\n\nconst CommandSeparator = React.forwardRef<HTMLDivElement, CommandSeparatorProps>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\"h-px bg-gray-200 dark:bg-gray-700 my-2\", className)} // 8px 여백\n {...props}\n />\n )\n)\nCommandSeparator.displayName = \"CommandSeparator\"\n\n/**\n * CommandEmpty 컴포넌트의 props / CommandEmpty component props\n * @typedef {Object} CommandEmptyProps\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\nexport interface CommandEmptyProps extends React.HTMLAttributes<HTMLDivElement> {}\n\nconst CommandEmpty = React.forwardRef<HTMLDivElement, CommandEmptyProps>(\n ({ className, children = \"결과가 없습니다.\", ...props }, ref) => (\n <div\n ref={ref}\n className={merge(\n \"py-8 text-center text-sm text-gray-500 dark:text-gray-400\", // 32px 패딩\n className\n )}\n {...props}\n >\n {children}\n </div>\n )\n)\nCommandEmpty.displayName = \"CommandEmpty\"\n\n// 편의 컴포넌트들\nexport const CommandDialog = React.forwardRef<HTMLDivElement, CommandProps>(\n ({ className, ...props }, ref) => (\n <Command ref={ref} className={className} {...props} />\n )\n)\nCommandDialog.displayName = \"CommandDialog\"\n\nexport { Command, CommandInput, CommandList, CommandItem, CommandGroup, CommandSeparator, CommandEmpty } ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\n\n/**\n * ScrollArea 컴포넌트의 props / ScrollArea component props\n * @typedef {Object} ScrollAreaProps\n * @property {React.ReactNode} children - 스크롤 영역 내용 / Scroll area content\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {\"vertical\" | \"horizontal\" | \"both\"} [orientation=\"vertical\"] - 스크롤 방향 / Scroll direction\n * @property {number} [scrollHideDelay=600] - 스크롤바 숨김 지연 시간 (ms) / Scrollbar hide delay (ms)\n * @property {\"auto\" | \"always\" | \"scroll\" | \"hover\"} [type=\"hover\"] - 스크롤바 표시 타입 / Scrollbar display type\n * @extends {React.HTMLAttributes<HTMLDivElement>}\n */\ninterface ScrollAreaProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n className?: string\n orientation?: \"vertical\" | \"horizontal\" | \"both\"\n scrollHideDelay?: number\n type?: \"auto\" | \"always\" | \"scroll\" | \"hover\"\n}\n\n/**\n * ScrollArea 컴포넌트 / ScrollArea component\n * \n * 커스텀 스크롤바를 가진 스크롤 영역 컴포넌트입니다.\n * 호버 시 스크롤바를 표시하거나 항상 표시할 수 있습니다.\n * \n * Scroll area component with custom scrollbar.\n * Can display scrollbar on hover or always.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <ScrollArea className=\"h-64\">\n * <div>긴 내용...</div>\n * </ScrollArea>\n * \n * @example\n * // 가로 스크롤, 항상 표시 / Horizontal scroll, always visible\n * <ScrollArea orientation=\"horizontal\" type=\"always\">\n * <div className=\"flex space-x-4\">...</div>\n * </ScrollArea>\n * \n * @param {ScrollAreaProps} props - ScrollArea 컴포넌트의 props / ScrollArea component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} ScrollArea 컴포넌트 / ScrollArea component\n */\nconst ScrollArea = React.forwardRef<HTMLDivElement, ScrollAreaProps>(\n ({ \n children, \n className, \n orientation = \"vertical\",\n scrollHideDelay = 600,\n type = \"hover\",\n ...props \n }, ref) => {\n const [showScrollbar, setShowScrollbar] = React.useState(false)\n const timeoutRef = React.useRef<ReturnType<typeof setTimeout> | undefined>(undefined)\n\n const handleMouseEnter = () => {\n if (type === \"hover\" || type === \"always\") {\n setShowScrollbar(true)\n }\n }\n\n const handleMouseLeave = () => {\n if (type === \"hover\") {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current)\n }\n timeoutRef.current = setTimeout(() => {\n setShowScrollbar(false)\n }, scrollHideDelay)\n }\n }\n\n React.useEffect(() => {\n if (type === \"always\") {\n setShowScrollbar(true)\n }\n }, [type])\n\n React.useEffect(() => {\n return () => {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current)\n }\n }\n }, [])\n\n return (\n <div\n ref={ref}\n className={merge(\n \"relative overflow-auto scrollbar-thin\",\n orientation === \"vertical\" && \"overflow-y-auto overflow-x-hidden\",\n orientation === \"horizontal\" && \"overflow-x-auto overflow-y-hidden\",\n orientation === \"both\" && \"overflow-auto\",\n showScrollbar ? \"scrollbar-visible\" : \"scrollbar-hidden\",\n className\n )}\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n {...props}\n >\n {children}\n </div>\n )\n }\n)\n\nScrollArea.displayName = \"ScrollArea\"\n\n/**\n * ScrollBar 컴포넌트의 props / ScrollBar component props\n * @typedef {Object} ScrollBarProps\n * @property {\"vertical\" | \"horizontal\"} [orientation=\"vertical\"] - 스크롤바 방향 / Scrollbar direction\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n */\ninterface ScrollBarProps {\n orientation?: \"vertical\" | \"horizontal\"\n className?: string\n}\n\n/**\n * ScrollBar 컴포넌트 / ScrollBar component\n * 커스텀 스크롤바를 표시합니다.\n * Displays a custom scrollbar.\n * \n * @component\n * @param {ScrollBarProps} props - ScrollBar 컴포넌트의 props / ScrollBar component props\n * @param {React.Ref<HTMLDivElement>} ref - div 요소 ref / div element ref\n * @returns {JSX.Element} ScrollBar 컴포넌트 / ScrollBar component\n */\nconst ScrollBar = React.forwardRef<HTMLDivElement, ScrollBarProps>(\n ({ orientation = \"vertical\", className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n className={merge(\n \"flex touch-none select-none transition-colors duration-150 ease-out\",\n orientation === \"vertical\" && \"h-full w-2.5 border-l border-l-transparent p-[1px]\",\n orientation === \"horizontal\" && \"h-2.5 flex-col border-t border-t-transparent p-[1px]\",\n className\n )}\n {...props}\n />\n )\n }\n)\n\nScrollBar.displayName = \"ScrollBar\"\n\nexport { ScrollArea, ScrollBar } ","import { useEffect, useState } from \"react\"\n\ninterface ScrollToggleOptions {\n threshold?: number\n showOnMount?: boolean\n smooth?: boolean\n}\n\nexport function useScrollToggle(options: ScrollToggleOptions = {}) {\n const {\n threshold = 400,\n showOnMount = false,\n smooth = true,\n } = options\n\n const [isVisible, setIsVisible] = useState(showOnMount)\n const [mounted, setMounted] = useState(false)\n\n useEffect(() => {\n setMounted(true)\n }, [])\n\n useEffect(() => {\n if (!mounted) return\n\n const toggleVisibility = () => {\n if (typeof window === \"undefined\") return\n setIsVisible(window.pageYOffset > threshold)\n }\n\n toggleVisibility()\n window.addEventListener(\"scroll\", toggleVisibility, { passive: true })\n window.addEventListener(\"resize\", toggleVisibility, { passive: true })\n\n return () => {\n window.removeEventListener(\"scroll\", toggleVisibility)\n window.removeEventListener(\"resize\", toggleVisibility)\n }\n }, [threshold, mounted])\n\n const scrollToTop = () => {\n if (typeof window === \"undefined\") return\n if (smooth) {\n window.scrollTo({ top: 0, behavior: \"smooth\" })\n } else {\n window.scrollTo(0, 0)\n }\n }\n\n return {\n isVisible,\n scrollToTop,\n mounted,\n }\n}\n\n","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\nimport { IconName } from \"../lib/icons\"\nimport { useScrollToggle } from \"../hooks/useScrollToggle\"\n\n/**\n * ScrollToTop 컴포넌트의 props / ScrollToTop component props\n * @typedef {Object} ScrollToTopProps\n * @property {number} [threshold=400] - 표시 임계값 (px, 이 값 이상 스크롤 시 표시) / Display threshold (px, shows when scrolled beyond this value)\n * @property {boolean} [smooth=true] - 부드러운 스크롤 여부 / Smooth scroll\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {IconName} [icon='arrowUp'] - 아이콘 이름 / Icon name\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - 버튼 크기 / Button size\n * @property {\"default\" | \"primary\" | \"secondary\" | \"outline\" | \"ghost\"} [variant=\"default\"] - 버튼 스타일 변형 / Button style variant\n * @property {boolean} [showOnMount=false] - 마운트 시 즉시 표시 여부 / Show immediately on mount\n * @extends {React.HTMLAttributes<HTMLButtonElement>}\n */\nexport interface ScrollToTopProps extends React.HTMLAttributes<HTMLButtonElement> {\n threshold?: number\n smooth?: boolean\n className?: string\n icon?: IconName\n size?: \"sm\" | \"md\" | \"lg\"\n variant?: \"default\" | \"primary\" | \"secondary\" | \"outline\" | \"ghost\"\n showOnMount?: boolean\n}\n\n/**\n * ScrollToTop 컴포넌트 / ScrollToTop component\n * \n * 페이지 상단으로 스크롤하는 버튼 컴포넌트입니다.\n * 지정된 임계값 이상 스크롤 시 자동으로 표시됩니다.\n * \n * Button component that scrolls to top of page.\n * Automatically appears when scrolled beyond specified threshold.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <ScrollToTop />\n * \n * @example\n * // 커스텀 설정 / Custom settings\n * <ScrollToTop \n * threshold={500}\n * variant=\"primary\"\n * size=\"lg\"\n * icon=\"arrowUp\"\n * />\n * \n * @param {ScrollToTopProps} props - ScrollToTop 컴포넌트의 props / ScrollToTop component props\n * @returns {JSX.Element} ScrollToTop 컴포넌트 / ScrollToTop component\n */\nconst ScrollToTop = ({ \n className, \n threshold = 400, \n smooth = true, \n icon = \"arrowUp\",\n size = \"md\",\n variant = \"default\",\n showOnMount = false,\n ...props \n}: ScrollToTopProps) => {\n // HUA Motion의 useScrollToggle 훅 사용\n const { isVisible, scrollToTop, mounted } = useScrollToggle({\n threshold,\n showOnMount,\n smooth\n })\n\n const sizeClasses = {\n sm: \"w-8 h-8 sm:w-10 sm:h-10\",\n md: \"w-10 h-10 sm:w-12 sm:h-12\", \n lg: \"w-12 h-12 sm:w-14 sm:h-14\"\n }\n\n\n\n const variantClasses = {\n default: \"bg-white/20 backdrop-blur-md border border-white/30 text-white hover:bg-white/30 hover:shadow-lg hover:shadow-black/20 dark:bg-slate-800/20 dark:border-slate-700/50 dark:text-slate-100 dark:hover:bg-slate-700/30\",\n primary: \"bg-blue-600/70 backdrop-blur-md border border-blue-500/40 text-white hover:bg-blue-500/80 hover:shadow-xl hover:shadow-blue-500/50 hover:scale-105 transition-all duration-300 dark:bg-blue-500/70 dark:border-blue-400/40 dark:hover:bg-blue-400/80 dark:hover:shadow-blue-400/50\",\n secondary: \"bg-slate-100/60 backdrop-blur-md border border-slate-200/50 text-slate-700 hover:bg-slate-200/70 hover:shadow-lg dark:bg-slate-700/30 dark:border-slate-600/50 dark:text-slate-200 dark:hover:bg-slate-600/40\",\n outline: \"border border-white/40 bg-white/15 backdrop-blur-md text-white hover:bg-white/25 hover:shadow-lg dark:border-slate-600/50 dark:bg-slate-800/15 dark:text-slate-200 dark:hover:bg-slate-700/25\",\n ghost: \"bg-transparent hover:bg-white/15 backdrop-blur-md text-white hover:shadow-lg dark:text-slate-200 dark:hover:bg-slate-700/25\"\n }\n\n return (\n <button\n onClick={scrollToTop}\n className={merge(\n \"fixed z-[9999] rounded-full transition-all duration-500 ease-in-out\",\n \"flex items-center justify-center\",\n \"focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-blue-500\",\n \"transform hover:scale-110 active:scale-95 shadow-lg\",\n // 페이드 애니메이션\n isVisible \n ? \"opacity-100 translate-y-0 pointer-events-auto\" \n : \"opacity-0 translate-y-4 pointer-events-none\",\n className,\n sizeClasses[size],\n variantClasses[variant]\n )}\n aria-label=\"Scroll to top\"\n {...props}\n >\n <Icon name={icon} className=\"w-5 h-5\" />\n </button>\n )\n}\n\nexport { ScrollToTop } ","\"use client\"\n\nimport React, { createContext, useContext, useEffect, useState } from \"react\"\n\ntype Theme = \"light\" | \"dark\" | \"system\"\n\n/**\n * ThemeProvider 컴포넌트의 props / ThemeProvider component props\n * @typedef {Object} ThemeProviderProps\n * @property {React.ReactNode} children - 자식 컴포넌트 / Child components\n * @property {\"light\" | \"dark\" | \"system\"} [defaultTheme=\"light\"] - 기본 테마 / Default theme\n * @property {string} [storageKey=\"hua-ui-theme\"] - localStorage 키 / localStorage key\n * @property {boolean} [enableSystem=true] - 시스템 테마 감지 활성화 / Enable system theme detection\n * @property {boolean} [enableTransition=true] - 테마 전환 애니메이션 활성화 / Enable theme transition animation\n */\ninterface ThemeProviderProps {\n children: React.ReactNode\n defaultTheme?: Theme\n storageKey?: string\n enableSystem?: boolean\n enableTransition?: boolean\n}\n\n/**\n * ThemeProvider의 상태 타입 / ThemeProvider state type\n * @typedef {Object} ThemeProviderState\n * @property {\"light\" | \"dark\" | \"system\"} theme - 현재 테마 / Current theme\n * @property {(theme: \"light\" | \"dark\" | \"system\") => void} setTheme - 테마 설정 함수 / Theme setter function\n * @property {\"light\" | \"dark\"} resolvedTheme - 실제 적용된 테마 (system일 경우 시스템 테마) / Actually applied theme (system theme when system is selected)\n * @property {() => void} toggleTheme - 테마 토글 함수 / Theme toggle function\n */\ninterface ThemeProviderState {\n theme: Theme\n setTheme: (theme: Theme) => void\n resolvedTheme: \"light\" | \"dark\"\n toggleTheme: () => void\n}\n\nconst initialState: ThemeProviderState = {\n theme: \"system\",\n setTheme: () => null,\n resolvedTheme: \"light\",\n toggleTheme: () => null,\n}\n\nconst ThemeProviderContext = createContext<ThemeProviderState>(initialState)\n\n/**\n * ThemeProvider 컴포넌트 / ThemeProvider component\n * \n * 테마 관리를 위한 Context Provider 컴포넌트입니다.\n * localStorage에 테마를 저장하고, 시스템 테마를 감지할 수 있습니다.\n * useTheme 훅을 통해 테마 상태에 접근할 수 있습니다.\n * \n * Context Provider component for theme management.\n * Saves theme to localStorage and can detect system theme.\n * Access theme state through useTheme hook.\n * \n * @component\n * @example\n * // 기본 사용 / Basic usage\n * <ThemeProvider>\n * <App />\n * </ThemeProvider>\n * \n * @example\n * // 커스텀 설정 / Custom settings\n * <ThemeProvider\n * defaultTheme=\"dark\"\n * storageKey=\"my-app-theme\"\n * enableSystem={true}\n * enableTransition={true}\n * >\n * <App />\n * </ThemeProvider>\n * \n * @param {ThemeProviderProps} props - ThemeProvider 컴포넌트의 props / ThemeProvider component props\n * @returns {JSX.Element} ThemeProvider 컴포넌트 / ThemeProvider component\n */\nexport function ThemeProvider({\n children,\n defaultTheme = \"light\", // system에서 light로 변경\n storageKey = \"hua-ui-theme\",\n enableSystem = true,\n enableTransition = true,\n ...props\n}: ThemeProviderProps): React.ReactElement {\n const [theme, setTheme] = useState<Theme>(defaultTheme)\n const [resolvedTheme, setResolvedTheme] = useState<\"light\" | \"dark\">(\"light\")\n\n useEffect(() => {\n // localStorage에서 테마 가져오기 (클라이언트에서만)\n if (typeof window !== 'undefined') {\n const savedTheme = localStorage.getItem(storageKey) as Theme\n if (savedTheme) {\n setTheme(savedTheme)\n }\n }\n }, [storageKey])\n\n useEffect(() => {\n const root = window.document.documentElement\n\n root.classList.remove(\"light\", \"dark\")\n\n if (theme === \"system\" && enableSystem) {\n const systemTheme = window.matchMedia(\"(prefers-color-scheme: dark)\")\n .matches\n ? \"dark\"\n : \"light\"\n\n root.classList.add(systemTheme)\n setResolvedTheme(systemTheme)\n } else {\n root.classList.add(theme)\n setResolvedTheme(theme as \"light\" | \"dark\")\n }\n\n if (enableTransition) {\n root.classList.add(\"transition-colors\", \"duration-300\")\n }\n }, [theme, enableSystem, enableTransition])\n\n useEffect(() => {\n if (theme === \"system\" && enableSystem) {\n const mediaQuery = window.matchMedia(\"(prefers-color-scheme: dark)\")\n\n const handleChange = () => {\n const systemTheme = mediaQuery.matches ? \"dark\" : \"light\"\n setResolvedTheme(systemTheme)\n document.documentElement.classList.remove(\"light\", \"dark\")\n document.documentElement.classList.add(systemTheme)\n }\n\n mediaQuery.addEventListener(\"change\", handleChange)\n return () => mediaQuery.removeEventListener(\"change\", handleChange)\n }\n }, [theme, enableSystem])\n\n const value = {\n theme,\n setTheme: (theme: Theme) => {\n if (typeof window !== 'undefined') {\n localStorage.setItem(storageKey, theme)\n }\n setTheme(theme)\n },\n resolvedTheme,\n toggleTheme: () => {\n const newTheme = theme === \"light\" ? \"dark\" : \"light\"\n setTheme(newTheme)\n },\n }\n\n return (\n <ThemeProviderContext.Provider {...props} value={value}>\n {children}\n </ThemeProviderContext.Provider>\n )\n}\n\n/**\n * useTheme 훅 / useTheme hook\n * \n * ThemeProvider의 테마 상태에 접근하는 훅입니다.\n * ThemeProvider 내부에서만 사용할 수 있습니다.\n * \n * Hook to access ThemeProvider's theme state.\n * Can only be used inside ThemeProvider.\n * \n * @example\n * const { theme, setTheme, resolvedTheme, toggleTheme } = useTheme()\n * \n * @returns {ThemeProviderState} 테마 상태와 함수들 / Theme state and functions\n * @throws {Error} ThemeProvider 외부에서 사용 시 에러 발생 / Error when used outside ThemeProvider\n */\nexport const useTheme = () => {\n const context = useContext(ThemeProviderContext)\n\n if (context === undefined)\n throw new Error(\"useTheme must be used within a ThemeProvider\")\n\n return context\n} ","\"use client\"\n\nimport React from \"react\"\nimport { merge } from \"../lib/utils\"\nimport { Icon } from \"./Icon\"\nimport { useTheme } from \"./ThemeProvider\"\n\n/**\n * ThemeToggle 컴포넌트의 props / ThemeToggle component props\n * @typedef {Object} ThemeToggleProps\n * @property {string} [className] - 추가 CSS 클래스 / Additional CSS class\n * @property {\"sm\" | \"md\" | \"lg\"} [size=\"md\"] - Toggle 크기 / Toggle size\n * @property {\"button\" | \"icon\" | \"switch\"} [variant=\"button\"] - Toggle 스타일 변형 / Toggle style variant\n * @property {boolean} [showLabel=false] - 라벨 표시 여부 / Show label\n * @property {Object} [label] - 커스텀 라벨 텍스트 / Custom label text\n * @property {string} [label.light=\"라이트\"] - 라이트 모드 라벨 / Light mode label\n * @property {string} [label.dark=\"다크\"] - 다크 모드 라벨 / Dark mode label\n * @property {string} [label.system=\"시스템\"] - 시스템 모드 라벨 / System mode label\n */\ninterface ThemeToggleProps {\n className?: string\n size?: \"sm\" | \"md\" | \"lg\"\n variant?: \"button\" | \"icon\" | \"switch\"\n showLabel?: boolean\n label?: {\n light?: string\n dark?: string\n system?: string\n }\n}\n\n/**\n * ThemeToggle 컴포넌트 / ThemeToggle component\n * \n * 테마를 전환하는 토글 컴포넌트입니다.\n * ThemeProvider와 함께 사용하며, light/dark/system 테마를 지원합니다.\n * \n * Toggle component for switching themes.\n * Used with ThemeProvider, supports light/dark/system themes.\n * \n * @component\n * @example\n * // 기본 사용 (버튼 스타일) / Basic usage (button style)\n * <ThemeToggle />\n * \n * @example\n * // 아이콘만 표시 / Icon only\n * <ThemeToggle variant=\"icon\" size=\"lg\" />\n * \n * @example\n * // Switch 스타일 / Switch style\n * <ThemeToggle variant=\"switch\" />\n * \n * @example\n * // 라벨과 함께 / With label\n * <ThemeToggle \n * showLabel\n * label={{ light: \"밝게\", dark: \"어둡게\" }}\n * />\n * \n * @param {ThemeToggleProps} props - ThemeToggle 컴포넌트의 props / ThemeToggle component props\n * @returns {JSX.Element} ThemeToggle 컴포넌트 / ThemeToggle component\n */\nexport function ThemeToggle({\n className,\n size = \"md\",\n variant = \"button\",\n showLabel = false,\n label = {\n light: \"라이트\",\n dark: \"다크\",\n system: \"시스템\"\n },\n ...props\n}: ThemeToggleProps) {\n const { theme, setTheme, resolvedTheme } = useTheme()\n\n const sizeClasses = {\n sm: \"h-10 w-10\", // 40px - 더 넉넉한 크기\n md: \"h-12 w-12\", // 48px - 더 넉넉한 크기\n lg: \"h-14 w-14\" // 56px - 더 넉넉한 크기\n }\n\n const iconSizes = {\n sm: 16,\n md: 20,\n lg: 24\n }\n\n const renderIcon = () => {\n if (theme === \"system\") {\n return <Icon name=\"monitor\" size={iconSizes[size]} />\n }\n return resolvedTheme === \"dark\" ? (\n <Icon name=\"moon\" size={iconSizes[size]} />\n ) : (\n <Icon name=\"sun\" size={iconSizes[size]} className=\"text-amber-600\" />\n )\n }\n\n const handleClick = () => {\n if (theme === \"system\") {\n setTheme(\"light\")\n } else if (theme === \"light\") {\n setTheme(\"dark\")\n } else if (theme === \"dark\") {\n setTheme(\"light\") // dark → light로 직접 전환\n }\n }\n\n if (variant === \"icon\") {\n return (\n <button\n onClick={handleClick}\n className={merge(\n \"inline-flex items-center justify-center rounded-lg transition-all duration-300 hover:bg-gray-100 dark:hover:bg-gray-800 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-blue-500/50 focus-visible:ring-offset-2\",\n sizeClasses[size],\n className\n )}\n {...props}\n >\n <div className=\"relative flex items-center justify-center w-full h-full\">\n <div\n className={merge(\n \"absolute inset-0 flex items-center justify-center transition-all duration-300\",\n resolvedTheme === \"dark\" ? \"rotate-0 opacity-100\" : \"rotate-90 opacity-0\"\n )}\n >\n <Icon name=\"moon\" size={iconSizes[size]} className=\"text-blue-500\" />\n </div>\n <div\n className={merge(\n \"absolute inset-0 flex items-center justify-center transition-all duration-300\",\n resolvedTheme === \"dark\" ? \"rotate-90 opacity-0\" : \"rotate-0 opacity-100\"\n )}\n >\n <Icon name=\"sun\" size={iconSizes[size]} className=\"text-amber-600 dark:text-yellow-500\" />\n </div>\n </div>\n </button>\n )\n }\n\n if (variant === \"switch\") {\n return (\n <button\n onClick={handleClick}\n className={merge(\n \"relative inline-flex h-6 w-11 items-center rounded-full transition-colors duration-300 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-blue-500/50 focus-visible:ring-offset-2\",\n resolvedTheme === \"dark\" \n ? \"bg-blue-600\" \n : \"bg-gray-200 dark:bg-gray-700\",\n className\n )}\n {...props}\n >\n <span\n className={merge(\n \"inline-block h-4 w-4 transform rounded-full bg-white transition-transform duration-300 shadow-lg\",\n resolvedTheme === \"dark\" ? \"translate-x-6\" : \"translate-x-1\"\n )}\n />\n <div className=\"absolute inset-0 flex items-center justify-between px-1.5\">\n <Icon name=\"sun\" size={12} className=\"text-amber-600 dark:text-yellow-500 opacity-0\" />\n <Icon name=\"moon\" size={12} className=\"text-blue-500 opacity-0\" />\n </div>\n </button>\n )\n }\n\n return (\n <button\n onClick={handleClick}\n className={merge(\n \"inline-flex items-center gap-3 rounded-lg px-4 py-3 text-sm font-medium transition-all duration-300 hover:bg-gray-100 dark:hover:bg-gray-800 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-blue-500/50 focus-visible:ring-offset-2\", // 12px 간격, 16px, 12px 패딩\n className\n )}\n {...props}\n >\n {renderIcon()}\n {showLabel && (\n <span>\n {theme === \"system\" ? label.system : theme === \"dark\" ? label.dark : label.light}\n </span>\n )}\n </button>\n )\n} ","/**\n * Icon Names - 자동완성 지원\n * \n * 이 파일은 TypeScript 자동완성을 위한 아이콘 이름 목록입니다.\n * 실제 아이콘은 icons.ts와 PROJECT_ICONS에서 관리됩니다.\n */\n\nimport type { IconName } from './icons'\nimport { PROJECT_ICONS } from './icon-providers'\n\n/**\n * PROJECT_ICONS에 정의된 모든 아이콘 이름\n */\nexport type ProjectIconName = keyof typeof PROJECT_ICONS\n\n/**\n * 사용 가능한 모든 아이콘 이름 (icons.ts + PROJECT_ICONS)\n */\nexport type AllIconName = IconName | ProjectIconName\n\n/**\n * 아이콘 이름 목록 (자동완성용)\n */\nexport const iconNames = [\n // Navigation\n 'home', 'menu', 'close', 'search', 'settings', 'user', 'bell',\n 'arrowLeft', 'arrowRight', 'arrowUp', 'arrowDown',\n 'chevronLeft', 'chevronRight', 'chevronUp', 'chevronDown',\n \n // Actions\n 'add', 'edit', 'delete', 'remove', 'check', 'share', 'download', 'upload',\n 'save', 'copy', 'refresh', 'search',\n \n // Status & Feedback\n 'loader', 'success', 'error', 'warning', 'info', 'alertCircle',\n 'heart', 'star', 'bookmark',\n \n // User & Auth\n 'logIn', 'logOut', 'shield', 'key', 'lock', 'unlock',\n 'eye', 'eyeOff', 'users', 'userPlus',\n \n // Data & Analytics\n 'chart', 'barChart', 'pieChart', 'trendingUp', 'trendingDown',\n 'activity', 'database', 'zap', 'circle', 'dollarSign', 'dollar', 'currency',\n \n // Files & Content\n 'fileText', 'file', 'folder', 'book', 'bookOpen',\n 'image', 'video', 'camera',\n \n // Communication\n 'message', 'messageSquare', 'phone', 'mail', 'send',\n \n // Media\n 'play', 'pause', 'mic', 'headphones',\n \n // Emotions\n 'smile', 'frown', 'meh', 'laugh', 'angry',\n 'thumbsUp', 'thumbsDown',\n \n // Time & Date\n 'clock', 'timer', 'calendar', 'calendarDays',\n \n // UI & Theme\n 'monitor', 'sun', 'moon', 'sparkles', 'lightbulb', 'brain',\n \n // Navigation Extended\n 'externalLink', 'link', 'moreHorizontal', 'moreVertical',\n] as const\n\n/**\n * 프로바이더별 아이콘 이름 매핑 (참고용)\n * \n * @example\n * // Lucide 아이콘 사용\n * <Icon name=\"home\" provider=\"lucide\" /> // Lucide: Home\n * \n * // Phosphor 아이콘 사용\n * <Icon name=\"home\" provider=\"phosphor\" /> // Phosphor: House\n * \n * // Untitled 아이콘 사용\n * <Icon name=\"home\" provider=\"untitled\" /> // Untitled: home\n */\nexport const iconProviderMapping: Record<string, {\n lucide: string\n phosphor: string\n untitled: string\n}> = PROJECT_ICONS\n\n/**\n * 아이콘 이름이 유효한지 확인\n */\nexport function isValidIconName(name: string): name is AllIconName {\n return name in PROJECT_ICONS || (iconNames as readonly string[]).includes(name)\n}\n\n/**\n * 프로바이더별 아이콘 이름 가져오기\n */\nexport function getIconNameForProvider(\n iconName: string,\n provider: 'lucide' | 'phosphor' | 'untitled'\n): string | null {\n const mapping = PROJECT_ICONS[iconName as keyof typeof PROJECT_ICONS]\n if (!mapping) return null\n \n return mapping[provider] || null\n}\n\n\n"]}