@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,14 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { HTMLMotionProps } from 'framer-motion';
|
|
3
|
+
export type ButtonVariant = 'primary' | 'secondary' | 'ghost' | 'subtle' | 'outline' | 'destructive';
|
|
4
|
+
export type ButtonSize = 'sm' | 'md' | 'lg';
|
|
5
|
+
export interface ButtonProps extends Omit<HTMLMotionProps<'button'>, 'size'> {
|
|
6
|
+
variant?: ButtonVariant;
|
|
7
|
+
size?: ButtonSize;
|
|
8
|
+
loading?: boolean;
|
|
9
|
+
leftIcon?: React.ReactNode;
|
|
10
|
+
rightIcon?: React.ReactNode;
|
|
11
|
+
fullWidth?: boolean;
|
|
12
|
+
}
|
|
13
|
+
export declare const Button: React.ForwardRefExoticComponent<Omit<ButtonProps, "ref"> & React.RefAttributes<HTMLButtonElement>>;
|
|
14
|
+
//# sourceMappingURL=Button.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Button.d.ts","sourceRoot":"","sources":["../../components/Button.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAU,eAAe,EAAE,MAAM,eAAe,CAAC;AAOxD,MAAM,MAAM,aAAa,GAAG,SAAS,GAAG,WAAW,GAAG,OAAO,GAAG,QAAQ,GAAG,SAAS,GAAG,aAAa,CAAC;AACrG,MAAM,MAAM,UAAU,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;AAE5C,MAAM,WAAW,WAAY,SAAQ,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;IACxE,OAAO,CAAC,EAAE,aAAa,CAAC;IACxB,IAAI,CAAC,EAAE,UAAU,CAAC;IAClB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,SAAS,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC5B,SAAS,CAAC,EAAE,OAAO,CAAC;CACvB;AA8DD,eAAO,MAAM,MAAM,oGAmDlB,CAAC"}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, 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-2
|
|
9
|
+
font-medium transition-apple
|
|
10
|
+
focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-accent-blue focus-visible:ring-offset-2
|
|
11
|
+
disabled:opacity-40 disabled:cursor-not-allowed disabled:pointer-events-none
|
|
12
|
+
select-none
|
|
13
|
+
`;
|
|
14
|
+
const variantStyles = {
|
|
15
|
+
primary: `
|
|
16
|
+
bg-accent-blue text-white
|
|
17
|
+
hover:bg-accent-blue-hover
|
|
18
|
+
active:bg-accent-blue-active
|
|
19
|
+
shadow-sm
|
|
20
|
+
`,
|
|
21
|
+
secondary: `
|
|
22
|
+
bg-surface-secondary text-text-primary
|
|
23
|
+
border border-border-primary
|
|
24
|
+
hover:bg-surface-primary hover:border-border-primary
|
|
25
|
+
active:bg-surface-secondary
|
|
26
|
+
shadow-xs
|
|
27
|
+
`,
|
|
28
|
+
ghost: `
|
|
29
|
+
bg-transparent text-accent-blue
|
|
30
|
+
hover:bg-accent-blue-tint
|
|
31
|
+
active:bg-accent-blue-tint
|
|
32
|
+
`,
|
|
33
|
+
subtle: `
|
|
34
|
+
bg-surface-secondary text-text-primary
|
|
35
|
+
hover:bg-surface-primary
|
|
36
|
+
active:bg-surface-secondary
|
|
37
|
+
`,
|
|
38
|
+
outline: `
|
|
39
|
+
bg-transparent text-text-primary
|
|
40
|
+
border border-border-primary
|
|
41
|
+
hover:bg-surface-secondary hover:border-border-secondary
|
|
42
|
+
active:bg-surface-tertiary
|
|
43
|
+
`,
|
|
44
|
+
destructive: `
|
|
45
|
+
bg-status-error text-white
|
|
46
|
+
hover:bg-red-600
|
|
47
|
+
active:bg-red-700
|
|
48
|
+
shadow-sm
|
|
49
|
+
`,
|
|
50
|
+
};
|
|
51
|
+
const sizeStyles = {
|
|
52
|
+
sm: 'h-8 px-3 text-sm rounded-lg',
|
|
53
|
+
md: 'h-10 px-4 text-base rounded-xl',
|
|
54
|
+
lg: 'h-12 px-6 text-lg rounded-xl',
|
|
55
|
+
};
|
|
56
|
+
/* ========================================
|
|
57
|
+
COMPONENT
|
|
58
|
+
======================================== */
|
|
59
|
+
export const Button = React.forwardRef(({ variant = 'primary', size = 'md', loading = false, leftIcon, rightIcon, fullWidth = false, children, className = '', disabled, ...props }, ref) => {
|
|
60
|
+
const combinedClassName = `
|
|
61
|
+
${baseStyles}
|
|
62
|
+
${variantStyles[variant]}
|
|
63
|
+
${sizeStyles[size]}
|
|
64
|
+
${fullWidth ? 'w-full' : ''}
|
|
65
|
+
${className}
|
|
66
|
+
`.trim().replace(/\s+/g, ' ');
|
|
67
|
+
return (_jsx(motion.button, { ref: ref, className: combinedClassName, disabled: disabled || loading, whileHover: { scale: disabled || loading ? 1 : 1.02 }, whileTap: { scale: disabled || loading ? 1 : 0.98 }, transition: {
|
|
68
|
+
type: 'spring',
|
|
69
|
+
stiffness: 400,
|
|
70
|
+
damping: 25,
|
|
71
|
+
mass: 0.6,
|
|
72
|
+
}, ...props, children: loading ? (_jsx(LoadingSpinner, { size: size })) : (_jsxs(_Fragment, { children: [leftIcon && _jsx("span", { className: "inline-flex", children: leftIcon }), children, rightIcon && _jsx("span", { className: "inline-flex", children: rightIcon })] })) }));
|
|
73
|
+
});
|
|
74
|
+
Button.displayName = 'Button';
|
|
75
|
+
/* ========================================
|
|
76
|
+
LOADING SPINNER
|
|
77
|
+
======================================== */
|
|
78
|
+
const LoadingSpinner = ({ size }) => {
|
|
79
|
+
const sizeMap = {
|
|
80
|
+
sm: 14,
|
|
81
|
+
md: 16,
|
|
82
|
+
lg: 18,
|
|
83
|
+
};
|
|
84
|
+
const spinnerSize = sizeMap[size];
|
|
85
|
+
return (_jsxs(motion.svg, { width: spinnerSize, height: spinnerSize, viewBox: "0 0 24 24", fill: "none", animate: { rotate: 360 }, transition: {
|
|
86
|
+
duration: 1,
|
|
87
|
+
repeat: Infinity,
|
|
88
|
+
ease: 'linear',
|
|
89
|
+
}, children: [_jsx("circle", { cx: "12", cy: "12", r: "10", stroke: "currentColor", strokeWidth: "3", strokeLinecap: "round", strokeDasharray: "60", strokeDashoffset: "15", opacity: "0.25" }), _jsx("circle", { cx: "12", cy: "12", r: "10", stroke: "currentColor", strokeWidth: "3", strokeLinecap: "round", strokeDasharray: "60", strokeDashoffset: "45" })] }));
|
|
90
|
+
};
|
|
91
|
+
//# sourceMappingURL=Button.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Button.js","sourceRoot":"","sources":["../../components/Button.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,MAAM,EAAmB,MAAM,eAAe,CAAC;AAmBxD;;8CAE8C;AAE9C,MAAM,UAAU,GAAG;;;;;;CAMlB,CAAC;AAEF,MAAM,aAAa,GAAkC;IACjD,OAAO,EAAE;;;;;GAKV;IACC,SAAS,EAAE;;;;;;GAMZ;IACC,KAAK,EAAE;;;;GAIR;IACC,MAAM,EAAE;;;;GAIT;IACC,OAAO,EAAE;;;;;GAKV;IACC,WAAW,EAAE;;;;;GAKd;CACF,CAAC;AAEF,MAAM,UAAU,GAA+B;IAC3C,EAAE,EAAE,6BAA6B;IACjC,EAAE,EAAE,gCAAgC;IACpC,EAAE,EAAE,8BAA8B;CACrC,CAAC;AAEF;;8CAE8C;AAE9C,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,CAAC,UAAU,CAClC,CACI,EACI,OAAO,GAAG,SAAS,EACnB,IAAI,GAAG,IAAI,EACX,OAAO,GAAG,KAAK,EACf,QAAQ,EACR,SAAS,EACT,SAAS,GAAG,KAAK,EACjB,QAAQ,EACR,SAAS,GAAG,EAAE,EACd,QAAQ,EACR,GAAG,KAAK,EACX,EACD,GAAG,EACL,EAAE;IACA,MAAM,iBAAiB,GAAG;QAC1B,UAAU;QACV,aAAa,CAAC,OAAO,CAAC;QACtB,UAAU,CAAC,IAAI,CAAC;QAChB,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE;QACzB,SAAS;KACZ,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAE1B,OAAO,CACH,KAAC,MAAM,CAAC,MAAM,IACV,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,iBAAiB,EAC5B,QAAQ,EAAE,QAAQ,IAAI,OAAO,EAC7B,UAAU,EAAE,EAAE,KAAK,EAAE,QAAQ,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,EACrD,QAAQ,EAAE,EAAE,KAAK,EAAE,QAAQ,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,EACnD,UAAU,EAAE;YACR,IAAI,EAAE,QAAQ;YACd,SAAS,EAAE,GAAG;YACd,OAAO,EAAE,EAAE;YACX,IAAI,EAAE,GAAG;SACZ,KACG,KAAK,YAER,OAAO,CAAC,CAAC,CAAC,CACP,KAAC,cAAc,IAAC,IAAI,EAAE,IAAI,GAAI,CACjC,CAAC,CAAC,CAAC,CACA,8BACK,QAAQ,IAAI,eAAM,SAAS,EAAC,aAAa,YAAE,QAAQ,GAAQ,EAC3D,QAAQ,EACR,SAAS,IAAI,eAAM,SAAS,EAAC,aAAa,YAAE,SAAS,GAAQ,IAC/D,CACN,GACW,CACnB,CAAC;AACN,CAAC,CACJ,CAAC;AAEF,MAAM,CAAC,WAAW,GAAG,QAAQ,CAAC;AAE9B;;8CAE8C;AAE9C,MAAM,cAAc,GAAmC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE;IAChE,MAAM,OAAO,GAAG;QACZ,EAAE,EAAE,EAAE;QACN,EAAE,EAAE,EAAE;QACN,EAAE,EAAE,EAAE;KACT,CAAC;IAEF,MAAM,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAElC,OAAO,CACH,MAAC,MAAM,CAAC,GAAG,IACP,KAAK,EAAE,WAAW,EAClB,MAAM,EAAE,WAAW,EACnB,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,MAAM,EACX,OAAO,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,EACxB,UAAU,EAAE;YACR,QAAQ,EAAE,CAAC;YACX,MAAM,EAAE,QAAQ;YAChB,IAAI,EAAE,QAAQ;SACjB,aAED,iBACI,EAAE,EAAC,IAAI,EACP,EAAE,EAAC,IAAI,EACP,CAAC,EAAC,IAAI,EACN,MAAM,EAAC,cAAc,EACrB,WAAW,EAAC,GAAG,EACf,aAAa,EAAC,OAAO,EACrB,eAAe,EAAC,IAAI,EACpB,gBAAgB,EAAC,IAAI,EACrB,OAAO,EAAC,MAAM,GAChB,EACF,iBACI,EAAE,EAAC,IAAI,EACP,EAAE,EAAC,IAAI,EACP,CAAC,EAAC,IAAI,EACN,MAAM,EAAC,cAAc,EACrB,WAAW,EAAC,GAAG,EACf,aAAa,EAAC,OAAO,EACrB,eAAe,EAAC,IAAI,EACpB,gBAAgB,EAAC,IAAI,GACvB,IACO,CAChB,CAAC;AACN,CAAC,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export type ButtonWithDropdownVariant = 'primary' | 'secondary' | 'tertiary';
|
|
3
|
+
export type ButtonWithDropdownSize = 'sm' | 'md' | 'lg';
|
|
4
|
+
export interface ButtonWithDropdownAction {
|
|
5
|
+
label: string;
|
|
6
|
+
onClick: () => void;
|
|
7
|
+
icon?: React.ElementType;
|
|
8
|
+
disabled?: boolean;
|
|
9
|
+
}
|
|
10
|
+
export interface ButtonWithDropdownProps {
|
|
11
|
+
label: string;
|
|
12
|
+
actions: ButtonWithDropdownAction[];
|
|
13
|
+
variant?: ButtonWithDropdownVariant;
|
|
14
|
+
size?: ButtonWithDropdownSize;
|
|
15
|
+
disabled?: boolean;
|
|
16
|
+
className?: string;
|
|
17
|
+
}
|
|
18
|
+
export declare const ButtonWithDropdown: React.ForwardRefExoticComponent<ButtonWithDropdownProps & React.RefAttributes<HTMLButtonElement>>;
|
|
19
|
+
//# sourceMappingURL=ButtonWithDropdown.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ButtonWithDropdown.d.ts","sourceRoot":"","sources":["../../components/ButtonWithDropdown.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAC;AAU1C,MAAM,MAAM,yBAAyB,GAAG,SAAS,GAAG,WAAW,GAAG,UAAU,CAAC;AAC7E,MAAM,MAAM,sBAAsB,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;AAExD,MAAM,WAAW,wBAAwB;IACrC,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,IAAI,CAAC,EAAE,KAAK,CAAC,WAAW,CAAC;IACzB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,MAAM,WAAW,uBAAuB;IACpC,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,wBAAwB,EAAE,CAAC;IACpC,OAAO,CAAC,EAAE,yBAAyB,CAAC;IACpC,IAAI,CAAC,EAAE,sBAAsB,CAAC;IAC9B,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAMD,eAAO,MAAM,kBAAkB,mGAoF9B,CAAC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
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
|
+
import { ChevronDown } from 'lucide-react';
|
|
6
|
+
import * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';
|
|
7
|
+
/* ========================================
|
|
8
|
+
BUTTON WITH DROPDOWN COMPONENT
|
|
9
|
+
======================================== */
|
|
10
|
+
export const ButtonWithDropdown = forwardRef(({ label, actions, variant = 'primary', size = 'md', disabled = false, className, }, ref) => {
|
|
11
|
+
const variants = {
|
|
12
|
+
primary: "bg-accent-blue text-white hover:bg-accent-blueHover active:bg-accent-blueActive shadow-sm",
|
|
13
|
+
secondary: "bg-surface-secondary text-text-primary hover:bg-surface-tertiary active:bg-surface-tertiary/80 border border-border-primary",
|
|
14
|
+
tertiary: "bg-transparent text-text-secondary hover:text-text-primary hover:bg-surface-secondary",
|
|
15
|
+
};
|
|
16
|
+
const sizes = {
|
|
17
|
+
sm: {
|
|
18
|
+
button: "h-8 px-3 text-sm gap-1.5",
|
|
19
|
+
icon: "w-3.5 h-3.5",
|
|
20
|
+
},
|
|
21
|
+
md: {
|
|
22
|
+
button: "h-10 px-4 text-base gap-2",
|
|
23
|
+
icon: "w-4 h-4",
|
|
24
|
+
},
|
|
25
|
+
lg: {
|
|
26
|
+
button: "h-12 px-5 text-lg gap-2.5",
|
|
27
|
+
icon: "w-5 h-5",
|
|
28
|
+
},
|
|
29
|
+
};
|
|
30
|
+
return (_jsxs(DropdownMenuPrimitive.Root, { children: [_jsx(DropdownMenuPrimitive.Trigger, { asChild: true, children: _jsxs(motion.button, { ref: ref, whileTap: { scale: 0.98 }, disabled: disabled, className: cn("inline-flex items-center justify-center font-medium rounded-xl transition-colors focus:outline-none focus:ring-2 focus:ring-accent-blue/20", variants[variant], sizes[size].button, disabled && "opacity-50 cursor-not-allowed", className), children: [label, _jsx(ChevronDown, { className: sizes[size].icon })] }) }), _jsx(DropdownMenuPrimitive.Portal, { children: _jsx(DropdownMenuPrimitive.Content, { align: "start", sideOffset: 4, className: cn("min-w-[160px] bg-surface-elevated border border-border-primary rounded-xl shadow-lg p-1", "z-dropdown", "animate-in fade-in-0 zoom-in-95"), children: actions.map((action, index) => (_jsxs(DropdownMenuPrimitive.Item, { onClick: action.onClick, disabled: action.disabled, className: cn("flex items-center gap-2 px-3 py-2 text-sm rounded-lg cursor-pointer outline-none transition-colors", "text-text-primary hover:bg-surface-secondary", "focus:bg-surface-secondary", action.disabled && "opacity-50 cursor-not-allowed"), children: [action.icon && _jsx(action.icon, { className: "w-4 h-4" }), action.label] }, index))) }) })] }));
|
|
31
|
+
});
|
|
32
|
+
ButtonWithDropdown.displayName = 'ButtonWithDropdown';
|
|
33
|
+
//# sourceMappingURL=ButtonWithDropdown.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ButtonWithDropdown.js","sourceRoot":"","sources":["../../components/ButtonWithDropdown.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,EAAE,EAAE,MAAM,cAAc,CAAC;AAClC,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAC3C,OAAO,KAAK,qBAAqB,MAAM,+BAA+B,CAAC;AAyBvE;;8CAE8C;AAE9C,MAAM,CAAC,MAAM,kBAAkB,GAAG,UAAU,CACxC,CACI,EACI,KAAK,EACL,OAAO,EACP,OAAO,GAAG,SAAS,EACnB,IAAI,GAAG,IAAI,EACX,QAAQ,GAAG,KAAK,EAChB,SAAS,GACZ,EACD,GAAG,EACL,EAAE;IACA,MAAM,QAAQ,GAAG;QACb,OAAO,EAAE,2FAA2F;QACpG,SAAS,EAAE,6HAA6H;QACxI,QAAQ,EAAE,uFAAuF;KACpG,CAAC;IAEF,MAAM,KAAK,GAAG;QACV,EAAE,EAAE;YACA,MAAM,EAAE,0BAA0B;YAClC,IAAI,EAAE,aAAa;SACtB;QACD,EAAE,EAAE;YACA,MAAM,EAAE,2BAA2B;YACnC,IAAI,EAAE,SAAS;SAClB;QACD,EAAE,EAAE;YACA,MAAM,EAAE,2BAA2B;YACnC,IAAI,EAAE,SAAS;SAClB;KACJ,CAAC;IAEF,OAAO,CACH,MAAC,qBAAqB,CAAC,IAAI,eACvB,KAAC,qBAAqB,CAAC,OAAO,IAAC,OAAO,kBAClC,MAAC,MAAM,CAAC,MAAM,IACV,GAAG,EAAE,GAAG,EACR,QAAQ,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EACzB,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAE,EAAE,CACT,4IAA4I,EAC5I,QAAQ,CAAC,OAAO,CAAC,EACjB,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,EAClB,QAAQ,IAAI,+BAA+B,EAC3C,SAAS,CACZ,aAEA,KAAK,EACN,KAAC,WAAW,IAAC,SAAS,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,GAAI,IAChC,GACY,EAEhC,KAAC,qBAAqB,CAAC,MAAM,cACzB,KAAC,qBAAqB,CAAC,OAAO,IAC1B,KAAK,EAAC,OAAO,EACb,UAAU,EAAE,CAAC,EACb,SAAS,EAAE,EAAE,CACT,yFAAyF,EACzF,YAAY,EACZ,iCAAiC,CACpC,YAEA,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,CAC5B,MAAC,qBAAqB,CAAC,IAAI,IAEvB,OAAO,EAAE,MAAM,CAAC,OAAO,EACvB,QAAQ,EAAE,MAAM,CAAC,QAAQ,EACzB,SAAS,EAAE,EAAE,CACT,oGAAoG,EACpG,8CAA8C,EAC9C,4BAA4B,EAC5B,MAAM,CAAC,QAAQ,IAAI,+BAA+B,CACrD,aAEA,MAAM,CAAC,IAAI,IAAI,KAAC,MAAM,CAAC,IAAI,IAAC,SAAS,EAAC,SAAS,GAAG,EAClD,MAAM,CAAC,KAAK,KAXR,KAAK,CAYe,CAChC,CAAC,GAC0B,GACL,IACN,CAChC,CAAC;AACN,CAAC,CACJ,CAAC;AAEF,kBAAkB,CAAC,WAAW,GAAG,oBAAoB,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export interface CalendarEvent {
|
|
3
|
+
id: string;
|
|
4
|
+
date: Date;
|
|
5
|
+
startTime?: string;
|
|
6
|
+
endTime?: string;
|
|
7
|
+
title: string;
|
|
8
|
+
description?: string;
|
|
9
|
+
color?: string;
|
|
10
|
+
location?: string;
|
|
11
|
+
}
|
|
12
|
+
export type CalendarView = 'month' | 'week' | 'day' | 'agenda';
|
|
13
|
+
export interface CalendarProps {
|
|
14
|
+
value?: Date;
|
|
15
|
+
onChange?: (date: Date) => void;
|
|
16
|
+
events?: CalendarEvent[];
|
|
17
|
+
onAddEvent?: (event: Omit<CalendarEvent, 'id'>) => void;
|
|
18
|
+
onUpdateEvent?: (id: string, event: Partial<CalendarEvent>) => void;
|
|
19
|
+
onDeleteEvent?: (id: string) => void;
|
|
20
|
+
minDate?: Date;
|
|
21
|
+
maxDate?: Date;
|
|
22
|
+
showWeekNumbers?: boolean;
|
|
23
|
+
highlightToday?: boolean;
|
|
24
|
+
defaultView?: CalendarView;
|
|
25
|
+
className?: string;
|
|
26
|
+
}
|
|
27
|
+
export declare const Calendar: React.FC<CalendarProps>;
|
|
28
|
+
//# sourceMappingURL=Calendar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Calendar.d.ts","sourceRoot":"","sources":["../../components/Calendar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAmB,MAAM,OAAO,CAAC;AAQxC,MAAM,WAAW,aAAa;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,IAAI,CAAC;IACX,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,MAAM,YAAY,GAAG,OAAO,GAAG,MAAM,GAAG,KAAK,GAAG,QAAQ,CAAC;AAE/D,MAAM,WAAW,aAAa;IAC1B,KAAK,CAAC,EAAE,IAAI,CAAC;IACb,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IAChC,MAAM,CAAC,EAAE,aAAa,EAAE,CAAC;IACzB,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,KAAK,IAAI,CAAC;IACxD,aAAa,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,CAAC,aAAa,CAAC,KAAK,IAAI,CAAC;IACpE,aAAa,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IACrC,OAAO,CAAC,EAAE,IAAI,CAAC;IACf,OAAO,CAAC,EAAE,IAAI,CAAC;IACf,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,WAAW,CAAC,EAAE,YAAY,CAAC;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAkBD,eAAO,MAAM,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,aAAa,CA8oB5C,CAAC"}
|
|
@@ -0,0 +1,365 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { useState } from 'react';
|
|
3
|
+
import { tokens } from '../tokens';
|
|
4
|
+
import { Button } from './Button';
|
|
5
|
+
import { Modal, ModalHeader, ModalTitle, ModalContent, ModalFooter, ModalCloseButton } from './Modal';
|
|
6
|
+
import { Input, Textarea } from './Input';
|
|
7
|
+
import { Select, SelectTrigger, SelectValue, SelectContent, SelectItem } from './Select';
|
|
8
|
+
import { AgendaView } from './AgendaView';
|
|
9
|
+
const DAYS = ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'];
|
|
10
|
+
const DAYS_FULL = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];
|
|
11
|
+
const MONTHS = [
|
|
12
|
+
'January', 'February', 'March', 'April', 'May', 'June',
|
|
13
|
+
'July', 'August', 'September', 'October', 'November', 'December'
|
|
14
|
+
];
|
|
15
|
+
const EVENT_COLORS = [
|
|
16
|
+
{ value: '#007AFF', label: 'Blue' },
|
|
17
|
+
{ value: '#34C759', label: 'Green' },
|
|
18
|
+
{ value: '#FF9500', label: 'Orange' },
|
|
19
|
+
{ value: '#FF3B30', label: 'Red' },
|
|
20
|
+
{ value: '#5AC8FA', label: 'Cyan' },
|
|
21
|
+
{ value: '#AF52DE', label: 'Purple' },
|
|
22
|
+
];
|
|
23
|
+
export const Calendar = ({ value, onChange, events = [], onAddEvent, onUpdateEvent, onDeleteEvent, minDate, maxDate, highlightToday = true, defaultView = 'month', className = '', }) => {
|
|
24
|
+
const [currentDate, setCurrentDate] = useState(value || new Date());
|
|
25
|
+
const [selectedDate, setSelectedDate] = useState(value || null);
|
|
26
|
+
const [view, setView] = useState(defaultView);
|
|
27
|
+
const [showEventModal, setShowEventModal] = useState(false);
|
|
28
|
+
const [selectedEvent, setSelectedEvent] = useState(null);
|
|
29
|
+
const [agendaPeriod, setAgendaPeriod] = useState(30);
|
|
30
|
+
const [eventFormData, setEventFormData] = useState({
|
|
31
|
+
title: '',
|
|
32
|
+
description: '',
|
|
33
|
+
date: new Date(),
|
|
34
|
+
startTime: '09:00',
|
|
35
|
+
endTime: '10:00',
|
|
36
|
+
color: '#007AFF',
|
|
37
|
+
location: '',
|
|
38
|
+
});
|
|
39
|
+
const today = new Date();
|
|
40
|
+
today.setHours(0, 0, 0, 0);
|
|
41
|
+
const getDaysInMonth = (date) => {
|
|
42
|
+
return new Date(date.getFullYear(), date.getMonth() + 1, 0).getDate();
|
|
43
|
+
};
|
|
44
|
+
const getFirstDayOfMonth = (date) => {
|
|
45
|
+
return new Date(date.getFullYear(), date.getMonth(), 1).getDay();
|
|
46
|
+
};
|
|
47
|
+
const isSameDay = (date1, date2) => {
|
|
48
|
+
return (date1.getDate() === date2.getDate() &&
|
|
49
|
+
date1.getMonth() === date2.getMonth() &&
|
|
50
|
+
date1.getFullYear() === date2.getFullYear());
|
|
51
|
+
};
|
|
52
|
+
const isDisabled = (date) => {
|
|
53
|
+
if (minDate && date < minDate)
|
|
54
|
+
return true;
|
|
55
|
+
if (maxDate && date > maxDate)
|
|
56
|
+
return true;
|
|
57
|
+
return false;
|
|
58
|
+
};
|
|
59
|
+
const getEventsForDate = (date) => {
|
|
60
|
+
return events.filter(event => isSameDay(event.date, date));
|
|
61
|
+
};
|
|
62
|
+
const handlePrevPeriod = () => {
|
|
63
|
+
if (view === 'month') {
|
|
64
|
+
setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() - 1));
|
|
65
|
+
}
|
|
66
|
+
else if (view === 'week') {
|
|
67
|
+
const newDate = new Date(currentDate);
|
|
68
|
+
newDate.setDate(newDate.getDate() - 7);
|
|
69
|
+
setCurrentDate(newDate);
|
|
70
|
+
}
|
|
71
|
+
else if (view === 'day') {
|
|
72
|
+
const newDate = new Date(currentDate);
|
|
73
|
+
newDate.setDate(newDate.getDate() - 1);
|
|
74
|
+
setCurrentDate(newDate);
|
|
75
|
+
}
|
|
76
|
+
};
|
|
77
|
+
const handleNextPeriod = () => {
|
|
78
|
+
if (view === 'month') {
|
|
79
|
+
setCurrentDate(new Date(currentDate.getFullYear(), currentDate.getMonth() + 1));
|
|
80
|
+
}
|
|
81
|
+
else if (view === 'week') {
|
|
82
|
+
const newDate = new Date(currentDate);
|
|
83
|
+
newDate.setDate(newDate.getDate() + 7);
|
|
84
|
+
setCurrentDate(newDate);
|
|
85
|
+
}
|
|
86
|
+
else if (view === 'day') {
|
|
87
|
+
const newDate = new Date(currentDate);
|
|
88
|
+
newDate.setDate(newDate.getDate() + 1);
|
|
89
|
+
setCurrentDate(newDate);
|
|
90
|
+
}
|
|
91
|
+
};
|
|
92
|
+
const handleToday = () => {
|
|
93
|
+
setCurrentDate(new Date());
|
|
94
|
+
setSelectedDate(new Date());
|
|
95
|
+
onChange?.(new Date());
|
|
96
|
+
};
|
|
97
|
+
const handleDateClick = (date) => {
|
|
98
|
+
if (!isDisabled(date)) {
|
|
99
|
+
setSelectedDate(date);
|
|
100
|
+
setEventFormData({ ...eventFormData, date });
|
|
101
|
+
onChange?.(date);
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
const handleAddEvent = () => {
|
|
105
|
+
setSelectedEvent(null);
|
|
106
|
+
setEventFormData({
|
|
107
|
+
title: '',
|
|
108
|
+
description: '',
|
|
109
|
+
date: selectedDate || new Date(),
|
|
110
|
+
startTime: '09:00',
|
|
111
|
+
endTime: '10:00',
|
|
112
|
+
color: '#007AFF',
|
|
113
|
+
location: '',
|
|
114
|
+
});
|
|
115
|
+
setShowEventModal(true);
|
|
116
|
+
};
|
|
117
|
+
const handleEditEvent = (event) => {
|
|
118
|
+
setSelectedEvent(event);
|
|
119
|
+
setEventFormData({
|
|
120
|
+
title: event.title,
|
|
121
|
+
description: event.description || '',
|
|
122
|
+
date: event.date,
|
|
123
|
+
startTime: event.startTime || '09:00',
|
|
124
|
+
endTime: event.endTime || '10:00',
|
|
125
|
+
color: event.color || '#007AFF',
|
|
126
|
+
location: event.location || '',
|
|
127
|
+
});
|
|
128
|
+
setShowEventModal(true);
|
|
129
|
+
};
|
|
130
|
+
const handleSaveEvent = () => {
|
|
131
|
+
if (!eventFormData.title.trim())
|
|
132
|
+
return;
|
|
133
|
+
if (selectedEvent) {
|
|
134
|
+
// Update existing event
|
|
135
|
+
onUpdateEvent?.(selectedEvent.id, {
|
|
136
|
+
...eventFormData,
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
// Create new event
|
|
141
|
+
onAddEvent?.({
|
|
142
|
+
...eventFormData,
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
setShowEventModal(false);
|
|
146
|
+
setSelectedEvent(null);
|
|
147
|
+
};
|
|
148
|
+
const handleDeleteEvent = () => {
|
|
149
|
+
if (selectedEvent) {
|
|
150
|
+
onDeleteEvent?.(selectedEvent.id);
|
|
151
|
+
setShowEventModal(false);
|
|
152
|
+
setSelectedEvent(null);
|
|
153
|
+
}
|
|
154
|
+
};
|
|
155
|
+
const getWeekDates = () => {
|
|
156
|
+
const startOfWeek = new Date(currentDate);
|
|
157
|
+
const day = startOfWeek.getDay();
|
|
158
|
+
startOfWeek.setDate(startOfWeek.getDate() - day);
|
|
159
|
+
const dates = [];
|
|
160
|
+
for (let i = 0; i < 7; i++) {
|
|
161
|
+
const date = new Date(startOfWeek);
|
|
162
|
+
date.setDate(date.getDate() + i);
|
|
163
|
+
dates.push(date);
|
|
164
|
+
}
|
|
165
|
+
return dates;
|
|
166
|
+
};
|
|
167
|
+
const renderMonthView = () => {
|
|
168
|
+
const daysInMonth = getDaysInMonth(currentDate);
|
|
169
|
+
const firstDay = getFirstDayOfMonth(currentDate);
|
|
170
|
+
const days = [];
|
|
171
|
+
// Previous month's trailing days
|
|
172
|
+
const prevMonthDays = getDaysInMonth(new Date(currentDate.getFullYear(), currentDate.getMonth() - 1));
|
|
173
|
+
for (let i = firstDay - 1; i >= 0; i--) {
|
|
174
|
+
const day = prevMonthDays - i;
|
|
175
|
+
days.push(_jsx("div", { className: "calendar-day-other", style: {
|
|
176
|
+
padding: tokens.spacing[2],
|
|
177
|
+
minHeight: '80px',
|
|
178
|
+
color: 'var(--color-text-quaternary)',
|
|
179
|
+
fontSize: tokens.typography.fontSize.sm,
|
|
180
|
+
}, children: day }, `prev-${day}`));
|
|
181
|
+
}
|
|
182
|
+
// Current month days
|
|
183
|
+
for (let day = 1; day <= daysInMonth; day++) {
|
|
184
|
+
const date = new Date(currentDate.getFullYear(), currentDate.getMonth(), day);
|
|
185
|
+
const isToday = highlightToday && isSameDay(date, today);
|
|
186
|
+
const isSelected = selectedDate && isSameDay(date, selectedDate);
|
|
187
|
+
const disabled = isDisabled(date);
|
|
188
|
+
const dayEvents = getEventsForDate(date);
|
|
189
|
+
days.push(_jsxs("div", { onClick: () => !disabled && handleDateClick(date), style: {
|
|
190
|
+
padding: tokens.spacing[2],
|
|
191
|
+
minHeight: '80px',
|
|
192
|
+
backgroundColor: isSelected ? 'var(--color-accent-blue-tint)' : 'transparent',
|
|
193
|
+
border: isToday ? '2px solid var(--color-accent-blue)' : '1px solid var(--color-border-secondary)',
|
|
194
|
+
borderRadius: tokens.radius.md,
|
|
195
|
+
cursor: disabled ? 'not-allowed' : 'pointer',
|
|
196
|
+
opacity: disabled ? 0.4 : 1,
|
|
197
|
+
transition: `all ${tokens.motion.duration.fast} ${tokens.motion.easing.standard}`,
|
|
198
|
+
}, onMouseEnter: (e) => {
|
|
199
|
+
if (!disabled) {
|
|
200
|
+
e.currentTarget.style.backgroundColor = isSelected ? 'var(--color-accent-blue-tint)' : 'var(--color-background-secondary)';
|
|
201
|
+
}
|
|
202
|
+
}, onMouseLeave: (e) => {
|
|
203
|
+
if (!disabled) {
|
|
204
|
+
e.currentTarget.style.backgroundColor = isSelected ? 'var(--color-accent-blue-tint)' : 'transparent';
|
|
205
|
+
}
|
|
206
|
+
}, children: [_jsx("div", { style: { fontWeight: isToday ? tokens.typography.fontWeight.semibold : tokens.typography.fontWeight.regular, color: isToday ? 'var(--color-accent-blue)' : 'var(--color-text-primary)', marginBottom: tokens.spacing[1] }, children: day }), _jsxs("div", { style: { display: 'flex', flexDirection: 'column', gap: tokens.spacing[1] }, children: [dayEvents.slice(0, 3).map((event) => (_jsxs("div", { onClick: (e) => {
|
|
207
|
+
e.stopPropagation();
|
|
208
|
+
handleEditEvent(event);
|
|
209
|
+
}, style: {
|
|
210
|
+
fontSize: tokens.typography.fontSize.xs,
|
|
211
|
+
padding: `2px ${tokens.spacing[1]}`,
|
|
212
|
+
backgroundColor: event.color || 'var(--color-accent-blue)',
|
|
213
|
+
color: '#FFFFFF',
|
|
214
|
+
borderRadius: tokens.radius.sm,
|
|
215
|
+
overflow: 'hidden',
|
|
216
|
+
textOverflow: 'ellipsis',
|
|
217
|
+
whiteSpace: 'nowrap',
|
|
218
|
+
cursor: 'pointer',
|
|
219
|
+
}, children: [event.startTime && `${event.startTime} `, event.title] }, event.id))), dayEvents.length > 3 && (_jsxs("div", { style: { fontSize: tokens.typography.fontSize.xs, color: 'var(--color-text-tertiary)', paddingLeft: tokens.spacing[1] }, children: ["+", dayEvents.length - 3, " more"] }))] })] }, `current-${day}`));
|
|
220
|
+
}
|
|
221
|
+
// Next month's leading days
|
|
222
|
+
const totalDays = days.length;
|
|
223
|
+
const remainingDays = totalDays % 7 === 0 ? 0 : 7 - (totalDays % 7);
|
|
224
|
+
for (let day = 1; day <= remainingDays; day++) {
|
|
225
|
+
days.push(_jsx("div", { className: "calendar-day-other", style: {
|
|
226
|
+
padding: tokens.spacing[2],
|
|
227
|
+
minHeight: '80px',
|
|
228
|
+
color: 'var(--color-text-quaternary)',
|
|
229
|
+
fontSize: tokens.typography.fontSize.sm,
|
|
230
|
+
}, children: day }, `next-${day}`));
|
|
231
|
+
}
|
|
232
|
+
return days;
|
|
233
|
+
};
|
|
234
|
+
const renderWeekView = () => {
|
|
235
|
+
const weekDates = getWeekDates();
|
|
236
|
+
const hours = Array.from({ length: 24 }, (_, i) => i);
|
|
237
|
+
return (_jsxs("div", { style: { display: 'flex', gap: tokens.spacing[2] }, children: [_jsxs("div", { style: { width: '60px', flexShrink: 0 }, children: [_jsx("div", { style: { height: '60px' } }), hours.map(hour => (_jsxs("div", { style: { height: '60px', fontSize: tokens.typography.fontSize.xs, color: 'var(--color-text-tertiary)', paddingTop: tokens.spacing[1] }, children: [hour.toString().padStart(2, '0'), ":00"] }, hour)))] }), weekDates.map((date, index) => {
|
|
238
|
+
const isToday = isSameDay(date, today);
|
|
239
|
+
const dayEvents = getEventsForDate(date);
|
|
240
|
+
return (_jsxs("div", { style: { flex: 1, minWidth: '100px' }, children: [_jsxs("div", { style: { height: '60px', textAlign: 'center', padding: tokens.spacing[2], backgroundColor: isToday ? 'var(--color-accent-blue-tint)' : 'transparent', borderRadius: tokens.radius.md }, children: [_jsx("div", { style: { fontSize: tokens.typography.fontSize.xs, color: 'var(--color-text-tertiary)' }, children: DAYS[date.getDay()] }), _jsx("div", { style: { fontSize: tokens.typography.fontSize.lg, fontWeight: isToday ? tokens.typography.fontWeight.bold : tokens.typography.fontWeight.medium, color: isToday ? 'var(--color-accent-blue)' : 'var(--color-text-primary)' }, children: date.getDate() })] }), _jsxs("div", { style: { position: 'relative' }, children: [hours.map(hour => (_jsx("div", { style: { height: '60px', borderTop: '1px solid var(--color-border-secondary)' } }, hour))), dayEvents.map(event => {
|
|
241
|
+
const startHour = event.startTime ? parseInt(event.startTime.split(':')[0]) : 9;
|
|
242
|
+
const startMinute = event.startTime ? parseInt(event.startTime.split(':')[1]) : 0;
|
|
243
|
+
const endHour = event.endTime ? parseInt(event.endTime.split(':')[0]) : 10;
|
|
244
|
+
const endMinute = event.endTime ? parseInt(event.endTime.split(':')[1]) : 0;
|
|
245
|
+
const top = startHour * 60 + startMinute;
|
|
246
|
+
const height = (endHour * 60 + endMinute) - top;
|
|
247
|
+
return (_jsxs("div", { onClick: () => handleEditEvent(event), style: {
|
|
248
|
+
position: 'absolute',
|
|
249
|
+
top: `${top}px`,
|
|
250
|
+
height: `${Math.max(height - 2, 20)}px`, // Subtract 2px for gap, min height 20px
|
|
251
|
+
left: '4px',
|
|
252
|
+
right: '4px',
|
|
253
|
+
backgroundColor: event.color || 'var(--color-accent-blue)',
|
|
254
|
+
color: '#FFFFFF',
|
|
255
|
+
borderRadius: tokens.radius.sm,
|
|
256
|
+
padding: tokens.spacing[1],
|
|
257
|
+
fontSize: tokens.typography.fontSize.xs,
|
|
258
|
+
overflow: 'hidden',
|
|
259
|
+
cursor: 'pointer',
|
|
260
|
+
zIndex: 10,
|
|
261
|
+
}, children: [_jsx("div", { style: { fontWeight: tokens.typography.fontWeight.semibold }, children: event.title }), event.startTime && _jsxs("div", { children: [event.startTime, " - ", event.endTime] })] }, event.id));
|
|
262
|
+
})] })] }, index));
|
|
263
|
+
})] }));
|
|
264
|
+
};
|
|
265
|
+
const renderDayView = () => {
|
|
266
|
+
const hours = Array.from({ length: 24 }, (_, i) => i);
|
|
267
|
+
const dayEvents = getEventsForDate(currentDate);
|
|
268
|
+
return (_jsxs("div", { style: { display: 'flex', gap: tokens.spacing[2] }, children: [_jsx("div", { style: { width: '80px', flexShrink: 0 }, children: hours.map(hour => (_jsxs("div", { style: { height: '80px', fontSize: tokens.typography.fontSize.sm, color: 'var(--color-text-tertiary)', paddingTop: tokens.spacing[2] }, children: [hour.toString().padStart(2, '0'), ":00"] }, hour))) }), _jsxs("div", { style: { flex: 1, position: 'relative' }, children: [hours.map(hour => (_jsx("div", { style: { height: '80px', borderTop: '1px solid var(--color-border-secondary)' } }, hour))), dayEvents.map(event => {
|
|
269
|
+
const startHour = event.startTime ? parseInt(event.startTime.split(':')[0]) : 9;
|
|
270
|
+
const startMinute = event.startTime ? parseInt(event.startTime.split(':')[1]) : 0;
|
|
271
|
+
const endHour = event.endTime ? parseInt(event.endTime.split(':')[0]) : 10;
|
|
272
|
+
const endMinute = event.endTime ? parseInt(event.endTime.split(':')[1]) : 0;
|
|
273
|
+
const top = (startHour * 80) + (startMinute * 80 / 60);
|
|
274
|
+
const height = ((endHour * 80) + (endMinute * 80 / 60)) - top;
|
|
275
|
+
return (_jsxs("div", { onClick: () => handleEditEvent(event), style: {
|
|
276
|
+
position: 'absolute',
|
|
277
|
+
top: `${top}px`,
|
|
278
|
+
height: `${Math.max(height - 2, 30)}px`, // Subtract 2px for gap, min height 30px
|
|
279
|
+
left: '8px',
|
|
280
|
+
right: '8px',
|
|
281
|
+
backgroundColor: event.color || 'var(--color-accent-blue)',
|
|
282
|
+
color: '#FFFFFF',
|
|
283
|
+
borderRadius: tokens.radius.md,
|
|
284
|
+
padding: tokens.spacing[2],
|
|
285
|
+
fontSize: tokens.typography.fontSize.sm,
|
|
286
|
+
overflow: 'hidden',
|
|
287
|
+
cursor: 'pointer',
|
|
288
|
+
boxShadow: tokens.shadows.sm,
|
|
289
|
+
zIndex: 10,
|
|
290
|
+
}, children: [_jsx("div", { style: { fontWeight: tokens.typography.fontWeight.bold, marginBottom: tokens.spacing[1] }, children: event.title }), _jsxs("div", { style: { fontSize: tokens.typography.fontSize.xs }, children: [event.startTime, " - ", event.endTime] }), event.location && _jsxs("div", { style: { fontSize: tokens.typography.fontSize.xs, marginTop: tokens.spacing[1] }, children: ["\uD83D\uDCCD ", event.location] })] }, event.id));
|
|
291
|
+
})] })] }));
|
|
292
|
+
};
|
|
293
|
+
const getViewTitle = () => {
|
|
294
|
+
if (view === 'month') {
|
|
295
|
+
return `${MONTHS[currentDate.getMonth()]} ${currentDate.getFullYear()}`;
|
|
296
|
+
}
|
|
297
|
+
else if (view === 'week') {
|
|
298
|
+
const weekDates = getWeekDates();
|
|
299
|
+
const start = weekDates[0];
|
|
300
|
+
const end = weekDates[6];
|
|
301
|
+
return `${MONTHS[start.getMonth()]} ${start.getDate()} - ${MONTHS[end.getMonth()]} ${end.getDate()}, ${end.getFullYear()}`;
|
|
302
|
+
}
|
|
303
|
+
else if (view === 'day') {
|
|
304
|
+
return `${DAYS_FULL[currentDate.getDay()]}, ${MONTHS[currentDate.getMonth()]} ${currentDate.getDate()}, ${currentDate.getFullYear()}`;
|
|
305
|
+
}
|
|
306
|
+
else if (view === 'agenda') {
|
|
307
|
+
// Agenda view - show date range
|
|
308
|
+
const endDate = new Date(currentDate);
|
|
309
|
+
endDate.setDate(endDate.getDate() + agendaPeriod - 1); // Subtract 1 because agendaPeriod is a count of days including the start day
|
|
310
|
+
return `${MONTHS[currentDate.getMonth()]} ${currentDate.getDate()} - ${MONTHS[endDate.getMonth()]} ${endDate.getDate()}, ${endDate.getFullYear()}`;
|
|
311
|
+
}
|
|
312
|
+
else {
|
|
313
|
+
return 'Agenda';
|
|
314
|
+
}
|
|
315
|
+
};
|
|
316
|
+
return (_jsxs("div", { className: `calendar ${className}`, style: {
|
|
317
|
+
backgroundColor: 'var(--color-background-primary)',
|
|
318
|
+
borderRadius: tokens.radius.lg,
|
|
319
|
+
padding: tokens.spacing[4],
|
|
320
|
+
border: `1px solid var(--color-border-primary)`,
|
|
321
|
+
boxShadow: tokens.shadows.sm,
|
|
322
|
+
width: '100%',
|
|
323
|
+
maxWidth: view === 'month' ? '800px' : '100%',
|
|
324
|
+
}, children: [_jsxs("div", { style: {
|
|
325
|
+
display: 'flex',
|
|
326
|
+
alignItems: 'center',
|
|
327
|
+
justifyContent: 'space-between',
|
|
328
|
+
marginBottom: tokens.spacing[4],
|
|
329
|
+
flexWrap: 'wrap',
|
|
330
|
+
gap: tokens.spacing[2],
|
|
331
|
+
}, children: [_jsxs("div", { style: { display: 'flex', alignItems: 'center', gap: tokens.spacing[2] }, children: [view !== 'agenda' && (_jsxs(_Fragment, { children: [_jsx(Button, { variant: "ghost", size: "sm", onClick: handlePrevPeriod, children: "\u2190" }), _jsx(Button, { variant: "ghost", size: "sm", onClick: handleToday, children: "Today" }), _jsx(Button, { variant: "ghost", size: "sm", onClick: handleNextPeriod, children: "\u2192" })] })), _jsx("h3", { style: {
|
|
332
|
+
margin: 0,
|
|
333
|
+
fontSize: tokens.typography.fontSize.lg,
|
|
334
|
+
fontWeight: tokens.typography.fontWeight.semibold,
|
|
335
|
+
color: 'var(--color-text-primary)',
|
|
336
|
+
}, children: getViewTitle() })] }), _jsxs("div", { style: { display: 'flex', alignItems: 'center', gap: tokens.spacing[2] }, children: [_jsx("div", { style: { display: 'flex', gap: tokens.spacing[1], backgroundColor: 'var(--color-background-secondary)', borderRadius: tokens.radius.md, padding: '2px' }, children: ['month', 'week', 'day', 'agenda'].map((v) => (_jsx("button", { onClick: () => setView(v), style: {
|
|
337
|
+
padding: `${tokens.spacing[1]} ${tokens.spacing[3]}`,
|
|
338
|
+
fontSize: tokens.typography.fontSize.sm,
|
|
339
|
+
fontWeight: tokens.typography.fontWeight.medium,
|
|
340
|
+
color: view === v ? '#FFFFFF' : 'var(--color-text-secondary)',
|
|
341
|
+
backgroundColor: view === v ? 'var(--color-accent-blue)' : 'transparent',
|
|
342
|
+
border: 'none',
|
|
343
|
+
borderRadius: tokens.radius.sm,
|
|
344
|
+
cursor: 'pointer',
|
|
345
|
+
transition: `all ${tokens.motion.duration.fast} ${tokens.motion.easing.standard}`,
|
|
346
|
+
textTransform: 'capitalize',
|
|
347
|
+
}, children: v }, v))) }), _jsx(Button, { variant: "primary", size: "sm", onClick: handleAddEvent, children: "+ Add Event" })] })] }), view === 'month' && (_jsx("div", { style: {
|
|
348
|
+
display: 'grid',
|
|
349
|
+
gridTemplateColumns: 'repeat(7, 1fr)',
|
|
350
|
+
gap: tokens.spacing[1],
|
|
351
|
+
marginBottom: tokens.spacing[2],
|
|
352
|
+
}, children: DAYS.map((day) => (_jsx("div", { style: {
|
|
353
|
+
padding: tokens.spacing[2],
|
|
354
|
+
textAlign: 'center',
|
|
355
|
+
fontSize: tokens.typography.fontSize.xs,
|
|
356
|
+
fontWeight: tokens.typography.fontWeight.semibold,
|
|
357
|
+
color: 'var(--color-text-tertiary)',
|
|
358
|
+
textTransform: 'uppercase',
|
|
359
|
+
}, children: day }, day))) })), _jsxs("div", { style: { overflowX: 'auto' }, children: [view === 'month' && (_jsx("div", { style: {
|
|
360
|
+
display: 'grid',
|
|
361
|
+
gridTemplateColumns: 'repeat(7, 1fr)',
|
|
362
|
+
gap: tokens.spacing[1],
|
|
363
|
+
}, children: renderMonthView() })), view === 'week' && renderWeekView(), view === 'day' && renderDayView(), view === 'agenda' && (_jsx(AgendaView, { events: events, currentDate: currentDate, days: agendaPeriod, onEventClick: handleEditEvent }))] }), _jsxs(Modal, { open: showEventModal, onOpenChange: setShowEventModal, size: "md", children: [_jsx(ModalCloseButton, {}), _jsx(ModalHeader, { children: _jsx(ModalTitle, { children: selectedEvent ? 'Edit Event' : 'Add Event' }) }), _jsx(ModalContent, { children: _jsxs("div", { className: "space-y-4", children: [_jsx(Input, { label: "Title", placeholder: "Event title", value: eventFormData.title, onChange: (e) => setEventFormData({ ...eventFormData, title: e.target.value }), required: true }), _jsx(Textarea, { label: "Description", placeholder: "Event description (optional)", value: eventFormData.description, onChange: (e) => setEventFormData({ ...eventFormData, description: e.target.value }), rows: 3 }), _jsxs("div", { style: { display: 'grid', gridTemplateColumns: '1fr 1fr', gap: tokens.spacing[3] }, children: [_jsx(Input, { label: "Start Time", type: "time", value: eventFormData.startTime, onChange: (e) => setEventFormData({ ...eventFormData, startTime: e.target.value }) }), _jsx(Input, { label: "End Time", type: "time", value: eventFormData.endTime, onChange: (e) => setEventFormData({ ...eventFormData, endTime: e.target.value }) })] }), _jsx(Input, { label: "Location", placeholder: "Event location (optional)", value: eventFormData.location, onChange: (e) => setEventFormData({ ...eventFormData, location: e.target.value }) }), _jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-text-primary mb-2", children: "Color" }), _jsxs(Select, { value: eventFormData.color, onValueChange: (value) => setEventFormData({ ...eventFormData, color: value }), children: [_jsx(SelectTrigger, { className: "w-full", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: EVENT_COLORS.map(color => (_jsx(SelectItem, { value: color.value, children: _jsxs("div", { style: { display: 'flex', alignItems: 'center', gap: tokens.spacing[2] }, children: [_jsx("div", { style: { width: '16px', height: '16px', borderRadius: '50%', backgroundColor: color.value } }), color.label] }) }, color.value))) })] })] })] }) }), _jsxs(ModalFooter, { children: [selectedEvent && (_jsx(Button, { variant: "ghost", onClick: handleDeleteEvent, style: { marginRight: 'auto', color: 'var(--color-status-error)' }, children: "Delete" })), _jsx(Button, { variant: "ghost", onClick: () => setShowEventModal(false), children: "Cancel" }), _jsx(Button, { variant: "primary", onClick: handleSaveEvent, disabled: !eventFormData.title.trim(), children: selectedEvent ? 'Update' : 'Add' })] })] })] }));
|
|
364
|
+
};
|
|
365
|
+
//# sourceMappingURL=Calendar.js.map
|