@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,102 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { motion, AnimatePresence } from 'framer-motion';
|
|
4
|
+
import { cn } from '../lib/utils';
|
|
5
|
+
export const CommandMenu = React.forwardRef(({ isOpen, onClose, groups, placeholder = 'Type a command or search...', className = '', emptyMessage = 'No results found.', }, ref) => {
|
|
6
|
+
const [search, setSearch] = React.useState('');
|
|
7
|
+
const [selectedIndex, setSelectedIndex] = React.useState(0);
|
|
8
|
+
const inputRef = React.useRef(null);
|
|
9
|
+
// Filter items based on search
|
|
10
|
+
const filteredGroups = React.useMemo(() => {
|
|
11
|
+
if (!search.trim())
|
|
12
|
+
return groups;
|
|
13
|
+
return groups
|
|
14
|
+
.map((group) => ({
|
|
15
|
+
...group,
|
|
16
|
+
items: group.items.filter((item) => {
|
|
17
|
+
const searchLower = search.toLowerCase();
|
|
18
|
+
const labelMatch = item.label.toLowerCase().includes(searchLower);
|
|
19
|
+
const descMatch = item.description?.toLowerCase().includes(searchLower);
|
|
20
|
+
const keywordMatch = item.keywords?.some((kw) => kw.toLowerCase().includes(searchLower));
|
|
21
|
+
return labelMatch || descMatch || keywordMatch;
|
|
22
|
+
}),
|
|
23
|
+
}))
|
|
24
|
+
.filter((group) => group.items.length > 0);
|
|
25
|
+
}, [groups, search]);
|
|
26
|
+
// Flatten items for keyboard navigation
|
|
27
|
+
const allItems = React.useMemo(() => {
|
|
28
|
+
return filteredGroups.flatMap((group) => group.items);
|
|
29
|
+
}, [filteredGroups]);
|
|
30
|
+
// Reset selection when search changes
|
|
31
|
+
React.useEffect(() => {
|
|
32
|
+
setSelectedIndex(0);
|
|
33
|
+
}, [search]);
|
|
34
|
+
// Focus input when opened
|
|
35
|
+
React.useEffect(() => {
|
|
36
|
+
if (isOpen) {
|
|
37
|
+
inputRef.current?.focus();
|
|
38
|
+
setSearch('');
|
|
39
|
+
setSelectedIndex(0);
|
|
40
|
+
}
|
|
41
|
+
}, [isOpen]);
|
|
42
|
+
// Handle keyboard navigation
|
|
43
|
+
React.useEffect(() => {
|
|
44
|
+
const handleKeyDown = (e) => {
|
|
45
|
+
if (!isOpen)
|
|
46
|
+
return;
|
|
47
|
+
switch (e.key) {
|
|
48
|
+
case 'Escape':
|
|
49
|
+
e.preventDefault();
|
|
50
|
+
onClose();
|
|
51
|
+
break;
|
|
52
|
+
case 'ArrowDown':
|
|
53
|
+
e.preventDefault();
|
|
54
|
+
setSelectedIndex((prev) => (prev + 1) % allItems.length);
|
|
55
|
+
break;
|
|
56
|
+
case 'ArrowUp':
|
|
57
|
+
e.preventDefault();
|
|
58
|
+
setSelectedIndex((prev) => (prev - 1 + allItems.length) % allItems.length);
|
|
59
|
+
break;
|
|
60
|
+
case 'Enter':
|
|
61
|
+
e.preventDefault();
|
|
62
|
+
if (allItems[selectedIndex]) {
|
|
63
|
+
allItems[selectedIndex].onSelect();
|
|
64
|
+
onClose();
|
|
65
|
+
}
|
|
66
|
+
break;
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
document.addEventListener('keydown', handleKeyDown);
|
|
70
|
+
return () => document.removeEventListener('keydown', handleKeyDown);
|
|
71
|
+
}, [isOpen, selectedIndex, allItems, onClose]);
|
|
72
|
+
// Lock body scroll when open
|
|
73
|
+
React.useEffect(() => {
|
|
74
|
+
if (isOpen) {
|
|
75
|
+
document.body.style.overflow = 'hidden';
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
document.body.style.overflow = '';
|
|
79
|
+
}
|
|
80
|
+
return () => {
|
|
81
|
+
document.body.style.overflow = '';
|
|
82
|
+
};
|
|
83
|
+
}, [isOpen]);
|
|
84
|
+
const handleBackdropClick = (e) => {
|
|
85
|
+
if (e.target === e.currentTarget) {
|
|
86
|
+
onClose();
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
let currentItemIndex = 0;
|
|
90
|
+
return (_jsx(AnimatePresence, { children: isOpen && (_jsxs("div", { className: "fixed inset-0 z-modal", onClick: handleBackdropClick, children: [_jsx(motion.div, { className: "absolute inset-0 bg-black/60 backdrop-blur-sm", initial: { opacity: 0 }, animate: { opacity: 1 }, exit: { opacity: 0 }, transition: { duration: 0.2 } }), _jsx("div", { className: "relative flex items-start justify-center pt-[20vh] px-4", children: _jsxs(motion.div, { ref: ref, className: cn('w-full max-w-2xl bg-surface-primary rounded-xl shadow-xl overflow-hidden', className), initial: { opacity: 0, scale: 0.95, y: -20 }, animate: { opacity: 1, scale: 1, y: 0 }, exit: { opacity: 0, scale: 0.95, y: -20 }, transition: { type: 'spring', stiffness: 300, damping: 30 }, onClick: (e) => e.stopPropagation(), children: [_jsxs("div", { className: "flex items-center gap-3 px-4 py-4 border-b border-border-primary", children: [_jsx("span", { className: "text-text-tertiary text-xl", children: "\uD83D\uDD0D" }), _jsx("input", { ref: inputRef, type: "text", value: search, onChange: (e) => setSearch(e.target.value), placeholder: placeholder, className: "flex-1 bg-transparent text-lg text-text-primary placeholder:text-text-tertiary outline-none" }), _jsx("kbd", { className: "hidden sm:inline-flex items-center gap-1 px-2 py-1 text-xs font-semibold text-text-tertiary bg-surface-secondary rounded border border-border-primary", children: "ESC" })] }), _jsx("div", { className: "max-h-[60vh] overflow-y-auto", children: allItems.length === 0 ? (_jsx("div", { className: "px-4 py-12 text-center", children: _jsx("p", { className: "text-text-tertiary", children: emptyMessage }) })) : (_jsx("div", { className: "py-2", children: filteredGroups.map((group, groupIdx) => (_jsxs("div", { className: "mb-4 last:mb-0", children: [group.title && (_jsx("div", { className: "px-4 py-2 text-xs font-semibold text-text-tertiary uppercase tracking-wide", children: group.title })), _jsx("div", { children: group.items.map((item) => {
|
|
91
|
+
const itemIndex = currentItemIndex++;
|
|
92
|
+
const isSelected = itemIndex === selectedIndex;
|
|
93
|
+
return (_jsxs(motion.button, { onClick: () => {
|
|
94
|
+
item.onSelect();
|
|
95
|
+
onClose();
|
|
96
|
+
}, className: cn('w-full flex items-center gap-3 px-4 py-3 text-left transition-colors', isSelected
|
|
97
|
+
? 'bg-accent-blue/10 text-text-primary'
|
|
98
|
+
: 'text-text-secondary hover:bg-surface-secondary'), whileHover: { x: 4 }, transition: { duration: 0.15 }, children: [item.icon && (_jsx("span", { className: "flex-shrink-0 text-lg", children: item.icon })), _jsxs("div", { className: "flex-1 min-w-0", children: [_jsx("div", { className: "font-medium text-text-primary", children: item.label }), item.description && (_jsx("div", { className: "text-xs text-text-tertiary truncate", children: item.description }))] }), item.shortcut && (_jsx("kbd", { className: "hidden sm:inline-flex items-center gap-1 px-2 py-1 text-xs font-semibold text-text-tertiary bg-surface-secondary rounded border border-border-primary", children: item.shortcut }))] }, item.id));
|
|
99
|
+
}) })] }, groupIdx))) })) }), _jsxs("div", { className: "flex items-center justify-between px-4 py-3 border-t border-border-primary bg-surface-secondary/30", children: [_jsxs("div", { className: "flex items-center gap-6 text-sm text-text-secondary", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsxs("div", { className: "flex items-center gap-1", children: [_jsx("kbd", { className: "min-w-[24px] h-6 px-2 flex items-center justify-center text-xs font-medium bg-surface-primary rounded border border-border-primary shadow-sm", children: "\u2191" }), _jsx("kbd", { className: "min-w-[24px] h-6 px-2 flex items-center justify-center text-xs font-medium bg-surface-primary rounded border border-border-primary shadow-sm", children: "\u2193" })] }), _jsx("span", { className: "text-text-tertiary", children: "to navigate" })] }), _jsxs("div", { className: "flex items-center gap-2", children: [_jsx("kbd", { className: "h-6 px-2 flex items-center justify-center text-xs font-medium bg-surface-primary rounded border border-border-primary shadow-sm", children: "\u21B5" }), _jsx("span", { className: "text-text-tertiary", children: "to select" })] }), _jsxs("div", { className: "flex items-center gap-2", children: [_jsx("kbd", { className: "h-6 px-2 flex items-center justify-center text-xs font-medium bg-surface-primary rounded border border-border-primary shadow-sm", children: "ESC" }), _jsx("span", { className: "text-text-tertiary", children: "to close" })] })] }), _jsxs("div", { className: "text-sm font-medium text-text-tertiary", children: [allItems.length, " ", allItems.length === 1 ? 'result' : 'results'] })] })] }) })] })) }));
|
|
100
|
+
});
|
|
101
|
+
CommandMenu.displayName = 'CommandMenu';
|
|
102
|
+
//# sourceMappingURL=CommandMenu.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CommandMenu.js","sourceRoot":"","sources":["../../components/CommandMenu.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export interface CommentUser {
|
|
3
|
+
id: string;
|
|
4
|
+
name: string;
|
|
5
|
+
avatarSrc?: string;
|
|
6
|
+
initials?: string;
|
|
7
|
+
}
|
|
8
|
+
export interface CommentData {
|
|
9
|
+
id: string;
|
|
10
|
+
author: CommentUser;
|
|
11
|
+
content: React.ReactNode;
|
|
12
|
+
timestamp: string;
|
|
13
|
+
likes?: number;
|
|
14
|
+
isLiked?: boolean;
|
|
15
|
+
replies?: CommentData[];
|
|
16
|
+
isEdited?: boolean;
|
|
17
|
+
}
|
|
18
|
+
export interface CommentThreadProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
19
|
+
comments: CommentData[];
|
|
20
|
+
currentUser?: CommentUser;
|
|
21
|
+
onReply?: (commentId: string, content: string) => void;
|
|
22
|
+
onLike?: (commentId: string) => void;
|
|
23
|
+
onEdit?: (commentId: string, newContent: string) => void;
|
|
24
|
+
onDelete?: (commentId: string) => void;
|
|
25
|
+
className?: string;
|
|
26
|
+
}
|
|
27
|
+
export declare const CommentThread: React.ForwardRefExoticComponent<CommentThreadProps & React.RefAttributes<HTMLDivElement>>;
|
|
28
|
+
//# sourceMappingURL=CommentThread.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CommentThread.d.ts","sourceRoot":"","sources":["../../components/CommentThread.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAmB,MAAM,OAAO,CAAC;AAoBxC,MAAM,WAAW,WAAW;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,WAAW;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,WAAW,CAAC;IACpB,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,OAAO,CAAC,EAAE,WAAW,EAAE,CAAC;IACxB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,MAAM,WAAW,kBAAmB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC5E,QAAQ,EAAE,WAAW,EAAE,CAAC;IACxB,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;IACvD,MAAM,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IACrC,MAAM,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,KAAK,IAAI,CAAC;IACzD,QAAQ,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IACvC,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAmMD,eAAO,MAAM,aAAa,2FA0DzB,CAAC"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React, { useState } from 'react';
|
|
3
|
+
import { cn } from '../lib/utils';
|
|
4
|
+
import { Avatar, AvatarImage, AvatarFallback } from './Avatar';
|
|
5
|
+
import { Button } from './Button';
|
|
6
|
+
import { Textarea } from './Textarea';
|
|
7
|
+
import { MessageSquare, Heart, CornerDownRight } from 'lucide-react';
|
|
8
|
+
import { Combobox } from './Combobox';
|
|
9
|
+
/* ========================================
|
|
10
|
+
COMPONENTS
|
|
11
|
+
======================================== */
|
|
12
|
+
const CommentItem = ({ comment, currentUser, depth = 0, onReply, onLike, onEdit, onDelete, }) => {
|
|
13
|
+
const [isReplying, setIsReplying] = useState(false);
|
|
14
|
+
const [isEditing, setIsEditing] = useState(false);
|
|
15
|
+
const [replyContent, setReplyContent] = useState('');
|
|
16
|
+
const [editContent, setEditContent] = useState(typeof comment.content === 'string' ? comment.content : '');
|
|
17
|
+
const handleReplySubmit = () => {
|
|
18
|
+
if (replyContent.trim() && onReply) {
|
|
19
|
+
onReply(comment.id, replyContent);
|
|
20
|
+
setIsReplying(false);
|
|
21
|
+
setReplyContent('');
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
const handleEditSubmit = () => {
|
|
25
|
+
if (editContent.trim() && onEdit) {
|
|
26
|
+
onEdit(comment.id, editContent);
|
|
27
|
+
setIsEditing(false);
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
const isAuthor = currentUser?.id === comment.author.id;
|
|
31
|
+
const maxDepth = 3; // Stop indenting after this depth to prevent squishing
|
|
32
|
+
const effectiveDepth = Math.min(depth, maxDepth);
|
|
33
|
+
return (_jsxs("div", { className: cn("group relative", depth > 0 && "mt-4"), children: [_jsxs("div", { className: "flex gap-3", children: [_jsxs(Avatar, { className: "w-8 h-8 flex-none border border-border-primary/50", children: [_jsx(AvatarImage, { src: comment.author.avatarSrc, alt: comment.author.name }), _jsx(AvatarFallback, { children: comment.author.initials || comment.author.name.charAt(0) })] }), _jsxs("div", { className: "flex-1 min-w-0 space-y-1.5", children: [_jsxs("div", { className: "flex items-center justify-between", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("span", { className: "text-sm font-semibold text-text-primary", children: comment.author.name }), _jsx("span", { className: "text-xs text-text-tertiary", children: comment.timestamp }), comment.isEdited && (_jsx("span", { className: "text-[10px] text-text-tertiary italic", children: "(edited)" }))] }), (isAuthor || onReply) && (_jsx("div", { className: "w-32", children: _jsx(Combobox, { items: [
|
|
34
|
+
...(onReply
|
|
35
|
+
? [{ value: "reply", label: "Reply" }]
|
|
36
|
+
: []),
|
|
37
|
+
...(isAuthor && onEdit
|
|
38
|
+
? [{ value: "edit", label: "Edit" }]
|
|
39
|
+
: []),
|
|
40
|
+
...(isAuthor && onDelete
|
|
41
|
+
? [{ value: "delete", label: "Delete" }]
|
|
42
|
+
: []),
|
|
43
|
+
], value: undefined, onChange: (val) => {
|
|
44
|
+
if (val === "reply" && onReply)
|
|
45
|
+
setIsReplying(!isReplying);
|
|
46
|
+
if (val === "edit" && onEdit)
|
|
47
|
+
setIsEditing(true);
|
|
48
|
+
if (val === "delete" && onDelete)
|
|
49
|
+
onDelete(comment.id);
|
|
50
|
+
}, placeholder: "Actions", className: "h-6 text-xs" }) }))] }), isEditing ? (_jsxs("div", { className: "space-y-2", children: [_jsx(Textarea, { value: editContent, onChange: (e) => setEditContent(e.target.value), className: "min-h-[80px] text-sm", autoFocus: true }), _jsxs("div", { className: "flex gap-2 justify-end", children: [_jsx(Button, { size: "sm", variant: "ghost", onClick: () => setIsEditing(false), children: "Cancel" }), _jsx(Button, { size: "sm", variant: "primary", onClick: handleEditSubmit, children: "Save" })] })] })) : (_jsx("div", { className: "text-sm text-text-secondary leading-relaxed break-words", children: comment.content })), !isEditing && (_jsxs("div", { className: "flex items-center gap-4 pt-1", children: [onLike && (_jsxs("button", { onClick: () => onLike(comment.id), className: cn("flex items-center gap-1.5 text-xs font-medium transition-colors", comment.isLiked
|
|
51
|
+
? "text-status-error"
|
|
52
|
+
: "text-text-tertiary hover:text-text-secondary"), children: [_jsx(Heart, { className: cn("w-3.5 h-3.5", comment.isLiked && "fill-current") }), comment.likes || 0] })), onReply && (_jsxs("button", { onClick: () => setIsReplying(!isReplying), className: "flex items-center gap-1.5 text-xs font-medium text-text-tertiary hover:text-text-secondary transition-colors", children: [_jsx(MessageSquare, { className: "w-3.5 h-3.5" }), "Reply"] }))] })), isReplying && (_jsxs("div", { className: "mt-3 flex gap-3 animate-in fade-in slide-in-from-top-2 duration-200", children: [_jsx("div", { className: "relative", children: _jsx(CornerDownRight, { className: "w-4 h-4 text-text-tertiary absolute -left-2 top-2" }) }), _jsxs("div", { className: "flex-1 space-y-2", children: [_jsx(Textarea, { placeholder: `Reply to ${comment.author.name}...`, value: replyContent, onChange: (e) => setReplyContent(e.target.value), className: "min-h-[80px] text-sm", autoFocus: true }), _jsxs("div", { className: "flex gap-2 justify-end", children: [_jsx(Button, { size: "sm", variant: "ghost", onClick: () => setIsReplying(false), children: "Cancel" }), _jsx(Button, { size: "sm", variant: "primary", onClick: handleReplySubmit, children: "Reply" })] })] })] }))] })] }), comment.replies && comment.replies.length > 0 && (_jsx("div", { className: cn("pl-4 border-l-2 border-border-primary/30 ml-4", depth >= maxDepth && "border-l-0 pl-0 ml-0"), children: comment.replies.map((reply) => (_jsx(CommentItem, { comment: reply, currentUser: currentUser, depth: depth + 1, onReply: onReply, onLike: onLike, onEdit: onEdit, onDelete: onDelete }, reply.id))) }))] }));
|
|
53
|
+
};
|
|
54
|
+
export const CommentThread = React.forwardRef(({ comments, currentUser, onReply, onLike, onEdit, onDelete, className, ...props }, ref) => {
|
|
55
|
+
const [newComment, setNewComment] = useState('');
|
|
56
|
+
const handleNewComment = () => {
|
|
57
|
+
if (newComment.trim() && onReply) {
|
|
58
|
+
// Use a special ID or null to indicate a root comment
|
|
59
|
+
onReply('root', newComment);
|
|
60
|
+
setNewComment('');
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
return (_jsxs("div", { ref: ref, className: cn("space-y-8", className), ...props, children: [currentUser && onReply && (_jsxs("div", { className: "flex gap-4", children: [_jsxs(Avatar, { className: "w-10 h-10 flex-none", children: [_jsx(AvatarImage, { src: currentUser.avatarSrc, alt: currentUser.name }), _jsx(AvatarFallback, { children: currentUser.initials || currentUser.name.charAt(0) })] }), _jsxs("div", { className: "flex-1 space-y-2", children: [_jsx(Textarea, { placeholder: "Write a comment...", value: newComment, onChange: (e) => setNewComment(e.target.value), className: "min-h-[100px]" }), _jsx("div", { className: "flex justify-end", children: _jsx(Button, { variant: "primary", onClick: handleNewComment, disabled: !newComment.trim(), children: "Post Comment" }) })] })] })), _jsx("div", { className: "space-y-6", children: comments.map((comment) => (_jsx(CommentItem, { comment: comment, currentUser: currentUser, onReply: onReply, onLike: onLike, onEdit: onEdit, onDelete: onDelete }, comment.id))) })] }));
|
|
64
|
+
});
|
|
65
|
+
CommentThread.displayName = 'CommentThread';
|
|
66
|
+
//# sourceMappingURL=CommentThread.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CommentThread.js","sourceRoot":"","sources":["../../components/CommentThread.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export interface ConfirmDialogProps {
|
|
3
|
+
/** Controls visibility of the dialog */
|
|
4
|
+
open: boolean;
|
|
5
|
+
/** Callback when visibility changes */
|
|
6
|
+
onOpenChange: (open: boolean) => void;
|
|
7
|
+
/** Title of the confirmation dialog */
|
|
8
|
+
title: string;
|
|
9
|
+
/** Description or body text */
|
|
10
|
+
description?: React.ReactNode;
|
|
11
|
+
/** Label for the confirm button */
|
|
12
|
+
confirmLabel?: string;
|
|
13
|
+
/** Label for the cancel button */
|
|
14
|
+
cancelLabel?: string;
|
|
15
|
+
/** Callback when confirm button is clicked */
|
|
16
|
+
onConfirm: () => void;
|
|
17
|
+
/** Callback when cancel button is clicked */
|
|
18
|
+
onCancel?: () => void;
|
|
19
|
+
/** Visual variant of the dialog */
|
|
20
|
+
variant?: 'default' | 'destructive' | 'warning' | 'info';
|
|
21
|
+
/** Whether the confirm action is loading */
|
|
22
|
+
isLoading?: boolean;
|
|
23
|
+
/** Custom icon to override the default variant icon */
|
|
24
|
+
icon?: React.ReactNode;
|
|
25
|
+
}
|
|
26
|
+
export declare const ConfirmDialog: React.FC<ConfirmDialogProps>;
|
|
27
|
+
//# sourceMappingURL=ConfirmDialog.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConfirmDialog.d.ts","sourceRoot":"","sources":["../../components/ConfirmDialog.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAS1B,MAAM,WAAW,kBAAkB;IAC/B,wCAAwC;IACxC,IAAI,EAAE,OAAO,CAAC;IACd,uCAAuC;IACvC,YAAY,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;IACtC,uCAAuC;IACvC,KAAK,EAAE,MAAM,CAAC;IACd,+BAA+B;IAC/B,WAAW,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC9B,mCAAmC;IACnC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,kCAAkC;IAClC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,8CAA8C;IAC9C,SAAS,EAAE,MAAM,IAAI,CAAC;IACtB,6CAA6C;IAC7C,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;IACtB,mCAAmC;IACnC,OAAO,CAAC,EAAE,SAAS,GAAG,aAAa,GAAG,SAAS,GAAG,MAAM,CAAC;IACzD,4CAA4C;IAC5C,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,uDAAuD;IACvD,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC1B;AAoDD,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CAiFtD,CAAC"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Modal, ModalFooter, ModalHeader, ModalTitle } from './Modal';
|
|
3
|
+
import { Button } from './Button';
|
|
4
|
+
/* ========================================
|
|
5
|
+
ICONS
|
|
6
|
+
======================================== */
|
|
7
|
+
const Icons = {
|
|
8
|
+
default: (_jsx("svg", { className: "w-6 h-6 text-accent-blue", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", children: _jsx("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" }) })),
|
|
9
|
+
destructive: (_jsx("svg", { className: "w-6 h-6 text-status-error", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z" }) })),
|
|
10
|
+
warning: (_jsx("svg", { className: "w-6 h-6 text-status-warning", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z" }) })),
|
|
11
|
+
info: (_jsx("svg", { className: "w-6 h-6 text-accent-blue", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", children: _jsx("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" }) })),
|
|
12
|
+
};
|
|
13
|
+
const VariantStyles = {
|
|
14
|
+
default: {
|
|
15
|
+
iconBg: 'bg-accent-blue/10',
|
|
16
|
+
confirmBtn: 'primary',
|
|
17
|
+
},
|
|
18
|
+
destructive: {
|
|
19
|
+
iconBg: 'bg-status-error/10',
|
|
20
|
+
confirmBtn: 'destructive',
|
|
21
|
+
},
|
|
22
|
+
warning: {
|
|
23
|
+
iconBg: 'bg-status-warning/10',
|
|
24
|
+
confirmBtn: 'warning', // Assuming Button has a warning variant or we use primary with custom class
|
|
25
|
+
},
|
|
26
|
+
info: {
|
|
27
|
+
iconBg: 'bg-accent-blue/10',
|
|
28
|
+
confirmBtn: 'primary',
|
|
29
|
+
},
|
|
30
|
+
};
|
|
31
|
+
/* ========================================
|
|
32
|
+
COMPONENT
|
|
33
|
+
======================================== */
|
|
34
|
+
export const ConfirmDialog = ({ open, onOpenChange, title, description, confirmLabel = 'Confirm', cancelLabel = 'Cancel', onConfirm, onCancel, variant = 'default', isLoading = false, icon, }) => {
|
|
35
|
+
const handleConfirm = () => {
|
|
36
|
+
onConfirm();
|
|
37
|
+
};
|
|
38
|
+
const handleCancel = () => {
|
|
39
|
+
if (onCancel)
|
|
40
|
+
onCancel();
|
|
41
|
+
onOpenChange(false);
|
|
42
|
+
};
|
|
43
|
+
const styles = VariantStyles[variant];
|
|
44
|
+
const Icon = icon || Icons[variant];
|
|
45
|
+
// Map variant to Button variant
|
|
46
|
+
const getButtonVariant = (v) => {
|
|
47
|
+
switch (v) {
|
|
48
|
+
case 'destructive': return 'destructive';
|
|
49
|
+
case 'warning': return 'primary'; // Could be improved with a specific warning variant
|
|
50
|
+
default: return 'primary';
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
return (_jsx(Modal, { open: open, onOpenChange: onOpenChange, size: "sm", children: _jsxs("div", { className: "flex flex-col sm:flex-row gap-4", children: [_jsx("div", { className: `
|
|
54
|
+
flex-shrink-0
|
|
55
|
+
w-12 h-12
|
|
56
|
+
rounded-full
|
|
57
|
+
flex items-center justify-center
|
|
58
|
+
${styles.iconBg}
|
|
59
|
+
mx-auto sm:mx-0
|
|
60
|
+
`, children: Icon }), _jsxs("div", { className: "flex-1 text-center sm:text-left", children: [_jsx(ModalHeader, { className: "!mb-2", children: _jsx(ModalTitle, { children: title }) }), description && (_jsx("div", { className: "text-sm text-text-secondary mb-6", children: description })), _jsxs(ModalFooter, { className: "!mt-0 !justify-center sm:!justify-end", children: [_jsx(Button, { variant: "ghost", onClick: handleCancel, disabled: isLoading, children: cancelLabel }), _jsx(Button, { variant: getButtonVariant(variant), onClick: handleConfirm, loading: isLoading, children: confirmLabel })] })] })] }) }));
|
|
61
|
+
};
|
|
62
|
+
//# sourceMappingURL=ConfirmDialog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConfirmDialog.js","sourceRoot":"","sources":["../../components/ConfirmDialog.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,KAAK,EAAkC,WAAW,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACtG,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAgClC;;8CAE8C;AAE9C,MAAM,KAAK,GAAG;IACV,OAAO,EAAE,CACL,cAAK,SAAS,EAAC,0BAA0B,EAAC,IAAI,EAAC,MAAM,EAAC,OAAO,EAAC,WAAW,EAAC,MAAM,EAAC,cAAc,YAC3F,eAAM,aAAa,EAAC,OAAO,EAAC,cAAc,EAAC,OAAO,EAAC,WAAW,EAAE,CAAC,EAAE,CAAC,EAAC,2DAA2D,GAAG,GACjI,CACT;IACD,WAAW,EAAE,CACT,cAAK,SAAS,EAAC,2BAA2B,EAAC,IAAI,EAAC,MAAM,EAAC,OAAO,EAAC,WAAW,EAAC,MAAM,EAAC,cAAc,YAC5F,eAAM,aAAa,EAAC,OAAO,EAAC,cAAc,EAAC,OAAO,EAAC,WAAW,EAAE,CAAC,EAAE,CAAC,EAAC,sIAAsI,GAAG,GAC5M,CACT;IACD,OAAO,EAAE,CACL,cAAK,SAAS,EAAC,6BAA6B,EAAC,IAAI,EAAC,MAAM,EAAC,OAAO,EAAC,WAAW,EAAC,MAAM,EAAC,cAAc,YAC9F,eAAM,aAAa,EAAC,OAAO,EAAC,cAAc,EAAC,OAAO,EAAC,WAAW,EAAE,CAAC,EAAE,CAAC,EAAC,sIAAsI,GAAG,GAC5M,CACT;IACD,IAAI,EAAE,CACF,cAAK,SAAS,EAAC,0BAA0B,EAAC,IAAI,EAAC,MAAM,EAAC,OAAO,EAAC,WAAW,EAAC,MAAM,EAAC,cAAc,YAC3F,eAAM,aAAa,EAAC,OAAO,EAAC,cAAc,EAAC,OAAO,EAAC,WAAW,EAAE,CAAC,EAAE,CAAC,EAAC,2DAA2D,GAAG,GACjI,CACT;CACJ,CAAC;AAEF,MAAM,aAAa,GAAG;IAClB,OAAO,EAAE;QACL,MAAM,EAAE,mBAAmB;QAC3B,UAAU,EAAE,SAAS;KACxB;IACD,WAAW,EAAE;QACT,MAAM,EAAE,oBAAoB;QAC5B,UAAU,EAAE,aAAa;KAC5B;IACD,OAAO,EAAE;QACL,MAAM,EAAE,sBAAsB;QAC9B,UAAU,EAAE,SAAS,EAAE,4EAA4E;KACtG;IACD,IAAI,EAAE;QACF,MAAM,EAAE,mBAAmB;QAC3B,UAAU,EAAE,SAAS;KACxB;CACJ,CAAC;AAEF;;8CAE8C;AAE9C,MAAM,CAAC,MAAM,aAAa,GAAiC,CAAC,EACxD,IAAI,EACJ,YAAY,EACZ,KAAK,EACL,WAAW,EACX,YAAY,GAAG,SAAS,EACxB,WAAW,GAAG,QAAQ,EACtB,SAAS,EACT,QAAQ,EACR,OAAO,GAAG,SAAS,EACnB,SAAS,GAAG,KAAK,EACjB,IAAI,GACP,EAAE,EAAE;IACD,MAAM,aAAa,GAAG,GAAG,EAAE;QACvB,SAAS,EAAE,CAAC;IAChB,CAAC,CAAC;IAEF,MAAM,YAAY,GAAG,GAAG,EAAE;QACtB,IAAI,QAAQ;YAAE,QAAQ,EAAE,CAAC;QACzB,YAAY,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC,CAAC;IAEF,MAAM,MAAM,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC;IACtC,MAAM,IAAI,GAAG,IAAI,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC;IAEpC,gCAAgC;IAChC,MAAM,gBAAgB,GAAG,CAAC,CAAS,EAAO,EAAE;QACxC,QAAQ,CAAC,EAAE,CAAC;YACR,KAAK,aAAa,CAAC,CAAC,OAAO,aAAa,CAAC;YACzC,KAAK,SAAS,CAAC,CAAC,OAAO,SAAS,CAAC,CAAC,oDAAoD;YACtF,OAAO,CAAC,CAAC,OAAO,SAAS,CAAC;QAC9B,CAAC;IACL,CAAC,CAAC;IAEF,OAAO,CACH,KAAC,KAAK,IAAC,IAAI,EAAE,IAAI,EAAE,YAAY,EAAE,YAAY,EAAE,IAAI,EAAC,IAAI,YACpD,eAAK,SAAS,EAAC,iCAAiC,aAE5C,cAAK,SAAS,EAAE;;;;;sBAKV,MAAM,CAAC,MAAM;;iBAElB,YACI,IAAI,GACH,EAGN,eAAK,SAAS,EAAC,iCAAiC,aAC5C,KAAC,WAAW,IAAC,SAAS,EAAC,OAAO,YAC1B,KAAC,UAAU,cAAE,KAAK,GAAc,GACtB,EAEb,WAAW,IAAI,CACZ,cAAK,SAAS,EAAC,kCAAkC,YAC5C,WAAW,GACV,CACT,EAED,MAAC,WAAW,IAAC,SAAS,EAAC,uCAAuC,aAC1D,KAAC,MAAM,IACH,OAAO,EAAC,OAAO,EACf,OAAO,EAAE,YAAY,EACrB,QAAQ,EAAE,SAAS,YAElB,WAAW,GACP,EACT,KAAC,MAAM,IACH,OAAO,EAAE,gBAAgB,CAAC,OAAO,CAAC,EAClC,OAAO,EAAE,aAAa,EACtB,OAAO,EAAE,SAAS,YAEjB,YAAY,GACR,IACC,IACZ,IACJ,GACF,CACX,CAAC;AACN,CAAC,CAAC"}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
export type ContextMenuProps = React.HTMLAttributes<HTMLDivElement> & {
|
|
3
|
+
open?: boolean;
|
|
4
|
+
defaultOpen?: boolean;
|
|
5
|
+
onOpenChange?: (open: boolean) => void;
|
|
6
|
+
};
|
|
7
|
+
declare const ContextMenu: {
|
|
8
|
+
({ children, open, defaultOpen, onOpenChange, ...props }: ContextMenuProps): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
displayName: string;
|
|
10
|
+
};
|
|
11
|
+
export type ContextMenuTriggerProps = React.HTMLAttributes<HTMLElement> & {
|
|
12
|
+
asChild?: boolean;
|
|
13
|
+
};
|
|
14
|
+
declare const ContextMenuTrigger: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLElement> & {
|
|
15
|
+
asChild?: boolean;
|
|
16
|
+
} & React.RefAttributes<HTMLElement>>;
|
|
17
|
+
export type ContextMenuContentProps = React.HTMLAttributes<HTMLDivElement>;
|
|
18
|
+
declare const ContextMenuContent: React.ForwardRefExoticComponent<ContextMenuContentProps & React.RefAttributes<HTMLDivElement>>;
|
|
19
|
+
export type ContextMenuGroupProps = React.HTMLAttributes<HTMLDivElement>;
|
|
20
|
+
declare const ContextMenuGroup: {
|
|
21
|
+
({ className, ...props }: ContextMenuGroupProps): import("react/jsx-runtime").JSX.Element;
|
|
22
|
+
displayName: string;
|
|
23
|
+
};
|
|
24
|
+
export type ContextMenuItemProps = React.HTMLAttributes<HTMLDivElement> & {
|
|
25
|
+
inset?: boolean;
|
|
26
|
+
onSelect?: () => void;
|
|
27
|
+
};
|
|
28
|
+
declare const ContextMenuItem: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLDivElement> & {
|
|
29
|
+
inset?: boolean;
|
|
30
|
+
onSelect?: () => void;
|
|
31
|
+
} & React.RefAttributes<HTMLDivElement>>;
|
|
32
|
+
export type ContextMenuCheckboxItemProps = React.HTMLAttributes<HTMLDivElement> & {
|
|
33
|
+
checked?: boolean;
|
|
34
|
+
onCheckedChange?: (checked: boolean) => void;
|
|
35
|
+
};
|
|
36
|
+
declare const ContextMenuCheckboxItem: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLDivElement> & {
|
|
37
|
+
checked?: boolean;
|
|
38
|
+
onCheckedChange?: (checked: boolean) => void;
|
|
39
|
+
} & React.RefAttributes<HTMLDivElement>>;
|
|
40
|
+
export type ContextMenuRadioGroupProps = React.HTMLAttributes<HTMLDivElement> & {
|
|
41
|
+
value?: string;
|
|
42
|
+
onValueChange?: (value: string) => void;
|
|
43
|
+
};
|
|
44
|
+
declare const ContextMenuRadioGroup: {
|
|
45
|
+
({ children, value, onValueChange, ...props }: ContextMenuRadioGroupProps): import("react/jsx-runtime").JSX.Element;
|
|
46
|
+
displayName: string;
|
|
47
|
+
};
|
|
48
|
+
export type ContextMenuRadioItemProps = React.HTMLAttributes<HTMLDivElement> & {
|
|
49
|
+
value: string;
|
|
50
|
+
};
|
|
51
|
+
declare const ContextMenuRadioItem: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLDivElement> & {
|
|
52
|
+
value: string;
|
|
53
|
+
} & React.RefAttributes<HTMLDivElement>>;
|
|
54
|
+
export type ContextMenuLabelProps = React.HTMLAttributes<HTMLDivElement> & {
|
|
55
|
+
inset?: boolean;
|
|
56
|
+
};
|
|
57
|
+
declare const ContextMenuLabel: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLDivElement> & {
|
|
58
|
+
inset?: boolean;
|
|
59
|
+
} & React.RefAttributes<HTMLDivElement>>;
|
|
60
|
+
export type ContextMenuSeparatorProps = React.HTMLAttributes<HTMLDivElement>;
|
|
61
|
+
declare const ContextMenuSeparator: React.ForwardRefExoticComponent<ContextMenuSeparatorProps & React.RefAttributes<HTMLDivElement>>;
|
|
62
|
+
declare const ContextMenuShortcut: {
|
|
63
|
+
({ className, ...props }: React.HTMLAttributes<HTMLSpanElement>): import("react/jsx-runtime").JSX.Element;
|
|
64
|
+
displayName: string;
|
|
65
|
+
};
|
|
66
|
+
export type ContextMenuSubProps = {
|
|
67
|
+
children: React.ReactNode;
|
|
68
|
+
};
|
|
69
|
+
declare const ContextMenuSub: {
|
|
70
|
+
({ children }: ContextMenuSubProps): import("react/jsx-runtime").JSX.Element;
|
|
71
|
+
displayName: string;
|
|
72
|
+
};
|
|
73
|
+
export type ContextMenuSubTriggerProps = React.HTMLAttributes<HTMLDivElement> & {
|
|
74
|
+
inset?: boolean;
|
|
75
|
+
};
|
|
76
|
+
declare const ContextMenuSubTrigger: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLDivElement> & {
|
|
77
|
+
inset?: boolean;
|
|
78
|
+
} & React.RefAttributes<HTMLDivElement>>;
|
|
79
|
+
export type ContextMenuSubContentProps = React.HTMLAttributes<HTMLDivElement>;
|
|
80
|
+
declare const ContextMenuSubContent: React.ForwardRefExoticComponent<ContextMenuSubContentProps & React.RefAttributes<HTMLDivElement>>;
|
|
81
|
+
declare const ContextMenuPortal: React.FC<{
|
|
82
|
+
children: React.ReactNode;
|
|
83
|
+
}>;
|
|
84
|
+
export { ContextMenu, ContextMenuTrigger, ContextMenuContent, ContextMenuItem, ContextMenuCheckboxItem, ContextMenuRadioItem, ContextMenuLabel, ContextMenuSeparator, ContextMenuShortcut, ContextMenuGroup, ContextMenuPortal, ContextMenuSub, ContextMenuSubContent, ContextMenuSubTrigger, ContextMenuRadioGroup, };
|
|
85
|
+
//# sourceMappingURL=ContextMenu.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ContextMenu.d.ts","sourceRoot":"","sources":["../../components/ContextMenu.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AA8B/B,MAAM,MAAM,gBAAgB,GAAG,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,GAAG;IAClE,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;CAC1C,CAAC;AAEF,QAAA,MAAM,WAAW;8DAMd,gBAAgB;;CA6ClB,CAAC;AAIF,MAAM,MAAM,uBAAuB,GAAG,KAAK,CAAC,cAAc,CAAC,WAAW,CAAC,GAAG;IAAE,OAAO,CAAC,EAAE,OAAO,CAAA;CAAE,CAAC;AAEhG,QAAA,MAAM,kBAAkB;cAF8D,OAAO;qCA6B5F,CAAC;AAGF,MAAM,MAAM,uBAAuB,GAAG,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;AAE3E,QAAA,MAAM,kBAAkB,gGAgCvB,CAAC;AAGF,MAAM,MAAM,qBAAqB,GAAG,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;AACzE,QAAA,MAAM,gBAAgB;8BAA6B,qBAAqB;;CAEvE,CAAC;AAGF,MAAM,MAAM,oBAAoB,GAAG,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,GAAG;IAAE,KAAK,CAAC,EAAE,OAAO,CAAC;IAAC,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAA;CAAE,CAAC;AAErH,QAAA,MAAM,eAAe;YAF+D,OAAO;eAAa,MAAM,IAAI;wCA6BjH,CAAC;AAGF,MAAM,MAAM,4BAA4B,GAAG,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,GAAG;IAC9E,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,eAAe,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;CAChD,CAAC;AAEF,QAAA,MAAM,uBAAuB;cAJf,OAAO;sBACC,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI;wCAkC/C,CAAC;AAGF,MAAM,MAAM,0BAA0B,GAAG,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,GAAG;IAC5E,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CAC3C,CAAC;AAEF,QAAA,MAAM,qBAAqB;mDAAkD,0BAA0B;;CAatG,CAAC;AAGF,MAAM,MAAM,yBAAyB,GAAG,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,GAAG;IAAE,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC;AAEjG,QAAA,MAAM,oBAAoB;WAF8D,MAAM;wCAoC7F,CAAC;AAGF,MAAM,MAAM,qBAAqB,GAAG,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,GAAG;IAAE,KAAK,CAAC,EAAE,OAAO,CAAA;CAAE,CAAC;AAE/F,QAAA,MAAM,gBAAgB;YAF+D,OAAO;wCAU3F,CAAC;AAGF,MAAM,MAAM,yBAAyB,GAAG,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;AAE7E,QAAA,MAAM,oBAAoB,kGAIzB,CAAC;AAGF,QAAA,MAAM,mBAAmB;8BAA6B,KAAK,CAAC,cAAc,CAAC,eAAe,CAAC;;CAE1F,CAAC;AAGF,MAAM,MAAM,mBAAmB,GAAG;IAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;CAAE,CAAC;AAEhE,QAAA,MAAM,cAAc;mBAAkB,mBAAmB;;CAYxD,CAAC;AAGF,MAAM,MAAM,0BAA0B,GAAG,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,GAAG;IAAE,KAAK,CAAC,EAAE,OAAO,CAAA;CAAE,CAAC;AAEpG,QAAA,MAAM,qBAAqB;YAF+D,OAAO;wCAwDhG,CAAC;AAGF,MAAM,MAAM,0BAA0B,GAAG,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;AAE9E,QAAA,MAAM,qBAAqB,mGAqC1B,CAAC;AAGF,QAAA,MAAM,iBAAiB,EAAE,KAAK,CAAC,EAAE,CAAC;IAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;CAAE,CAE9D,CAAC;AAGF,OAAO,EACH,WAAW,EACX,kBAAkB,EAClB,kBAAkB,EAClB,eAAe,EACf,uBAAuB,EACvB,oBAAoB,EACpB,gBAAgB,EAChB,oBAAoB,EACpB,mBAAmB,EACnB,gBAAgB,EAChB,iBAAiB,EACjB,cAAc,EACd,qBAAqB,EACrB,qBAAqB,EACrB,qBAAqB,GACxB,CAAC"}
|