@hua-labs/ui 1.0.0 → 1.1.0-alpha.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +897 -210
- package/dist/ComponentLayout-BxCenSAm.d.mts +73 -0
- package/dist/advanced/dashboard.d.ts +7 -0
- package/dist/advanced/dashboard.d.ts.map +1 -0
- package/dist/advanced/motion.d.ts +2 -0
- package/dist/advanced/motion.d.ts.map +1 -0
- package/dist/advanced-dashboard.d.mts +4 -0
- package/dist/advanced-dashboard.js +2 -0
- package/dist/advanced-dashboard.js.map +1 -0
- package/dist/advanced-dashboard.mjs +2 -0
- package/dist/advanced-dashboard.mjs.map +1 -0
- package/dist/advanced-motion.d.mts +93 -0
- package/dist/advanced-motion.js +2 -0
- package/dist/advanced-motion.js.map +1 -0
- package/dist/advanced-motion.mjs +2 -0
- package/dist/advanced-motion.mjs.map +1 -0
- package/dist/advanced.d.mts +734 -0
- package/dist/advanced.d.ts +17 -0
- package/dist/advanced.d.ts.map +1 -0
- package/dist/advanced.js +2 -0
- package/dist/advanced.js.map +1 -0
- package/dist/advanced.mjs +2 -0
- package/dist/advanced.mjs.map +1 -0
- package/dist/chunk-627HOIRV.mjs +2 -0
- package/dist/chunk-627HOIRV.mjs.map +1 -0
- package/dist/chunk-ACEKLG37.mjs +2 -0
- package/dist/chunk-ACEKLG37.mjs.map +1 -0
- package/dist/chunk-E5PN4LUS.mjs +2 -0
- package/dist/chunk-E5PN4LUS.mjs.map +1 -0
- package/dist/chunk-KHEJZ3U4.mjs +2 -0
- package/dist/chunk-KHEJZ3U4.mjs.map +1 -0
- package/dist/chunk-MXGXBG63.mjs +2 -0
- package/dist/chunk-MXGXBG63.mjs.map +1 -0
- package/dist/chunk-R5KCFRYV.mjs +2 -0
- package/dist/chunk-R5KCFRYV.mjs.map +1 -0
- package/dist/chunk-UGSYQDR4.mjs +2 -0
- package/dist/chunk-UGSYQDR4.mjs.map +1 -0
- package/dist/chunk-UUHAXGMO.mjs +2 -0
- package/dist/chunk-UUHAXGMO.mjs.map +1 -0
- package/dist/chunk-VU264VFN.mjs +2 -0
- package/dist/chunk-VU264VFN.mjs.map +1 -0
- package/dist/chunk-ZFS4B5QT.mjs +2 -0
- package/dist/chunk-ZFS4B5QT.mjs.map +1 -0
- package/dist/components/Accordion.d.ts +109 -1
- package/dist/components/Accordion.d.ts.map +1 -1
- package/dist/components/Action.d.ts +68 -0
- package/dist/components/Action.d.ts.map +1 -0
- package/dist/components/ActionToolbar.d.ts +65 -0
- package/dist/components/ActionToolbar.d.ts.map +1 -0
- package/dist/components/Alert.d.ts +49 -0
- package/dist/components/Alert.d.ts.map +1 -1
- package/dist/components/Autocomplete.d.ts +88 -0
- package/dist/components/Autocomplete.d.ts.map +1 -0
- package/dist/components/Avatar.d.ts +71 -1
- package/dist/components/Avatar.d.ts.map +1 -1
- package/dist/components/Badge.d.ts +32 -2
- package/dist/components/Badge.d.ts.map +1 -1
- package/dist/components/Bookmark.d.ts +49 -0
- package/dist/components/Bookmark.d.ts.map +1 -0
- package/dist/components/BottomSheet.d.ts +91 -1
- package/dist/components/BottomSheet.d.ts.map +1 -1
- package/dist/components/Breadcrumb.d.ts +73 -14
- package/dist/components/Breadcrumb.d.ts.map +1 -1
- package/dist/components/Button.d.ts +82 -7
- package/dist/components/Button.d.ts.map +1 -1
- package/dist/components/Card.d.ts +122 -5
- package/dist/components/Card.d.ts.map +1 -1
- package/dist/components/ChatMessage.d.ts +67 -1
- package/dist/components/ChatMessage.d.ts.map +1 -1
- package/dist/components/Checkbox.d.ts +48 -2
- package/dist/components/Checkbox.d.ts.map +1 -1
- package/dist/components/Command.d.ts +82 -1
- package/dist/components/Command.d.ts.map +1 -1
- package/dist/components/ComponentLayout.d.ts +72 -0
- package/dist/components/ComponentLayout.d.ts.map +1 -0
- package/dist/components/ConfirmModal.d.ts +66 -1
- package/dist/components/ConfirmModal.d.ts.map +1 -1
- package/dist/components/Container.d.ts +39 -0
- package/dist/components/Container.d.ts.map +1 -1
- package/dist/components/ContextMenu.d.ts +51 -1
- package/dist/components/ContextMenu.d.ts.map +1 -1
- package/dist/components/DatePicker.d.ts +62 -0
- package/dist/components/DatePicker.d.ts.map +1 -0
- package/dist/components/Divider.d.ts +13 -3
- package/dist/components/Divider.d.ts.map +1 -1
- package/dist/components/Drawer.d.ts +103 -1
- package/dist/components/Drawer.d.ts.map +1 -1
- package/dist/components/Dropdown.d.ts +51 -1
- package/dist/components/Dropdown.d.ts.map +1 -1
- package/dist/components/EmotionAnalysis.d.ts +59 -1
- package/dist/components/EmotionAnalysis.d.ts.map +1 -1
- package/dist/components/EmotionButton.d.ts +35 -1
- package/dist/components/EmotionButton.d.ts.map +1 -1
- package/dist/components/EmotionMeter.d.ts +38 -2
- package/dist/components/EmotionMeter.d.ts.map +1 -1
- package/dist/components/EmotionSelector.d.ts +51 -1
- package/dist/components/EmotionSelector.d.ts.map +1 -1
- package/dist/components/FeatureCard.d.ts +61 -0
- package/dist/components/FeatureCard.d.ts.map +1 -0
- package/dist/components/Form.d.ts +114 -0
- package/dist/components/Form.d.ts.map +1 -0
- package/dist/components/Grid.d.ts +42 -1
- package/dist/components/Grid.d.ts.map +1 -1
- package/dist/components/HeroSection.d.ts +77 -0
- package/dist/components/HeroSection.d.ts.map +1 -0
- package/dist/components/Icon/Icon.d.ts +159 -0
- package/dist/components/Icon/Icon.d.ts.map +1 -0
- package/dist/components/Icon/IconProvider.d.ts +94 -0
- package/dist/components/Icon/IconProvider.d.ts.map +1 -0
- package/dist/components/Icon/icon-store.d.ts +21 -0
- package/dist/components/Icon/icon-store.d.ts.map +1 -0
- package/dist/components/Icon/index.d.ts +10 -0
- package/dist/components/Icon/index.d.ts.map +1 -0
- package/dist/components/InfoCard.d.ts +48 -0
- package/dist/components/InfoCard.d.ts.map +1 -0
- package/dist/components/Input.d.ts +40 -8
- package/dist/components/Input.d.ts.map +1 -1
- package/dist/components/Label.d.ts +50 -0
- package/dist/components/Label.d.ts.map +1 -0
- package/dist/components/LanguageToggle.d.ts +41 -1
- package/dist/components/LanguageToggle.d.ts.map +1 -1
- package/dist/components/Link.d.ts +52 -0
- package/dist/components/Link.d.ts.map +1 -0
- package/dist/components/LoadingSpinner.d.ts +44 -5
- package/dist/components/LoadingSpinner.d.ts.map +1 -1
- package/dist/components/Menu.d.ts +92 -1
- package/dist/components/Menu.d.ts.map +1 -1
- package/dist/components/Modal.d.ts +67 -5
- package/dist/components/Modal.d.ts.map +1 -1
- package/dist/components/Navigation.d.ts +72 -0
- package/dist/components/Navigation.d.ts.map +1 -0
- package/dist/components/PageNavigation.d.ts +48 -0
- package/dist/components/PageNavigation.d.ts.map +1 -0
- package/dist/components/PageTransition.d.ts +44 -1
- package/dist/components/PageTransition.d.ts.map +1 -1
- package/dist/components/Pagination.d.ts +52 -1
- package/dist/components/Pagination.d.ts.map +1 -1
- package/dist/components/Panel.d.ts +99 -0
- package/dist/components/Panel.d.ts.map +1 -0
- package/dist/components/Popover.d.ts +46 -1
- package/dist/components/Popover.d.ts.map +1 -1
- package/dist/components/Progress.d.ts +52 -3
- package/dist/components/Progress.d.ts.map +1 -1
- package/dist/components/Radio.d.ts +44 -2
- package/dist/components/Radio.d.ts.map +1 -1
- package/dist/components/ScrollArea.d.ts +53 -1
- package/dist/components/ScrollArea.d.ts.map +1 -1
- package/dist/components/ScrollIndicator.d.ts +43 -1
- package/dist/components/ScrollIndicator.d.ts.map +1 -1
- package/dist/components/ScrollProgress.d.ts +37 -0
- package/dist/components/ScrollProgress.d.ts.map +1 -1
- package/dist/components/ScrollToTop.d.ts +48 -11
- package/dist/components/ScrollToTop.d.ts.map +1 -1
- package/dist/components/SectionHeader.d.ts +42 -0
- package/dist/components/SectionHeader.d.ts.map +1 -0
- package/dist/components/Select.d.ts +59 -2
- package/dist/components/Select.d.ts.map +1 -1
- package/dist/components/Skeleton.d.ts +44 -1
- package/dist/components/Skeleton.d.ts.map +1 -1
- package/dist/components/Slider.d.ts +75 -0
- package/dist/components/Slider.d.ts.map +1 -0
- package/dist/components/Stack.d.ts +42 -1
- package/dist/components/Stack.d.ts.map +1 -1
- package/dist/components/StatsPanel.d.ts +72 -0
- package/dist/components/StatsPanel.d.ts.map +1 -0
- package/dist/components/Switch.d.ts +48 -2
- package/dist/components/Switch.d.ts.map +1 -1
- package/dist/components/Table.d.ts +206 -0
- package/dist/components/Table.d.ts.map +1 -0
- package/dist/components/Tabs.d.ts +123 -10
- package/dist/components/Tabs.d.ts.map +1 -1
- package/dist/components/Textarea.d.ts +48 -2
- package/dist/components/Textarea.d.ts.map +1 -1
- package/dist/components/ThemeProvider.d.ts +67 -2
- package/dist/components/ThemeProvider.d.ts.map +1 -1
- package/dist/components/ThemeToggle.d.ts +44 -0
- package/dist/components/ThemeToggle.d.ts.map +1 -1
- package/dist/components/Toast.d.ts +75 -1
- package/dist/components/Toast.d.ts.map +1 -1
- package/dist/components/Toggle.d.ts +62 -0
- package/dist/components/Toggle.d.ts.map +1 -0
- package/dist/components/Tooltip.d.ts +48 -1
- package/dist/components/Tooltip.d.ts.map +1 -1
- package/dist/components/Upload.d.ts +87 -0
- package/dist/components/Upload.d.ts.map +1 -0
- package/dist/components/advanced/AdvancedPageTransition.d.ts +25 -0
- package/dist/components/advanced/AdvancedPageTransition.d.ts.map +1 -0
- package/dist/components/advanced/index.d.ts +4 -0
- package/dist/components/advanced/index.d.ts.map +1 -0
- package/dist/components/advanced/usePageTransition.d.ts +33 -0
- package/dist/components/advanced/usePageTransition.d.ts.map +1 -0
- package/dist/components/advanced/usePageTransitionManager.d.ts +44 -0
- package/dist/components/advanced/usePageTransitionManager.d.ts.map +1 -0
- package/dist/components/dashboard/ActivityFeed.d.ts +87 -0
- package/dist/components/dashboard/ActivityFeed.d.ts.map +1 -0
- package/dist/components/dashboard/BarChart.d.ts +82 -0
- package/dist/components/dashboard/BarChart.d.ts.map +1 -0
- package/dist/components/dashboard/DashboardGrid.d.ts +44 -0
- package/dist/components/dashboard/DashboardGrid.d.ts.map +1 -0
- package/dist/components/dashboard/DashboardSidebar.d.ts +105 -0
- package/dist/components/dashboard/DashboardSidebar.d.ts.map +1 -0
- package/dist/components/dashboard/DashboardToolbar.d.ts +120 -0
- package/dist/components/dashboard/DashboardToolbar.d.ts.map +1 -0
- package/dist/components/dashboard/EmptyState.d.ts +61 -0
- package/dist/components/dashboard/EmptyState.d.ts.map +1 -0
- package/dist/components/dashboard/MembershipBadge.d.ts +45 -0
- package/dist/components/dashboard/MembershipBadge.d.ts.map +1 -0
- package/dist/components/dashboard/MerchantList.d.ts +98 -0
- package/dist/components/dashboard/MerchantList.d.ts.map +1 -0
- package/dist/components/dashboard/MetricCard.d.ts +75 -0
- package/dist/components/dashboard/MetricCard.d.ts.map +1 -0
- package/dist/components/dashboard/MiniBarChart.d.ts +60 -0
- package/dist/components/dashboard/MiniBarChart.d.ts.map +1 -0
- package/dist/components/dashboard/NotificationCard.d.ts +89 -0
- package/dist/components/dashboard/NotificationCard.d.ts.map +1 -0
- package/dist/components/dashboard/ProfileCard.d.ts +82 -0
- package/dist/components/dashboard/ProfileCard.d.ts.map +1 -0
- package/dist/components/dashboard/ProgressCard.d.ts +71 -0
- package/dist/components/dashboard/ProgressCard.d.ts.map +1 -0
- package/dist/components/dashboard/QuickActionCard.d.ts +63 -0
- package/dist/components/dashboard/QuickActionCard.d.ts.map +1 -0
- package/dist/components/dashboard/RoutingBreakdownCard.d.ts +88 -0
- package/dist/components/dashboard/RoutingBreakdownCard.d.ts.map +1 -0
- package/dist/components/dashboard/SettlementTimeline.d.ts +90 -0
- package/dist/components/dashboard/SettlementTimeline.d.ts.map +1 -0
- package/dist/components/dashboard/StatCard.d.ts +70 -0
- package/dist/components/dashboard/StatCard.d.ts.map +1 -0
- package/dist/components/dashboard/SummaryCard.d.ts +73 -0
- package/dist/components/dashboard/SummaryCard.d.ts.map +1 -0
- package/dist/components/dashboard/TransactionDetailDrawer.d.ts +183 -0
- package/dist/components/dashboard/TransactionDetailDrawer.d.ts.map +1 -0
- package/dist/components/dashboard/TransactionsTable.d.ts +137 -0
- package/dist/components/dashboard/TransactionsTable.d.ts.map +1 -0
- package/dist/components/dashboard/TrendChart.d.ts +75 -0
- package/dist/components/dashboard/TrendChart.d.ts.map +1 -0
- package/dist/components/dashboard/index.d.ts +41 -0
- package/dist/components/dashboard/index.d.ts.map +1 -0
- package/dist/components/scrollbar/scrollbar.d.ts +12 -0
- package/dist/components/scrollbar/scrollbar.d.ts.map +1 -0
- package/dist/dashboard-QMssHf5j.d.mts +1801 -0
- package/dist/feedback.d.mts +103 -0
- package/dist/feedback.d.ts +21 -0
- package/dist/feedback.d.ts.map +1 -0
- package/dist/feedback.js +2 -0
- package/dist/feedback.js.map +1 -0
- package/dist/feedback.mjs +2 -0
- package/dist/feedback.mjs.map +1 -0
- package/dist/form.d.mts +803 -0
- package/dist/form.d.ts +42 -0
- package/dist/form.d.ts.map +1 -0
- package/dist/form.js +2 -0
- package/dist/form.js.map +1 -0
- package/dist/form.mjs +2 -0
- package/dist/form.mjs.map +1 -0
- package/dist/hooks/useScrollToggle.d.ts +12 -0
- package/dist/hooks/useScrollToggle.d.ts.map +1 -0
- package/dist/icons-DoSGIez_.d.mts +135 -0
- package/dist/index.d.mts +3770 -0
- package/dist/index.d.ts +76 -38
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +37 -49
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +37 -0
- package/dist/index.mjs.map +1 -0
- package/dist/lib/icon-aliases.d.ts +24 -0
- package/dist/lib/icon-aliases.d.ts.map +1 -0
- package/dist/lib/icon-names.d.ts +47 -0
- package/dist/lib/icon-names.d.ts.map +1 -0
- package/dist/lib/icon-providers.d.ts +559 -0
- package/dist/lib/icon-providers.d.ts.map +1 -0
- package/dist/lib/icons.d.ts +113 -24
- package/dist/lib/icons.d.ts.map +1 -1
- package/dist/lib/phosphor-icons.d.ts +6 -0
- package/dist/lib/phosphor-icons.d.ts.map +1 -0
- package/dist/lib/styles/colors.d.ts +131 -0
- package/dist/lib/styles/colors.d.ts.map +1 -0
- package/dist/lib/styles/index.d.ts +8 -0
- package/dist/lib/styles/index.d.ts.map +1 -0
- package/dist/lib/styles/utils.d.ts +87 -0
- package/dist/lib/styles/utils.d.ts.map +1 -0
- package/dist/lib/styles/variants.d.ts +79 -0
- package/dist/lib/styles/variants.d.ts.map +1 -0
- package/dist/lib/types/common.d.ts +80 -0
- package/dist/lib/types/common.d.ts.map +1 -0
- package/dist/lib/types/index.d.ts +6 -0
- package/dist/lib/types/index.d.ts.map +1 -0
- package/dist/lib/utils.d.ts +73 -1
- package/dist/lib/utils.d.ts.map +1 -1
- package/dist/navigation.d.mts +105 -0
- package/dist/navigation.d.ts +22 -0
- package/dist/navigation.d.ts.map +1 -0
- package/dist/navigation.js +2 -0
- package/dist/navigation.js.map +1 -0
- package/dist/navigation.mjs +2 -0
- package/dist/navigation.mjs.map +1 -0
- package/package.json +92 -25
- package/src/styles/toast.css +23 -0
- package/dist/components/Accordion.js +0 -84
- package/dist/components/Alert.js +0 -61
- package/dist/components/Avatar.js +0 -18
- package/dist/components/Badge.js +0 -15
- package/dist/components/BottomSheet.js +0 -96
- package/dist/components/Breadcrumb.js +0 -47
- package/dist/components/Button.js +0 -23
- package/dist/components/Card.js +0 -18
- package/dist/components/ChatMessage.js +0 -59
- package/dist/components/Checkbox.js +0 -30
- package/dist/components/Command.js +0 -119
- package/dist/components/ConfirmModal.js +0 -53
- package/dist/components/Container.js +0 -23
- package/dist/components/ContextMenu.js +0 -110
- package/dist/components/Divider.js +0 -39
- package/dist/components/Drawer.js +0 -79
- package/dist/components/Dropdown.js +0 -174
- package/dist/components/EmotionAnalysis.js +0 -40
- package/dist/components/EmotionButton.js +0 -16
- package/dist/components/EmotionMeter.js +0 -21
- package/dist/components/EmotionSelector.js +0 -46
- package/dist/components/Grid.js +0 -44
- package/dist/components/Icon.d.ts +0 -26
- package/dist/components/Icon.d.ts.map +0 -1
- package/dist/components/Icon.js +0 -48
- package/dist/components/Input.js +0 -25
- package/dist/components/LanguageToggle.js +0 -61
- package/dist/components/LoadingSpinner.js +0 -37
- package/dist/components/Menu.js +0 -122
- package/dist/components/Modal.js +0 -62
- package/dist/components/PageTransition.js +0 -39
- package/dist/components/Pagination.js +0 -87
- package/dist/components/Popover.js +0 -159
- package/dist/components/Progress.js +0 -51
- package/dist/components/Radio.js +0 -29
- package/dist/components/ScrollArea.js +0 -42
- package/dist/components/ScrollIndicator.js +0 -60
- package/dist/components/ScrollProgress.js +0 -39
- package/dist/components/ScrollToTop.js +0 -46
- package/dist/components/Select.js +0 -29
- package/dist/components/Skeleton.js +0 -71
- package/dist/components/Stack.js +0 -34
- package/dist/components/Switch.js +0 -29
- package/dist/components/Tabs.js +0 -117
- package/dist/components/Textarea.js +0 -31
- package/dist/components/ThemeProvider.js +0 -76
- package/dist/components/ThemeToggle.js +0 -49
- package/dist/components/Toast.js +0 -138
- package/dist/components/Tooltip.js +0 -102
- package/dist/lib/icons.js +0 -321
- package/dist/lib/utils.js +0 -5
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/Action.tsx","../src/components/Link.tsx","../src/components/Modal.tsx","../src/components/Container.tsx","../src/components/Grid.tsx","../src/components/Stack.tsx","../src/components/Divider.tsx","../src/components/Panel.tsx","../src/components/ActionToolbar.tsx","../src/components/Navigation.tsx","../src/components/Pagination.tsx","../src/components/Progress.tsx","../src/components/Alert.tsx","../src/components/BottomSheet.tsx","../src/components/ConfirmModal.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":["isBrowser","useReducedMotion","reduce","setReduce","React","_a","mq","onChange","Action","className","children","actionType","feedback","particleEffect","rippleEffect","soundEffect","hapticFeedback","transparency","blurIntensity","glowIntensity","glowColor","loading","iconOnly","disabled","rest","ref","reduced","runEffects","event","AudioContextClass","audioContext","oscillator","gainNode","button","rect","x","y","size","ripple","style","i","particle","angle","velocity","vx","vy","styleVars","cls","merge","onClick","href","anchorRest","jsx","Button","e","btnRest","Link","variant","external","variantClasses","sizeClasses","useCombinedRefs","refs","node","Modal","isOpen","onClose","showCloseButton","closeOnOverlayClick","title","description","showBackdrop","backdropClassName","centered","modalRef","combinedRef","handleEscape","scrollbarWidth","handleOverlayClick","titleId","descriptionId","jsxs","Container","padding","fluid","props","paddingClasses","Grid","cols","gap","gapX","gapY","responsive","colsClasses","gapClasses","gapXClasses","gapYClasses","Stack","direction","spacing","align","justify","wrap","directionClasses","spacingClasses","alignClasses","justifyClasses","DividerComponent","orientation","color","orientationClasses","colorClasses","Divider","Panel","effect","borderOpacity","shadowOpacity","hoverEffect","animationEffect","customPadding","rounded","customRounded","background","gradientColors","patternType","backgroundImage","backgroundVideo","interactive","hoverScale","hoverRotate","hoverGlow","cardProps","styleClasses","baseClasses","effectClasses","roundedClasses","patternBackground","backgroundStyles","styles","hoverClasses","classes","panelClasses","Card","ActionToolbarComponent","isSelectMode","totalCount","selectedCount","actions","selectModeActions","onToggleSelectMode","onToggleSelectAll","onCancelSelect","getBadgeColor","useCallback","renderButton","action","key","Icon","index","ActionToolbar","Navigation","value","defaultValue","onValueChange","scale","activeTab","setActiveTab","isControlled","currentValue","child","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","Fragment","Progress","max","showValue","animated","striped","label","percentage","getStripedClasses","ProgressSuccess","ProgressWarning","ProgressError","ProgressInfo","ProgressWrapper","ProgressGroup","Alert","icon","closable","getIconClasses","getDefaultIcon","AlertSuccess","AlertWarning","AlertError","AlertInfo","BottomSheet","open","onOpenChange","height","closeOnBackdropClick","closeOnEscape","showDragHandle","snapPoints","defaultSnap","isVisible","setIsVisible","isAnimating","setIsAnimating","currentHeight","setCurrentHeight","isDragging","setIsDragging","startY","setStartY","currentY","setCurrentY","heightClasses","timer","handleTouchStart","handleTouchMove","handleTouchEnd","deltaY","threshold","currentIndex","nextIndex","BottomSheetHeader","BottomSheetContent","ConfirmModal","onConfirm","message","warning","confirmText","cancelText","confirmButtonText","type","showInput","inputValue","onInputChange","inputPlaceholder","inputLabel","requiredInputValue","showCancel","config","isDisabled","Accordion","collapsible","openItems","setOpenItems","handleItemToggle","itemValue","newOpenItems","item","itemValues","values","childProps","handleKeyDown","target","newIndex","triggerElement","AccordionItem","onToggle","AccordionTrigger","iconPosition","defaultIcon","contentId","triggerId","AccordionContent","dataValue","setHeight","contentRef","TabsContent","Tabs","handleTabChange","newValue","TabsList","listRef","tabValues","TabsTrigger","TabsPills","TabsUnderline","TabsCards","Menu","MenuItem","MenuSeparator","MenuLabel","MenuHorizontal","MenuVertical","MenuCompact","ContextMenu","controlledOpen","trigger","placement","offset","internalOpen","setInternalOpen","coords","setCoords","triggerRef","menuRef","handleOpenChange","newOpen","handleContextMenu","updatePosition","menuRect","viewportWidth","viewportHeight","handleClickOutside","ContextMenuItem","ContextMenuSeparator","ContextMenuLabel","ContextMenuGroup","Command","placeholder","controlledSearchValue","onSearchChange","internalSearchValue","setInternalSearchValue","selectedIndex","setSelectedIndex","commandRef","inputRef","searchValue","handleSearchChange","items","itemCount","prev","selectedItem","_b","CommandInput","CommandList","CommandItem","selected","onSelect","CommandGroup","heading","CommandSeparator","CommandEmpty","CommandDialog","ScrollArea","scrollHideDelay","showScrollbar","setShowScrollbar","timeoutRef","handleMouseEnter","handleMouseLeave","ScrollBar","useScrollToggle","options","showOnMount","smooth","useState","mounted","setMounted","useEffect","toggleVisibility","ScrollToTop","scrollToTop","initialState","ThemeProviderContext","createContext","ThemeProvider","defaultTheme","storageKey","enableSystem","enableTransition","theme","setTheme","resolvedTheme","setResolvedTheme","savedTheme","root","systemTheme","mediaQuery","handleChange","useTheme","context","useContext","ThemeToggle","showLabel","iconSizes","renderIcon","iconNames","iconProviderMapping","PROJECT_ICONS","isValidIconName","name","getIconNameForProvider","iconName","provider","mapping"],"mappings":"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","file":"index.mjs","sourcesContent":["\"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 * 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} ","\"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\"\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\"\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\"\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 * 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 { 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\"\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"]}
|