@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,15 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export type AvatarGroupSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';
|
|
3
|
+
export interface AvatarGroupItem {
|
|
4
|
+
src?: string;
|
|
5
|
+
alt: string;
|
|
6
|
+
fallback?: string;
|
|
7
|
+
}
|
|
8
|
+
export interface AvatarGroupProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
9
|
+
items: AvatarGroupItem[];
|
|
10
|
+
max?: number;
|
|
11
|
+
size?: AvatarGroupSize;
|
|
12
|
+
showTooltip?: boolean;
|
|
13
|
+
}
|
|
14
|
+
export declare const AvatarGroup: React.ForwardRefExoticComponent<AvatarGroupProps & React.RefAttributes<HTMLDivElement>>;
|
|
15
|
+
//# sourceMappingURL=AvatarGroup.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AvatarGroup.d.ts","sourceRoot":"","sources":["../../components/AvatarGroup.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAC;AAQ1C,MAAM,MAAM,eAAe,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;AAE/D,MAAM,WAAW,eAAe;IAC5B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,gBAAiB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC1E,KAAK,EAAE,eAAe,EAAE,CAAC;IACzB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,eAAe,CAAC;IACvB,WAAW,CAAC,EAAE,OAAO,CAAC;CACzB;AAMD,eAAO,MAAM,WAAW,yFA0FvB,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef } from 'react';
|
|
3
|
+
import { cn } from '../lib/utils';
|
|
4
|
+
import { motion } from 'framer-motion';
|
|
5
|
+
/* ========================================
|
|
6
|
+
AVATAR GROUP COMPONENT
|
|
7
|
+
======================================== */
|
|
8
|
+
export const AvatarGroup = forwardRef(({ items, max = 5, size = 'md', showTooltip = true, className, ...props }, ref) => {
|
|
9
|
+
const sizes = {
|
|
10
|
+
xs: "w-6 h-6 text-xs",
|
|
11
|
+
sm: "w-8 h-8 text-sm",
|
|
12
|
+
md: "w-10 h-10 text-base",
|
|
13
|
+
lg: "w-12 h-12 text-lg",
|
|
14
|
+
xl: "w-14 h-14 text-xl",
|
|
15
|
+
};
|
|
16
|
+
const displayItems = items.slice(0, max);
|
|
17
|
+
const remainingCount = items.length - max;
|
|
18
|
+
const getInitials = (name) => {
|
|
19
|
+
const parts = name.split(' ');
|
|
20
|
+
if (parts.length >= 2) {
|
|
21
|
+
return `${parts[0][0]}${parts[1][0]}`.toUpperCase();
|
|
22
|
+
}
|
|
23
|
+
return name.slice(0, 2).toUpperCase();
|
|
24
|
+
};
|
|
25
|
+
return (_jsxs("div", { ref: ref, className: cn("flex items-center -space-x-2", className), ...props, children: [displayItems.map((item, index) => (_jsxs(motion.div, { initial: { scale: 0, opacity: 0 }, animate: { scale: 1, opacity: 1 }, transition: { delay: index * 0.05 }, className: "relative group", children: [_jsx("div", { className: cn("relative inline-flex items-center justify-center rounded-full border-2 border-surface-primary bg-surface-secondary overflow-hidden ring-0 hover:ring-2 hover:ring-accent-blue/20 transition-all hover:z-10", sizes[size]), children: item.src ? (_jsx("img", { src: item.src, alt: item.alt, className: "w-full h-full object-cover" })) : (_jsx("span", { className: "font-medium text-text-primary", children: item.fallback || getInitials(item.alt) })) }), showTooltip && (_jsx("div", { className: "absolute bottom-full left-1/2 -translate-x-1/2 mb-2 px-2 py-1 bg-surface-elevated border border-border-primary rounded-lg shadow-lg opacity-0 group-hover:opacity-100 transition-opacity pointer-events-none whitespace-nowrap z-20", children: _jsx("span", { className: "text-xs text-text-primary", children: item.alt }) }))] }, index))), remainingCount > 0 && (_jsxs(motion.div, { initial: { scale: 0, opacity: 0 }, animate: { scale: 1, opacity: 1 }, transition: { delay: displayItems.length * 0.05 }, className: cn("relative inline-flex items-center justify-center rounded-full border-2 border-surface-primary bg-surface-tertiary font-medium text-text-secondary hover:bg-surface-secondary hover:ring-2 hover:ring-accent-blue/20 transition-all cursor-default hover:z-10", sizes[size]), children: ["+", remainingCount] }))] }));
|
|
26
|
+
});
|
|
27
|
+
AvatarGroup.displayName = 'AvatarGroup';
|
|
28
|
+
//# sourceMappingURL=AvatarGroup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AvatarGroup.js","sourceRoot":"","sources":["../../components/AvatarGroup.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { HTMLMotionProps } from 'framer-motion';
|
|
3
|
+
export type BadgeVariant = 'default' | 'primary' | 'success' | 'warning' | 'error' | 'info';
|
|
4
|
+
export type BadgeSize = 'sm' | 'md' | 'lg';
|
|
5
|
+
export interface BadgeProps extends Omit<HTMLMotionProps<'span'>, 'size'> {
|
|
6
|
+
variant?: BadgeVariant;
|
|
7
|
+
size?: BadgeSize;
|
|
8
|
+
dot?: boolean;
|
|
9
|
+
children?: React.ReactNode;
|
|
10
|
+
}
|
|
11
|
+
export declare const Badge: React.ForwardRefExoticComponent<Omit<BadgeProps, "ref"> & React.RefAttributes<HTMLSpanElement>>;
|
|
12
|
+
export interface NotificationBadgeProps {
|
|
13
|
+
count?: number;
|
|
14
|
+
max?: number;
|
|
15
|
+
showZero?: boolean;
|
|
16
|
+
dot?: boolean;
|
|
17
|
+
children: React.ReactNode;
|
|
18
|
+
className?: string;
|
|
19
|
+
}
|
|
20
|
+
export declare const NotificationBadge: React.FC<NotificationBadgeProps>;
|
|
21
|
+
//# sourceMappingURL=Badge.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Badge.d.ts","sourceRoot":"","sources":["../../components/Badge.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAU,eAAe,EAAE,MAAM,eAAe,CAAC;AAMxD,MAAM,MAAM,YAAY,GAAG,SAAS,GAAG,SAAS,GAAG,SAAS,GAAG,SAAS,GAAG,OAAO,GAAG,MAAM,CAAC;AAC5F,MAAM,MAAM,SAAS,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;AAE3C,MAAM,WAAW,UAAW,SAAQ,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC;IACvE,OAAO,CAAC,EAAE,YAAY,CAAC;IACvB,IAAI,CAAC,EAAE,SAAS,CAAC;IACjB,GAAG,CAAC,EAAE,OAAO,CAAC;IACd,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC5B;AAuDD,eAAO,MAAM,KAAK,iGA2DjB,CAAC;AAQF,MAAM,WAAW,sBAAsB;IACrC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,GAAG,CAAC,EAAE,OAAO,CAAC;IACd,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,eAAO,MAAM,iBAAiB,EAAE,KAAK,CAAC,EAAE,CAAC,sBAAsB,CA2C9D,CAAC"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { motion } from 'framer-motion';
|
|
4
|
+
/* ========================================
|
|
5
|
+
STYLES
|
|
6
|
+
======================================== */
|
|
7
|
+
const baseStyles = `
|
|
8
|
+
inline-flex items-center justify-center gap-1.5
|
|
9
|
+
font-medium
|
|
10
|
+
rounded-full
|
|
11
|
+
transition-apple
|
|
12
|
+
`;
|
|
13
|
+
const variantStyles = {
|
|
14
|
+
default: `
|
|
15
|
+
bg-surface-secondary
|
|
16
|
+
text-text-primary
|
|
17
|
+
border border-border-primary
|
|
18
|
+
`,
|
|
19
|
+
primary: `
|
|
20
|
+
bg-accent-blue
|
|
21
|
+
text-white
|
|
22
|
+
`,
|
|
23
|
+
success: `
|
|
24
|
+
bg-status-success/10
|
|
25
|
+
text-status-success
|
|
26
|
+
border border-status-success/20
|
|
27
|
+
`,
|
|
28
|
+
warning: `
|
|
29
|
+
bg-status-warning/10
|
|
30
|
+
text-status-warning
|
|
31
|
+
border border-status-warning/20
|
|
32
|
+
`,
|
|
33
|
+
error: `
|
|
34
|
+
bg-status-error/10
|
|
35
|
+
text-status-error
|
|
36
|
+
border border-status-error/20
|
|
37
|
+
`,
|
|
38
|
+
info: `
|
|
39
|
+
bg-status-info/10
|
|
40
|
+
text-status-info
|
|
41
|
+
border border-status-info/20
|
|
42
|
+
`,
|
|
43
|
+
};
|
|
44
|
+
const sizeStyles = {
|
|
45
|
+
sm: 'h-5 px-2 text-xs',
|
|
46
|
+
md: 'h-6 px-2.5 text-sm',
|
|
47
|
+
lg: 'h-7 px-3 text-base',
|
|
48
|
+
};
|
|
49
|
+
/* ========================================
|
|
50
|
+
COMPONENT
|
|
51
|
+
======================================== */
|
|
52
|
+
export const Badge = React.forwardRef(({ variant = 'default', size = 'md', dot = false, children, className = '', ...props }, ref) => {
|
|
53
|
+
const combinedClassName = `
|
|
54
|
+
${baseStyles}
|
|
55
|
+
${variantStyles[variant]}
|
|
56
|
+
${sizeStyles[size]}
|
|
57
|
+
${className}
|
|
58
|
+
`.trim().replace(/\s+/g, ' ');
|
|
59
|
+
const dotSizeMap = {
|
|
60
|
+
sm: 'w-1.5 h-1.5',
|
|
61
|
+
md: 'w-2 h-2',
|
|
62
|
+
lg: 'w-2.5 h-2.5',
|
|
63
|
+
};
|
|
64
|
+
const dotColorMap = {
|
|
65
|
+
default: 'bg-text-primary',
|
|
66
|
+
primary: 'bg-white',
|
|
67
|
+
success: 'bg-status-success',
|
|
68
|
+
warning: 'bg-status-warning',
|
|
69
|
+
error: 'bg-status-error',
|
|
70
|
+
info: 'bg-status-info',
|
|
71
|
+
};
|
|
72
|
+
return (_jsxs(motion.span, { ref: ref, className: combinedClassName, initial: { opacity: 0, scale: 0.9 }, animate: { opacity: 1, scale: 1 }, transition: {
|
|
73
|
+
duration: 0.16,
|
|
74
|
+
ease: [0.16, 1, 0.3, 1],
|
|
75
|
+
}, ...props, children: [dot && (_jsx("span", { className: `
|
|
76
|
+
${dotSizeMap[size]}
|
|
77
|
+
${dotColorMap[variant]}
|
|
78
|
+
rounded-full
|
|
79
|
+
` })), children] }));
|
|
80
|
+
});
|
|
81
|
+
Badge.displayName = 'Badge';
|
|
82
|
+
export const NotificationBadge = ({ count = 0, max = 99, showZero = false, dot = false, children, className = '', }) => {
|
|
83
|
+
const displayCount = count > max ? `${max}+` : count;
|
|
84
|
+
const shouldShow = count > 0 || showZero;
|
|
85
|
+
return (_jsxs("div", { className: `relative inline-flex ${className}`, children: [children, shouldShow && (_jsx(motion.span, { className: `
|
|
86
|
+
absolute -top-1 -right-1
|
|
87
|
+
${dot
|
|
88
|
+
? 'w-2 h-2'
|
|
89
|
+
: 'min-w-[18px] h-[18px] px-1'}
|
|
90
|
+
flex items-center justify-center
|
|
91
|
+
bg-status-error
|
|
92
|
+
text-white
|
|
93
|
+
text-xs
|
|
94
|
+
font-semibold
|
|
95
|
+
rounded-full
|
|
96
|
+
border-2 border-background-primary
|
|
97
|
+
`, initial: { scale: 0 }, animate: { scale: 1 }, transition: {
|
|
98
|
+
type: 'spring',
|
|
99
|
+
stiffness: 500,
|
|
100
|
+
damping: 25,
|
|
101
|
+
}, children: !dot && displayCount }))] }));
|
|
102
|
+
};
|
|
103
|
+
//# sourceMappingURL=Badge.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Badge.js","sourceRoot":"","sources":["../../components/Badge.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export type BarcodeFormat = 'code128' | 'ean13' | 'upca' | 'code39' | 'itf14' | 'qrcode';
|
|
3
|
+
export interface BarcodeGeneratorProps {
|
|
4
|
+
/** Initial value for the barcode */
|
|
5
|
+
defaultValue?: string;
|
|
6
|
+
/** Barcode format (default: code128) */
|
|
7
|
+
format?: BarcodeFormat;
|
|
8
|
+
/** Scale factor (1-5, default: 3) */
|
|
9
|
+
scale?: number;
|
|
10
|
+
/** Show the text value below the barcode */
|
|
11
|
+
includeText?: boolean;
|
|
12
|
+
/** Show an internal input to change the value */
|
|
13
|
+
showInput?: boolean;
|
|
14
|
+
/** Class name for the container */
|
|
15
|
+
className?: string;
|
|
16
|
+
}
|
|
17
|
+
export declare const BarcodeGenerator: React.FC<BarcodeGeneratorProps>;
|
|
18
|
+
//# sourceMappingURL=BarcodeGenerator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BarcodeGenerator.d.ts","sourceRoot":"","sources":["../../components/BarcodeGenerator.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA8B,MAAM,OAAO,CAAC;AAOnD,MAAM,MAAM,aAAa,GAAG,SAAS,GAAG,OAAO,GAAG,MAAM,GAAG,QAAQ,GAAG,OAAO,GAAG,QAAQ,CAAC;AAEzF,MAAM,WAAW,qBAAqB;IAClC,oCAAoC;IACpC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,wCAAwC;IACxC,MAAM,CAAC,EAAE,aAAa,CAAC;IACvB,qCAAqC;IACrC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,4CAA4C;IAC5C,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,iDAAiD;IACjD,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,mCAAmC;IACnC,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,qBAAqB,CAmJ5D,CAAC"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useEffect } from 'react';
|
|
3
|
+
import { cn } from '../lib/utils';
|
|
4
|
+
import { Button } from './Button';
|
|
5
|
+
import { Input } from './Input';
|
|
6
|
+
import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from './Select';
|
|
7
|
+
import { Download, Copy, Check, RefreshCw, Barcode } from 'lucide-react';
|
|
8
|
+
export const BarcodeGenerator = ({ defaultValue = "1234567890", format = "code128", scale = 3, includeText = true, showInput = false, className }) => {
|
|
9
|
+
const [value, setValue] = useState(defaultValue);
|
|
10
|
+
const [selectedFormat, setSelectedFormat] = useState(format);
|
|
11
|
+
const [imgSrc, setImgSrc] = useState("");
|
|
12
|
+
const [isLoading, setIsLoading] = useState(true);
|
|
13
|
+
const [isCopied, setIsCopied] = useState(false);
|
|
14
|
+
// Generate URL using bwip-js API
|
|
15
|
+
useEffect(() => {
|
|
16
|
+
if (!value)
|
|
17
|
+
return;
|
|
18
|
+
setIsLoading(true);
|
|
19
|
+
const encodedValue = encodeURIComponent(value);
|
|
20
|
+
// bwip-js API parameters
|
|
21
|
+
// bcid: Barcode type
|
|
22
|
+
// text: Text to encode
|
|
23
|
+
// scale: Scale factor (x-axis)
|
|
24
|
+
// rotate: Rotation (N, R, L, I)
|
|
25
|
+
// includetext: Show human readable text
|
|
26
|
+
const url = `https://bwipjs-api.metafloor.com/?bcid=${selectedFormat}&text=${encodedValue}&scale=${scale}&rotate=N${includeText ? '&includetext' : ''}`;
|
|
27
|
+
// Preload image
|
|
28
|
+
const img = new Image();
|
|
29
|
+
img.src = url;
|
|
30
|
+
img.onload = () => {
|
|
31
|
+
setImgSrc(url);
|
|
32
|
+
setIsLoading(false);
|
|
33
|
+
};
|
|
34
|
+
img.onerror = () => {
|
|
35
|
+
// Handle error (e.g. invalid characters for format)
|
|
36
|
+
setIsLoading(false);
|
|
37
|
+
};
|
|
38
|
+
}, [value, selectedFormat, scale, includeText]);
|
|
39
|
+
const handleDownload = async () => {
|
|
40
|
+
try {
|
|
41
|
+
const response = await fetch(imgSrc);
|
|
42
|
+
const blob = await response.blob();
|
|
43
|
+
const url = window.URL.createObjectURL(blob);
|
|
44
|
+
const link = document.createElement('a');
|
|
45
|
+
link.href = url;
|
|
46
|
+
link.download = `barcode-${value}-${Date.now()}.png`;
|
|
47
|
+
document.body.appendChild(link);
|
|
48
|
+
link.click();
|
|
49
|
+
document.body.removeChild(link);
|
|
50
|
+
window.URL.revokeObjectURL(url);
|
|
51
|
+
}
|
|
52
|
+
catch (error) {
|
|
53
|
+
console.error("Error downloading barcode:", error);
|
|
54
|
+
window.open(imgSrc, '_blank');
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
const handleCopyValue = () => {
|
|
58
|
+
navigator.clipboard.writeText(value);
|
|
59
|
+
setIsCopied(true);
|
|
60
|
+
setTimeout(() => setIsCopied(false), 2000);
|
|
61
|
+
};
|
|
62
|
+
return (_jsxs("div", { className: cn("flex flex-col items-center gap-6 p-6 rounded-2xl bg-surface-primary border border-border-primary shadow-sm w-full max-w-md", className), children: [showInput && (_jsxs("div", { className: "w-full space-y-4", children: [_jsxs("div", { className: "space-y-2", children: [_jsx("label", { className: "text-sm font-medium text-text-secondary", children: "Content" }), _jsx(Input, { value: value, onChange: (e) => setValue(e.target.value), placeholder: "Enter value...", className: "w-full" })] }), _jsxs("div", { className: "space-y-2", children: [_jsx("label", { className: "text-sm font-medium text-text-secondary", children: "Format" }), _jsxs(Select, { value: selectedFormat, onValueChange: (v) => setSelectedFormat(v), children: [_jsx(SelectTrigger, { children: _jsx(SelectValue, { placeholder: "Select format" }) }), _jsxs(SelectContent, { children: [_jsx(SelectItem, { value: "code128", children: "Code 128 (Standard)" }), _jsx(SelectItem, { value: "ean13", children: "EAN-13 (Retail)" }), _jsx(SelectItem, { value: "upca", children: "UPC-A (US Retail)" }), _jsx(SelectItem, { value: "code39", children: "Code 39" }), _jsx(SelectItem, { value: "itf14", children: "ITF-14 (Logistics)" })] })] })] })] })), _jsxs("div", { className: "relative min-h-[120px] w-full flex items-center justify-center p-4 bg-white rounded-xl border border-border-secondary shadow-inner overflow-hidden", children: [isLoading && (_jsx("div", { className: "absolute inset-0 flex items-center justify-center bg-white/80 z-10", children: _jsx(RefreshCw, { className: "w-6 h-6 text-accent-blue animate-spin" }) })), imgSrc ? (_jsx("img", { src: imgSrc, alt: `Barcode ${value}`, className: "max-w-full h-auto object-contain mix-blend-multiply" })) : (_jsxs("div", { className: "flex flex-col items-center text-text-tertiary", children: [_jsx(Barcode, { className: "w-8 h-8 mb-2 opacity-50" }), _jsx("span", { className: "text-xs", children: "Invalid Data" })] }))] }), _jsxs("div", { className: "flex items-center gap-2 w-full", children: [_jsxs(Button, { variant: "outline", className: "flex-1", onClick: handleCopyValue, title: "Copy value to clipboard", children: [isCopied ? _jsx(Check, { className: "w-4 h-4 mr-2" }) : _jsx(Copy, { className: "w-4 h-4 mr-2" }), isCopied ? "Copied" : "Copy Text"] }), _jsxs(Button, { variant: "primary", className: "flex-1", onClick: handleDownload, disabled: !imgSrc || isLoading, children: [_jsx(Download, { className: "w-4 h-4 mr-2" }), "Download"] })] })] }));
|
|
63
|
+
};
|
|
64
|
+
//# sourceMappingURL=BarcodeGenerator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BarcodeGenerator.js","sourceRoot":"","sources":["../../components/BarcodeGenerator.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Blockquote.d.ts","sourceRoot":"","sources":["../../components/Blockquote.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,MAAM,WAAW,eAAe;IAC5B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CA8BhD,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { Quote } from 'lucide-react';
|
|
3
|
+
import { Text } from './Text';
|
|
4
|
+
export const Blockquote = ({ children, author, source, className = '', }) => {
|
|
5
|
+
return (_jsxs("figure", { className: `relative pl-6 border-l-4 border-accent-blue/30 ${className}`, children: [_jsx("div", { className: "absolute -top-3 -left-3.5 bg-background-primary p-1 rounded-full", children: _jsx(Quote, { className: "w-5 h-5 text-accent-blue fill-accent-blue/10" }) }), _jsx("blockquote", { className: "mb-3 pt-1", children: _jsxs(Text, { variant: "lead", italic: true, color: "secondary", className: "!leading-relaxed", children: ["\"", children, "\""] }) }), (author || source) && (_jsxs("figcaption", { className: "flex items-center gap-2 text-sm pl-1", children: [_jsx("div", { className: "w-6 h-[1px] bg-border-primary" }), author && _jsx("span", { className: "font-semibold text-text-primary", children: author }), source && (_jsxs(_Fragment, { children: [_jsx("span", { className: "text-text-quaternary", children: "\u2022" }), _jsx("cite", { className: "text-text-tertiary not-italic", children: source })] }))] }))] }));
|
|
6
|
+
};
|
|
7
|
+
Blockquote.displayName = 'Blockquote';
|
|
8
|
+
//# sourceMappingURL=Blockquote.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Blockquote.js","sourceRoot":"","sources":["../../components/Blockquote.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,KAAK,EAAE,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAS9B,MAAM,CAAC,MAAM,UAAU,GAA8B,CAAC,EAClD,QAAQ,EACR,MAAM,EACN,MAAM,EACN,SAAS,GAAG,EAAE,GACjB,EAAE,EAAE;IACD,OAAO,CACH,kBAAQ,SAAS,EAAE,kDAAkD,SAAS,EAAE,aAC5E,cAAK,SAAS,EAAC,kEAAkE,YAC7E,KAAC,KAAK,IAAC,SAAS,EAAC,8CAA8C,GAAG,GAChE,EACN,qBAAY,SAAS,EAAC,WAAW,YAC7B,MAAC,IAAI,IAAC,OAAO,EAAC,MAAM,EAAC,MAAM,QAAC,KAAK,EAAC,WAAW,EAAC,SAAS,EAAC,kBAAkB,mBACpE,QAAQ,UACP,GACE,EACZ,CAAC,MAAM,IAAI,MAAM,CAAC,IAAI,CACnB,sBAAY,SAAS,EAAC,sCAAsC,aACxD,cAAK,SAAS,EAAC,+BAA+B,GAAG,EAChD,MAAM,IAAI,eAAM,SAAS,EAAC,iCAAiC,YAAE,MAAM,GAAQ,EAC3E,MAAM,IAAI,CACP,8BACI,eAAM,SAAS,EAAC,sBAAsB,uBAAS,EAC/C,eAAM,SAAS,EAAC,+BAA+B,YAAE,MAAM,GAAQ,IAChE,CACN,IACQ,CAChB,IACI,CACZ,CAAC;AACN,CAAC,CAAC;AAEF,UAAU,CAAC,WAAW,GAAG,YAAY,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { type LucideIcon } from 'lucide-react';
|
|
3
|
+
export interface BottomNavigationItem {
|
|
4
|
+
id: string;
|
|
5
|
+
label: string;
|
|
6
|
+
icon: LucideIcon;
|
|
7
|
+
href?: string;
|
|
8
|
+
onClick?: () => void;
|
|
9
|
+
active?: boolean;
|
|
10
|
+
badge?: string | number;
|
|
11
|
+
disabled?: boolean;
|
|
12
|
+
}
|
|
13
|
+
export interface BottomNavigationProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
14
|
+
items: BottomNavigationItem[];
|
|
15
|
+
variant?: 'default' | 'glass' | 'elevated';
|
|
16
|
+
showLabels?: boolean;
|
|
17
|
+
size?: 'sm' | 'md' | 'lg';
|
|
18
|
+
onItemClick?: (item: BottomNavigationItem) => void;
|
|
19
|
+
}
|
|
20
|
+
export declare const BottomNavigation: React.ForwardRefExoticComponent<BottomNavigationProps & React.RefAttributes<HTMLDivElement>>;
|
|
21
|
+
//# sourceMappingURL=BottomNavigation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BottomNavigation.d.ts","sourceRoot":"","sources":["../../components/BottomNavigation.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,EAAE,KAAK,UAAU,EAAE,MAAM,cAAc,CAAC;AAM/C,MAAM,WAAW,oBAAoB;IACjC,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,UAAU,CAAC;IACjB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACxB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,MAAM,WAAW,qBAAsB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC/E,KAAK,EAAE,oBAAoB,EAAE,CAAC;IAC9B,OAAO,CAAC,EAAE,SAAS,GAAG,OAAO,GAAG,UAAU,CAAC;IAC3C,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,IAAI,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;IAC1B,WAAW,CAAC,EAAE,CAAC,IAAI,EAAE,oBAAoB,KAAK,IAAI,CAAC;CACtD;AAsKD,eAAO,MAAM,gBAAgB,8FA+C5B,CAAC"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { cn } from '../lib/utils';
|
|
5
|
+
import { motion } from 'framer-motion';
|
|
6
|
+
/* ========================================
|
|
7
|
+
HELPER FUNCTIONS
|
|
8
|
+
======================================== */
|
|
9
|
+
const variantStyles = {
|
|
10
|
+
default: 'bg-surface-primary border-t border-border-primary',
|
|
11
|
+
glass: 'glass border-t border-border-secondary/50',
|
|
12
|
+
elevated: 'bg-surface-primary border-t border-border-primary shadow-lg',
|
|
13
|
+
};
|
|
14
|
+
const sizeStyles = {
|
|
15
|
+
sm: {
|
|
16
|
+
container: 'h-16',
|
|
17
|
+
icon: 'w-5 h-5',
|
|
18
|
+
label: 'text-xs',
|
|
19
|
+
padding: 'px-2 py-1',
|
|
20
|
+
gap: 'gap-1',
|
|
21
|
+
},
|
|
22
|
+
md: {
|
|
23
|
+
container: 'h-20',
|
|
24
|
+
icon: 'w-6 h-6',
|
|
25
|
+
label: 'text-xs',
|
|
26
|
+
padding: 'px-3 py-2',
|
|
27
|
+
gap: 'gap-1.5',
|
|
28
|
+
},
|
|
29
|
+
lg: {
|
|
30
|
+
container: 'h-24',
|
|
31
|
+
icon: 'w-7 h-7',
|
|
32
|
+
label: 'text-sm',
|
|
33
|
+
padding: 'px-4 py-3',
|
|
34
|
+
gap: 'gap-2',
|
|
35
|
+
},
|
|
36
|
+
};
|
|
37
|
+
const NavigationItem = ({ item, showLabel, size, onItemClick, }) => {
|
|
38
|
+
const { icon: iconSize, label: labelSize, padding, gap } = sizeStyles[size];
|
|
39
|
+
const Icon = item.icon;
|
|
40
|
+
const isActive = item.active || false;
|
|
41
|
+
const isDisabled = item.disabled || false;
|
|
42
|
+
const handleClick = () => {
|
|
43
|
+
if (isDisabled)
|
|
44
|
+
return;
|
|
45
|
+
if (item.onClick) {
|
|
46
|
+
item.onClick();
|
|
47
|
+
}
|
|
48
|
+
if (onItemClick) {
|
|
49
|
+
onItemClick(item);
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
const Component = item.href && !isDisabled ? 'a' : 'button';
|
|
53
|
+
return (_jsx(motion.div, { className: cn("flex flex-col items-center justify-center relative", gap, padding, "flex-1 min-w-0", isDisabled && "opacity-40 cursor-not-allowed"), whileHover: !isDisabled ? { scale: 1.05 } : {}, whileTap: !isDisabled ? { scale: 0.95 } : {}, transition: { type: 'spring', stiffness: 400, damping: 25 }, children: _jsxs(Component, { href: item.href, onClick: handleClick, disabled: isDisabled, className: cn("flex flex-col items-center justify-center relative", gap, "w-full min-w-0", "focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-accent-blue focus-visible:ring-offset-2 rounded-lg", isDisabled && "cursor-not-allowed"), children: [_jsxs("div", { className: "relative", children: [_jsx(motion.div, { className: cn("flex items-center justify-center rounded-lg transition-colors", iconSize, isActive
|
|
54
|
+
? "text-accent-blue"
|
|
55
|
+
: "text-text-secondary"), animate: {
|
|
56
|
+
scale: isActive ? 1.1 : 1,
|
|
57
|
+
}, transition: { type: 'spring', stiffness: 400, damping: 25 }, children: _jsx(Icon, { className: iconSize, strokeWidth: isActive ? 2.5 : 2 }) }), isActive && (_jsx(motion.div, { layoutId: "bottom-nav-indicator", className: "absolute -bottom-1 left-1/2 -translate-x-1/2 w-1 h-1 bg-accent-blue rounded-full", initial: { scale: 0 }, animate: { scale: 1 }, transition: { type: 'spring', stiffness: 400, damping: 25 } })), item.badge && (_jsx(motion.div, { initial: { scale: 0 }, animate: { scale: 1 }, className: cn("absolute -top-1 -right-1 min-w-[18px] h-[18px] px-1.5 flex items-center justify-center", "bg-status-error text-white text-[10px] font-bold rounded-full", typeof item.badge === 'number' && item.badge > 99 && "px-1"), children: typeof item.badge === 'number' && item.badge > 99 ? '99+' : item.badge }))] }), showLabel && (_jsx(motion.span, { className: cn(labelSize, "font-medium text-center truncate w-full", isActive
|
|
58
|
+
? "text-accent-blue"
|
|
59
|
+
: "text-text-secondary"), animate: {
|
|
60
|
+
opacity: isActive ? 1 : 0.7,
|
|
61
|
+
}, children: item.label }))] }) }));
|
|
62
|
+
};
|
|
63
|
+
/* ========================================
|
|
64
|
+
MAIN COMPONENT
|
|
65
|
+
======================================== */
|
|
66
|
+
export const BottomNavigation = React.forwardRef(({ items, variant = 'default', showLabels = true, size = 'md', onItemClick, className, ...props }, ref) => {
|
|
67
|
+
const { container } = sizeStyles[size];
|
|
68
|
+
return (_jsx(motion.nav, { ref: ref, className: cn(`fixed bottom-0 left-0 right-0 z-50 pb-safe`, "flex items-center justify-around", // Keep flex properties
|
|
69
|
+
variantStyles[variant], container, // Keep container height
|
|
70
|
+
className), initial: { y: '100%' }, animate: { y: 0 }, exit: { y: '100%' }, transition: {
|
|
71
|
+
type: 'spring',
|
|
72
|
+
stiffness: 300,
|
|
73
|
+
damping: 30,
|
|
74
|
+
}, ...props, children: items.map((item) => (_jsx(NavigationItem, { item: item, showLabel: showLabels, size: size, onItemClick: onItemClick }, item.id))) }));
|
|
75
|
+
});
|
|
76
|
+
BottomNavigation.displayName = 'BottomNavigation';
|
|
77
|
+
//# sourceMappingURL=BottomNavigation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BottomNavigation.js","sourceRoot":"","sources":["../../components/BottomNavigation.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
declare const Breadcrumb: React.ForwardRefExoticComponent<Omit<React.DetailedHTMLProps<React.HTMLAttributes<HTMLElement>, HTMLElement>, "ref"> & {
|
|
3
|
+
separator?: React.ReactNode;
|
|
4
|
+
} & React.RefAttributes<HTMLElement>>;
|
|
5
|
+
declare const BreadcrumbList: React.ForwardRefExoticComponent<Omit<React.DetailedHTMLProps<React.OlHTMLAttributes<HTMLOListElement>, HTMLOListElement>, "ref"> & React.RefAttributes<HTMLOListElement>>;
|
|
6
|
+
declare const BreadcrumbItem: React.ForwardRefExoticComponent<Omit<React.DetailedHTMLProps<React.LiHTMLAttributes<HTMLLIElement>, HTMLLIElement>, "ref"> & React.RefAttributes<HTMLLIElement>>;
|
|
7
|
+
declare const BreadcrumbLink: React.ForwardRefExoticComponent<Omit<React.DetailedHTMLProps<React.AnchorHTMLAttributes<HTMLAnchorElement>, HTMLAnchorElement>, "ref"> & {
|
|
8
|
+
asChild?: boolean;
|
|
9
|
+
} & React.RefAttributes<HTMLAnchorElement>>;
|
|
10
|
+
declare const BreadcrumbPage: React.ForwardRefExoticComponent<Omit<React.DetailedHTMLProps<React.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, "ref"> & React.RefAttributes<HTMLSpanElement>>;
|
|
11
|
+
declare const BreadcrumbSeparator: {
|
|
12
|
+
({ children, className, ...props }: React.ComponentProps<"li">): import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
displayName: string;
|
|
14
|
+
};
|
|
15
|
+
declare const BreadcrumbEllipsis: {
|
|
16
|
+
({ className, ...props }: React.ComponentProps<"span">): import("react/jsx-runtime").JSX.Element;
|
|
17
|
+
displayName: string;
|
|
18
|
+
};
|
|
19
|
+
export { Breadcrumb, BreadcrumbList, BreadcrumbItem, BreadcrumbLink, BreadcrumbPage, BreadcrumbSeparator, BreadcrumbEllipsis, };
|
|
20
|
+
//# sourceMappingURL=Breadcrumb.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Breadcrumb.d.ts","sourceRoot":"","sources":["../../components/Breadcrumb.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAI/B,QAAA,MAAM,UAAU;gBAGI,KAAK,CAAC,SAAS;qCAE2C,CAAC;AAG/E,QAAA,MAAM,cAAc,2KAYlB,CAAC;AAGH,QAAA,MAAM,cAAc,kKASlB,CAAC;AAGH,QAAA,MAAM,cAAc;cAGF,OAAO;2CAWvB,CAAC;AAGH,QAAA,MAAM,cAAc,sKAYlB,CAAC;AAGH,QAAA,MAAM,mBAAmB;wCAItB,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC;;CAS5B,CAAC;AAGF,QAAA,MAAM,kBAAkB;8BAGrB,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC;;CAU9B,CAAC;AAGF,OAAO,EACH,UAAU,EACV,cAAc,EACd,cAAc,EACd,cAAc,EACd,cAAc,EACd,mBAAmB,EACnB,kBAAkB,GACrB,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import * as React from "react";
|
|
4
|
+
import { ChevronRight, MoreHorizontal } from "lucide-react";
|
|
5
|
+
import { cn } from "../lib/utils";
|
|
6
|
+
const Breadcrumb = React.forwardRef(({ ...props }, ref) => _jsx("nav", { ref: ref, "aria-label": "breadcrumb", ...props }));
|
|
7
|
+
Breadcrumb.displayName = "Breadcrumb";
|
|
8
|
+
const BreadcrumbList = React.forwardRef(({ className, ...props }, ref) => (_jsx("ol", { ref: ref, className: cn("flex flex-wrap items-center gap-1.5 break-words text-sm text-text-secondary sm:gap-2.5", className), ...props })));
|
|
9
|
+
BreadcrumbList.displayName = "BreadcrumbList";
|
|
10
|
+
const BreadcrumbItem = React.forwardRef(({ className, ...props }, ref) => (_jsx("li", { ref: ref, className: cn("inline-flex items-center gap-1.5", className), ...props })));
|
|
11
|
+
BreadcrumbItem.displayName = "BreadcrumbItem";
|
|
12
|
+
const BreadcrumbLink = React.forwardRef(({ asChild, className, ...props }, ref) => {
|
|
13
|
+
const Comp = asChild ? React.Fragment : "a";
|
|
14
|
+
return (_jsx(Comp, { ref: ref, className: cn("transition-colors hover:text-text-primary", className), ...props }));
|
|
15
|
+
});
|
|
16
|
+
BreadcrumbLink.displayName = "BreadcrumbLink";
|
|
17
|
+
const BreadcrumbPage = React.forwardRef(({ className, ...props }, ref) => (_jsx("span", { ref: ref, role: "link", "aria-disabled": "true", "aria-current": "page", className: cn("font-normal text-text-primary", className), ...props })));
|
|
18
|
+
BreadcrumbPage.displayName = "BreadcrumbPage";
|
|
19
|
+
const BreadcrumbSeparator = ({ children, className, ...props }) => (_jsx("li", { role: "presentation", "aria-hidden": "true", className: cn("[&>svg]:size-3.5", className), ...props, children: children ?? _jsx(ChevronRight, {}) }));
|
|
20
|
+
BreadcrumbSeparator.displayName = "BreadcrumbSeparator";
|
|
21
|
+
const BreadcrumbEllipsis = ({ className, ...props }) => (_jsxs("span", { role: "presentation", "aria-hidden": "true", className: cn("flex h-9 w-9 items-center justify-center", className), ...props, children: [_jsx(MoreHorizontal, { className: "h-4 w-4" }), _jsx("span", { className: "sr-only", children: "More" })] }));
|
|
22
|
+
BreadcrumbEllipsis.displayName = "BreadcrumbElipssis";
|
|
23
|
+
export { Breadcrumb, BreadcrumbList, BreadcrumbItem, BreadcrumbLink, BreadcrumbPage, BreadcrumbSeparator, BreadcrumbEllipsis, };
|
|
24
|
+
//# sourceMappingURL=Breadcrumb.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Breadcrumb.js","sourceRoot":"","sources":["../../components/Breadcrumb.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export interface BreadcrumbItem {
|
|
3
|
+
label: string;
|
|
4
|
+
href?: string;
|
|
5
|
+
icon?: React.ReactNode;
|
|
6
|
+
}
|
|
7
|
+
export interface TabItem {
|
|
8
|
+
id: string;
|
|
9
|
+
label: string;
|
|
10
|
+
icon?: React.ReactNode;
|
|
11
|
+
badge?: number;
|
|
12
|
+
}
|
|
13
|
+
export interface BreadcrumbTabsHybridProps {
|
|
14
|
+
breadcrumbs: BreadcrumbItem[];
|
|
15
|
+
tabs: TabItem[];
|
|
16
|
+
activeTab?: string;
|
|
17
|
+
onTabChange?: (tabId: string) => void;
|
|
18
|
+
onBreadcrumbClick?: (index: number) => void;
|
|
19
|
+
variant?: 'default' | 'compact' | 'elevated';
|
|
20
|
+
showHomeIcon?: boolean;
|
|
21
|
+
className?: string;
|
|
22
|
+
}
|
|
23
|
+
export declare const BreadcrumbTabsHybrid: React.FC<BreadcrumbTabsHybridProps>;
|
|
24
|
+
export default BreadcrumbTabsHybrid;
|
|
25
|
+
//# sourceMappingURL=BreadcrumbTabsHybrid.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BreadcrumbTabsHybrid.d.ts","sourceRoot":"","sources":["../../components/BreadcrumbTabsHybrid.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAsC,MAAM,OAAO,CAAC;AAG3D,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CACxB;AAED,MAAM,WAAW,OAAO;IACtB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,yBAAyB;IACxC,WAAW,EAAE,cAAc,EAAE,CAAC;IAC9B,IAAI,EAAE,OAAO,EAAE,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACtC,iBAAiB,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC5C,OAAO,CAAC,EAAE,SAAS,GAAG,SAAS,GAAG,UAAU,CAAC;IAC7C,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,eAAO,MAAM,oBAAoB,EAAE,KAAK,CAAC,EAAE,CAAC,yBAAyB,CA0JpE,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React, { useState, useRef, useEffect } from 'react';
|
|
3
|
+
import { ChevronRight, Home } from 'lucide-react';
|
|
4
|
+
export const BreadcrumbTabsHybrid = ({ breadcrumbs, tabs, activeTab: controlledActiveTab, onTabChange, onBreadcrumbClick, variant = 'default', showHomeIcon = true, className = '', }) => {
|
|
5
|
+
const [internalActiveTab, setInternalActiveTab] = useState(tabs[0]?.id || '');
|
|
6
|
+
const activeTab = controlledActiveTab ?? internalActiveTab;
|
|
7
|
+
const tabRefs = useRef({});
|
|
8
|
+
const [indicatorStyle, setIndicatorStyle] = useState({ left: 0, width: 0 });
|
|
9
|
+
const handleTabClick = (tabId) => {
|
|
10
|
+
if (!controlledActiveTab) {
|
|
11
|
+
setInternalActiveTab(tabId);
|
|
12
|
+
}
|
|
13
|
+
onTabChange?.(tabId);
|
|
14
|
+
};
|
|
15
|
+
const handleBreadcrumbClick = (index, href) => {
|
|
16
|
+
if (onBreadcrumbClick) {
|
|
17
|
+
onBreadcrumbClick(index);
|
|
18
|
+
}
|
|
19
|
+
else if (href) {
|
|
20
|
+
window.location.href = href;
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
// Update indicator position when active tab changes
|
|
24
|
+
useEffect(() => {
|
|
25
|
+
const activeTabElement = tabRefs.current[activeTab];
|
|
26
|
+
if (activeTabElement) {
|
|
27
|
+
const { offsetLeft, offsetWidth } = activeTabElement;
|
|
28
|
+
setIndicatorStyle({
|
|
29
|
+
left: offsetLeft,
|
|
30
|
+
width: offsetWidth,
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
}, [activeTab, tabs]);
|
|
34
|
+
const variantClasses = {
|
|
35
|
+
default: 'bg-background-secondary border-b border-border-primary',
|
|
36
|
+
compact: 'bg-transparent',
|
|
37
|
+
elevated: 'bg-surface-primary shadow-sm border border-border-primary rounded-xl',
|
|
38
|
+
};
|
|
39
|
+
return (_jsxs("div", { className: `breadcrumb-tabs-hybrid ${variantClasses[variant]} ${className}`, children: [_jsx("div", { className: "breadcrumb-section px-6 pt-4 pb-2", children: _jsxs("nav", { "aria-label": "Breadcrumb", className: "flex items-center gap-1.5", children: [showHomeIcon && breadcrumbs.length > 0 && (_jsxs(_Fragment, { children: [_jsx("button", { onClick: () => handleBreadcrumbClick(0, breadcrumbs[0].href), className: "breadcrumb-home-button p-1.5 rounded-lg hover:bg-background-tertiary/50 transition-colors duration-200", "aria-label": "Home", children: _jsx(Home, { className: "w-4 h-4 text-text-secondary" }) }), breadcrumbs.length > 1 && (_jsx(ChevronRight, { className: "w-4 h-4 text-text-quaternary flex-shrink-0" }))] })), breadcrumbs.slice(showHomeIcon ? 1 : 0).map((crumb, index) => {
|
|
40
|
+
const actualIndex = showHomeIcon ? index + 1 : index;
|
|
41
|
+
const isLast = actualIndex === breadcrumbs.length - 1;
|
|
42
|
+
return (_jsxs(React.Fragment, { children: [_jsxs("button", { onClick: () => handleBreadcrumbClick(actualIndex, crumb.href), className: `breadcrumb-item flex items-center gap-2 px-2.5 py-1.5 rounded-lg transition-all duration-200 ${isLast
|
|
43
|
+
? 'text-text-primary font-medium cursor-default'
|
|
44
|
+
: 'text-text-secondary hover:text-text-primary hover:bg-background-tertiary/50'}`, "aria-current": isLast ? 'page' : undefined, disabled: isLast, children: [crumb.icon && (_jsx("span", { className: "flex-shrink-0", children: crumb.icon })), _jsx("span", { className: "text-sm whitespace-nowrap", children: crumb.label })] }), !isLast && (_jsx(ChevronRight, { className: "w-4 h-4 text-text-quaternary flex-shrink-0" }))] }, actualIndex));
|
|
45
|
+
})] }) }), _jsxs("div", { className: "tabs-section px-6 relative", children: [_jsxs("div", { className: "flex items-center gap-1 relative", children: [tabs.map((tab) => {
|
|
46
|
+
const isActive = tab.id === activeTab;
|
|
47
|
+
return (_jsxs("button", { ref: (el) => { tabRefs.current[tab.id] = el; }, onClick: () => handleTabClick(tab.id), className: `tab-item relative flex items-center gap-2 px-4 py-3 text-sm font-medium transition-all duration-200 ${isActive
|
|
48
|
+
? 'text-accent-blue'
|
|
49
|
+
: 'text-text-secondary hover:text-text-primary'}`, role: "tab", "aria-selected": isActive, "aria-controls": `tabpanel-${tab.id}`, children: [tab.icon && (_jsx("span", { className: "flex-shrink-0 w-4 h-4", children: tab.icon })), _jsx("span", { children: tab.label }), tab.badge !== undefined && tab.badge > 0 && (_jsx("span", { className: `badge inline-flex items-center justify-center min-w-[18px] h-[18px] px-1.5 rounded-full text-xs font-semibold transition-colors duration-200 ${isActive
|
|
50
|
+
? 'bg-accent-blue text-white'
|
|
51
|
+
: 'bg-background-tertiary text-text-secondary'}`, children: tab.badge > 99 ? '99+' : tab.badge }))] }, tab.id));
|
|
52
|
+
}), _jsx("div", { className: "tab-indicator absolute bottom-0 h-0.5 bg-accent-blue transition-all duration-300 ease-out", style: {
|
|
53
|
+
left: `${indicatorStyle.left}px`,
|
|
54
|
+
width: `${indicatorStyle.width}px`,
|
|
55
|
+
} })] }), variant !== 'elevated' && (_jsx("div", { className: "absolute bottom-0 left-0 right-0 h-px bg-border-primary" }))] })] }));
|
|
56
|
+
};
|
|
57
|
+
export default BreadcrumbTabsHybrid;
|
|
58
|
+
//# sourceMappingURL=BreadcrumbTabsHybrid.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BreadcrumbTabsHybrid.js","sourceRoot":"","sources":["../../components/BreadcrumbTabsHybrid.tsx"],"names":[],"mappings":"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"}
|