@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,13 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export interface FileUploadProps {
|
|
3
|
+
label?: string;
|
|
4
|
+
onChange?: (file: File | null) => void;
|
|
5
|
+
accept?: string;
|
|
6
|
+
maxSize?: number;
|
|
7
|
+
disabled?: boolean;
|
|
8
|
+
error?: string;
|
|
9
|
+
helperText?: string;
|
|
10
|
+
className?: string;
|
|
11
|
+
}
|
|
12
|
+
export declare const FileUpload: React.FC<FileUploadProps>;
|
|
13
|
+
//# sourceMappingURL=FileUpload.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FileUpload.d.ts","sourceRoot":"","sources":["../../components/FileUpload.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA2B,MAAM,OAAO,CAAC;AAShD,MAAM,WAAW,eAAe;IAC5B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI,KAAK,IAAI,CAAC;IACvC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAmBD,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAoNhD,CAAC"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useRef, useState } from 'react';
|
|
3
|
+
import { motion, AnimatePresence } from 'framer-motion';
|
|
4
|
+
import { Upload, X, File, AlertCircle } from 'lucide-react';
|
|
5
|
+
import { cn } from '../lib/utils';
|
|
6
|
+
/* ========================================
|
|
7
|
+
UTILITY FUNCTIONS
|
|
8
|
+
======================================== */
|
|
9
|
+
const formatBytes = (bytes, decimals = 2) => {
|
|
10
|
+
if (bytes === 0)
|
|
11
|
+
return '0 Bytes';
|
|
12
|
+
const k = 1024;
|
|
13
|
+
const dm = decimals < 0 ? 0 : decimals;
|
|
14
|
+
const sizes = ['Bytes', 'KB', 'MB', 'GB', 'TB'];
|
|
15
|
+
const i = Math.floor(Math.log(bytes) / Math.log(k));
|
|
16
|
+
return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + ' ' + sizes[i];
|
|
17
|
+
};
|
|
18
|
+
/* ========================================
|
|
19
|
+
FILE UPLOAD COMPONENT
|
|
20
|
+
======================================== */
|
|
21
|
+
export const FileUpload = ({ label, onChange, accept, maxSize, disabled = false, error: customError, helperText, className, }) => {
|
|
22
|
+
const [file, setFile] = useState(null);
|
|
23
|
+
const [isDragging, setIsDragging] = useState(false);
|
|
24
|
+
const [internalError, setInternalError] = useState(null);
|
|
25
|
+
const inputRef = useRef(null);
|
|
26
|
+
const error = customError || internalError;
|
|
27
|
+
const handleDragOver = (e) => {
|
|
28
|
+
e.preventDefault();
|
|
29
|
+
if (!disabled) {
|
|
30
|
+
setIsDragging(true);
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
const handleDragLeave = (e) => {
|
|
34
|
+
e.preventDefault();
|
|
35
|
+
setIsDragging(false);
|
|
36
|
+
};
|
|
37
|
+
const validateFile = (file) => {
|
|
38
|
+
setInternalError(null);
|
|
39
|
+
// Validate size
|
|
40
|
+
if (maxSize && file.size > maxSize) {
|
|
41
|
+
setInternalError(`File size must be less than ${formatBytes(maxSize)}`);
|
|
42
|
+
return false;
|
|
43
|
+
}
|
|
44
|
+
// Validate type (basic check based on accept prop)
|
|
45
|
+
if (accept) {
|
|
46
|
+
const acceptedTypes = accept.split(',').map(t => t.trim());
|
|
47
|
+
const fileType = file.type;
|
|
48
|
+
const fileName = file.name;
|
|
49
|
+
const isValid = acceptedTypes.some(type => {
|
|
50
|
+
if (type.endsWith('/*')) {
|
|
51
|
+
return fileType.startsWith(type.replace('/*', ''));
|
|
52
|
+
}
|
|
53
|
+
if (type.startsWith('.')) {
|
|
54
|
+
return fileName.toLowerCase().endsWith(type.toLowerCase());
|
|
55
|
+
}
|
|
56
|
+
return fileType === type;
|
|
57
|
+
});
|
|
58
|
+
if (!isValid) {
|
|
59
|
+
setInternalError(`File type not accepted`);
|
|
60
|
+
return false;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return true;
|
|
64
|
+
};
|
|
65
|
+
const handleDrop = (e) => {
|
|
66
|
+
e.preventDefault();
|
|
67
|
+
setIsDragging(false);
|
|
68
|
+
if (disabled)
|
|
69
|
+
return;
|
|
70
|
+
const droppedFile = e.dataTransfer.files[0];
|
|
71
|
+
if (droppedFile) {
|
|
72
|
+
if (validateFile(droppedFile)) {
|
|
73
|
+
setFile(droppedFile);
|
|
74
|
+
onChange?.(droppedFile);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
};
|
|
78
|
+
const handleFileChange = (e) => {
|
|
79
|
+
const selectedFile = e.target.files?.[0];
|
|
80
|
+
if (selectedFile) {
|
|
81
|
+
if (validateFile(selectedFile)) {
|
|
82
|
+
setFile(selectedFile);
|
|
83
|
+
onChange?.(selectedFile);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
// Reset input so same file can be selected again if needed
|
|
87
|
+
if (inputRef.current) {
|
|
88
|
+
inputRef.current.value = '';
|
|
89
|
+
}
|
|
90
|
+
};
|
|
91
|
+
const handleRemove = (e) => {
|
|
92
|
+
e.stopPropagation();
|
|
93
|
+
setFile(null);
|
|
94
|
+
setInternalError(null);
|
|
95
|
+
onChange?.(null);
|
|
96
|
+
};
|
|
97
|
+
const handleClick = () => {
|
|
98
|
+
if (!disabled) {
|
|
99
|
+
inputRef.current?.click();
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
return (_jsxs("div", { className: cn("w-full", className), children: [label && (_jsx("label", { className: "block text-sm font-medium text-text-primary mb-2", children: label })), _jsxs("div", { onClick: handleClick, onDragOver: handleDragOver, onDragLeave: handleDragLeave, onDrop: handleDrop, className: cn("relative group cursor-pointer rounded-xl border-2 border-dashed transition-all duration-200 ease-in-out overflow-hidden", "min-h-[120px] flex flex-col items-center justify-center p-6 text-center", isDragging
|
|
103
|
+
? "border-accent-blue bg-accent-blue/5 scale-[1.01]"
|
|
104
|
+
: "border-border-secondary bg-surface-primary hover:bg-surface-secondary hover:border-border-primary", error && "border-status-error bg-status-error/5", disabled && "opacity-50 cursor-not-allowed hover:bg-surface-primary hover:border-border-secondary"), children: [_jsx("input", { ref: inputRef, type: "file", className: "hidden", accept: accept, onChange: handleFileChange, disabled: disabled }), _jsx(AnimatePresence, { mode: "wait", children: file ? (_jsxs(motion.div, { initial: { opacity: 0, scale: 0.9 }, animate: { opacity: 1, scale: 1 }, exit: { opacity: 0, scale: 0.9 }, className: "flex items-center gap-4 w-full max-w-md bg-surface-secondary p-3 rounded-lg border border-border-primary", onClick: (e) => e.stopPropagation(), children: [_jsx("div", { className: "p-2 bg-surface-tertiary rounded-md", children: _jsx(File, { className: "w-6 h-6 text-accent-blue" }) }), _jsxs("div", { className: "flex-1 text-left overflow-hidden", children: [_jsx("p", { className: "text-sm font-medium text-text-primary truncate", children: file.name }), _jsx("p", { className: "text-xs text-text-tertiary", children: formatBytes(file.size) })] }), _jsx("button", { onClick: handleRemove, className: "p-1.5 rounded-md hover:bg-surface-tertiary text-text-tertiary hover:text-status-error transition-colors", type: "button", children: _jsx(X, { className: "w-4 h-4" }) })] })) : (_jsxs(motion.div, { initial: { opacity: 0 }, animate: { opacity: 1 }, exit: { opacity: 0 }, className: "flex flex-col items-center gap-2", children: [_jsx("div", { className: cn("p-3 rounded-full bg-surface-secondary transition-colors group-hover:bg-surface-tertiary", isDragging && "bg-accent-blue/10 text-accent-blue"), children: _jsx(Upload, { className: cn("w-6 h-6 text-text-secondary transition-colors", isDragging && "text-accent-blue") }) }), _jsxs("div", { className: "space-y-1", children: [_jsxs("p", { className: "text-sm font-medium text-text-primary", children: [_jsx("span", { className: "text-accent-blue hover:underline", children: "Click to upload" }), " or drag and drop"] }), _jsxs("p", { className: "text-xs text-text-tertiary", children: [accept ? `Accepted formats: ${accept.replace(/,/g, ', ')}` : 'All files accepted', maxSize && ` • Max size: ${formatBytes(maxSize)}`] })] })] })) })] }), (error || helperText) && (_jsxs(motion.div, { initial: { opacity: 0, y: -4 }, animate: { opacity: 1, y: 0 }, className: "mt-2 flex items-center gap-2", children: [error && _jsx(AlertCircle, { className: "w-4 h-4 text-status-error" }), _jsx("p", { className: cn("text-sm", error ? "text-status-error" : "text-text-secondary"), children: error || helperText })] }))] }));
|
|
105
|
+
};
|
|
106
|
+
FileUpload.displayName = 'FileUpload';
|
|
107
|
+
//# sourceMappingURL=FileUpload.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FileUpload.js","sourceRoot":"","sources":["../../components/FileUpload.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export interface FilterOption {
|
|
3
|
+
id: string;
|
|
4
|
+
label: string;
|
|
5
|
+
value: string;
|
|
6
|
+
count?: number;
|
|
7
|
+
}
|
|
8
|
+
export interface FilterGroup {
|
|
9
|
+
id: string;
|
|
10
|
+
label: string;
|
|
11
|
+
type: 'select' | 'multiselect' | 'date' | 'search' | 'custom';
|
|
12
|
+
options?: FilterOption[];
|
|
13
|
+
placeholder?: string;
|
|
14
|
+
icon?: React.ReactNode;
|
|
15
|
+
customContent?: React.ReactNode;
|
|
16
|
+
}
|
|
17
|
+
export interface ActiveFilter {
|
|
18
|
+
groupId: string;
|
|
19
|
+
optionId: string;
|
|
20
|
+
label: string;
|
|
21
|
+
value: string;
|
|
22
|
+
}
|
|
23
|
+
export interface FilterBarProps {
|
|
24
|
+
groups: FilterGroup[];
|
|
25
|
+
activeFilters?: ActiveFilter[];
|
|
26
|
+
onFilterChange?: (filters: ActiveFilter[]) => void;
|
|
27
|
+
onClearAll?: () => void;
|
|
28
|
+
searchPlaceholder?: string;
|
|
29
|
+
showSearch?: boolean;
|
|
30
|
+
showFilterCount?: boolean;
|
|
31
|
+
className?: string;
|
|
32
|
+
}
|
|
33
|
+
export declare const FilterBar: React.FC<FilterBarProps>;
|
|
34
|
+
export default FilterBar;
|
|
35
|
+
//# sourceMappingURL=FilterBar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FilterBar.d.ts","sourceRoot":"","sources":["../../components/FilterBar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAmB,MAAM,OAAO,CAAC;AAMxC,MAAM,WAAW,YAAY;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,WAAW;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,QAAQ,GAAG,aAAa,GAAG,MAAM,GAAG,QAAQ,GAAG,QAAQ,CAAC;IAC9D,OAAO,CAAC,EAAE,YAAY,EAAE,CAAC;IACzB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,aAAa,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CACnC;AAED,MAAM,WAAW,YAAY;IACzB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,cAAc;IAC3B,MAAM,EAAE,WAAW,EAAE,CAAC;IACtB,aAAa,CAAC,EAAE,YAAY,EAAE,CAAC;IAC/B,cAAc,CAAC,EAAE,CAAC,OAAO,EAAE,YAAY,EAAE,KAAK,IAAI,CAAC;IACnD,UAAU,CAAC,EAAE,MAAM,IAAI,CAAC;IACxB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,eAAO,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAoK9C,CAAC;AAEF,eAAe,SAAS,CAAC"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useState } from 'react';
|
|
3
|
+
import { X, Filter } from 'lucide-react';
|
|
4
|
+
import { Button } from './Button';
|
|
5
|
+
import { SearchInput } from './SearchInput';
|
|
6
|
+
import { FilterSelect } from './Select';
|
|
7
|
+
export const FilterBar = ({ groups, activeFilters = [], onFilterChange, onClearAll, searchPlaceholder = 'Search...', showSearch = true, showFilterCount = true, className = '', }) => {
|
|
8
|
+
const [searchQuery, setSearchQuery] = useState('');
|
|
9
|
+
const handleFilterChange = (groupId, value) => {
|
|
10
|
+
const group = groups.find(g => g.id === groupId);
|
|
11
|
+
if (!group || !group.options)
|
|
12
|
+
return;
|
|
13
|
+
let newFilters = [...activeFilters];
|
|
14
|
+
if (group.type === 'multiselect') {
|
|
15
|
+
// Remove all existing filters for this group
|
|
16
|
+
newFilters = newFilters.filter(f => f.groupId !== groupId);
|
|
17
|
+
// Add new filters for selected values
|
|
18
|
+
const values = Array.isArray(value) ? value : [value];
|
|
19
|
+
values.forEach(val => {
|
|
20
|
+
const option = group.options?.find(o => o.value === val);
|
|
21
|
+
if (option) {
|
|
22
|
+
newFilters.push({
|
|
23
|
+
groupId,
|
|
24
|
+
optionId: option.id,
|
|
25
|
+
label: option.label,
|
|
26
|
+
value: option.value,
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
// For single select, remove existing filter for this group and add new one
|
|
33
|
+
newFilters = newFilters.filter(f => f.groupId !== groupId);
|
|
34
|
+
const option = group.options?.find(o => o.value === value);
|
|
35
|
+
if (option) {
|
|
36
|
+
newFilters.push({
|
|
37
|
+
groupId,
|
|
38
|
+
optionId: option.id,
|
|
39
|
+
label: option.label,
|
|
40
|
+
value: option.value,
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
onFilterChange?.(newFilters);
|
|
45
|
+
};
|
|
46
|
+
const handleRemoveFilter = (filter) => {
|
|
47
|
+
const newFilters = activeFilters.filter(f => !(f.groupId === filter.groupId && f.optionId === filter.optionId));
|
|
48
|
+
onFilterChange?.(newFilters);
|
|
49
|
+
};
|
|
50
|
+
const handleClearAll = () => {
|
|
51
|
+
onFilterChange?.([]);
|
|
52
|
+
onClearAll?.();
|
|
53
|
+
setSearchQuery('');
|
|
54
|
+
};
|
|
55
|
+
const getGroupValue = (groupId) => {
|
|
56
|
+
const group = groups.find(g => g.id === groupId);
|
|
57
|
+
const groupFilters = activeFilters.filter(f => f.groupId === groupId);
|
|
58
|
+
if (!group || groupFilters.length === 0)
|
|
59
|
+
return undefined;
|
|
60
|
+
if (group.type === 'multiselect') {
|
|
61
|
+
return groupFilters.map(f => f.value);
|
|
62
|
+
}
|
|
63
|
+
return groupFilters[0]?.value;
|
|
64
|
+
};
|
|
65
|
+
return (_jsxs("div", { className: `bg-surface-primary border border-border-primary rounded-xl p-4 ${className}`, children: [_jsxs("div", { className: "flex flex-wrap items-center gap-3", children: [showSearch && (_jsx("div", { className: "flex-1 min-w-[200px]", children: _jsx(SearchInput, { value: searchQuery, onChange: setSearchQuery, placeholder: searchPlaceholder }) })), groups.map((group) => {
|
|
66
|
+
if (group.type === 'custom') {
|
|
67
|
+
return (_jsx("div", { children: group.customContent }, group.id));
|
|
68
|
+
}
|
|
69
|
+
const filterOptions = group.options?.map(opt => ({
|
|
70
|
+
id: opt.id,
|
|
71
|
+
label: opt.label,
|
|
72
|
+
value: opt.value,
|
|
73
|
+
count: opt.count,
|
|
74
|
+
})) || [];
|
|
75
|
+
return (_jsx(FilterSelect, { label: group.label, options: filterOptions, value: getGroupValue(group.id), onChange: (value) => handleFilterChange(group.id, value), icon: group.icon || _jsx(Filter, { className: "w-4 h-4" }), multiselect: group.type === 'multiselect' }, group.id));
|
|
76
|
+
}), showFilterCount && activeFilters.length > 0 && (_jsxs("div", { className: "flex items-center gap-2 px-3 py-2 rounded-lg bg-surface-secondary text-text-secondary text-sm", children: [_jsx(Filter, { className: "w-4 h-4" }), _jsxs("span", { children: [activeFilters.length, " active"] })] })), activeFilters.length > 0 && (_jsx(Button, { variant: "ghost", size: "sm", onClick: handleClearAll, leftIcon: _jsx(X, { className: "w-4 h-4" }), children: "Clear all" }))] }), activeFilters.length > 0 && (_jsx("div", { className: "flex flex-wrap gap-2 mt-4 pt-4 border-t border-border-primary", children: activeFilters.map((filter, index) => (_jsxs("div", { className: "inline-flex items-center gap-2 px-3 py-1.5 rounded-full bg-accent-blue/10 text-accent-blue text-sm", children: [_jsx("span", { className: "font-medium", children: filter.label }), _jsx("button", { onClick: () => handleRemoveFilter(filter), className: "hover:bg-accent-blue/20 rounded-full p-0.5 transition-colors", children: _jsx(X, { className: "w-3.5 h-3.5" }) })] }, `${filter.groupId}-${filter.optionId}-${index}`))) }))] }));
|
|
77
|
+
};
|
|
78
|
+
export default FilterBar;
|
|
79
|
+
//# sourceMappingURL=FilterBar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FilterBar.js","sourceRoot":"","sources":["../../components/FilterBar.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACxC,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAsB,MAAM,UAAU,CAAC;AAqC5D,MAAM,CAAC,MAAM,SAAS,GAA6B,CAAC,EAChD,MAAM,EACN,aAAa,GAAG,EAAE,EAClB,cAAc,EACd,UAAU,EACV,iBAAiB,GAAG,WAAW,EAC/B,UAAU,GAAG,IAAI,EACjB,eAAe,GAAG,IAAI,EACtB,SAAS,GAAG,EAAE,GACjB,EAAE,EAAE;IACD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IAEnD,MAAM,kBAAkB,GAAG,CAAC,OAAe,EAAE,KAAwB,EAAE,EAAE;QACrE,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC,CAAC;QACjD,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,OAAO;YAAE,OAAO;QAErC,IAAI,UAAU,GAAG,CAAC,GAAG,aAAa,CAAC,CAAC;QAEpC,IAAI,KAAK,CAAC,IAAI,KAAK,aAAa,EAAE,CAAC;YAC/B,6CAA6C;YAC7C,UAAU,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,CAAC;YAE3D,sCAAsC;YACtC,MAAM,MAAM,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;YACtD,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;gBACjB,MAAM,MAAM,GAAG,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,GAAG,CAAC,CAAC;gBACzD,IAAI,MAAM,EAAE,CAAC;oBACT,UAAU,CAAC,IAAI,CAAC;wBACZ,OAAO;wBACP,QAAQ,EAAE,MAAM,CAAC,EAAE;wBACnB,KAAK,EAAE,MAAM,CAAC,KAAK;wBACnB,KAAK,EAAE,MAAM,CAAC,KAAK;qBACtB,CAAC,CAAC;gBACP,CAAC;YACL,CAAC,CAAC,CAAC;QACP,CAAC;aAAM,CAAC;YACJ,2EAA2E;YAC3E,UAAU,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,CAAC;YAC3D,MAAM,MAAM,GAAG,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC;YAC3D,IAAI,MAAM,EAAE,CAAC;gBACT,UAAU,CAAC,IAAI,CAAC;oBACZ,OAAO;oBACP,QAAQ,EAAE,MAAM,CAAC,EAAE;oBACnB,KAAK,EAAE,MAAM,CAAC,KAAK;oBACnB,KAAK,EAAE,MAAM,CAAC,KAAK;iBACtB,CAAC,CAAC;YACP,CAAC;QACL,CAAC;QAED,cAAc,EAAE,CAAC,UAAU,CAAC,CAAC;IACjC,CAAC,CAAC;IAEF,MAAM,kBAAkB,GAAG,CAAC,MAAoB,EAAE,EAAE;QAChD,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CACnC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,KAAK,MAAM,CAAC,OAAO,IAAI,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,QAAQ,CAAC,CACzE,CAAC;QACF,cAAc,EAAE,CAAC,UAAU,CAAC,CAAC;IACjC,CAAC,CAAC;IAEF,MAAM,cAAc,GAAG,GAAG,EAAE;QACxB,cAAc,EAAE,CAAC,EAAE,CAAC,CAAC;QACrB,UAAU,EAAE,EAAE,CAAC;QACf,cAAc,CAAC,EAAE,CAAC,CAAC;IACvB,CAAC,CAAC;IAEF,MAAM,aAAa,GAAG,CAAC,OAAe,EAAiC,EAAE;QACrE,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC,CAAC;QACjD,MAAM,YAAY,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,CAAC;QAEtE,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,SAAS,CAAC;QAE1D,IAAI,KAAK,CAAC,IAAI,KAAK,aAAa,EAAE,CAAC;YAC/B,OAAO,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QAC1C,CAAC;QAED,OAAO,YAAY,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC;IAClC,CAAC,CAAC;IAEF,OAAO,CACH,eAAK,SAAS,EAAE,kEAAkE,SAAS,EAAE,aACzF,eAAK,SAAS,EAAC,mCAAmC,aAE7C,UAAU,IAAI,CACX,cAAK,SAAS,EAAC,sBAAsB,YACjC,KAAC,WAAW,IACR,KAAK,EAAE,WAAW,EAClB,QAAQ,EAAE,cAAc,EACxB,WAAW,EAAE,iBAAiB,GAChC,GACA,CACT,EAGA,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;wBAClB,IAAI,KAAK,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;4BAC1B,OAAO,CACH,wBACK,KAAK,CAAC,aAAa,IADd,KAAK,CAAC,EAAE,CAEZ,CACT,CAAC;wBACN,CAAC;wBAED,MAAM,aAAa,GAAyB,KAAK,CAAC,OAAO,EAAE,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;4BACnE,EAAE,EAAE,GAAG,CAAC,EAAE;4BACV,KAAK,EAAE,GAAG,CAAC,KAAK;4BAChB,KAAK,EAAE,GAAG,CAAC,KAAK;4BAChB,KAAK,EAAE,GAAG,CAAC,KAAK;yBACnB,CAAC,CAAC,IAAI,EAAE,CAAC;wBAEV,OAAO,CACH,KAAC,YAAY,IAET,KAAK,EAAE,KAAK,CAAC,KAAK,EAClB,OAAO,EAAE,aAAa,EACtB,KAAK,EAAE,aAAa,CAAC,KAAK,CAAC,EAAE,CAAC,EAC9B,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,kBAAkB,CAAC,KAAK,CAAC,EAAE,EAAE,KAAK,CAAC,EACxD,IAAI,EAAE,KAAK,CAAC,IAAI,IAAI,KAAC,MAAM,IAAC,SAAS,EAAC,SAAS,GAAG,EAClD,WAAW,EAAE,KAAK,CAAC,IAAI,KAAK,aAAa,IANpC,KAAK,CAAC,EAAE,CAOf,CACL,CAAC;oBACN,CAAC,CAAC,EAGD,eAAe,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,IAAI,CAC5C,eAAK,SAAS,EAAC,+FAA+F,aAC1G,KAAC,MAAM,IAAC,SAAS,EAAC,SAAS,GAAG,EAC9B,2BAAO,aAAa,CAAC,MAAM,eAAe,IACxC,CACT,EAGA,aAAa,CAAC,MAAM,GAAG,CAAC,IAAI,CACzB,KAAC,MAAM,IACH,OAAO,EAAC,OAAO,EACf,IAAI,EAAC,IAAI,EACT,OAAO,EAAE,cAAc,EACvB,QAAQ,EAAE,KAAC,CAAC,IAAC,SAAS,EAAC,SAAS,GAAG,0BAG9B,CACZ,IACC,EAGL,aAAa,CAAC,MAAM,GAAG,CAAC,IAAI,CACzB,cAAK,SAAS,EAAC,+DAA+D,YACzE,aAAa,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,CAClC,eAEI,SAAS,EAAC,oGAAoG,aAE9G,eAAM,SAAS,EAAC,aAAa,YAAE,MAAM,CAAC,KAAK,GAAQ,EACnD,iBACI,OAAO,EAAE,GAAG,EAAE,CAAC,kBAAkB,CAAC,MAAM,CAAC,EACzC,SAAS,EAAC,8DAA8D,YAExE,KAAC,CAAC,IAAC,SAAS,EAAC,aAAa,GAAG,GACxB,KATJ,GAAG,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,QAAQ,IAAI,KAAK,EAAE,CAUlD,CACT,CAAC,GACA,CACT,IACC,CACT,CAAC;AACN,CAAC,CAAC;AAEF,eAAe,SAAS,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export interface FloatingToolbarAction {
|
|
3
|
+
id: string;
|
|
4
|
+
label?: string;
|
|
5
|
+
icon: React.ReactNode;
|
|
6
|
+
onClick: () => void;
|
|
7
|
+
disabled?: boolean;
|
|
8
|
+
tooltip?: string;
|
|
9
|
+
variant?: 'default' | 'primary' | 'danger';
|
|
10
|
+
}
|
|
11
|
+
export interface FloatingToolbarProps {
|
|
12
|
+
actions: FloatingToolbarAction[];
|
|
13
|
+
position?: 'top' | 'bottom' | 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right';
|
|
14
|
+
variant?: 'default' | 'compact' | 'glass';
|
|
15
|
+
showLabels?: boolean;
|
|
16
|
+
dismissible?: boolean;
|
|
17
|
+
onDismiss?: () => void;
|
|
18
|
+
className?: string;
|
|
19
|
+
offset?: number;
|
|
20
|
+
defaultActiveId?: string;
|
|
21
|
+
}
|
|
22
|
+
export declare const FloatingToolbar: React.FC<FloatingToolbarProps>;
|
|
23
|
+
export default FloatingToolbar;
|
|
24
|
+
//# sourceMappingURL=FloatingToolbar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FloatingToolbar.d.ts","sourceRoot":"","sources":["../../components/FloatingToolbar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA8B,MAAM,OAAO,CAAC;AAGnD,MAAM,WAAW,qBAAqB;IACpC,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC;IACtB,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,SAAS,GAAG,SAAS,GAAG,QAAQ,CAAC;CAC5C;AAED,MAAM,WAAW,oBAAoB;IACnC,OAAO,EAAE,qBAAqB,EAAE,CAAC;IACjC,QAAQ,CAAC,EAAE,KAAK,GAAG,QAAQ,GAAG,UAAU,GAAG,WAAW,GAAG,aAAa,GAAG,cAAc,CAAC;IACxF,OAAO,CAAC,EAAE,SAAS,GAAG,SAAS,GAAG,OAAO,CAAC;IAC1C,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,IAAI,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC,oBAAoB,CAgR1D,CAAC;AAEF,eAAe,eAAe,CAAC"}
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useEffect } from 'react';
|
|
3
|
+
import { X, ChevronUp } from 'lucide-react';
|
|
4
|
+
export const FloatingToolbar = ({ actions, position = 'bottom', variant = 'default', showLabels = false, dismissible = false, onDismiss, className = '', offset = 24, defaultActiveId, }) => {
|
|
5
|
+
const [isExpanded, setIsExpanded] = useState(true);
|
|
6
|
+
const [isAnimating, setIsAnimating] = useState(false);
|
|
7
|
+
const [activeActionId, setActiveActionId] = useState(defaultActiveId);
|
|
8
|
+
useEffect(() => {
|
|
9
|
+
setIsAnimating(true);
|
|
10
|
+
const timer = setTimeout(() => setIsAnimating(false), 300);
|
|
11
|
+
return () => clearTimeout(timer);
|
|
12
|
+
}, []);
|
|
13
|
+
const handleDismiss = () => {
|
|
14
|
+
setIsExpanded(false);
|
|
15
|
+
onDismiss?.();
|
|
16
|
+
};
|
|
17
|
+
const handleExpand = () => {
|
|
18
|
+
setIsExpanded(true);
|
|
19
|
+
};
|
|
20
|
+
const handleActionClick = (action) => {
|
|
21
|
+
setActiveActionId(action.id);
|
|
22
|
+
action.onClick();
|
|
23
|
+
};
|
|
24
|
+
const positionClasses = {
|
|
25
|
+
top: 'top-0 left-1/2 -translate-x-1/2',
|
|
26
|
+
bottom: 'bottom-0 left-1/2 -translate-x-1/2',
|
|
27
|
+
'top-left': 'top-0 left-0',
|
|
28
|
+
'top-right': 'top-0 right-0',
|
|
29
|
+
'bottom-left': 'bottom-0 left-0',
|
|
30
|
+
'bottom-right': 'bottom-0 right-0',
|
|
31
|
+
};
|
|
32
|
+
const variantClasses = {
|
|
33
|
+
default: 'bg-surface-primary border border-border-primary shadow-lg',
|
|
34
|
+
compact: 'bg-surface-primary border border-border-primary shadow-md',
|
|
35
|
+
glass: 'glass border border-border-primary shadow-xl',
|
|
36
|
+
};
|
|
37
|
+
const animationClasses = {
|
|
38
|
+
top: isAnimating ? 'animate-slide-down' : '',
|
|
39
|
+
bottom: isAnimating ? 'animate-slide-up' : '',
|
|
40
|
+
'top-left': isAnimating ? 'animate-scale-in' : '',
|
|
41
|
+
'top-right': isAnimating ? 'animate-scale-in' : '',
|
|
42
|
+
'bottom-left': isAnimating ? 'animate-scale-in' : '',
|
|
43
|
+
'bottom-right': isAnimating ? 'animate-scale-in' : '',
|
|
44
|
+
};
|
|
45
|
+
const getActionVariantClasses = (actionVariant, isActive) => {
|
|
46
|
+
if (isActive) {
|
|
47
|
+
return 'text-accent-blue border-b-2 border-accent-blue';
|
|
48
|
+
}
|
|
49
|
+
switch (actionVariant) {
|
|
50
|
+
case 'primary':
|
|
51
|
+
return 'text-accent-blue hover:bg-accent-blue/10';
|
|
52
|
+
case 'danger':
|
|
53
|
+
return 'text-status-error hover:bg-status-error/10';
|
|
54
|
+
default:
|
|
55
|
+
return 'text-text-primary hover:bg-background-tertiary/50';
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
// Collapsed state - show small expand button
|
|
59
|
+
if (!isExpanded && dismissible) {
|
|
60
|
+
return (_jsx("div", { className: `floating-toolbar-collapsed fixed ${positionClasses[position]} z-50 ${className}`, style: {
|
|
61
|
+
margin: `${offset}px`,
|
|
62
|
+
}, children: _jsx("button", { onClick: handleExpand, className: `${variantClasses[variant]} rounded-full p-3 hover:scale-110 transition-all duration-200 animate-scale-in`, "aria-label": "Expand toolbar", children: _jsx(ChevronUp, { className: "w-5 h-5 text-text-primary" }) }) }));
|
|
63
|
+
}
|
|
64
|
+
return (_jsxs("div", { className: `floating-toolbar fixed ${positionClasses[position]} ${animationClasses[position]} z-50 ${className}`, style: {
|
|
65
|
+
margin: `${offset}px`,
|
|
66
|
+
}, children: [_jsxs("div", { className: `toolbar-container ${variantClasses[variant]} rounded-2xl ${variant === 'compact' ? 'p-1.5' : 'p-2'} flex items-center gap-1`, children: [_jsx("div", { className: "flex items-center gap-1", children: actions.map((action) => {
|
|
67
|
+
const isActive = activeActionId === action.id;
|
|
68
|
+
return (_jsxs("button", { onClick: () => handleActionClick(action), disabled: action.disabled, className: `toolbar-action relative flex items-center gap-2 ${variant === 'compact' ? 'px-2.5 py-2' : 'px-3 py-2.5'} rounded-xl font-medium text-sm transition-all duration-200 ${getActionVariantClasses(action.variant, isActive)} disabled:opacity-40 disabled:cursor-not-allowed group`, title: action.tooltip || action.label, "aria-label": action.label || action.tooltip, "aria-pressed": isActive, children: [_jsx("span", { className: "flex-shrink-0 w-5 h-5", children: action.icon }), showLabels && action.label && (_jsx("span", { className: "whitespace-nowrap", children: action.label })), action.tooltip && !showLabels && !isActive && (_jsxs("span", { className: "tooltip absolute bottom-full left-1/2 -translate-x-1/2 mb-2 px-3 py-1.5 bg-gray-900 dark:bg-gray-100 text-white dark:text-gray-900 text-xs font-medium rounded-lg opacity-0 invisible group-hover:opacity-100 group-hover:visible transition-all duration-200 whitespace-nowrap pointer-events-none shadow-lg", children: [action.tooltip, _jsx("span", { className: "tooltip-arrow absolute top-full left-1/2 -translate-x-1/2 -mt-px border-4 border-transparent border-t-gray-900 dark:border-t-gray-100" })] }))] }, action.id));
|
|
69
|
+
}) }), dismissible && (_jsxs(_Fragment, { children: [_jsx("div", { className: "w-px h-6 bg-border-primary mx-1" }), _jsx("button", { onClick: handleDismiss, className: `dismiss-button flex items-center justify-center ${variant === 'compact' ? 'w-8 h-8' : 'w-9 h-9'} rounded-xl text-text-secondary hover:text-text-primary hover:bg-background-tertiary/50 transition-all duration-200`, "aria-label": "Collapse toolbar", children: _jsx(X, { className: "w-4 h-4" }) })] }))] }), _jsx("style", { dangerouslySetInnerHTML: {
|
|
70
|
+
__html: `
|
|
71
|
+
.floating-toolbar {
|
|
72
|
+
-webkit-font-smoothing: antialiased;
|
|
73
|
+
-moz-osx-font-smoothing: grayscale;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
.toolbar-container {
|
|
77
|
+
user-select: none;
|
|
78
|
+
-webkit-user-select: none;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
.toolbar-action {
|
|
82
|
+
position: relative;
|
|
83
|
+
overflow: visible;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
.toolbar-action:not([aria-pressed="true"])::before {
|
|
87
|
+
content: '';
|
|
88
|
+
position: absolute;
|
|
89
|
+
inset: 0;
|
|
90
|
+
border-radius: 12px;
|
|
91
|
+
background: currentColor;
|
|
92
|
+
opacity: 0;
|
|
93
|
+
transition: opacity 200ms cubic-bezier(0.16, 1, 0.3, 1);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
.toolbar-action:not([aria-pressed="true"]):hover::before {
|
|
97
|
+
opacity: 0.08;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
.toolbar-action:not([aria-pressed="true"]):active::before {
|
|
101
|
+
opacity: 0.12;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
.toolbar-action:disabled::before {
|
|
105
|
+
opacity: 0;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
.tooltip {
|
|
109
|
+
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
|
|
110
|
+
z-index: 100;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
.dark .tooltip {
|
|
114
|
+
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
@keyframes slideUp {
|
|
118
|
+
from {
|
|
119
|
+
opacity: 0;
|
|
120
|
+
transform: translateY(12px) translateX(-50%);
|
|
121
|
+
}
|
|
122
|
+
to {
|
|
123
|
+
opacity: 1;
|
|
124
|
+
transform: translateY(0) translateX(-50%);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
@keyframes slideDown {
|
|
129
|
+
from {
|
|
130
|
+
opacity: 0;
|
|
131
|
+
transform: translateY(-12px) translateX(-50%);
|
|
132
|
+
}
|
|
133
|
+
to {
|
|
134
|
+
opacity: 1;
|
|
135
|
+
transform: translateY(0) translateX(-50%);
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
@keyframes scaleIn {
|
|
140
|
+
from {
|
|
141
|
+
opacity: 0;
|
|
142
|
+
transform: scale(0.92);
|
|
143
|
+
}
|
|
144
|
+
to {
|
|
145
|
+
opacity: 1;
|
|
146
|
+
transform: scale(1);
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
.animate-slide-up {
|
|
151
|
+
animation: slideUp 300ms cubic-bezier(0.16, 1, 0.3, 1);
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
.animate-slide-down {
|
|
155
|
+
animation: slideDown 300ms cubic-bezier(0.16, 1, 0.3, 1);
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
.animate-scale-in {
|
|
159
|
+
animation: scaleIn 300ms cubic-bezier(0.16, 1, 0.3, 1);
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
@media (max-width: 640px) {
|
|
163
|
+
.floating-toolbar {
|
|
164
|
+
max-width: calc(100vw - 32px);
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
.toolbar-container {
|
|
168
|
+
overflow-x: auto;
|
|
169
|
+
-webkit-overflow-scrolling: touch;
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
.toolbar-container::-webkit-scrollbar {
|
|
173
|
+
display: none;
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
`,
|
|
177
|
+
} })] }));
|
|
178
|
+
};
|
|
179
|
+
export default FloatingToolbar;
|
|
180
|
+
//# sourceMappingURL=FloatingToolbar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FloatingToolbar.js","sourceRoot":"","sources":["../../components/FloatingToolbar.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export interface FooterProps extends React.HTMLAttributes<HTMLElement> {
|
|
3
|
+
children: React.ReactNode;
|
|
4
|
+
}
|
|
5
|
+
export declare const Footer: React.ForwardRefExoticComponent<FooterProps & React.RefAttributes<HTMLElement>>;
|
|
6
|
+
export interface FooterTopProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
7
|
+
title?: string;
|
|
8
|
+
description?: string;
|
|
9
|
+
icon?: React.ReactNode;
|
|
10
|
+
socials?: React.ReactNode;
|
|
11
|
+
}
|
|
12
|
+
export declare const FooterTop: React.ForwardRefExoticComponent<FooterTopProps & React.RefAttributes<HTMLDivElement>>;
|
|
13
|
+
export interface FooterContentProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
14
|
+
children: React.ReactNode;
|
|
15
|
+
}
|
|
16
|
+
export declare const FooterContent: React.ForwardRefExoticComponent<FooterContentProps & React.RefAttributes<HTMLDivElement>>;
|
|
17
|
+
export interface FooterColumnProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
18
|
+
title?: string;
|
|
19
|
+
children: React.ReactNode;
|
|
20
|
+
/** Number of columns to span (out of 12). Defaults to auto-sizing (equal width) */
|
|
21
|
+
span?: number;
|
|
22
|
+
}
|
|
23
|
+
export declare const FooterColumn: React.ForwardRefExoticComponent<FooterColumnProps & React.RefAttributes<HTMLDivElement>>;
|
|
24
|
+
export interface FooterLinkProps extends React.AnchorHTMLAttributes<HTMLAnchorElement> {
|
|
25
|
+
as?: React.ElementType;
|
|
26
|
+
}
|
|
27
|
+
export declare const FooterLink: React.ForwardRefExoticComponent<FooterLinkProps & React.RefAttributes<HTMLAnchorElement>>;
|
|
28
|
+
export interface FooterBottomProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
29
|
+
children: React.ReactNode;
|
|
30
|
+
}
|
|
31
|
+
export declare const FooterBottom: React.ForwardRefExoticComponent<FooterBottomProps & React.RefAttributes<HTMLDivElement>>;
|
|
32
|
+
//# sourceMappingURL=Footer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Footer.d.ts","sourceRoot":"","sources":["../../components/Footer.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAQ1B,MAAM,WAAW,WAAY,SAAQ,KAAK,CAAC,cAAc,CAAC,WAAW,CAAC;IAClE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC7B;AAED,eAAO,MAAM,MAAM,iFAelB,CAAC;AAQF,MAAM,WAAW,cACb,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC5C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC7B;AAED,eAAO,MAAM,SAAS,uFAuCrB,CAAC;AAQF,MAAM,WAAW,kBACb,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC5C,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC7B;AAED,eAAO,MAAM,aAAa,2FAkBxB,CAAC;AAQH,MAAM,WAAW,iBACb,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC5C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,mFAAmF;IACnF,IAAI,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,eAAO,MAAM,YAAY,0FAyBvB,CAAC;AAOH,MAAM,WAAW,eACb,SAAQ,KAAK,CAAC,oBAAoB,CAAC,iBAAiB,CAAC;IACrD,EAAE,CAAC,EAAE,KAAK,CAAC,WAAW,CAAC;CAC1B;AAED,eAAO,MAAM,UAAU,2FAgBrB,CAAC;AAOH,MAAM,WAAW,iBACb,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC5C,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC7B;AAED,eAAO,MAAM,YAAY,0FAgBvB,CAAC"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { cn } from '../lib/utils';
|
|
4
|
+
import { Col, GridContainer, Row } from './GridSystem';
|
|
5
|
+
export const Footer = React.forwardRef(({ className, children, ...props }, ref) => {
|
|
6
|
+
return (_jsx("footer", { ref: ref, className: cn('w-full bg-surface-secondary border-t border-border-primary pt-12 pb-10', className), ...props, children: children }));
|
|
7
|
+
});
|
|
8
|
+
Footer.displayName = 'Footer';
|
|
9
|
+
export const FooterTop = React.forwardRef(({ className, title = "Acme Inc.", description, icon, socials, ...props }, ref) => {
|
|
10
|
+
return (_jsxs(GridContainer, { ref: ref, className: cn("max-w-3xl flex flex-col items-center text-center mb-12", className), ...props, children: [icon ? (icon) : (_jsx("div", { className: "w-14 h-14 rounded-full bg-text-primary text-background flex items-center justify-center text-lg font-bold", children: "A" })), _jsx("h2", { className: "text-xl font-semibold mt-4", children: title }), description && (_jsx("p", { className: "mt-2 text-sm text-text-secondary max-w-prose", children: description })), socials && (_jsx("div", { className: "flex items-center gap-4 mt-4 text-text-secondary", children: socials }))] }));
|
|
11
|
+
});
|
|
12
|
+
FooterTop.displayName = "FooterTop";
|
|
13
|
+
export const FooterContent = React.forwardRef(({ className, children, ...props }, ref) => {
|
|
14
|
+
return (_jsx(GridContainer, { as: "div", ref: ref, className: cn(className), ...props, children: _jsx(Row, { className: "justify-between w-full", children: children }) }));
|
|
15
|
+
});
|
|
16
|
+
FooterContent.displayName = 'FooterContent';
|
|
17
|
+
export const FooterColumn = React.forwardRef(({ className, title, children, span, ...props }, ref) => {
|
|
18
|
+
return (_jsxs(Col, { ref: ref, xs: 12, md: span || true, className: cn('flex flex-col gap-3 mb-8 md:mb-0',
|
|
19
|
+
// Reset width on desktop if using auto-layout (flex-1), so w-full from xs doesn't persist
|
|
20
|
+
!span && 'md:w-auto md:flex-1', className), ...props, children: [title && (_jsx("h3", { className: "font-semibold text-text-primary text-sm tracking-wide uppercase mb-1", children: title })), _jsx("div", { className: "flex flex-col gap-2", children: children })] }));
|
|
21
|
+
});
|
|
22
|
+
FooterColumn.displayName = 'FooterColumn';
|
|
23
|
+
export const FooterLink = React.forwardRef(({ className, as: Component = 'a', children, ...props }, ref) => {
|
|
24
|
+
return (_jsx(Component, { ref: ref, className: cn('text-sm text-text-secondary hover:text-text-primary transition-colors w-fit', className), ...props, children: children }));
|
|
25
|
+
});
|
|
26
|
+
FooterLink.displayName = 'FooterLink';
|
|
27
|
+
export const FooterBottom = React.forwardRef(({ className, children, ...props }, ref) => {
|
|
28
|
+
return (_jsx(GridContainer, { ref: ref, className: cn('pt-8 mt-8 border-t border-border-primary flex flex-col md:flex-row justify-between items-center gap-4 text-sm text-text-tertiary', className), ...props, children: children }));
|
|
29
|
+
});
|
|
30
|
+
FooterBottom.displayName = 'FooterBottom';
|
|
31
|
+
//# sourceMappingURL=Footer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Footer.js","sourceRoot":"","sources":["../../components/Footer.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { LightboxImage } from './Lightbox';
|
|
3
|
+
export interface GalleryProps {
|
|
4
|
+
images: LightboxImage[];
|
|
5
|
+
columns?: number;
|
|
6
|
+
gap?: number;
|
|
7
|
+
aspectRatio?: 'square' | 'video' | 'portrait' | 'auto';
|
|
8
|
+
className?: string;
|
|
9
|
+
}
|
|
10
|
+
export declare const Gallery: React.FC<GalleryProps>;
|
|
11
|
+
//# sourceMappingURL=Gallery.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Gallery.d.ts","sourceRoot":"","sources":["../../components/Gallery.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAmB,MAAM,OAAO,CAAC;AAGxC,OAAO,EAAY,aAAa,EAAE,MAAM,YAAY,CAAC;AAGrD,MAAM,WAAW,YAAY;IACzB,MAAM,EAAE,aAAa,EAAE,CAAC;IACxB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,WAAW,CAAC,EAAE,QAAQ,GAAG,OAAO,GAAG,UAAU,GAAG,MAAM,CAAC;IACvD,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AA+DD,eAAO,MAAM,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAuD1C,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { useState } from 'react';
|
|
3
|
+
import { motion } from 'framer-motion';
|
|
4
|
+
import { cn } from '../lib/utils';
|
|
5
|
+
import { Lightbox } from './Lightbox';
|
|
6
|
+
import { Maximize2, ImageOff } from 'lucide-react';
|
|
7
|
+
const GalleryItem = ({ image, index, aspectRatio, getAspectRatioClass, onClick }) => {
|
|
8
|
+
const [hasError, setHasError] = useState(false);
|
|
9
|
+
return (_jsxs(motion.div, { layoutId: `gallery-image-${index}`, className: cn("group relative overflow-hidden rounded-xl bg-surface-secondary cursor-zoom-in", getAspectRatioClass()), onClick: onClick, whileHover: { scale: 1.02 }, transition: { type: "spring", stiffness: 400, damping: 30 }, children: [hasError ? (_jsxs("div", { className: "w-full h-full flex flex-col items-center justify-center bg-surface-tertiary text-text-secondary p-4 text-center select-none", children: [_jsx(ImageOff, { className: "w-8 h-8 mb-2 opacity-50" }), _jsx("span", { className: "text-xs font-medium opacity-70 truncate max-w-full px-2", children: image.alt || "Image not found" })] })) : (_jsx("img", { src: image.src, alt: image.alt || `Gallery image ${index + 1}`, className: cn("w-full h-full object-cover transition-transform duration-500 group-hover:scale-110", aspectRatio === 'auto' ? "h-auto" : ""), loading: "lazy", onError: () => setHasError(true) })), !hasError && (_jsx("div", { className: "absolute inset-0 bg-black/0 group-hover:bg-black/20 transition-colors duration-300 flex items-center justify-center opacity-0 group-hover:opacity-100", children: _jsx("div", { className: "bg-black/50 backdrop-blur-sm p-2 rounded-full text-white", children: _jsx(Maximize2, { className: "w-5 h-5" }) }) })), image.caption && !hasError && (_jsx("div", { className: "absolute bottom-0 left-0 right-0 p-3 bg-gradient-to-t from-black/80 to-transparent opacity-0 group-hover:opacity-100 transition-opacity duration-300 translate-y-2 group-hover:translate-y-0", children: _jsx("p", { className: "text-white text-xs font-medium truncate", children: image.caption }) }))] }));
|
|
10
|
+
};
|
|
11
|
+
export const Gallery = ({ images, columns = 3, gap = 16, aspectRatio = 'square', className, }) => {
|
|
12
|
+
const [lightboxOpen, setLightboxOpen] = useState(false);
|
|
13
|
+
const [currentIndex, setCurrentIndex] = useState(0);
|
|
14
|
+
const openLightbox = (index) => {
|
|
15
|
+
setCurrentIndex(index);
|
|
16
|
+
setLightboxOpen(true);
|
|
17
|
+
};
|
|
18
|
+
const getAspectRatioClass = () => {
|
|
19
|
+
switch (aspectRatio) {
|
|
20
|
+
case 'square': return 'aspect-square';
|
|
21
|
+
case 'video': return 'aspect-video';
|
|
22
|
+
case 'portrait': return 'aspect-[3/4]';
|
|
23
|
+
case 'auto': return '';
|
|
24
|
+
default: return 'aspect-square';
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
return (_jsxs(_Fragment, { children: [_jsx("div", { className: cn("grid", className), style: {
|
|
28
|
+
gridTemplateColumns: `repeat(auto-fill, minmax(min(100%, ${100 / columns}% - ${gap}px), 1fr))`,
|
|
29
|
+
gap: `${gap}px`
|
|
30
|
+
}, children: images.map((image, index) => (_jsx(GalleryItem, { image: image, index: index, aspectRatio: aspectRatio, getAspectRatioClass: getAspectRatioClass, onClick: () => openLightbox(index) }, index))) }), _jsx(Lightbox, { isOpen: lightboxOpen, images: images, currentIndex: currentIndex, onClose: () => setLightboxOpen(false), onIndexChange: setCurrentIndex })] }));
|
|
31
|
+
};
|
|
32
|
+
//# sourceMappingURL=Gallery.js.map
|