@smart-coder-labs/apple-design-system 1.0.0
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 +442 -0
- package/dist/cli/commands/add.d.ts +2 -0
- package/dist/cli/commands/add.d.ts.map +1 -0
- package/dist/cli/commands/add.js +102 -0
- package/dist/cli/commands/add.js.map +1 -0
- package/dist/cli/commands/init.d.ts +2 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +73 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +20 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/utils/registry.d.ts +4 -0
- package/dist/cli/utils/registry.d.ts.map +1 -0
- package/dist/cli/utils/registry.js +52 -0
- package/dist/cli/utils/registry.js.map +1 -0
- package/dist/components/AIThinkingIndicator.d.ts +10 -0
- package/dist/components/AIThinkingIndicator.d.ts.map +1 -0
- package/dist/components/AIThinkingIndicator.js +60 -0
- package/dist/components/AIThinkingIndicator.js.map +1 -0
- package/dist/components/Accordion.d.ts +27 -0
- package/dist/components/Accordion.d.ts.map +1 -0
- package/dist/components/Accordion.js +123 -0
- package/dist/components/Accordion.js.map +1 -0
- package/dist/components/ActivityFeed.d.ts +26 -0
- package/dist/components/ActivityFeed.d.ts.map +1 -0
- package/dist/components/ActivityFeed.js +55 -0
- package/dist/components/ActivityFeed.js.map +1 -0
- package/dist/components/ActivityMonitor.d.ts +38 -0
- package/dist/components/ActivityMonitor.d.ts.map +1 -0
- package/dist/components/ActivityMonitor.js +164 -0
- package/dist/components/ActivityMonitor.js.map +1 -0
- package/dist/components/AddressSelector.d.ts +23 -0
- package/dist/components/AddressSelector.d.ts.map +1 -0
- package/dist/components/AddressSelector.js +145 -0
- package/dist/components/AddressSelector.js.map +1 -0
- package/dist/components/AgendaView.d.ts +11 -0
- package/dist/components/AgendaView.d.ts.map +1 -0
- package/dist/components/AgendaView.js +47 -0
- package/dist/components/AgendaView.js.map +1 -0
- package/dist/components/Alert.d.ts +9 -0
- package/dist/components/Alert.d.ts.map +1 -0
- package/dist/components/Alert.js +38 -0
- package/dist/components/Alert.js.map +1 -0
- package/dist/components/AudioPlayer.d.ts +11 -0
- package/dist/components/AudioPlayer.d.ts.map +1 -0
- package/dist/components/AudioPlayer.js +116 -0
- package/dist/components/AudioPlayer.js.map +1 -0
- package/dist/components/Avatar.d.ts +17 -0
- package/dist/components/Avatar.d.ts.map +1 -0
- package/dist/components/Avatar.js +74 -0
- package/dist/components/Avatar.js.map +1 -0
- package/dist/components/AvatarGroup.d.ts +15 -0
- package/dist/components/AvatarGroup.d.ts.map +1 -0
- package/dist/components/AvatarGroup.js +28 -0
- package/dist/components/AvatarGroup.js.map +1 -0
- package/dist/components/Badge.d.ts +21 -0
- package/dist/components/Badge.d.ts.map +1 -0
- package/dist/components/Badge.js +103 -0
- package/dist/components/Badge.js.map +1 -0
- package/dist/components/BarcodeGenerator.d.ts +18 -0
- package/dist/components/BarcodeGenerator.d.ts.map +1 -0
- package/dist/components/BarcodeGenerator.js +64 -0
- package/dist/components/BarcodeGenerator.js.map +1 -0
- package/dist/components/Blockquote.d.ts +9 -0
- package/dist/components/Blockquote.d.ts.map +1 -0
- package/dist/components/Blockquote.js +8 -0
- package/dist/components/Blockquote.js.map +1 -0
- package/dist/components/BottomNavigation.d.ts +21 -0
- package/dist/components/BottomNavigation.d.ts.map +1 -0
- package/dist/components/BottomNavigation.js +77 -0
- package/dist/components/BottomNavigation.js.map +1 -0
- package/dist/components/Breadcrumb.d.ts +20 -0
- package/dist/components/Breadcrumb.d.ts.map +1 -0
- package/dist/components/Breadcrumb.js +24 -0
- package/dist/components/Breadcrumb.js.map +1 -0
- package/dist/components/BreadcrumbTabsHybrid.d.ts +25 -0
- package/dist/components/BreadcrumbTabsHybrid.d.ts.map +1 -0
- package/dist/components/BreadcrumbTabsHybrid.js +58 -0
- package/dist/components/BreadcrumbTabsHybrid.js.map +1 -0
- package/dist/components/Button.d.ts +14 -0
- package/dist/components/Button.d.ts.map +1 -0
- package/dist/components/Button.js +91 -0
- package/dist/components/Button.js.map +1 -0
- package/dist/components/ButtonWithDropdown.d.ts +19 -0
- package/dist/components/ButtonWithDropdown.d.ts.map +1 -0
- package/dist/components/ButtonWithDropdown.js +33 -0
- package/dist/components/ButtonWithDropdown.js.map +1 -0
- package/dist/components/Calendar.d.ts +28 -0
- package/dist/components/Calendar.d.ts.map +1 -0
- package/dist/components/Calendar.js +365 -0
- package/dist/components/Calendar.js.map +1 -0
- package/dist/components/Callout.d.ts +11 -0
- package/dist/components/Callout.d.ts.map +1 -0
- package/dist/components/Callout.js +35 -0
- package/dist/components/Callout.js.map +1 -0
- package/dist/components/Caption.d.ts +6 -0
- package/dist/components/Caption.d.ts.map +1 -0
- package/dist/components/Caption.js +7 -0
- package/dist/components/Caption.js.map +1 -0
- package/dist/components/Card.d.ts +30 -0
- package/dist/components/Card.d.ts.map +1 -0
- package/dist/components/Card.js +72 -0
- package/dist/components/Card.js.map +1 -0
- package/dist/components/CartPreview.d.ts +28 -0
- package/dist/components/CartPreview.d.ts.map +1 -0
- package/dist/components/CartPreview.js +80 -0
- package/dist/components/CartPreview.js.map +1 -0
- package/dist/components/Chart.d.ts +19 -0
- package/dist/components/Chart.d.ts.map +1 -0
- package/dist/components/Chart.js +46 -0
- package/dist/components/Chart.js.map +1 -0
- package/dist/components/ChatBubble.d.ts +19 -0
- package/dist/components/ChatBubble.d.ts.map +1 -0
- package/dist/components/ChatBubble.js +27 -0
- package/dist/components/ChatBubble.js.map +1 -0
- package/dist/components/ChatInput.d.ts +22 -0
- package/dist/components/ChatInput.d.ts.map +1 -0
- package/dist/components/ChatInput.js +115 -0
- package/dist/components/ChatInput.js.map +1 -0
- package/dist/components/Checkbox.d.ts +10 -0
- package/dist/components/Checkbox.d.ts.map +1 -0
- package/dist/components/Checkbox.js +35 -0
- package/dist/components/Checkbox.js.map +1 -0
- package/dist/components/Chip.d.ts +14 -0
- package/dist/components/Chip.d.ts.map +1 -0
- package/dist/components/Chip.js +43 -0
- package/dist/components/Chip.js.map +1 -0
- package/dist/components/CodeBlock.d.ts +9 -0
- package/dist/components/CodeBlock.d.ts.map +1 -0
- package/dist/components/CodeBlock.js +16 -0
- package/dist/components/CodeBlock.js.map +1 -0
- package/dist/components/Collapsible.d.ts +19 -0
- package/dist/components/Collapsible.d.ts.map +1 -0
- package/dist/components/Collapsible.js +42 -0
- package/dist/components/Collapsible.js.map +1 -0
- package/dist/components/Combobox.d.ts +17 -0
- package/dist/components/Combobox.d.ts.map +1 -0
- package/dist/components/Combobox.js +114 -0
- package/dist/components/Combobox.js.map +1 -0
- package/dist/components/CommandMenu.d.ts +36 -0
- package/dist/components/CommandMenu.d.ts.map +1 -0
- package/dist/components/CommandMenu.js +102 -0
- package/dist/components/CommandMenu.js.map +1 -0
- package/dist/components/CommentThread.d.ts +28 -0
- package/dist/components/CommentThread.d.ts.map +1 -0
- package/dist/components/CommentThread.js +66 -0
- package/dist/components/CommentThread.js.map +1 -0
- package/dist/components/ConfirmDialog.d.ts +27 -0
- package/dist/components/ConfirmDialog.d.ts.map +1 -0
- package/dist/components/ConfirmDialog.js +62 -0
- package/dist/components/ConfirmDialog.js.map +1 -0
- package/dist/components/ContextMenu.d.ts +85 -0
- package/dist/components/ContextMenu.d.ts.map +1 -0
- package/dist/components/ContextMenu.js +191 -0
- package/dist/components/ContextMenu.js.map +1 -0
- package/dist/components/ControlCenterToggles.d.ts +18 -0
- package/dist/components/ControlCenterToggles.d.ts.map +1 -0
- package/dist/components/ControlCenterToggles.js +14 -0
- package/dist/components/ControlCenterToggles.js.map +1 -0
- package/dist/components/Counters.d.ts +16 -0
- package/dist/components/Counters.d.ts.map +1 -0
- package/dist/components/Counters.js +9 -0
- package/dist/components/Counters.js.map +1 -0
- package/dist/components/CountersListWithChart.d.ts +15 -0
- package/dist/components/CountersListWithChart.d.ts.map +1 -0
- package/dist/components/CountersListWithChart.js +22 -0
- package/dist/components/CountersListWithChart.js.map +1 -0
- package/dist/components/DataGrid.d.ts +38 -0
- package/dist/components/DataGrid.d.ts.map +1 -0
- package/dist/components/DataGrid.js +271 -0
- package/dist/components/DataGrid.js.map +1 -0
- package/dist/components/DatePicker.d.ts +17 -0
- package/dist/components/DatePicker.d.ts.map +1 -0
- package/dist/components/DatePicker.js +248 -0
- package/dist/components/DatePicker.js.map +1 -0
- package/dist/components/DateRangePicker.d.ts +21 -0
- package/dist/components/DateRangePicker.d.ts.map +1 -0
- package/dist/components/DateRangePicker.js +213 -0
- package/dist/components/DateRangePicker.js.map +1 -0
- package/dist/components/DefinitionList.d.ts +21 -0
- package/dist/components/DefinitionList.d.ts.map +1 -0
- package/dist/components/DefinitionList.js +44 -0
- package/dist/components/DefinitionList.js.map +1 -0
- package/dist/components/DescriptionBlock.d.ts +36 -0
- package/dist/components/DescriptionBlock.d.ts.map +1 -0
- package/dist/components/DescriptionBlock.js +27 -0
- package/dist/components/DescriptionBlock.js.map +1 -0
- package/dist/components/DeviceList.d.ts +24 -0
- package/dist/components/DeviceList.d.ts.map +1 -0
- package/dist/components/DeviceList.js +46 -0
- package/dist/components/DeviceList.js.map +1 -0
- package/dist/components/DiffViewer.d.ts +13 -0
- package/dist/components/DiffViewer.d.ts.map +1 -0
- package/dist/components/DiffViewer.js +93 -0
- package/dist/components/DiffViewer.js.map +1 -0
- package/dist/components/Divider.d.ts +28 -0
- package/dist/components/Divider.d.ts.map +1 -0
- package/dist/components/Divider.js +16 -0
- package/dist/components/Divider.js.map +1 -0
- package/dist/components/DockBar.d.ts +29 -0
- package/dist/components/DockBar.d.ts.map +1 -0
- package/dist/components/DockBar.js +64 -0
- package/dist/components/DockBar.js.map +1 -0
- package/dist/components/EmptyState.d.ts +25 -0
- package/dist/components/EmptyState.d.ts.map +1 -0
- package/dist/components/EmptyState.js +20 -0
- package/dist/components/EmptyState.js.map +1 -0
- package/dist/components/ErrorBoundary.d.ts +24 -0
- package/dist/components/ErrorBoundary.d.ts.map +1 -0
- package/dist/components/ErrorBoundary.js +55 -0
- package/dist/components/ErrorBoundary.js.map +1 -0
- package/dist/components/FAB.d.ts +15 -0
- package/dist/components/FAB.d.ts.map +1 -0
- package/dist/components/FAB.js +46 -0
- package/dist/components/FAB.js.map +1 -0
- package/dist/components/FABGroup.d.ts +15 -0
- package/dist/components/FABGroup.d.ts.map +1 -0
- package/dist/components/FABGroup.js +47 -0
- package/dist/components/FABGroup.js.map +1 -0
- package/dist/components/FileIntelligencePreview.d.ts +25 -0
- package/dist/components/FileIntelligencePreview.d.ts.map +1 -0
- package/dist/components/FileIntelligencePreview.js +66 -0
- package/dist/components/FileIntelligencePreview.js.map +1 -0
- package/dist/components/FileUpload.d.ts +13 -0
- package/dist/components/FileUpload.d.ts.map +1 -0
- package/dist/components/FileUpload.js +107 -0
- package/dist/components/FileUpload.js.map +1 -0
- package/dist/components/FilterBar.d.ts +35 -0
- package/dist/components/FilterBar.d.ts.map +1 -0
- package/dist/components/FilterBar.js +79 -0
- package/dist/components/FilterBar.js.map +1 -0
- package/dist/components/FloatingToolbar.d.ts +24 -0
- package/dist/components/FloatingToolbar.d.ts.map +1 -0
- package/dist/components/FloatingToolbar.js +180 -0
- package/dist/components/FloatingToolbar.js.map +1 -0
- package/dist/components/Footer.d.ts +32 -0
- package/dist/components/Footer.d.ts.map +1 -0
- package/dist/components/Footer.js +31 -0
- package/dist/components/Footer.js.map +1 -0
- package/dist/components/Gallery.d.ts +11 -0
- package/dist/components/Gallery.d.ts.map +1 -0
- package/dist/components/Gallery.js +32 -0
- package/dist/components/Gallery.js.map +1 -0
- package/dist/components/GestureCard.d.ts +12 -0
- package/dist/components/GestureCard.d.ts.map +1 -0
- package/dist/components/GestureCard.js +58 -0
- package/dist/components/GestureCard.js.map +1 -0
- package/dist/components/GridSystem.d.ts +72 -0
- package/dist/components/GridSystem.d.ts.map +1 -0
- package/dist/components/GridSystem.js +65 -0
- package/dist/components/GridSystem.js.map +1 -0
- package/dist/components/HamburgerMenuIcon.d.ts +24 -0
- package/dist/components/HamburgerMenuIcon.d.ts.map +1 -0
- package/dist/components/HamburgerMenuIcon.js +44 -0
- package/dist/components/HamburgerMenuIcon.js.map +1 -0
- package/dist/components/HapticButton.d.ts +23 -0
- package/dist/components/HapticButton.d.ts.map +1 -0
- package/dist/components/HapticButton.js +104 -0
- package/dist/components/HapticButton.js.map +1 -0
- package/dist/components/Heading.d.ts +6 -0
- package/dist/components/Heading.d.ts.map +1 -0
- package/dist/components/Heading.js +7 -0
- package/dist/components/Heading.js.map +1 -0
- package/dist/components/IconButton.d.ts +14 -0
- package/dist/components/IconButton.d.ts.map +1 -0
- package/dist/components/IconButton.js +39 -0
- package/dist/components/IconButton.js.map +1 -0
- package/dist/components/ImageCarousel.d.ts +18 -0
- package/dist/components/ImageCarousel.d.ts.map +1 -0
- package/dist/components/ImageCarousel.js +74 -0
- package/dist/components/ImageCarousel.js.map +1 -0
- package/dist/components/ImageCropper.d.ts +10 -0
- package/dist/components/ImageCropper.d.ts.map +1 -0
- package/dist/components/ImageCropper.js +138 -0
- package/dist/components/ImageCropper.js.map +1 -0
- package/dist/components/Input.d.ts +18 -0
- package/dist/components/Input.d.ts.map +1 -0
- package/dist/components/Input.js +117 -0
- package/dist/components/Input.js.map +1 -0
- package/dist/components/InspectorPanel.d.ts +18 -0
- package/dist/components/InspectorPanel.d.ts.map +1 -0
- package/dist/components/InspectorPanel.js +33 -0
- package/dist/components/InspectorPanel.js.map +1 -0
- package/dist/components/InvoicePreview.d.ts +41 -0
- package/dist/components/InvoicePreview.d.ts.map +1 -0
- package/dist/components/InvoicePreview.js +106 -0
- package/dist/components/InvoicePreview.js.map +1 -0
- package/dist/components/JsonViewer.d.ts +17 -0
- package/dist/components/JsonViewer.d.ts.map +1 -0
- package/dist/components/JsonViewer.js +58 -0
- package/dist/components/JsonViewer.js.map +1 -0
- package/dist/components/KPIBlock.d.ts +23 -0
- package/dist/components/KPIBlock.d.ts.map +1 -0
- package/dist/components/KPIBlock.js +82 -0
- package/dist/components/KPIBlock.js.map +1 -0
- package/dist/components/KanbanBoard.d.ts +34 -0
- package/dist/components/KanbanBoard.d.ts.map +1 -0
- package/dist/components/KanbanBoard.js +296 -0
- package/dist/components/KanbanBoard.js.map +1 -0
- package/dist/components/KeyValueInfo.d.ts +28 -0
- package/dist/components/KeyValueInfo.d.ts.map +1 -0
- package/dist/components/KeyValueInfo.js +80 -0
- package/dist/components/KeyValueInfo.js.map +1 -0
- package/dist/components/Label.d.ts +8 -0
- package/dist/components/Label.d.ts.map +1 -0
- package/dist/components/Label.js +9 -0
- package/dist/components/Label.js.map +1 -0
- package/dist/components/Layout.d.ts +16 -0
- package/dist/components/Layout.d.ts.map +1 -0
- package/dist/components/Layout.js +26 -0
- package/dist/components/Layout.js.map +1 -0
- package/dist/components/Lightbox.d.ts +18 -0
- package/dist/components/Lightbox.d.ts.map +1 -0
- package/dist/components/Lightbox.js +60 -0
- package/dist/components/Lightbox.js.map +1 -0
- package/dist/components/LoadingOverlay.d.ts +32 -0
- package/dist/components/LoadingOverlay.d.ts.map +1 -0
- package/dist/components/LoadingOverlay.js +10 -0
- package/dist/components/LoadingOverlay.js.map +1 -0
- package/dist/components/LoginForm.d.ts +14 -0
- package/dist/components/LoginForm.d.ts.map +1 -0
- package/dist/components/LoginForm.js +36 -0
- package/dist/components/LoginForm.js.map +1 -0
- package/dist/components/MaintenanceMode.d.ts +41 -0
- package/dist/components/MaintenanceMode.d.ts.map +1 -0
- package/dist/components/MaintenanceMode.js +21 -0
- package/dist/components/MaintenanceMode.js.map +1 -0
- package/dist/components/MarkdownEditor.d.ts +14 -0
- package/dist/components/MarkdownEditor.d.ts.map +1 -0
- package/dist/components/MarkdownEditor.js +55 -0
- package/dist/components/MarkdownEditor.js.map +1 -0
- package/dist/components/MasonryLayout.d.ts +31 -0
- package/dist/components/MasonryLayout.d.ts.map +1 -0
- package/dist/components/MasonryLayout.js +17 -0
- package/dist/components/MasonryLayout.js.map +1 -0
- package/dist/components/MenuBar.d.ts +34 -0
- package/dist/components/MenuBar.d.ts.map +1 -0
- package/dist/components/MenuBar.js +66 -0
- package/dist/components/MenuBar.js.map +1 -0
- package/dist/components/MessageReactions.d.ts +22 -0
- package/dist/components/MessageReactions.d.ts.map +1 -0
- package/dist/components/MessageReactions.js +37 -0
- package/dist/components/MessageReactions.js.map +1 -0
- package/dist/components/Modal.d.ts +37 -0
- package/dist/components/Modal.d.ts.map +1 -0
- package/dist/components/Modal.js +93 -0
- package/dist/components/Modal.js.map +1 -0
- package/dist/components/ModalStackManager.d.ts +34 -0
- package/dist/components/ModalStackManager.d.ts.map +1 -0
- package/dist/components/ModalStackManager.js +52 -0
- package/dist/components/ModalStackManager.js.map +1 -0
- package/dist/components/MultiFileUpload.d.ts +15 -0
- package/dist/components/MultiFileUpload.d.ts.map +1 -0
- package/dist/components/MultiFileUpload.js +138 -0
- package/dist/components/MultiFileUpload.js.map +1 -0
- package/dist/components/NavBar.d.ts +30 -0
- package/dist/components/NavBar.d.ts.map +1 -0
- package/dist/components/NavBar.js +80 -0
- package/dist/components/NavBar.js.map +1 -0
- package/dist/components/NavigationDrawer.d.ts +48 -0
- package/dist/components/NavigationDrawer.d.ts.map +1 -0
- package/dist/components/NavigationDrawer.js +95 -0
- package/dist/components/NavigationDrawer.js.map +1 -0
- package/dist/components/NotificationCenterPanel.d.ts +25 -0
- package/dist/components/NotificationCenterPanel.d.ts.map +1 -0
- package/dist/components/NotificationCenterPanel.js +50 -0
- package/dist/components/NotificationCenterPanel.js.map +1 -0
- package/dist/components/OTPInput.d.ts +15 -0
- package/dist/components/OTPInput.d.ts.map +1 -0
- package/dist/components/OTPInput.js +144 -0
- package/dist/components/OTPInput.js.map +1 -0
- package/dist/components/OfflineState.d.ts +36 -0
- package/dist/components/OfflineState.d.ts.map +1 -0
- package/dist/components/OfflineState.js +21 -0
- package/dist/components/OfflineState.js.map +1 -0
- package/dist/components/OrderSummary.d.ts +19 -0
- package/dist/components/OrderSummary.d.ts.map +1 -0
- package/dist/components/OrderSummary.js +8 -0
- package/dist/components/OrderSummary.js.map +1 -0
- package/dist/components/Pagination.d.ts +28 -0
- package/dist/components/Pagination.d.ts.map +1 -0
- package/dist/components/Pagination.js +119 -0
- package/dist/components/Pagination.js.map +1 -0
- package/dist/components/Panel.d.ts +14 -0
- package/dist/components/Panel.d.ts.map +1 -0
- package/dist/components/Panel.js +27 -0
- package/dist/components/Panel.js.map +1 -0
- package/dist/components/Paragraph.d.ts +6 -0
- package/dist/components/Paragraph.d.ts.map +1 -0
- package/dist/components/Paragraph.js +7 -0
- package/dist/components/Paragraph.js.map +1 -0
- package/dist/components/PasswordInput.d.ts +16 -0
- package/dist/components/PasswordInput.d.ts.map +1 -0
- package/dist/components/PasswordInput.js +66 -0
- package/dist/components/PasswordInput.js.map +1 -0
- package/dist/components/PaymentMethodSelector.d.ts +22 -0
- package/dist/components/PaymentMethodSelector.d.ts.map +1 -0
- package/dist/components/PaymentMethodSelector.js +24 -0
- package/dist/components/PaymentMethodSelector.js.map +1 -0
- package/dist/components/PermissionsMatrix.d.ts +23 -0
- package/dist/components/PermissionsMatrix.d.ts.map +1 -0
- package/dist/components/PermissionsMatrix.js +52 -0
- package/dist/components/PermissionsMatrix.js.map +1 -0
- package/dist/components/Popover.d.ts +19 -0
- package/dist/components/Popover.d.ts.map +1 -0
- package/dist/components/Popover.js +159 -0
- package/dist/components/Popover.js.map +1 -0
- package/dist/components/PriceDisplay.d.ts +18 -0
- package/dist/components/PriceDisplay.d.ts.map +1 -0
- package/dist/components/PriceDisplay.js +37 -0
- package/dist/components/PriceDisplay.js.map +1 -0
- package/dist/components/ProductCard.d.ts +30 -0
- package/dist/components/ProductCard.d.ts.map +1 -0
- package/dist/components/ProductCard.js +73 -0
- package/dist/components/ProductCard.js.map +1 -0
- package/dist/components/Progress.d.ts +9 -0
- package/dist/components/Progress.d.ts.map +1 -0
- package/dist/components/Progress.js +13 -0
- package/dist/components/Progress.js.map +1 -0
- package/dist/components/PromptSuggestionChips.d.ts +15 -0
- package/dist/components/PromptSuggestionChips.d.ts.map +1 -0
- package/dist/components/PromptSuggestionChips.js +17 -0
- package/dist/components/PromptSuggestionChips.js.map +1 -0
- package/dist/components/PropertyList.d.ts +29 -0
- package/dist/components/PropertyList.d.ts.map +1 -0
- package/dist/components/PropertyList.js +90 -0
- package/dist/components/PropertyList.js.map +1 -0
- package/dist/components/QRCodeGenerator.d.ts +17 -0
- package/dist/components/QRCodeGenerator.d.ts.map +1 -0
- package/dist/components/QRCodeGenerator.js +56 -0
- package/dist/components/QRCodeGenerator.js.map +1 -0
- package/dist/components/QuantitySelector.d.ts +16 -0
- package/dist/components/QuantitySelector.d.ts.map +1 -0
- package/dist/components/QuantitySelector.js +55 -0
- package/dist/components/QuantitySelector.js.map +1 -0
- package/dist/components/QueryBuilder.d.ts +30 -0
- package/dist/components/QueryBuilder.d.ts.map +1 -0
- package/dist/components/QueryBuilder.js +227 -0
- package/dist/components/QueryBuilder.js.map +1 -0
- package/dist/components/RadioGroup.d.ts +16 -0
- package/dist/components/RadioGroup.d.ts.map +1 -0
- package/dist/components/RadioGroup.js +36 -0
- package/dist/components/RadioGroup.js.map +1 -0
- package/dist/components/RangeSlider.d.ts +18 -0
- package/dist/components/RangeSlider.d.ts.map +1 -0
- package/dist/components/RangeSlider.js +121 -0
- package/dist/components/RangeSlider.js.map +1 -0
- package/dist/components/RatingInput.d.ts +15 -0
- package/dist/components/RatingInput.d.ts.map +1 -0
- package/dist/components/RatingInput.js +44 -0
- package/dist/components/RatingInput.js.map +1 -0
- package/dist/components/RecoveryCodeDisplay.d.ts +12 -0
- package/dist/components/RecoveryCodeDisplay.d.ts.map +1 -0
- package/dist/components/RecoveryCodeDisplay.js +48 -0
- package/dist/components/RecoveryCodeDisplay.js.map +1 -0
- package/dist/components/ResizablePanel.d.ts +18 -0
- package/dist/components/ResizablePanel.d.ts.map +1 -0
- package/dist/components/ResizablePanel.js +64 -0
- package/dist/components/ResizablePanel.js.map +1 -0
- package/dist/components/Reviews.d.ts +26 -0
- package/dist/components/Reviews.d.ts.map +1 -0
- package/dist/components/Reviews.js +30 -0
- package/dist/components/Reviews.js.map +1 -0
- package/dist/components/RichTextEditor.d.ts +14 -0
- package/dist/components/RichTextEditor.d.ts.map +1 -0
- package/dist/components/RichTextEditor.js +38 -0
- package/dist/components/RichTextEditor.js.map +1 -0
- package/dist/components/RotarySelector.d.ts +20 -0
- package/dist/components/RotarySelector.d.ts.map +1 -0
- package/dist/components/RotarySelector.js +99 -0
- package/dist/components/RotarySelector.js.map +1 -0
- package/dist/components/SchedulerTimeline.d.ts +31 -0
- package/dist/components/SchedulerTimeline.d.ts.map +1 -0
- package/dist/components/SchedulerTimeline.js +210 -0
- package/dist/components/SchedulerTimeline.js.map +1 -0
- package/dist/components/ScrollArea.d.ts +11 -0
- package/dist/components/ScrollArea.d.ts.map +1 -0
- package/dist/components/ScrollArea.js +132 -0
- package/dist/components/ScrollArea.js.map +1 -0
- package/dist/components/SearchInput.d.ts +13 -0
- package/dist/components/SearchInput.d.ts.map +1 -0
- package/dist/components/SearchInput.js +34 -0
- package/dist/components/SearchInput.js.map +1 -0
- package/dist/components/SectionHeader.d.ts +27 -0
- package/dist/components/SectionHeader.d.ts.map +1 -0
- package/dist/components/SectionHeader.js +18 -0
- package/dist/components/SectionHeader.js.map +1 -0
- package/dist/components/SecurityActivityLog.d.ts +20 -0
- package/dist/components/SecurityActivityLog.d.ts.map +1 -0
- package/dist/components/SecurityActivityLog.js +56 -0
- package/dist/components/SecurityActivityLog.js.map +1 -0
- package/dist/components/SegmentedInput.d.ts +15 -0
- package/dist/components/SegmentedInput.d.ts.map +1 -0
- package/dist/components/SegmentedInput.js +134 -0
- package/dist/components/SegmentedInput.js.map +1 -0
- package/dist/components/Select.d.ts +57 -0
- package/dist/components/Select.d.ts.map +1 -0
- package/dist/components/Select.js +275 -0
- package/dist/components/Select.js.map +1 -0
- package/dist/components/Sheet.d.ts +35 -0
- package/dist/components/Sheet.d.ts.map +1 -0
- package/dist/components/Sheet.js +117 -0
- package/dist/components/Sheet.js.map +1 -0
- package/dist/components/Sidebar.d.ts +23 -0
- package/dist/components/Sidebar.d.ts.map +1 -0
- package/dist/components/Sidebar.js +21 -0
- package/dist/components/Sidebar.js.map +1 -0
- package/dist/components/SignaturePad.d.ts +19 -0
- package/dist/components/SignaturePad.d.ts.map +1 -0
- package/dist/components/SignaturePad.js +133 -0
- package/dist/components/SignaturePad.js.map +1 -0
- package/dist/components/SignupForm.d.ts +15 -0
- package/dist/components/SignupForm.d.ts.map +1 -0
- package/dist/components/SignupForm.js +50 -0
- package/dist/components/SignupForm.js.map +1 -0
- package/dist/components/Skeleton.d.ts +3 -0
- package/dist/components/Skeleton.d.ts.map +1 -0
- package/dist/components/Skeleton.js +13 -0
- package/dist/components/Skeleton.js.map +1 -0
- package/dist/components/SlideToDelete.d.ts +26 -0
- package/dist/components/SlideToDelete.d.ts.map +1 -0
- package/dist/components/SlideToDelete.js +88 -0
- package/dist/components/SlideToDelete.js.map +1 -0
- package/dist/components/Slider.d.ts +18 -0
- package/dist/components/Slider.d.ts.map +1 -0
- package/dist/components/Slider.js +99 -0
- package/dist/components/Slider.js.map +1 -0
- package/dist/components/Snackbar.d.ts +16 -0
- package/dist/components/Snackbar.d.ts.map +1 -0
- package/dist/components/Snackbar.js +39 -0
- package/dist/components/Snackbar.js.map +1 -0
- package/dist/components/Spacer.d.ts +21 -0
- package/dist/components/Spacer.d.ts.map +1 -0
- package/dist/components/Spacer.js +44 -0
- package/dist/components/Spacer.js.map +1 -0
- package/dist/components/Sparkline.d.ts +17 -0
- package/dist/components/Sparkline.d.ts.map +1 -0
- package/dist/components/Sparkline.js +41 -0
- package/dist/components/Sparkline.js.map +1 -0
- package/dist/components/Spinner.d.ts +8 -0
- package/dist/components/Spinner.d.ts.map +1 -0
- package/dist/components/Spinner.js +26 -0
- package/dist/components/Spinner.js.map +1 -0
- package/dist/components/SplitButton.d.ts +20 -0
- package/dist/components/SplitButton.d.ts.map +1 -0
- package/dist/components/SplitButton.js +48 -0
- package/dist/components/SplitButton.js.map +1 -0
- package/dist/components/SplitView.d.ts +40 -0
- package/dist/components/SplitView.d.ts.map +1 -0
- package/dist/components/SplitView.js +14 -0
- package/dist/components/SplitView.js.map +1 -0
- package/dist/components/StatisticDisplay.d.ts +48 -0
- package/dist/components/StatisticDisplay.d.ts.map +1 -0
- package/dist/components/StatisticDisplay.js +141 -0
- package/dist/components/StatisticDisplay.js.map +1 -0
- package/dist/components/Stepper.d.ts +24 -0
- package/dist/components/Stepper.d.ts.map +1 -0
- package/dist/components/Stepper.js +99 -0
- package/dist/components/Stepper.js.map +1 -0
- package/dist/components/StickyContainer.d.ts +32 -0
- package/dist/components/StickyContainer.d.ts.map +1 -0
- package/dist/components/StickyContainer.js +17 -0
- package/dist/components/StickyContainer.js.map +1 -0
- package/dist/components/Switch.d.ts +12 -0
- package/dist/components/Switch.d.ts.map +1 -0
- package/dist/components/Switch.js +46 -0
- package/dist/components/Switch.js.map +1 -0
- package/dist/components/Table.d.ts +22 -0
- package/dist/components/Table.d.ts.map +1 -0
- package/dist/components/Table.js +72 -0
- package/dist/components/Table.js.map +1 -0
- package/dist/components/Tabs.d.ts +29 -0
- package/dist/components/Tabs.d.ts.map +1 -0
- package/dist/components/Tabs.js +63 -0
- package/dist/components/Tabs.js.map +1 -0
- package/dist/components/Tag.d.ts +14 -0
- package/dist/components/Tag.d.ts.map +1 -0
- package/dist/components/Tag.js +44 -0
- package/dist/components/Tag.js.map +1 -0
- package/dist/components/TagsInput.d.ts +15 -0
- package/dist/components/TagsInput.d.ts.map +1 -0
- package/dist/components/TagsInput.js +54 -0
- package/dist/components/TagsInput.js.map +1 -0
- package/dist/components/Text.d.ts +21 -0
- package/dist/components/Text.d.ts.map +1 -0
- package/dist/components/Text.js +47 -0
- package/dist/components/Text.js.map +1 -0
- package/dist/components/Textarea.d.ts +6 -0
- package/dist/components/Textarea.d.ts.map +1 -0
- package/dist/components/Textarea.js +10 -0
- package/dist/components/Textarea.js.map +1 -0
- package/dist/components/ThemeToggle.d.ts +22 -0
- package/dist/components/ThemeToggle.d.ts.map +1 -0
- package/dist/components/ThemeToggle.js +81 -0
- package/dist/components/ThemeToggle.js.map +1 -0
- package/dist/components/TimePicker.d.ts +15 -0
- package/dist/components/TimePicker.d.ts.map +1 -0
- package/dist/components/TimePicker.js +148 -0
- package/dist/components/TimePicker.js.map +1 -0
- package/dist/components/Timeline.d.ts +21 -0
- package/dist/components/Timeline.d.ts.map +1 -0
- package/dist/components/Timeline.js +63 -0
- package/dist/components/Timeline.js.map +1 -0
- package/dist/components/Title.d.ts +17 -0
- package/dist/components/Title.d.ts.map +1 -0
- package/dist/components/Title.js +46 -0
- package/dist/components/Title.js.map +1 -0
- package/dist/components/Toast.d.ts +25 -0
- package/dist/components/Toast.d.ts.map +1 -0
- package/dist/components/Toast.js +96 -0
- package/dist/components/Toast.js.map +1 -0
- package/dist/components/Tooltip.d.ts +13 -0
- package/dist/components/Tooltip.d.ts.map +1 -0
- package/dist/components/Tooltip.js +20 -0
- package/dist/components/Tooltip.js.map +1 -0
- package/dist/components/TopActionBar.d.ts +60 -0
- package/dist/components/TopActionBar.d.ts.map +1 -0
- package/dist/components/TopActionBar.js +69 -0
- package/dist/components/TopActionBar.js.map +1 -0
- package/dist/components/TreeView.d.ts +29 -0
- package/dist/components/TreeView.d.ts.map +1 -0
- package/dist/components/TreeView.js +97 -0
- package/dist/components/TreeView.js.map +1 -0
- package/dist/components/TwoFactorAuth.d.ts +12 -0
- package/dist/components/TwoFactorAuth.d.ts.map +1 -0
- package/dist/components/TwoFactorAuth.js +48 -0
- package/dist/components/TwoFactorAuth.js.map +1 -0
- package/dist/components/VideoPlayer.d.ts +11 -0
- package/dist/components/VideoPlayer.d.ts.map +1 -0
- package/dist/components/VideoPlayer.js +132 -0
- package/dist/components/VideoPlayer.js.map +1 -0
- package/dist/components/VoiceRecorder.d.ts +11 -0
- package/dist/components/VoiceRecorder.d.ts.map +1 -0
- package/dist/components/VoiceRecorder.js +145 -0
- package/dist/components/VoiceRecorder.js.map +1 -0
- package/dist/components/WindowControls.d.ts +10 -0
- package/dist/components/WindowControls.d.ts.map +1 -0
- package/dist/components/WindowControls.js +18 -0
- package/dist/components/WindowControls.js.map +1 -0
- package/dist/components/WindowFrame.d.ts +11 -0
- package/dist/components/WindowFrame.d.ts.map +1 -0
- package/dist/components/WindowFrame.js +26 -0
- package/dist/components/WindowFrame.js.map +1 -0
- package/dist/globals.css +316 -0
- package/dist/index.d.ts +249 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +144 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/utils.d.ts +3 -0
- package/dist/lib/utils.d.ts.map +1 -0
- package/dist/lib/utils.js +6 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/scripts/build-registry.d.ts +2 -0
- package/dist/scripts/build-registry.d.ts.map +1 -0
- package/dist/scripts/build-registry.js +58 -0
- package/dist/scripts/build-registry.js.map +1 -0
- package/dist/tokens.d.ts +281 -0
- package/dist/tokens.d.ts.map +1 -0
- package/dist/tokens.js +265 -0
- package/dist/tokens.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/package.json +118 -0
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useRef, useEffect } from 'react';
|
|
3
|
+
import { motion, AnimatePresence } from 'framer-motion';
|
|
4
|
+
/* ========================================
|
|
5
|
+
UTILITY FUNCTIONS
|
|
6
|
+
======================================== */
|
|
7
|
+
const formatDate = (date, format = 'medium') => {
|
|
8
|
+
const optionsMap = {
|
|
9
|
+
short: { month: 'numeric', day: 'numeric', year: 'numeric' },
|
|
10
|
+
medium: { month: 'short', day: 'numeric', year: 'numeric' },
|
|
11
|
+
long: { month: 'long', day: 'numeric', year: 'numeric' },
|
|
12
|
+
};
|
|
13
|
+
return new Intl.DateTimeFormat('en-US', optionsMap[format]).format(date);
|
|
14
|
+
};
|
|
15
|
+
const isSameDay = (date1, date2) => {
|
|
16
|
+
return (date1.getFullYear() === date2.getFullYear() &&
|
|
17
|
+
date1.getMonth() === date2.getMonth() &&
|
|
18
|
+
date1.getDate() === date2.getDate());
|
|
19
|
+
};
|
|
20
|
+
const getDaysInMonth = (year, month) => {
|
|
21
|
+
return new Date(year, month + 1, 0).getDate();
|
|
22
|
+
};
|
|
23
|
+
const getFirstDayOfMonth = (year, month) => {
|
|
24
|
+
return new Date(year, month, 1).getDay();
|
|
25
|
+
};
|
|
26
|
+
const isDateDisabled = (date, minDate, maxDate) => {
|
|
27
|
+
if (minDate && date < minDate)
|
|
28
|
+
return true;
|
|
29
|
+
if (maxDate && date > maxDate)
|
|
30
|
+
return true;
|
|
31
|
+
return false;
|
|
32
|
+
};
|
|
33
|
+
/* ========================================
|
|
34
|
+
STYLES
|
|
35
|
+
======================================== */
|
|
36
|
+
const baseInputStyles = `
|
|
37
|
+
w-full
|
|
38
|
+
bg-surface-primary
|
|
39
|
+
border border-border-primary
|
|
40
|
+
text-text-primary
|
|
41
|
+
placeholder:text-text-tertiary
|
|
42
|
+
transition-apple
|
|
43
|
+
focus:outline-none
|
|
44
|
+
focus:border-accent-blue
|
|
45
|
+
focus:ring-2
|
|
46
|
+
focus:ring-accent-blue/20
|
|
47
|
+
disabled:opacity-40
|
|
48
|
+
disabled:cursor-not-allowed
|
|
49
|
+
cursor-pointer
|
|
50
|
+
`;
|
|
51
|
+
const sizeStyles = {
|
|
52
|
+
sm: 'h-8 px-3 text-sm rounded-lg',
|
|
53
|
+
md: 'h-10 px-4 text-base rounded-xl',
|
|
54
|
+
lg: 'h-12 px-5 text-lg rounded-xl',
|
|
55
|
+
};
|
|
56
|
+
const Calendar = ({ range, onSelectDate, minDate, maxDate, currentMonth, onMonthChange, }) => {
|
|
57
|
+
const [hoveredDate, setHoveredDate] = useState(null);
|
|
58
|
+
const year = currentMonth.getFullYear();
|
|
59
|
+
const month = currentMonth.getMonth();
|
|
60
|
+
const daysInMonth = getDaysInMonth(year, month);
|
|
61
|
+
const firstDay = getFirstDayOfMonth(year, month);
|
|
62
|
+
const today = new Date();
|
|
63
|
+
const days = Array.from({ length: daysInMonth }, (_, i) => i + 1);
|
|
64
|
+
const emptyDays = Array.from({ length: firstDay }, (_, i) => i);
|
|
65
|
+
const monthNames = [
|
|
66
|
+
'January', 'February', 'March', 'April', 'May', 'June',
|
|
67
|
+
'July', 'August', 'September', 'October', 'November', 'December'
|
|
68
|
+
];
|
|
69
|
+
const handlePrevMonth = () => {
|
|
70
|
+
const newDate = new Date(year, month - 1, 1);
|
|
71
|
+
onMonthChange(newDate);
|
|
72
|
+
};
|
|
73
|
+
const handleNextMonth = () => {
|
|
74
|
+
const newDate = new Date(year, month + 1, 1);
|
|
75
|
+
onMonthChange(newDate);
|
|
76
|
+
};
|
|
77
|
+
const handleDayClick = (day) => {
|
|
78
|
+
const date = new Date(year, month, day);
|
|
79
|
+
if (!isDateDisabled(date, minDate, maxDate)) {
|
|
80
|
+
onSelectDate(date);
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
const isDateInRange = (date) => {
|
|
84
|
+
if (range.from && range.to) {
|
|
85
|
+
return date >= range.from && date <= range.to;
|
|
86
|
+
}
|
|
87
|
+
if (range.from && hoveredDate) {
|
|
88
|
+
return (date >= range.from && date <= hoveredDate) || (date <= range.from && date >= hoveredDate);
|
|
89
|
+
}
|
|
90
|
+
return false;
|
|
91
|
+
};
|
|
92
|
+
return (_jsx(motion.div, { initial: { opacity: 0, y: -8, scale: 0.96 }, animate: { opacity: 1, y: 0, scale: 1 }, exit: { opacity: 0, y: -8, scale: 0.96 }, transition: {
|
|
93
|
+
type: 'spring',
|
|
94
|
+
stiffness: 400,
|
|
95
|
+
damping: 30,
|
|
96
|
+
}, className: "absolute top-full left-0 mt-2 z-[1300] w-full min-w-[300px] max-w-[340px]", children: _jsxs("div", { className: "bg-surface-primary border border-border-primary rounded-2xl shadow-lg p-4 backdrop-blur-xl", children: [_jsxs("div", { className: "flex items-center justify-between mb-4", children: [_jsx(motion.button, { whileHover: { scale: 1.05 }, whileTap: { scale: 0.95 }, onClick: handlePrevMonth, className: "p-2 rounded-lg hover:bg-surface-secondary transition-apple", type: "button", children: _jsx("svg", { className: "w-5 h-5 text-text-primary", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M15 19l-7-7 7-7" }) }) }), _jsxs("h3", { className: "text-base font-semibold text-text-primary", children: [monthNames[month], " ", year] }), _jsx(motion.button, { whileHover: { scale: 1.05 }, whileTap: { scale: 0.95 }, onClick: handleNextMonth, className: "p-2 rounded-lg hover:bg-surface-secondary transition-apple", type: "button", children: _jsx("svg", { className: "w-5 h-5 text-text-primary", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M9 5l7 7-7 7" }) }) })] }), _jsx("div", { className: "grid grid-cols-7 gap-1 mb-2", children: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'].map((day) => (_jsx("div", { className: "text-center text-xs font-medium text-text-tertiary py-2", children: day }, day))) }), _jsxs("div", { className: "grid grid-cols-7 gap-1", onMouseLeave: () => setHoveredDate(null), children: [emptyDays.map((_, index) => (_jsx("div", { className: "aspect-square" }, `empty-${index}`))), days.map((day) => {
|
|
97
|
+
const date = new Date(year, month, day);
|
|
98
|
+
const isSelectedStart = range.from && isSameDay(date, range.from);
|
|
99
|
+
const isSelectedEnd = range.to && isSameDay(date, range.to);
|
|
100
|
+
const isSelected = isSelectedStart || isSelectedEnd;
|
|
101
|
+
const isInRange = isDateInRange(date);
|
|
102
|
+
const isToday = isSameDay(date, today);
|
|
103
|
+
const isDisabled = isDateDisabled(date, minDate, maxDate);
|
|
104
|
+
let roundedClass = 'rounded-lg';
|
|
105
|
+
if (isInRange) {
|
|
106
|
+
if (isSelectedStart && isSelectedEnd)
|
|
107
|
+
roundedClass = 'rounded-lg';
|
|
108
|
+
else if (isSelectedStart)
|
|
109
|
+
roundedClass = 'rounded-l-lg rounded-r-none';
|
|
110
|
+
else if (isSelectedEnd)
|
|
111
|
+
roundedClass = 'rounded-r-lg rounded-l-none';
|
|
112
|
+
else
|
|
113
|
+
roundedClass = 'rounded-none';
|
|
114
|
+
}
|
|
115
|
+
return (_jsx(motion.button, { whileHover: !isDisabled ? { scale: 1.05, zIndex: 10 } : {}, whileTap: !isDisabled ? { scale: 0.95 } : {}, onClick: () => handleDayClick(day), onMouseEnter: () => setHoveredDate(date), disabled: isDisabled, className: `
|
|
116
|
+
aspect-square text-sm font-medium relative
|
|
117
|
+
transition-colors duration-200
|
|
118
|
+
${roundedClass}
|
|
119
|
+
${isSelected
|
|
120
|
+
? 'bg-accent-blue text-white z-10'
|
|
121
|
+
: isInRange
|
|
122
|
+
? 'bg-accent-blue/10 text-text-primary'
|
|
123
|
+
: isToday
|
|
124
|
+
? 'bg-accent-blue/5 text-accent-blue border border-accent-blue/20'
|
|
125
|
+
: 'text-text-primary hover:bg-surface-secondary'}
|
|
126
|
+
${isDisabled ? 'opacity-30 cursor-not-allowed' : 'cursor-pointer'}
|
|
127
|
+
`, type: "button", children: day }, day));
|
|
128
|
+
})] })] }) }));
|
|
129
|
+
};
|
|
130
|
+
/* ========================================
|
|
131
|
+
DATE RANGE PICKER COMPONENT
|
|
132
|
+
======================================== */
|
|
133
|
+
export const DateRangePicker = ({ label, value, onChange, placeholder = 'Select date range', error, helperText, disabled = false, minDate, maxDate, dateFormat = 'medium', size = 'md', className = '', }) => {
|
|
134
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
135
|
+
const [range, setRange] = useState(value || { from: null, to: null });
|
|
136
|
+
const [currentMonth, setCurrentMonth] = useState(value?.from || new Date());
|
|
137
|
+
const containerRef = useRef(null);
|
|
138
|
+
const hasError = !!error;
|
|
139
|
+
// Sync state with props
|
|
140
|
+
useEffect(() => {
|
|
141
|
+
if (value) {
|
|
142
|
+
setRange(value);
|
|
143
|
+
if (value.from)
|
|
144
|
+
setCurrentMonth(value.from);
|
|
145
|
+
}
|
|
146
|
+
}, [value]);
|
|
147
|
+
useEffect(() => {
|
|
148
|
+
const handleClickOutside = (event) => {
|
|
149
|
+
if (containerRef.current && !containerRef.current.contains(event.target)) {
|
|
150
|
+
setIsOpen(false);
|
|
151
|
+
}
|
|
152
|
+
};
|
|
153
|
+
if (isOpen) {
|
|
154
|
+
document.addEventListener('mousedown', handleClickOutside);
|
|
155
|
+
}
|
|
156
|
+
return () => {
|
|
157
|
+
document.removeEventListener('mousedown', handleClickOutside);
|
|
158
|
+
};
|
|
159
|
+
}, [isOpen]);
|
|
160
|
+
const handleSelectDate = (date) => {
|
|
161
|
+
let newRange = { ...range };
|
|
162
|
+
if (!range.from || (range.from && range.to)) {
|
|
163
|
+
// Start new range
|
|
164
|
+
newRange = { from: date, to: null };
|
|
165
|
+
}
|
|
166
|
+
else {
|
|
167
|
+
// Complete range
|
|
168
|
+
if (date < range.from) {
|
|
169
|
+
newRange = { from: date, to: range.from };
|
|
170
|
+
}
|
|
171
|
+
else {
|
|
172
|
+
newRange = { from: range.from, to: date };
|
|
173
|
+
}
|
|
174
|
+
setIsOpen(false); // Close on second selection
|
|
175
|
+
}
|
|
176
|
+
setRange(newRange);
|
|
177
|
+
onChange?.(newRange);
|
|
178
|
+
};
|
|
179
|
+
const handleInputClick = () => {
|
|
180
|
+
if (!disabled && !isOpen) {
|
|
181
|
+
setIsOpen(true);
|
|
182
|
+
}
|
|
183
|
+
};
|
|
184
|
+
const handleClear = (e) => {
|
|
185
|
+
e.stopPropagation();
|
|
186
|
+
const newRange = { from: null, to: null };
|
|
187
|
+
setRange(newRange);
|
|
188
|
+
onChange?.(newRange);
|
|
189
|
+
};
|
|
190
|
+
const getDisplayText = () => {
|
|
191
|
+
if (!range.from)
|
|
192
|
+
return '';
|
|
193
|
+
if (!range.to)
|
|
194
|
+
return formatDate(range.from, dateFormat);
|
|
195
|
+
return `${formatDate(range.from, dateFormat)} - ${formatDate(range.to, dateFormat)}`;
|
|
196
|
+
};
|
|
197
|
+
const inputClassName = `
|
|
198
|
+
${baseInputStyles}
|
|
199
|
+
${sizeStyles[size]}
|
|
200
|
+
${hasError ? 'border-status-error focus:border-status-error focus:ring-status-error/20' : ''}
|
|
201
|
+
${className}
|
|
202
|
+
`.trim().replace(/\s+/g, ' ');
|
|
203
|
+
return (_jsxs("div", { className: "w-full", ref: containerRef, children: [label && (_jsx("label", { className: "block text-sm font-medium text-text-primary mb-2", children: label })), _jsxs("div", { className: "relative", children: [_jsx(motion.div, { whileHover: !disabled ? { scale: 1.005 } : {}, transition: {
|
|
204
|
+
type: 'spring',
|
|
205
|
+
stiffness: 300,
|
|
206
|
+
damping: 30,
|
|
207
|
+
}, children: _jsx("input", { type: "text", readOnly: true, value: getDisplayText(), onClick: handleInputClick, placeholder: placeholder, disabled: disabled, className: inputClassName }) }), _jsxs("div", { className: "absolute right-3 top-1/2 -translate-y-1/2 flex items-center gap-1", children: [range.from && !disabled && (_jsx(motion.button, { whileHover: { scale: 1.1 }, whileTap: { scale: 0.9 }, onClick: handleClear, className: "p-1 rounded-md hover:bg-surface-secondary transition-apple", type: "button", children: _jsx("svg", { className: "w-4 h-4 text-text-tertiary", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M6 18L18 6M6 6l12 12" }) }) })), _jsx("svg", { className: "w-5 h-5 text-text-tertiary pointer-events-none", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M8 7V3m8 4V3m-9 8h10M5 21h14a2 2 0 002-2V7a2 2 0 00-2-2H5a2 2 0 00-2 2v12a2 2 0 002 2z" }) })] }), _jsx(AnimatePresence, { children: isOpen && (_jsx(Calendar, { range: range, onSelectDate: handleSelectDate, minDate: minDate, maxDate: maxDate, currentMonth: currentMonth, onMonthChange: setCurrentMonth })) })] }), (error || helperText) && (_jsx(motion.p, { initial: { opacity: 0, y: -4 }, animate: { opacity: 1, y: 0 }, transition: { duration: 0.16 }, className: `
|
|
208
|
+
mt-2 text-sm
|
|
209
|
+
${hasError ? 'text-status-error' : 'text-text-secondary'}
|
|
210
|
+
`, children: error || helperText }))] }));
|
|
211
|
+
};
|
|
212
|
+
DateRangePicker.displayName = 'DateRangePicker';
|
|
213
|
+
//# sourceMappingURL=DateRangePicker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateRangePicker.js","sourceRoot":"","sources":["../../components/DateRangePicker.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export type DefinitionItem = {
|
|
3
|
+
term: React.ReactNode;
|
|
4
|
+
description: React.ReactNode;
|
|
5
|
+
};
|
|
6
|
+
export type DefinitionListVariant = 'default' | 'bordered' | 'striped' | 'compact';
|
|
7
|
+
export type DefinitionListOrientation = 'horizontal' | 'vertical';
|
|
8
|
+
export interface DefinitionListProps extends React.HTMLAttributes<HTMLDListElement> {
|
|
9
|
+
items: DefinitionItem[];
|
|
10
|
+
variant?: DefinitionListVariant;
|
|
11
|
+
orientation?: DefinitionListOrientation;
|
|
12
|
+
divider?: boolean;
|
|
13
|
+
hoverable?: boolean;
|
|
14
|
+
density?: 'comfortable' | 'compact';
|
|
15
|
+
}
|
|
16
|
+
export declare const DefinitionList: React.ForwardRefExoticComponent<DefinitionListProps & React.RefAttributes<HTMLDListElement>>;
|
|
17
|
+
export interface CompactDefinitionListProps extends Omit<DefinitionListProps, 'density' | 'variant'> {
|
|
18
|
+
variant?: Exclude<DefinitionListVariant, 'compact'>;
|
|
19
|
+
}
|
|
20
|
+
export declare const CompactDefinitionList: React.ForwardRefExoticComponent<CompactDefinitionListProps & React.RefAttributes<HTMLDListElement>>;
|
|
21
|
+
//# sourceMappingURL=DefinitionList.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DefinitionList.d.ts","sourceRoot":"","sources":["../../components/DefinitionList.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAC;AAQ1C,MAAM,MAAM,cAAc,GAAG;IACzB,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC;IACtB,WAAW,EAAE,KAAK,CAAC,SAAS,CAAC;CAChC,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAAG,SAAS,GAAG,UAAU,GAAG,SAAS,GAAG,SAAS,CAAC;AACnF,MAAM,MAAM,yBAAyB,GAAG,YAAY,GAAG,UAAU,CAAC;AAElE,MAAM,WAAW,mBAAoB,SAAQ,KAAK,CAAC,cAAc,CAAC,gBAAgB,CAAC;IAC/E,KAAK,EAAE,cAAc,EAAE,CAAC;IACxB,OAAO,CAAC,EAAE,qBAAqB,CAAC;IAChC,WAAW,CAAC,EAAE,yBAAyB,CAAC;IACxC,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,OAAO,CAAC,EAAE,aAAa,GAAG,SAAS,CAAC;CACvC;AAMD,eAAO,MAAM,cAAc,8FAsG1B,CAAC;AAQF,MAAM,WAAW,0BAA2B,SAAQ,IAAI,CAAC,mBAAmB,EAAE,SAAS,GAAG,SAAS,CAAC;IAChG,OAAO,CAAC,EAAE,OAAO,CAAC,qBAAqB,EAAE,SAAS,CAAC,CAAC;CACvD;AAED,eAAO,MAAM,qBAAqB,qGAIjC,CAAC"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef } from 'react';
|
|
3
|
+
import { motion } from 'framer-motion';
|
|
4
|
+
import { cn } from '../lib/utils';
|
|
5
|
+
/* ========================================
|
|
6
|
+
DEFINITION LIST COMPONENT
|
|
7
|
+
======================================== */
|
|
8
|
+
export const DefinitionList = forwardRef(({ items, variant = 'default', orientation = 'horizontal', divider = false, hoverable = false, density = 'comfortable', className, ...props }, ref) => {
|
|
9
|
+
const isHorizontal = orientation === 'horizontal';
|
|
10
|
+
const isCompact = density === 'compact';
|
|
11
|
+
const containerVariants = {
|
|
12
|
+
default: "bg-surface-primary",
|
|
13
|
+
bordered: "bg-surface-primary border border-border-primary rounded-xl",
|
|
14
|
+
striped: "bg-surface-primary",
|
|
15
|
+
compact: "bg-transparent",
|
|
16
|
+
};
|
|
17
|
+
const itemVariants = {
|
|
18
|
+
default: "",
|
|
19
|
+
bordered: "border-b border-border-primary last:border-b-0",
|
|
20
|
+
striped: "even:bg-surface-secondary/50",
|
|
21
|
+
compact: "",
|
|
22
|
+
};
|
|
23
|
+
const paddingClass = isCompact ? "py-2" : "py-3";
|
|
24
|
+
const gapClass = isCompact ? "gap-2" : "gap-4";
|
|
25
|
+
const MotionDL = motion.dl;
|
|
26
|
+
return (_jsx(MotionDL, { ref: ref, className: cn("overflow-hidden", containerVariants[variant], variant === 'bordered' && "shadow-sm", className), initial: { opacity: 0, y: 8 }, animate: { opacity: 1, y: 0 }, transition: {
|
|
27
|
+
duration: 0.22,
|
|
28
|
+
ease: [0.16, 1, 0.3, 1],
|
|
29
|
+
}, ...props, children: items.map((item, index) => (_jsxs(motion.div, { className: cn("group", itemVariants[variant], isHorizontal
|
|
30
|
+
? `flex ${gapClass} ${paddingClass} px-4 sm:px-6`
|
|
31
|
+
: `flex flex-col ${gapClass} ${paddingClass} px-4 sm:px-6`, divider && index !== items.length - 1 && "border-b border-border-primary", hoverable && "transition-colors hover:bg-surface-secondary/30 cursor-default"), initial: { opacity: 0, x: -10 }, animate: { opacity: 1, x: 0 }, transition: {
|
|
32
|
+
duration: 0.2,
|
|
33
|
+
delay: index * 0.03,
|
|
34
|
+
ease: [0.16, 1, 0.3, 1],
|
|
35
|
+
}, children: [_jsx("dt", { className: cn("font-semibold text-text-primary", isHorizontal
|
|
36
|
+
? "min-w-[140px] sm:min-w-[180px] flex-shrink-0"
|
|
37
|
+
: "mb-1", isCompact ? "text-sm" : "text-base"), children: item.term }), _jsx("dd", { className: cn("text-text-secondary", isHorizontal ? "flex-1" : "", isCompact ? "text-sm" : "text-base"), children: item.description })] }, index))) }));
|
|
38
|
+
});
|
|
39
|
+
DefinitionList.displayName = 'DefinitionList';
|
|
40
|
+
export const CompactDefinitionList = forwardRef((props, ref) => {
|
|
41
|
+
return _jsx(DefinitionList, { ref: ref, ...props, density: "compact" });
|
|
42
|
+
});
|
|
43
|
+
CompactDefinitionList.displayName = 'CompactDefinitionList';
|
|
44
|
+
//# sourceMappingURL=DefinitionList.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DefinitionList.js","sourceRoot":"","sources":["../../components/DefinitionList.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export type DescriptionHighlightTrend = 'up' | 'down' | 'neutral';
|
|
3
|
+
export interface DescriptionHighlightProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
4
|
+
label: React.ReactNode;
|
|
5
|
+
value: React.ReactNode;
|
|
6
|
+
change?: React.ReactNode;
|
|
7
|
+
trend?: DescriptionHighlightTrend;
|
|
8
|
+
icon?: React.ReactNode;
|
|
9
|
+
badge?: React.ReactNode;
|
|
10
|
+
helper?: React.ReactNode;
|
|
11
|
+
emphasis?: 'default' | 'soft';
|
|
12
|
+
compact?: boolean;
|
|
13
|
+
}
|
|
14
|
+
export type DescriptionMetadataItem = {
|
|
15
|
+
label: React.ReactNode;
|
|
16
|
+
value: React.ReactNode;
|
|
17
|
+
icon?: React.ReactNode;
|
|
18
|
+
hint?: React.ReactNode;
|
|
19
|
+
};
|
|
20
|
+
export interface DescriptionBlockProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'title'> {
|
|
21
|
+
eyebrow?: React.ReactNode;
|
|
22
|
+
title: React.ReactNode;
|
|
23
|
+
subtitle?: React.ReactNode;
|
|
24
|
+
description?: React.ReactNode;
|
|
25
|
+
badges?: React.ReactNode[];
|
|
26
|
+
metadata?: DescriptionMetadataItem[];
|
|
27
|
+
metadataColumns?: 1 | 2 | 3;
|
|
28
|
+
media?: React.ReactNode;
|
|
29
|
+
actions?: React.ReactNode;
|
|
30
|
+
footer?: React.ReactNode;
|
|
31
|
+
layout?: 'stacked' | 'split';
|
|
32
|
+
variant?: 'default' | 'soft' | 'panel' | 'glass';
|
|
33
|
+
align?: 'start' | 'center';
|
|
34
|
+
}
|
|
35
|
+
export declare const DescriptionBlock: React.ForwardRefExoticComponent<DescriptionBlockProps & React.RefAttributes<HTMLDivElement>>;
|
|
36
|
+
//# sourceMappingURL=DescriptionBlock.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DescriptionBlock.d.ts","sourceRoot":"","sources":["../../components/DescriptionBlock.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAC;AAS1C,MAAM,MAAM,yBAAyB,GAAG,IAAI,GAAG,MAAM,GAAG,SAAS,CAAC;AAElE,MAAM,WAAW,yBAA0B,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IACnF,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,KAAK,CAAC,EAAE,yBAAyB,CAAC;IAClC,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACxB,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,QAAQ,CAAC,EAAE,SAAS,GAAG,MAAM,CAAC;IAC9B,OAAO,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,MAAM,MAAM,uBAAuB,GAAG;IAClC,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC1B,CAAC;AAEF,MAAM,WAAW,qBAAsB,SAAQ,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,OAAO,CAAC;IAC9F,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,WAAW,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC9B,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,EAAE,CAAC;IAC3B,QAAQ,CAAC,EAAE,uBAAuB,EAAE,CAAC;IACrC,eAAe,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAC5B,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACxB,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,MAAM,CAAC,EAAE,SAAS,GAAG,OAAO,CAAC;IAC7B,OAAO,CAAC,EAAE,SAAS,GAAG,MAAM,GAAG,OAAO,GAAG,OAAO,CAAC;IACjD,KAAK,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC;CAC9B;AAMD,eAAO,MAAM,gBAAgB,8FAwI5B,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef } from 'react';
|
|
3
|
+
import { motion } from 'framer-motion';
|
|
4
|
+
import { cn } from '../lib/utils';
|
|
5
|
+
import { Badge } from './Badge';
|
|
6
|
+
/* ========================================
|
|
7
|
+
DESCRIPTION BLOCK
|
|
8
|
+
======================================== */
|
|
9
|
+
export const DescriptionBlock = forwardRef(({ eyebrow, title, subtitle, description, badges, metadata, metadataColumns = 2, media, actions, footer, layout = 'stacked', variant = 'default', align = 'start', className, ...props }, ref) => {
|
|
10
|
+
const MotionSection = motion.section;
|
|
11
|
+
const variantClasses = {
|
|
12
|
+
default: 'bg-surface-primary border border-border-primary shadow-sm',
|
|
13
|
+
soft: 'bg-surface-secondary/60 border border-border-primary/50',
|
|
14
|
+
panel: 'bg-surface-primary/90 border border-border-primary shadow-lg',
|
|
15
|
+
glass: 'bg-white/5 dark:bg-white/2 backdrop-blur-2xl border border-white/10 shadow-[0_20px_80px_rgba(15,23,42,0.15)]',
|
|
16
|
+
};
|
|
17
|
+
const metadataGrid = {
|
|
18
|
+
1: 'grid-cols-1',
|
|
19
|
+
2: 'grid-cols-1 sm:grid-cols-2',
|
|
20
|
+
3: 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-3',
|
|
21
|
+
};
|
|
22
|
+
return (_jsxs(MotionSection, { ref: ref, className: cn('rounded-3xl p-6 sm:p-8 space-y-6', variantClasses[variant], className), initial: { opacity: 0, y: 20 }, animate: { opacity: 1, y: 0 }, transition: { duration: 0.3, ease: [0.16, 1, 0.3, 1] }, ...props, children: [_jsx("div", { className: cn(layout === 'split'
|
|
23
|
+
? 'grid gap-8 lg:grid-cols-[1.8fr_1fr]'
|
|
24
|
+
: 'space-y-10'), children: _jsxs("div", { className: cn('space-y-7', align === 'center' && 'text-center items-center flex flex-col'), children: [eyebrow && (_jsx("p", { className: "text-xs font-semibold uppercase tracking-[0.35em] text-text-tertiary", children: eyebrow })), _jsxs("div", { className: "space-y-3 w-full", children: [_jsxs("div", { className: "space-y-2", children: [_jsx("div", { className: cn('text-3xl font-semibold tracking-tight text-text-primary', align === 'center' && 'text-center'), children: title }), subtitle && (_jsx("p", { className: cn('text-lg text-text-secondary', align === 'center' && 'text-center'), children: subtitle }))] }), badges && badges.length > 0 && (_jsx("div", { className: cn('flex flex-wrap gap-2', align === 'center' && 'justify-center'), children: badges.map((badge, index) => (_jsx(Badge, { size: "sm", className: "bg-surface-secondary/60 border border-border-primary/60 text-text-secondary", children: badge }, index))) }))] }), description && (_jsx("div", { className: cn('text-base text-text-secondary leading-relaxed max-w-2xl', align === 'center' && 'mx-auto text-center'), children: description })), actions && (_jsx("div", { className: cn('flex flex-wrap gap-3', align === 'center' && 'justify-center'), children: actions })), media && (_jsx("div", { className: "overflow-hidden rounded-2xl border border-border-primary/60 bg-surface-secondary/40", children: media })), metadata && metadata.length > 0 && (_jsxs("div", { className: "space-y-4", children: [_jsx("p", { className: "text-xs font-semibold uppercase tracking-[0.3em] text-text-tertiary", children: "Detalles" }), _jsx("div", { className: cn('grid gap-6', metadataGrid[metadataColumns]), children: metadata.map((item, index) => (_jsxs("div", { className: "rounded-2xl border border-border-primary/40 bg-surface-secondary/30 p-5 space-y-1.5", children: [_jsxs("div", { className: "flex items-center gap-2 text-xs font-semibold uppercase tracking-wide text-text-tertiary", children: [item.icon && _jsx("span", { className: "text-text-tertiary", children: item.icon }), _jsx("span", { children: item.label })] }), _jsx("div", { className: "text-text-primary text-lg font-semibold break-words", children: item.value }), item.hint && (_jsx("p", { className: "text-sm text-text-secondary", children: item.hint }))] }, index))) })] }))] }) }), layout === 'stacked' && footer && (_jsxs(_Fragment, { children: [_jsx("br", {}), _jsx("div", { className: "rounded-2xl border border-dashed border-border-primary/60 p-4 text-sm text-text-secondary", children: footer })] }))] }));
|
|
25
|
+
});
|
|
26
|
+
DescriptionBlock.displayName = 'DescriptionBlock';
|
|
27
|
+
//# sourceMappingURL=DescriptionBlock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DescriptionBlock.js","sourceRoot":"","sources":["../../components/DescriptionBlock.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export type DeviceType = 'phone' | 'tablet' | 'laptop' | 'desktop' | 'other';
|
|
3
|
+
export type DeviceStatus = 'active' | 'inactive' | 'suspended';
|
|
4
|
+
export interface Device {
|
|
5
|
+
id: string;
|
|
6
|
+
name: string;
|
|
7
|
+
type: DeviceType;
|
|
8
|
+
os?: string;
|
|
9
|
+
browser?: string;
|
|
10
|
+
lastActive?: string;
|
|
11
|
+
location?: string;
|
|
12
|
+
ipAddress?: string;
|
|
13
|
+
status: DeviceStatus;
|
|
14
|
+
isCurrentDevice?: boolean;
|
|
15
|
+
}
|
|
16
|
+
export interface DeviceListProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
17
|
+
devices: Device[];
|
|
18
|
+
onRemove?: (device: Device) => void;
|
|
19
|
+
onMoreActions?: (device: Device) => void;
|
|
20
|
+
showActions?: boolean;
|
|
21
|
+
className?: string;
|
|
22
|
+
}
|
|
23
|
+
export declare const DeviceList: React.ForwardRefExoticComponent<DeviceListProps & React.RefAttributes<HTMLDivElement>>;
|
|
24
|
+
//# sourceMappingURL=DeviceList.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DeviceList.d.ts","sourceRoot":"","sources":["../../components/DeviceList.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAW1B,MAAM,MAAM,UAAU,GAAG,OAAO,GAAG,QAAQ,GAAG,QAAQ,GAAG,SAAS,GAAG,OAAO,CAAC;AAC7E,MAAM,MAAM,YAAY,GAAG,QAAQ,GAAG,UAAU,GAAG,WAAW,CAAC;AAE/D,MAAM,WAAW,MAAM;IACnB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,UAAU,CAAC;IACjB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,YAAY,CAAC;IACrB,eAAe,CAAC,EAAE,OAAO,CAAC;CAC7B;AAED,MAAM,WAAW,eAAgB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IACzE,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;IACpC,aAAa,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;IACzC,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAuCD,eAAO,MAAM,UAAU,wFA6FtB,CAAC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { cn } from '../lib/utils';
|
|
5
|
+
import { motion } from 'framer-motion';
|
|
6
|
+
import { Smartphone, Monitor, Tablet, Laptop, Trash2, MoreVertical } from 'lucide-react';
|
|
7
|
+
import { Button } from './Button';
|
|
8
|
+
import { Badge } from './Badge';
|
|
9
|
+
/* ========================================
|
|
10
|
+
HELPERS
|
|
11
|
+
======================================== */
|
|
12
|
+
const getDeviceIcon = (type) => {
|
|
13
|
+
switch (type) {
|
|
14
|
+
case 'phone':
|
|
15
|
+
return _jsx(Smartphone, { className: "w-5 h-5" });
|
|
16
|
+
case 'tablet':
|
|
17
|
+
return _jsx(Tablet, { className: "w-5 h-5" });
|
|
18
|
+
case 'laptop':
|
|
19
|
+
return _jsx(Laptop, { className: "w-5 h-5" });
|
|
20
|
+
case 'desktop':
|
|
21
|
+
return _jsx(Monitor, { className: "w-5 h-5" });
|
|
22
|
+
default:
|
|
23
|
+
return _jsx(Smartphone, { className: "w-5 h-5" });
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
const getStatusBadge = (status, isCurrent) => {
|
|
27
|
+
if (isCurrent) {
|
|
28
|
+
return _jsx(Badge, { variant: "success", size: "sm", children: "Current Device" });
|
|
29
|
+
}
|
|
30
|
+
switch (status) {
|
|
31
|
+
case 'active':
|
|
32
|
+
return _jsx(Badge, { variant: "success", size: "sm", children: "Active" });
|
|
33
|
+
case 'inactive':
|
|
34
|
+
return _jsx(Badge, { variant: "default", size: "sm", children: "Inactive" });
|
|
35
|
+
case 'suspended':
|
|
36
|
+
return _jsx(Badge, { variant: "error", size: "sm", children: "Suspended" });
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
/* ========================================
|
|
40
|
+
COMPONENT
|
|
41
|
+
======================================== */
|
|
42
|
+
export const DeviceList = React.forwardRef(({ devices, onRemove, onMoreActions, showActions = true, className, ...props }, ref) => {
|
|
43
|
+
return (_jsx("div", { ref: ref, className: cn("w-full space-y-2", className), ...props, children: devices.map((device, index) => (_jsxs(motion.div, { initial: { opacity: 0, y: 10 }, animate: { opacity: 1, y: 0 }, transition: { delay: index * 0.05 }, className: cn("flex items-center gap-4 p-4 rounded-xl border", "bg-surface-primary border-border-primary", "hover:bg-surface-secondary transition-colors"), children: [_jsx("div", { className: "flex-shrink-0 p-2 bg-surface-secondary rounded-lg text-text-tertiary", children: getDeviceIcon(device.type) }), _jsxs("div", { className: "flex-1 min-w-0", children: [_jsxs("div", { className: "flex items-center gap-2 mb-1", children: [_jsx("h3", { className: "text-sm font-semibold text-text-primary truncate", children: device.name }), getStatusBadge(device.status, device.isCurrentDevice)] }), _jsxs("div", { className: "flex flex-wrap items-center gap-3 text-xs text-text-secondary", children: [device.os && _jsx("span", { children: device.os }), device.browser && (_jsxs(_Fragment, { children: [_jsx("span", { className: "text-text-tertiary", children: "\u2022" }), _jsx("span", { children: device.browser })] })), device.lastActive && (_jsxs(_Fragment, { children: [_jsx("span", { className: "text-text-tertiary", children: "\u2022" }), _jsxs("span", { children: ["Last active: ", device.lastActive] })] }))] }), device.location && (_jsx("p", { className: "text-xs text-text-tertiary mt-1", children: device.location }))] }), showActions && (_jsxs("div", { className: "flex-shrink-0 flex items-center gap-2", children: [onMoreActions && (_jsx(Button, { variant: "ghost", size: "sm", onClick: () => onMoreActions(device), children: _jsx(MoreVertical, { className: "w-4 h-4" }) })), onRemove && !device.isCurrentDevice && (_jsx(Button, { variant: "ghost", size: "sm", onClick: () => onRemove(device), children: _jsx(Trash2, { className: "w-4 h-4 text-status-error" }) }))] }))] }, device.id))) }));
|
|
44
|
+
});
|
|
45
|
+
DeviceList.displayName = 'DeviceList';
|
|
46
|
+
//# sourceMappingURL=DeviceList.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DeviceList.js","sourceRoot":"","sources":["../../components/DeviceList.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,EAAE,EAAE,MAAM,cAAc,CAAC;AAClC,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,YAAY,EAA6B,MAAM,cAAc,CAAC;AACpH,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AA8BhC;;8CAE8C;AAE9C,MAAM,aAAa,GAAG,CAAC,IAAgB,EAAE,EAAE;IACvC,QAAQ,IAAI,EAAE,CAAC;QACX,KAAK,OAAO;YACR,OAAO,KAAC,UAAU,IAAC,SAAS,EAAC,SAAS,GAAG,CAAC;QAC9C,KAAK,QAAQ;YACT,OAAO,KAAC,MAAM,IAAC,SAAS,EAAC,SAAS,GAAG,CAAC;QAC1C,KAAK,QAAQ;YACT,OAAO,KAAC,MAAM,IAAC,SAAS,EAAC,SAAS,GAAG,CAAC;QAC1C,KAAK,SAAS;YACV,OAAO,KAAC,OAAO,IAAC,SAAS,EAAC,SAAS,GAAG,CAAC;QAC3C;YACI,OAAO,KAAC,UAAU,IAAC,SAAS,EAAC,SAAS,GAAG,CAAC;IAClD,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,cAAc,GAAG,CAAC,MAAoB,EAAE,SAAmB,EAAE,EAAE;IACjE,IAAI,SAAS,EAAE,CAAC;QACZ,OAAO,KAAC,KAAK,IAAC,OAAO,EAAC,SAAS,EAAC,IAAI,EAAC,IAAI,+BAAuB,CAAC;IACrE,CAAC;IACD,QAAQ,MAAM,EAAE,CAAC;QACb,KAAK,QAAQ;YACT,OAAO,KAAC,KAAK,IAAC,OAAO,EAAC,SAAS,EAAC,IAAI,EAAC,IAAI,uBAAe,CAAC;QAC7D,KAAK,UAAU;YACX,OAAO,KAAC,KAAK,IAAC,OAAO,EAAC,SAAS,EAAC,IAAI,EAAC,IAAI,yBAAiB,CAAC;QAC/D,KAAK,WAAW;YACZ,OAAO,KAAC,KAAK,IAAC,OAAO,EAAC,OAAO,EAAC,IAAI,EAAC,IAAI,0BAAkB,CAAC;IAClE,CAAC;AACL,CAAC,CAAC;AAEF;;8CAE8C;AAE9C,MAAM,CAAC,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,CACtC,CACI,EACI,OAAO,EACP,QAAQ,EACR,aAAa,EACb,WAAW,GAAG,IAAI,EAClB,SAAS,EACT,GAAG,KAAK,EACX,EACD,GAAG,EACL,EAAE;IACA,OAAO,CACH,cACI,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,EAAE,CAAC,kBAAkB,EAAE,SAAS,CAAC,KACxC,KAAK,YAER,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,CAC5B,MAAC,MAAM,CAAC,GAAG,IAEP,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAC9B,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAC7B,UAAU,EAAE,EAAE,KAAK,EAAE,KAAK,GAAG,IAAI,EAAE,EACnC,SAAS,EAAE,EAAE,CACT,+CAA+C,EAC/C,0CAA0C,EAC1C,8CAA8C,CACjD,aAGD,cAAK,SAAS,EAAC,sEAAsE,YAChF,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GACzB,EAGN,eAAK,SAAS,EAAC,gBAAgB,aAC3B,eAAK,SAAS,EAAC,8BAA8B,aACzC,aAAI,SAAS,EAAC,kDAAkD,YAC3D,MAAM,CAAC,IAAI,GACX,EACJ,cAAc,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,eAAe,CAAC,IACpD,EACN,eAAK,SAAS,EAAC,+DAA+D,aACzE,MAAM,CAAC,EAAE,IAAI,yBAAO,MAAM,CAAC,EAAE,GAAQ,EACrC,MAAM,CAAC,OAAO,IAAI,CACf,8BACI,eAAM,SAAS,EAAC,oBAAoB,uBAAS,EAC7C,yBAAO,MAAM,CAAC,OAAO,GAAQ,IAC9B,CACN,EACA,MAAM,CAAC,UAAU,IAAI,CAClB,8BACI,eAAM,SAAS,EAAC,oBAAoB,uBAAS,EAC7C,4CAAoB,MAAM,CAAC,UAAU,IAAQ,IAC9C,CACN,IACC,EACL,MAAM,CAAC,QAAQ,IAAI,CAChB,YAAG,SAAS,EAAC,iCAAiC,YACzC,MAAM,CAAC,QAAQ,GAChB,CACP,IACC,EAGL,WAAW,IAAI,CACZ,eAAK,SAAS,EAAC,uCAAuC,aACjD,aAAa,IAAI,CACd,KAAC,MAAM,IACH,OAAO,EAAC,OAAO,EACf,IAAI,EAAC,IAAI,EACT,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,MAAM,CAAC,YAEpC,KAAC,YAAY,IAAC,SAAS,EAAC,SAAS,GAAG,GAC/B,CACZ,EACA,QAAQ,IAAI,CAAC,MAAM,CAAC,eAAe,IAAI,CACpC,KAAC,MAAM,IACH,OAAO,EAAC,OAAO,EACf,IAAI,EAAC,IAAI,EACT,OAAO,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,YAE/B,KAAC,MAAM,IAAC,SAAS,EAAC,2BAA2B,GAAG,GAC3C,CACZ,IACC,CACT,KAnEI,MAAM,CAAC,EAAE,CAoEL,CAChB,CAAC,GACA,CACT,CAAC;AACN,CAAC,CACJ,CAAC;AAEF,UAAU,CAAC,WAAW,GAAG,YAAY,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export type DiffViewMode = 'unified' | 'split';
|
|
3
|
+
export interface DiffViewerProps {
|
|
4
|
+
oldText: string;
|
|
5
|
+
newText: string;
|
|
6
|
+
oldTitle?: string;
|
|
7
|
+
newTitle?: string;
|
|
8
|
+
initialMode?: DiffViewMode;
|
|
9
|
+
className?: string;
|
|
10
|
+
hideHeader?: boolean;
|
|
11
|
+
}
|
|
12
|
+
export declare const DiffViewer: React.FC<DiffViewerProps>;
|
|
13
|
+
//# sourceMappingURL=DiffViewer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DiffViewer.d.ts","sourceRoot":"","sources":["../../components/DiffViewer.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA4B,MAAM,OAAO,CAAC;AASjD,MAAM,MAAM,YAAY,GAAG,SAAS,GAAG,OAAO,CAAC;AAE/C,MAAM,WAAW,eAAe;IAC5B,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,YAAY,CAAC;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,OAAO,CAAC;CACxB;AAwED,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAyLhD,CAAC"}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useMemo, useState } from 'react';
|
|
3
|
+
import { cn } from '../lib/utils';
|
|
4
|
+
import { Button } from './Button';
|
|
5
|
+
import { Columns, Rows } from 'lucide-react';
|
|
6
|
+
/* ========================================
|
|
7
|
+
DIFF ALGORITHM (Simple LCS)
|
|
8
|
+
======================================== */
|
|
9
|
+
const computeDiff = (oldText, newText) => {
|
|
10
|
+
const oldLines = oldText.split('\n');
|
|
11
|
+
const newLines = newText.split('\n');
|
|
12
|
+
const N = oldLines.length;
|
|
13
|
+
const M = newLines.length;
|
|
14
|
+
// LCS Matrix
|
|
15
|
+
const lcs = Array(N + 1).fill(0).map(() => Array(M + 1).fill(0));
|
|
16
|
+
for (let i = 1; i <= N; i++) {
|
|
17
|
+
for (let j = 1; j <= M; j++) {
|
|
18
|
+
if (oldLines[i - 1] === newLines[j - 1]) {
|
|
19
|
+
lcs[i][j] = lcs[i - 1][j - 1] + 1;
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
lcs[i][j] = Math.max(lcs[i - 1][j], lcs[i][j - 1]);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
// Backtrack
|
|
27
|
+
const diff = [];
|
|
28
|
+
let i = N;
|
|
29
|
+
let j = M;
|
|
30
|
+
while (i > 0 || j > 0) {
|
|
31
|
+
if (i > 0 && j > 0 && oldLines[i - 1] === newLines[j - 1]) {
|
|
32
|
+
diff.unshift({
|
|
33
|
+
type: 'unchanged',
|
|
34
|
+
content: oldLines[i - 1],
|
|
35
|
+
oldLineNumber: i,
|
|
36
|
+
newLineNumber: j
|
|
37
|
+
});
|
|
38
|
+
i--;
|
|
39
|
+
j--;
|
|
40
|
+
}
|
|
41
|
+
else if (j > 0 && (i === 0 || lcs[i][j - 1] >= lcs[i - 1][j])) {
|
|
42
|
+
diff.unshift({
|
|
43
|
+
type: 'added',
|
|
44
|
+
content: newLines[j - 1],
|
|
45
|
+
newLineNumber: j
|
|
46
|
+
});
|
|
47
|
+
j--;
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
diff.unshift({
|
|
51
|
+
type: 'removed',
|
|
52
|
+
content: oldLines[i - 1],
|
|
53
|
+
oldLineNumber: i
|
|
54
|
+
});
|
|
55
|
+
i--;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
return diff;
|
|
59
|
+
};
|
|
60
|
+
/* ========================================
|
|
61
|
+
COMPONENTS
|
|
62
|
+
======================================== */
|
|
63
|
+
export const DiffViewer = ({ oldText, newText, oldTitle = 'Original', newTitle = 'Modified', initialMode = 'unified', className, hideHeader = false, }) => {
|
|
64
|
+
const [mode, setMode] = useState(initialMode);
|
|
65
|
+
const diffLines = useMemo(() => computeDiff(oldText, newText), [oldText, newText]);
|
|
66
|
+
const renderUnified = () => (_jsx("div", { className: "font-mono text-xs", children: diffLines.map((line, idx) => (_jsxs("div", { className: cn("flex", line.type === 'added' && "bg-green-100/50 dark:bg-green-900/20", line.type === 'removed' && "bg-red-100/50 dark:bg-red-900/20", line.type === 'unchanged' && "hover:bg-black/5 dark:hover:bg-white/5"), children: [_jsx("div", { className: "flex-none w-12 text-right pr-4 py-0.5 select-none text-text-tertiary border-r border-border-primary/30 opacity-50", children: line.oldLineNumber || '' }), _jsx("div", { className: "flex-none w-12 text-right pr-4 py-0.5 select-none text-text-tertiary border-r border-border-primary/30 opacity-50", children: line.newLineNumber || '' }), _jsxs("div", { className: cn("flex-none w-8 text-center py-0.5 select-none font-bold", line.type === 'added' && "text-green-600 dark:text-green-400", line.type === 'removed' && "text-red-600 dark:text-red-400", line.type === 'unchanged' && "text-text-secondary"), children: [line.type === 'added' && '+', line.type === 'removed' && '-'] }), _jsx("div", { className: cn("flex-1 py-0.5 px-4 whitespace-pre-wrap break-all", line.type === 'added' && "text-green-900 dark:text-green-100", line.type === 'removed' && "text-red-900 dark:text-red-100 line-through opacity-70", line.type === 'unchanged' && "text-text-secondary"), children: line.content })] }, idx))) }));
|
|
67
|
+
const renderSplit = () => {
|
|
68
|
+
// For split view, we need to align changes.
|
|
69
|
+
// This simple implementation just renders two columns but doesn't perfectly align complex diff blocks vertically
|
|
70
|
+
// like a sophisticated diff tool (e.g. GitHub) would with empty spacers.
|
|
71
|
+
// To improve this without deps, we can process the diffLines to insert "empty" placeholders.
|
|
72
|
+
const leftSide = [];
|
|
73
|
+
const rightSide = [];
|
|
74
|
+
diffLines.forEach(line => {
|
|
75
|
+
if (line.type === 'unchanged') {
|
|
76
|
+
leftSide.push(line);
|
|
77
|
+
rightSide.push(line);
|
|
78
|
+
}
|
|
79
|
+
else if (line.type === 'removed') {
|
|
80
|
+
leftSide.push(line);
|
|
81
|
+
rightSide.push({ type: 'unchanged', content: '', newLineNumber: undefined }); // Placeholder
|
|
82
|
+
}
|
|
83
|
+
else if (line.type === 'added') {
|
|
84
|
+
leftSide.push({ type: 'unchanged', content: '', oldLineNumber: undefined }); // Placeholder
|
|
85
|
+
rightSide.push(line);
|
|
86
|
+
}
|
|
87
|
+
});
|
|
88
|
+
return (_jsxs("div", { className: "flex font-mono text-xs divide-x divide-border-primary/30", children: [_jsx("div", { className: "flex-1 min-w-0", children: leftSide.map((line, idx) => (_jsxs("div", { className: cn("flex", line.type === 'removed' && "bg-red-100/50 dark:bg-red-900/20", !line.oldLineNumber && line.content === '' && "bg-black/5 dark:bg-white/5" // Placeholder styling
|
|
89
|
+
), children: [_jsx("div", { className: "flex-none w-12 text-right pr-4 py-0.5 select-none text-text-tertiary border-r border-border-primary/30 opacity-50", children: line.oldLineNumber || '' }), _jsx("div", { className: cn("flex-1 py-0.5 px-4 whitespace-pre-wrap break-all", line.type === 'removed' ? "text-red-900 dark:text-red-100" : "text-text-secondary", !line.oldLineNumber && "select-none"), children: line.content })] }, idx))) }), _jsx("div", { className: "flex-1 min-w-0", children: rightSide.map((line, idx) => (_jsxs("div", { className: cn("flex", line.type === 'added' && "bg-green-100/50 dark:bg-green-900/20", !line.newLineNumber && line.content === '' && "bg-black/5 dark:bg-white/5"), children: [_jsx("div", { className: "flex-none w-12 text-right pr-4 py-0.5 select-none text-text-tertiary border-r border-border-primary/30 opacity-50", children: line.newLineNumber || '' }), _jsx("div", { className: cn("flex-1 py-0.5 px-4 whitespace-pre-wrap break-all", line.type === 'added' ? "text-green-900 dark:text-green-100" : "text-text-secondary", !line.newLineNumber && "select-none"), children: line.content })] }, idx))) })] }));
|
|
90
|
+
};
|
|
91
|
+
return (_jsxs("div", { className: cn("border border-border-primary/50 rounded-lg overflow-hidden bg-surface-primary", className), children: [!hideHeader && (_jsxs("div", { className: "flex items-center justify-between px-4 py-2 bg-surface-secondary border-b border-border-primary/50", children: [_jsxs("div", { className: "flex items-center gap-4 text-sm", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("span", { className: "w-2 h-2 rounded-full bg-red-500/50" }), _jsx("span", { className: "font-medium text-text-secondary", children: oldTitle })] }), _jsx("span", { className: "text-text-tertiary", children: "\u2192" }), _jsxs("div", { className: "flex items-center gap-2", children: [_jsx("span", { className: "w-2 h-2 rounded-full bg-green-500/50" }), _jsx("span", { className: "font-medium text-text-secondary", children: newTitle })] })] }), _jsxs("div", { className: "flex bg-surface-primary rounded-md p-0.5 border border-border-primary/50", children: [_jsxs(Button, { variant: "ghost", size: "sm", onClick: () => setMode('unified'), className: cn("h-6 px-2 text-xs gap-1.5", mode === 'unified' ? "bg-surface-secondary shadow-sm text-text-primary" : "text-text-tertiary"), children: [_jsx(Rows, { className: "w-3.5 h-3.5" }), "Unified"] }), _jsxs(Button, { variant: "ghost", size: "sm", onClick: () => setMode('split'), className: cn("h-6 px-2 text-xs gap-1.5", mode === 'split' ? "bg-surface-secondary shadow-sm text-text-primary" : "text-text-tertiary"), children: [_jsx(Columns, { className: "w-3.5 h-3.5" }), "Split"] })] })] })), _jsx("div", { className: "overflow-x-auto", children: mode === 'unified' ? renderUnified() : renderSplit() })] }));
|
|
92
|
+
};
|
|
93
|
+
//# sourceMappingURL=DiffViewer.js.map
|