@smart-coder-labs/apple-design-system 1.0.0 → 1.0.2
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 +13 -13
- package/dist/cli/commands/add.js +25 -18
- package/dist/cli/commands/add.js.map +1 -1
- package/dist/cli/commands/init.js +27 -20
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/index.js +8 -6
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/utils/registry.js +8 -3
- package/dist/cli/utils/registry.js.map +1 -1
- package/dist/index.d.ts +0 -240
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +7 -136
- package/dist/index.js.map +1 -1
- package/dist/lib/utils.js +7 -4
- package/dist/lib/utils.js.map +1 -1
- package/dist/scripts/build-registry.js +13 -8
- package/dist/scripts/build-registry.js.map +1 -1
- package/dist/tokens.js +4 -1
- package/dist/tokens.js.map +1 -1
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +4 -1
- package/dist/components/AIThinkingIndicator.d.ts +0 -10
- package/dist/components/AIThinkingIndicator.d.ts.map +0 -1
- package/dist/components/AIThinkingIndicator.js +0 -60
- package/dist/components/AIThinkingIndicator.js.map +0 -1
- package/dist/components/Accordion.d.ts +0 -27
- package/dist/components/Accordion.d.ts.map +0 -1
- package/dist/components/Accordion.js +0 -123
- package/dist/components/Accordion.js.map +0 -1
- package/dist/components/ActivityFeed.d.ts +0 -26
- package/dist/components/ActivityFeed.d.ts.map +0 -1
- package/dist/components/ActivityFeed.js +0 -55
- package/dist/components/ActivityFeed.js.map +0 -1
- package/dist/components/ActivityMonitor.d.ts +0 -38
- package/dist/components/ActivityMonitor.d.ts.map +0 -1
- package/dist/components/ActivityMonitor.js +0 -164
- package/dist/components/ActivityMonitor.js.map +0 -1
- package/dist/components/AddressSelector.d.ts +0 -23
- package/dist/components/AddressSelector.d.ts.map +0 -1
- package/dist/components/AddressSelector.js +0 -145
- package/dist/components/AddressSelector.js.map +0 -1
- package/dist/components/AgendaView.d.ts +0 -11
- package/dist/components/AgendaView.d.ts.map +0 -1
- package/dist/components/AgendaView.js +0 -47
- package/dist/components/AgendaView.js.map +0 -1
- package/dist/components/Alert.d.ts +0 -9
- package/dist/components/Alert.d.ts.map +0 -1
- package/dist/components/Alert.js +0 -38
- package/dist/components/Alert.js.map +0 -1
- package/dist/components/AudioPlayer.d.ts +0 -11
- package/dist/components/AudioPlayer.d.ts.map +0 -1
- package/dist/components/AudioPlayer.js +0 -116
- package/dist/components/AudioPlayer.js.map +0 -1
- package/dist/components/Avatar.d.ts +0 -17
- package/dist/components/Avatar.d.ts.map +0 -1
- package/dist/components/Avatar.js +0 -74
- package/dist/components/Avatar.js.map +0 -1
- package/dist/components/AvatarGroup.d.ts +0 -15
- package/dist/components/AvatarGroup.d.ts.map +0 -1
- package/dist/components/AvatarGroup.js +0 -28
- package/dist/components/AvatarGroup.js.map +0 -1
- package/dist/components/Badge.d.ts +0 -21
- package/dist/components/Badge.d.ts.map +0 -1
- package/dist/components/Badge.js +0 -103
- package/dist/components/Badge.js.map +0 -1
- package/dist/components/BarcodeGenerator.d.ts +0 -18
- package/dist/components/BarcodeGenerator.d.ts.map +0 -1
- package/dist/components/BarcodeGenerator.js +0 -64
- package/dist/components/BarcodeGenerator.js.map +0 -1
- package/dist/components/Blockquote.d.ts +0 -9
- package/dist/components/Blockquote.d.ts.map +0 -1
- package/dist/components/Blockquote.js +0 -8
- package/dist/components/Blockquote.js.map +0 -1
- package/dist/components/BottomNavigation.d.ts +0 -21
- package/dist/components/BottomNavigation.d.ts.map +0 -1
- package/dist/components/BottomNavigation.js +0 -77
- package/dist/components/BottomNavigation.js.map +0 -1
- package/dist/components/Breadcrumb.d.ts +0 -20
- package/dist/components/Breadcrumb.d.ts.map +0 -1
- package/dist/components/Breadcrumb.js +0 -24
- package/dist/components/Breadcrumb.js.map +0 -1
- package/dist/components/BreadcrumbTabsHybrid.d.ts +0 -25
- package/dist/components/BreadcrumbTabsHybrid.d.ts.map +0 -1
- package/dist/components/BreadcrumbTabsHybrid.js +0 -58
- package/dist/components/BreadcrumbTabsHybrid.js.map +0 -1
- package/dist/components/Button.d.ts +0 -14
- package/dist/components/Button.d.ts.map +0 -1
- package/dist/components/Button.js +0 -91
- package/dist/components/Button.js.map +0 -1
- package/dist/components/ButtonWithDropdown.d.ts +0 -19
- package/dist/components/ButtonWithDropdown.d.ts.map +0 -1
- package/dist/components/ButtonWithDropdown.js +0 -33
- package/dist/components/ButtonWithDropdown.js.map +0 -1
- package/dist/components/Calendar.d.ts +0 -28
- package/dist/components/Calendar.d.ts.map +0 -1
- package/dist/components/Calendar.js +0 -365
- package/dist/components/Calendar.js.map +0 -1
- package/dist/components/Callout.d.ts +0 -11
- package/dist/components/Callout.d.ts.map +0 -1
- package/dist/components/Callout.js +0 -35
- package/dist/components/Callout.js.map +0 -1
- package/dist/components/Caption.d.ts +0 -6
- package/dist/components/Caption.d.ts.map +0 -1
- package/dist/components/Caption.js +0 -7
- package/dist/components/Caption.js.map +0 -1
- package/dist/components/Card.d.ts +0 -30
- package/dist/components/Card.d.ts.map +0 -1
- package/dist/components/Card.js +0 -72
- package/dist/components/Card.js.map +0 -1
- package/dist/components/CartPreview.d.ts +0 -28
- package/dist/components/CartPreview.d.ts.map +0 -1
- package/dist/components/CartPreview.js +0 -80
- package/dist/components/CartPreview.js.map +0 -1
- package/dist/components/Chart.d.ts +0 -19
- package/dist/components/Chart.d.ts.map +0 -1
- package/dist/components/Chart.js +0 -46
- package/dist/components/Chart.js.map +0 -1
- package/dist/components/ChatBubble.d.ts +0 -19
- package/dist/components/ChatBubble.d.ts.map +0 -1
- package/dist/components/ChatBubble.js +0 -27
- package/dist/components/ChatBubble.js.map +0 -1
- package/dist/components/ChatInput.d.ts +0 -22
- package/dist/components/ChatInput.d.ts.map +0 -1
- package/dist/components/ChatInput.js +0 -115
- package/dist/components/ChatInput.js.map +0 -1
- package/dist/components/Checkbox.d.ts +0 -10
- package/dist/components/Checkbox.d.ts.map +0 -1
- package/dist/components/Checkbox.js +0 -35
- package/dist/components/Checkbox.js.map +0 -1
- package/dist/components/Chip.d.ts +0 -14
- package/dist/components/Chip.d.ts.map +0 -1
- package/dist/components/Chip.js +0 -43
- package/dist/components/Chip.js.map +0 -1
- package/dist/components/CodeBlock.d.ts +0 -9
- package/dist/components/CodeBlock.d.ts.map +0 -1
- package/dist/components/CodeBlock.js +0 -16
- package/dist/components/CodeBlock.js.map +0 -1
- package/dist/components/Collapsible.d.ts +0 -19
- package/dist/components/Collapsible.d.ts.map +0 -1
- package/dist/components/Collapsible.js +0 -42
- package/dist/components/Collapsible.js.map +0 -1
- package/dist/components/Combobox.d.ts +0 -17
- package/dist/components/Combobox.d.ts.map +0 -1
- package/dist/components/Combobox.js +0 -114
- package/dist/components/Combobox.js.map +0 -1
- package/dist/components/CommandMenu.d.ts +0 -36
- package/dist/components/CommandMenu.d.ts.map +0 -1
- package/dist/components/CommandMenu.js +0 -102
- package/dist/components/CommandMenu.js.map +0 -1
- package/dist/components/CommentThread.d.ts +0 -28
- package/dist/components/CommentThread.d.ts.map +0 -1
- package/dist/components/CommentThread.js +0 -66
- package/dist/components/CommentThread.js.map +0 -1
- package/dist/components/ConfirmDialog.d.ts +0 -27
- package/dist/components/ConfirmDialog.d.ts.map +0 -1
- package/dist/components/ConfirmDialog.js +0 -62
- package/dist/components/ConfirmDialog.js.map +0 -1
- package/dist/components/ContextMenu.d.ts +0 -85
- package/dist/components/ContextMenu.d.ts.map +0 -1
- package/dist/components/ContextMenu.js +0 -191
- package/dist/components/ContextMenu.js.map +0 -1
- package/dist/components/ControlCenterToggles.d.ts +0 -18
- package/dist/components/ControlCenterToggles.d.ts.map +0 -1
- package/dist/components/ControlCenterToggles.js +0 -14
- package/dist/components/ControlCenterToggles.js.map +0 -1
- package/dist/components/Counters.d.ts +0 -16
- package/dist/components/Counters.d.ts.map +0 -1
- package/dist/components/Counters.js +0 -9
- package/dist/components/Counters.js.map +0 -1
- package/dist/components/CountersListWithChart.d.ts +0 -15
- package/dist/components/CountersListWithChart.d.ts.map +0 -1
- package/dist/components/CountersListWithChart.js +0 -22
- package/dist/components/CountersListWithChart.js.map +0 -1
- package/dist/components/DataGrid.d.ts +0 -38
- package/dist/components/DataGrid.d.ts.map +0 -1
- package/dist/components/DataGrid.js +0 -271
- package/dist/components/DataGrid.js.map +0 -1
- package/dist/components/DatePicker.d.ts +0 -17
- package/dist/components/DatePicker.d.ts.map +0 -1
- package/dist/components/DatePicker.js +0 -248
- package/dist/components/DatePicker.js.map +0 -1
- package/dist/components/DateRangePicker.d.ts +0 -21
- package/dist/components/DateRangePicker.d.ts.map +0 -1
- package/dist/components/DateRangePicker.js +0 -213
- package/dist/components/DateRangePicker.js.map +0 -1
- package/dist/components/DefinitionList.d.ts +0 -21
- package/dist/components/DefinitionList.d.ts.map +0 -1
- package/dist/components/DefinitionList.js +0 -44
- package/dist/components/DefinitionList.js.map +0 -1
- package/dist/components/DescriptionBlock.d.ts +0 -36
- package/dist/components/DescriptionBlock.d.ts.map +0 -1
- package/dist/components/DescriptionBlock.js +0 -27
- package/dist/components/DescriptionBlock.js.map +0 -1
- package/dist/components/DeviceList.d.ts +0 -24
- package/dist/components/DeviceList.d.ts.map +0 -1
- package/dist/components/DeviceList.js +0 -46
- package/dist/components/DeviceList.js.map +0 -1
- package/dist/components/DiffViewer.d.ts +0 -13
- package/dist/components/DiffViewer.d.ts.map +0 -1
- package/dist/components/DiffViewer.js +0 -93
- package/dist/components/DiffViewer.js.map +0 -1
- package/dist/components/Divider.d.ts +0 -28
- package/dist/components/Divider.d.ts.map +0 -1
- package/dist/components/Divider.js +0 -16
- package/dist/components/Divider.js.map +0 -1
- package/dist/components/DockBar.d.ts +0 -29
- package/dist/components/DockBar.d.ts.map +0 -1
- package/dist/components/DockBar.js +0 -64
- package/dist/components/DockBar.js.map +0 -1
- package/dist/components/EmptyState.d.ts +0 -25
- package/dist/components/EmptyState.d.ts.map +0 -1
- package/dist/components/EmptyState.js +0 -20
- package/dist/components/EmptyState.js.map +0 -1
- package/dist/components/ErrorBoundary.d.ts +0 -24
- package/dist/components/ErrorBoundary.d.ts.map +0 -1
- package/dist/components/ErrorBoundary.js +0 -55
- package/dist/components/ErrorBoundary.js.map +0 -1
- package/dist/components/FAB.d.ts +0 -15
- package/dist/components/FAB.d.ts.map +0 -1
- package/dist/components/FAB.js +0 -46
- package/dist/components/FAB.js.map +0 -1
- package/dist/components/FABGroup.d.ts +0 -15
- package/dist/components/FABGroup.d.ts.map +0 -1
- package/dist/components/FABGroup.js +0 -47
- package/dist/components/FABGroup.js.map +0 -1
- package/dist/components/FileIntelligencePreview.d.ts +0 -25
- package/dist/components/FileIntelligencePreview.d.ts.map +0 -1
- package/dist/components/FileIntelligencePreview.js +0 -66
- package/dist/components/FileIntelligencePreview.js.map +0 -1
- package/dist/components/FileUpload.d.ts +0 -13
- package/dist/components/FileUpload.d.ts.map +0 -1
- package/dist/components/FileUpload.js +0 -107
- package/dist/components/FileUpload.js.map +0 -1
- package/dist/components/FilterBar.d.ts +0 -35
- package/dist/components/FilterBar.d.ts.map +0 -1
- package/dist/components/FilterBar.js +0 -79
- package/dist/components/FilterBar.js.map +0 -1
- package/dist/components/FloatingToolbar.d.ts +0 -24
- package/dist/components/FloatingToolbar.d.ts.map +0 -1
- package/dist/components/FloatingToolbar.js +0 -180
- package/dist/components/FloatingToolbar.js.map +0 -1
- package/dist/components/Footer.d.ts +0 -32
- package/dist/components/Footer.d.ts.map +0 -1
- package/dist/components/Footer.js +0 -31
- package/dist/components/Footer.js.map +0 -1
- package/dist/components/Gallery.d.ts +0 -11
- package/dist/components/Gallery.d.ts.map +0 -1
- package/dist/components/Gallery.js +0 -32
- package/dist/components/Gallery.js.map +0 -1
- package/dist/components/GestureCard.d.ts +0 -12
- package/dist/components/GestureCard.d.ts.map +0 -1
- package/dist/components/GestureCard.js +0 -58
- package/dist/components/GestureCard.js.map +0 -1
- package/dist/components/GridSystem.d.ts +0 -72
- package/dist/components/GridSystem.d.ts.map +0 -1
- package/dist/components/GridSystem.js +0 -65
- package/dist/components/GridSystem.js.map +0 -1
- package/dist/components/HamburgerMenuIcon.d.ts +0 -24
- package/dist/components/HamburgerMenuIcon.d.ts.map +0 -1
- package/dist/components/HamburgerMenuIcon.js +0 -44
- package/dist/components/HamburgerMenuIcon.js.map +0 -1
- package/dist/components/HapticButton.d.ts +0 -23
- package/dist/components/HapticButton.d.ts.map +0 -1
- package/dist/components/HapticButton.js +0 -104
- package/dist/components/HapticButton.js.map +0 -1
- package/dist/components/Heading.d.ts +0 -6
- package/dist/components/Heading.d.ts.map +0 -1
- package/dist/components/Heading.js +0 -7
- package/dist/components/Heading.js.map +0 -1
- package/dist/components/IconButton.d.ts +0 -14
- package/dist/components/IconButton.d.ts.map +0 -1
- package/dist/components/IconButton.js +0 -39
- package/dist/components/IconButton.js.map +0 -1
- package/dist/components/ImageCarousel.d.ts +0 -18
- package/dist/components/ImageCarousel.d.ts.map +0 -1
- package/dist/components/ImageCarousel.js +0 -74
- package/dist/components/ImageCarousel.js.map +0 -1
- package/dist/components/ImageCropper.d.ts +0 -10
- package/dist/components/ImageCropper.d.ts.map +0 -1
- package/dist/components/ImageCropper.js +0 -138
- package/dist/components/ImageCropper.js.map +0 -1
- package/dist/components/Input.d.ts +0 -18
- package/dist/components/Input.d.ts.map +0 -1
- package/dist/components/Input.js +0 -117
- package/dist/components/Input.js.map +0 -1
- package/dist/components/InspectorPanel.d.ts +0 -18
- package/dist/components/InspectorPanel.d.ts.map +0 -1
- package/dist/components/InspectorPanel.js +0 -33
- package/dist/components/InspectorPanel.js.map +0 -1
- package/dist/components/InvoicePreview.d.ts +0 -41
- package/dist/components/InvoicePreview.d.ts.map +0 -1
- package/dist/components/InvoicePreview.js +0 -106
- package/dist/components/InvoicePreview.js.map +0 -1
- package/dist/components/JsonViewer.d.ts +0 -17
- package/dist/components/JsonViewer.d.ts.map +0 -1
- package/dist/components/JsonViewer.js +0 -58
- package/dist/components/JsonViewer.js.map +0 -1
- package/dist/components/KPIBlock.d.ts +0 -23
- package/dist/components/KPIBlock.d.ts.map +0 -1
- package/dist/components/KPIBlock.js +0 -82
- package/dist/components/KPIBlock.js.map +0 -1
- package/dist/components/KanbanBoard.d.ts +0 -34
- package/dist/components/KanbanBoard.d.ts.map +0 -1
- package/dist/components/KanbanBoard.js +0 -296
- package/dist/components/KanbanBoard.js.map +0 -1
- package/dist/components/KeyValueInfo.d.ts +0 -28
- package/dist/components/KeyValueInfo.d.ts.map +0 -1
- package/dist/components/KeyValueInfo.js +0 -80
- package/dist/components/KeyValueInfo.js.map +0 -1
- package/dist/components/Label.d.ts +0 -8
- package/dist/components/Label.d.ts.map +0 -1
- package/dist/components/Label.js +0 -9
- package/dist/components/Label.js.map +0 -1
- package/dist/components/Layout.d.ts +0 -16
- package/dist/components/Layout.d.ts.map +0 -1
- package/dist/components/Layout.js +0 -26
- package/dist/components/Layout.js.map +0 -1
- package/dist/components/Lightbox.d.ts +0 -18
- package/dist/components/Lightbox.d.ts.map +0 -1
- package/dist/components/Lightbox.js +0 -60
- package/dist/components/Lightbox.js.map +0 -1
- package/dist/components/LoadingOverlay.d.ts +0 -32
- package/dist/components/LoadingOverlay.d.ts.map +0 -1
- package/dist/components/LoadingOverlay.js +0 -10
- package/dist/components/LoadingOverlay.js.map +0 -1
- package/dist/components/LoginForm.d.ts +0 -14
- package/dist/components/LoginForm.d.ts.map +0 -1
- package/dist/components/LoginForm.js +0 -36
- package/dist/components/LoginForm.js.map +0 -1
- package/dist/components/MaintenanceMode.d.ts +0 -41
- package/dist/components/MaintenanceMode.d.ts.map +0 -1
- package/dist/components/MaintenanceMode.js +0 -21
- package/dist/components/MaintenanceMode.js.map +0 -1
- package/dist/components/MarkdownEditor.d.ts +0 -14
- package/dist/components/MarkdownEditor.d.ts.map +0 -1
- package/dist/components/MarkdownEditor.js +0 -55
- package/dist/components/MarkdownEditor.js.map +0 -1
- package/dist/components/MasonryLayout.d.ts +0 -31
- package/dist/components/MasonryLayout.d.ts.map +0 -1
- package/dist/components/MasonryLayout.js +0 -17
- package/dist/components/MasonryLayout.js.map +0 -1
- package/dist/components/MenuBar.d.ts +0 -34
- package/dist/components/MenuBar.d.ts.map +0 -1
- package/dist/components/MenuBar.js +0 -66
- package/dist/components/MenuBar.js.map +0 -1
- package/dist/components/MessageReactions.d.ts +0 -22
- package/dist/components/MessageReactions.d.ts.map +0 -1
- package/dist/components/MessageReactions.js +0 -37
- package/dist/components/MessageReactions.js.map +0 -1
- package/dist/components/Modal.d.ts +0 -37
- package/dist/components/Modal.d.ts.map +0 -1
- package/dist/components/Modal.js +0 -93
- package/dist/components/Modal.js.map +0 -1
- package/dist/components/ModalStackManager.d.ts +0 -34
- package/dist/components/ModalStackManager.d.ts.map +0 -1
- package/dist/components/ModalStackManager.js +0 -52
- package/dist/components/ModalStackManager.js.map +0 -1
- package/dist/components/MultiFileUpload.d.ts +0 -15
- package/dist/components/MultiFileUpload.d.ts.map +0 -1
- package/dist/components/MultiFileUpload.js +0 -138
- package/dist/components/MultiFileUpload.js.map +0 -1
- package/dist/components/NavBar.d.ts +0 -30
- package/dist/components/NavBar.d.ts.map +0 -1
- package/dist/components/NavBar.js +0 -80
- package/dist/components/NavBar.js.map +0 -1
- package/dist/components/NavigationDrawer.d.ts +0 -48
- package/dist/components/NavigationDrawer.d.ts.map +0 -1
- package/dist/components/NavigationDrawer.js +0 -95
- package/dist/components/NavigationDrawer.js.map +0 -1
- package/dist/components/NotificationCenterPanel.d.ts +0 -25
- package/dist/components/NotificationCenterPanel.d.ts.map +0 -1
- package/dist/components/NotificationCenterPanel.js +0 -50
- package/dist/components/NotificationCenterPanel.js.map +0 -1
- package/dist/components/OTPInput.d.ts +0 -15
- package/dist/components/OTPInput.d.ts.map +0 -1
- package/dist/components/OTPInput.js +0 -144
- package/dist/components/OTPInput.js.map +0 -1
- package/dist/components/OfflineState.d.ts +0 -36
- package/dist/components/OfflineState.d.ts.map +0 -1
- package/dist/components/OfflineState.js +0 -21
- package/dist/components/OfflineState.js.map +0 -1
- package/dist/components/OrderSummary.d.ts +0 -19
- package/dist/components/OrderSummary.d.ts.map +0 -1
- package/dist/components/OrderSummary.js +0 -8
- package/dist/components/OrderSummary.js.map +0 -1
- package/dist/components/Pagination.d.ts +0 -28
- package/dist/components/Pagination.d.ts.map +0 -1
- package/dist/components/Pagination.js +0 -119
- package/dist/components/Pagination.js.map +0 -1
- package/dist/components/Panel.d.ts +0 -14
- package/dist/components/Panel.d.ts.map +0 -1
- package/dist/components/Panel.js +0 -27
- package/dist/components/Panel.js.map +0 -1
- package/dist/components/Paragraph.d.ts +0 -6
- package/dist/components/Paragraph.d.ts.map +0 -1
- package/dist/components/Paragraph.js +0 -7
- package/dist/components/Paragraph.js.map +0 -1
- package/dist/components/PasswordInput.d.ts +0 -16
- package/dist/components/PasswordInput.d.ts.map +0 -1
- package/dist/components/PasswordInput.js +0 -66
- package/dist/components/PasswordInput.js.map +0 -1
- package/dist/components/PaymentMethodSelector.d.ts +0 -22
- package/dist/components/PaymentMethodSelector.d.ts.map +0 -1
- package/dist/components/PaymentMethodSelector.js +0 -24
- package/dist/components/PaymentMethodSelector.js.map +0 -1
- package/dist/components/PermissionsMatrix.d.ts +0 -23
- package/dist/components/PermissionsMatrix.d.ts.map +0 -1
- package/dist/components/PermissionsMatrix.js +0 -52
- package/dist/components/PermissionsMatrix.js.map +0 -1
- package/dist/components/Popover.d.ts +0 -19
- package/dist/components/Popover.d.ts.map +0 -1
- package/dist/components/Popover.js +0 -159
- package/dist/components/Popover.js.map +0 -1
- package/dist/components/PriceDisplay.d.ts +0 -18
- package/dist/components/PriceDisplay.d.ts.map +0 -1
- package/dist/components/PriceDisplay.js +0 -37
- package/dist/components/PriceDisplay.js.map +0 -1
- package/dist/components/ProductCard.d.ts +0 -30
- package/dist/components/ProductCard.d.ts.map +0 -1
- package/dist/components/ProductCard.js +0 -73
- package/dist/components/ProductCard.js.map +0 -1
- package/dist/components/Progress.d.ts +0 -9
- package/dist/components/Progress.d.ts.map +0 -1
- package/dist/components/Progress.js +0 -13
- package/dist/components/Progress.js.map +0 -1
- package/dist/components/PromptSuggestionChips.d.ts +0 -15
- package/dist/components/PromptSuggestionChips.d.ts.map +0 -1
- package/dist/components/PromptSuggestionChips.js +0 -17
- package/dist/components/PromptSuggestionChips.js.map +0 -1
- package/dist/components/PropertyList.d.ts +0 -29
- package/dist/components/PropertyList.d.ts.map +0 -1
- package/dist/components/PropertyList.js +0 -90
- package/dist/components/PropertyList.js.map +0 -1
- package/dist/components/QRCodeGenerator.d.ts +0 -17
- package/dist/components/QRCodeGenerator.d.ts.map +0 -1
- package/dist/components/QRCodeGenerator.js +0 -56
- package/dist/components/QRCodeGenerator.js.map +0 -1
- package/dist/components/QuantitySelector.d.ts +0 -16
- package/dist/components/QuantitySelector.d.ts.map +0 -1
- package/dist/components/QuantitySelector.js +0 -55
- package/dist/components/QuantitySelector.js.map +0 -1
- package/dist/components/QueryBuilder.d.ts +0 -30
- package/dist/components/QueryBuilder.d.ts.map +0 -1
- package/dist/components/QueryBuilder.js +0 -227
- package/dist/components/QueryBuilder.js.map +0 -1
- package/dist/components/RadioGroup.d.ts +0 -16
- package/dist/components/RadioGroup.d.ts.map +0 -1
- package/dist/components/RadioGroup.js +0 -36
- package/dist/components/RadioGroup.js.map +0 -1
- package/dist/components/RangeSlider.d.ts +0 -18
- package/dist/components/RangeSlider.d.ts.map +0 -1
- package/dist/components/RangeSlider.js +0 -121
- package/dist/components/RangeSlider.js.map +0 -1
- package/dist/components/RatingInput.d.ts +0 -15
- package/dist/components/RatingInput.d.ts.map +0 -1
- package/dist/components/RatingInput.js +0 -44
- package/dist/components/RatingInput.js.map +0 -1
- package/dist/components/RecoveryCodeDisplay.d.ts +0 -12
- package/dist/components/RecoveryCodeDisplay.d.ts.map +0 -1
- package/dist/components/RecoveryCodeDisplay.js +0 -48
- package/dist/components/RecoveryCodeDisplay.js.map +0 -1
- package/dist/components/ResizablePanel.d.ts +0 -18
- package/dist/components/ResizablePanel.d.ts.map +0 -1
- package/dist/components/ResizablePanel.js +0 -64
- package/dist/components/ResizablePanel.js.map +0 -1
- package/dist/components/Reviews.d.ts +0 -26
- package/dist/components/Reviews.d.ts.map +0 -1
- package/dist/components/Reviews.js +0 -30
- package/dist/components/Reviews.js.map +0 -1
- package/dist/components/RichTextEditor.d.ts +0 -14
- package/dist/components/RichTextEditor.d.ts.map +0 -1
- package/dist/components/RichTextEditor.js +0 -38
- package/dist/components/RichTextEditor.js.map +0 -1
- package/dist/components/RotarySelector.d.ts +0 -20
- package/dist/components/RotarySelector.d.ts.map +0 -1
- package/dist/components/RotarySelector.js +0 -99
- package/dist/components/RotarySelector.js.map +0 -1
- package/dist/components/SchedulerTimeline.d.ts +0 -31
- package/dist/components/SchedulerTimeline.d.ts.map +0 -1
- package/dist/components/SchedulerTimeline.js +0 -210
- package/dist/components/SchedulerTimeline.js.map +0 -1
- package/dist/components/ScrollArea.d.ts +0 -11
- package/dist/components/ScrollArea.d.ts.map +0 -1
- package/dist/components/ScrollArea.js +0 -132
- package/dist/components/ScrollArea.js.map +0 -1
- package/dist/components/SearchInput.d.ts +0 -13
- package/dist/components/SearchInput.d.ts.map +0 -1
- package/dist/components/SearchInput.js +0 -34
- package/dist/components/SearchInput.js.map +0 -1
- package/dist/components/SectionHeader.d.ts +0 -27
- package/dist/components/SectionHeader.d.ts.map +0 -1
- package/dist/components/SectionHeader.js +0 -18
- package/dist/components/SectionHeader.js.map +0 -1
- package/dist/components/SecurityActivityLog.d.ts +0 -20
- package/dist/components/SecurityActivityLog.d.ts.map +0 -1
- package/dist/components/SecurityActivityLog.js +0 -56
- package/dist/components/SecurityActivityLog.js.map +0 -1
- package/dist/components/SegmentedInput.d.ts +0 -15
- package/dist/components/SegmentedInput.d.ts.map +0 -1
- package/dist/components/SegmentedInput.js +0 -134
- package/dist/components/SegmentedInput.js.map +0 -1
- package/dist/components/Select.d.ts +0 -57
- package/dist/components/Select.d.ts.map +0 -1
- package/dist/components/Select.js +0 -275
- package/dist/components/Select.js.map +0 -1
- package/dist/components/Sheet.d.ts +0 -35
- package/dist/components/Sheet.d.ts.map +0 -1
- package/dist/components/Sheet.js +0 -117
- package/dist/components/Sheet.js.map +0 -1
- package/dist/components/Sidebar.d.ts +0 -23
- package/dist/components/Sidebar.d.ts.map +0 -1
- package/dist/components/Sidebar.js +0 -21
- package/dist/components/Sidebar.js.map +0 -1
- package/dist/components/SignaturePad.d.ts +0 -19
- package/dist/components/SignaturePad.d.ts.map +0 -1
- package/dist/components/SignaturePad.js +0 -133
- package/dist/components/SignaturePad.js.map +0 -1
- package/dist/components/SignupForm.d.ts +0 -15
- package/dist/components/SignupForm.d.ts.map +0 -1
- package/dist/components/SignupForm.js +0 -50
- package/dist/components/SignupForm.js.map +0 -1
- package/dist/components/Skeleton.d.ts +0 -3
- package/dist/components/Skeleton.d.ts.map +0 -1
- package/dist/components/Skeleton.js +0 -13
- package/dist/components/Skeleton.js.map +0 -1
- package/dist/components/SlideToDelete.d.ts +0 -26
- package/dist/components/SlideToDelete.d.ts.map +0 -1
- package/dist/components/SlideToDelete.js +0 -88
- package/dist/components/SlideToDelete.js.map +0 -1
- package/dist/components/Slider.d.ts +0 -18
- package/dist/components/Slider.d.ts.map +0 -1
- package/dist/components/Slider.js +0 -99
- package/dist/components/Slider.js.map +0 -1
- package/dist/components/Snackbar.d.ts +0 -16
- package/dist/components/Snackbar.d.ts.map +0 -1
- package/dist/components/Snackbar.js +0 -39
- package/dist/components/Snackbar.js.map +0 -1
- package/dist/components/Spacer.d.ts +0 -21
- package/dist/components/Spacer.d.ts.map +0 -1
- package/dist/components/Spacer.js +0 -44
- package/dist/components/Spacer.js.map +0 -1
- package/dist/components/Sparkline.d.ts +0 -17
- package/dist/components/Sparkline.d.ts.map +0 -1
- package/dist/components/Sparkline.js +0 -41
- package/dist/components/Sparkline.js.map +0 -1
- package/dist/components/Spinner.d.ts +0 -8
- package/dist/components/Spinner.d.ts.map +0 -1
- package/dist/components/Spinner.js +0 -26
- package/dist/components/Spinner.js.map +0 -1
- package/dist/components/SplitButton.d.ts +0 -20
- package/dist/components/SplitButton.d.ts.map +0 -1
- package/dist/components/SplitButton.js +0 -48
- package/dist/components/SplitButton.js.map +0 -1
- package/dist/components/SplitView.d.ts +0 -40
- package/dist/components/SplitView.d.ts.map +0 -1
- package/dist/components/SplitView.js +0 -14
- package/dist/components/SplitView.js.map +0 -1
- package/dist/components/StatisticDisplay.d.ts +0 -48
- package/dist/components/StatisticDisplay.d.ts.map +0 -1
- package/dist/components/StatisticDisplay.js +0 -141
- package/dist/components/StatisticDisplay.js.map +0 -1
- package/dist/components/Stepper.d.ts +0 -24
- package/dist/components/Stepper.d.ts.map +0 -1
- package/dist/components/Stepper.js +0 -99
- package/dist/components/Stepper.js.map +0 -1
- package/dist/components/StickyContainer.d.ts +0 -32
- package/dist/components/StickyContainer.d.ts.map +0 -1
- package/dist/components/StickyContainer.js +0 -17
- package/dist/components/StickyContainer.js.map +0 -1
- package/dist/components/Switch.d.ts +0 -12
- package/dist/components/Switch.d.ts.map +0 -1
- package/dist/components/Switch.js +0 -46
- package/dist/components/Switch.js.map +0 -1
- package/dist/components/Table.d.ts +0 -22
- package/dist/components/Table.d.ts.map +0 -1
- package/dist/components/Table.js +0 -72
- package/dist/components/Table.js.map +0 -1
- package/dist/components/Tabs.d.ts +0 -29
- package/dist/components/Tabs.d.ts.map +0 -1
- package/dist/components/Tabs.js +0 -63
- package/dist/components/Tabs.js.map +0 -1
- package/dist/components/Tag.d.ts +0 -14
- package/dist/components/Tag.d.ts.map +0 -1
- package/dist/components/Tag.js +0 -44
- package/dist/components/Tag.js.map +0 -1
- package/dist/components/TagsInput.d.ts +0 -15
- package/dist/components/TagsInput.d.ts.map +0 -1
- package/dist/components/TagsInput.js +0 -54
- package/dist/components/TagsInput.js.map +0 -1
- package/dist/components/Text.d.ts +0 -21
- package/dist/components/Text.d.ts.map +0 -1
- package/dist/components/Text.js +0 -47
- package/dist/components/Text.js.map +0 -1
- package/dist/components/Textarea.d.ts +0 -6
- package/dist/components/Textarea.d.ts.map +0 -1
- package/dist/components/Textarea.js +0 -10
- package/dist/components/Textarea.js.map +0 -1
- package/dist/components/ThemeToggle.d.ts +0 -22
- package/dist/components/ThemeToggle.d.ts.map +0 -1
- package/dist/components/ThemeToggle.js +0 -81
- package/dist/components/ThemeToggle.js.map +0 -1
- package/dist/components/TimePicker.d.ts +0 -15
- package/dist/components/TimePicker.d.ts.map +0 -1
- package/dist/components/TimePicker.js +0 -148
- package/dist/components/TimePicker.js.map +0 -1
- package/dist/components/Timeline.d.ts +0 -21
- package/dist/components/Timeline.d.ts.map +0 -1
- package/dist/components/Timeline.js +0 -63
- package/dist/components/Timeline.js.map +0 -1
- package/dist/components/Title.d.ts +0 -17
- package/dist/components/Title.d.ts.map +0 -1
- package/dist/components/Title.js +0 -46
- package/dist/components/Title.js.map +0 -1
- package/dist/components/Toast.d.ts +0 -25
- package/dist/components/Toast.d.ts.map +0 -1
- package/dist/components/Toast.js +0 -96
- package/dist/components/Toast.js.map +0 -1
- package/dist/components/Tooltip.d.ts +0 -13
- package/dist/components/Tooltip.d.ts.map +0 -1
- package/dist/components/Tooltip.js +0 -20
- package/dist/components/Tooltip.js.map +0 -1
- package/dist/components/TopActionBar.d.ts +0 -60
- package/dist/components/TopActionBar.d.ts.map +0 -1
- package/dist/components/TopActionBar.js +0 -69
- package/dist/components/TopActionBar.js.map +0 -1
- package/dist/components/TreeView.d.ts +0 -29
- package/dist/components/TreeView.d.ts.map +0 -1
- package/dist/components/TreeView.js +0 -97
- package/dist/components/TreeView.js.map +0 -1
- package/dist/components/TwoFactorAuth.d.ts +0 -12
- package/dist/components/TwoFactorAuth.d.ts.map +0 -1
- package/dist/components/TwoFactorAuth.js +0 -48
- package/dist/components/TwoFactorAuth.js.map +0 -1
- package/dist/components/VideoPlayer.d.ts +0 -11
- package/dist/components/VideoPlayer.d.ts.map +0 -1
- package/dist/components/VideoPlayer.js +0 -132
- package/dist/components/VideoPlayer.js.map +0 -1
- package/dist/components/VoiceRecorder.d.ts +0 -11
- package/dist/components/VoiceRecorder.d.ts.map +0 -1
- package/dist/components/VoiceRecorder.js +0 -145
- package/dist/components/VoiceRecorder.js.map +0 -1
- package/dist/components/WindowControls.d.ts +0 -10
- package/dist/components/WindowControls.d.ts.map +0 -1
- package/dist/components/WindowControls.js +0 -18
- package/dist/components/WindowControls.js.map +0 -1
- package/dist/components/WindowFrame.d.ts +0 -11
- package/dist/components/WindowFrame.d.ts.map +0 -1
- package/dist/components/WindowFrame.js +0 -26
- package/dist/components/WindowFrame.js.map +0 -1
|
@@ -1,133 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { useRef, useState, useEffect } from 'react';
|
|
3
|
-
import { cn } from '../lib/utils';
|
|
4
|
-
import { Button } from './Button';
|
|
5
|
-
import { Eraser, Download } from 'lucide-react';
|
|
6
|
-
export const SignaturePad = ({ width, height = 200, penColor = '#000000', backgroundColor = '#FFFFFF', strokeWidth = 2, onEnd, className }) => {
|
|
7
|
-
const canvasRef = useRef(null);
|
|
8
|
-
const [isDrawing, setIsDrawing] = useState(false);
|
|
9
|
-
const [hasSignature, setHasSignature] = useState(false);
|
|
10
|
-
const containerRef = useRef(null);
|
|
11
|
-
// Initialize canvas context
|
|
12
|
-
useEffect(() => {
|
|
13
|
-
const canvas = canvasRef.current;
|
|
14
|
-
if (!canvas)
|
|
15
|
-
return;
|
|
16
|
-
const ctx = canvas.getContext('2d');
|
|
17
|
-
if (!ctx)
|
|
18
|
-
return;
|
|
19
|
-
ctx.lineCap = 'round';
|
|
20
|
-
ctx.lineJoin = 'round';
|
|
21
|
-
ctx.strokeStyle = penColor;
|
|
22
|
-
ctx.lineWidth = strokeWidth;
|
|
23
|
-
// Fill background
|
|
24
|
-
ctx.fillStyle = backgroundColor;
|
|
25
|
-
ctx.fillRect(0, 0, canvas.width, canvas.height);
|
|
26
|
-
}, [penColor, backgroundColor, strokeWidth]);
|
|
27
|
-
// Handle resizing
|
|
28
|
-
useEffect(() => {
|
|
29
|
-
const handleResize = () => {
|
|
30
|
-
if (containerRef.current && canvasRef.current && !width) {
|
|
31
|
-
const containerWidth = containerRef.current.offsetWidth;
|
|
32
|
-
const canvas = canvasRef.current;
|
|
33
|
-
// Save current content
|
|
34
|
-
const tempCanvas = document.createElement('canvas');
|
|
35
|
-
const tempCtx = tempCanvas.getContext('2d');
|
|
36
|
-
tempCanvas.width = canvas.width;
|
|
37
|
-
tempCanvas.height = canvas.height;
|
|
38
|
-
tempCtx?.drawImage(canvas, 0, 0);
|
|
39
|
-
// Resize
|
|
40
|
-
canvas.width = containerWidth;
|
|
41
|
-
canvas.height = height;
|
|
42
|
-
// Restore context settings
|
|
43
|
-
const ctx = canvas.getContext('2d');
|
|
44
|
-
if (ctx) {
|
|
45
|
-
ctx.lineCap = 'round';
|
|
46
|
-
ctx.lineJoin = 'round';
|
|
47
|
-
ctx.strokeStyle = penColor;
|
|
48
|
-
ctx.lineWidth = strokeWidth;
|
|
49
|
-
ctx.fillStyle = backgroundColor;
|
|
50
|
-
ctx.fillRect(0, 0, canvas.width, canvas.height);
|
|
51
|
-
// Restore content (optional, might look stretched or cropped)
|
|
52
|
-
// For a signature pad, usually clearing on resize is safer or just keeping it fixed
|
|
53
|
-
// Here we just re-fill background to avoid transparency issues
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
};
|
|
57
|
-
handleResize();
|
|
58
|
-
window.addEventListener('resize', handleResize);
|
|
59
|
-
return () => window.removeEventListener('resize', handleResize);
|
|
60
|
-
}, [width, height, penColor, strokeWidth, backgroundColor]);
|
|
61
|
-
const getCoordinates = (event) => {
|
|
62
|
-
const canvas = canvasRef.current;
|
|
63
|
-
if (!canvas)
|
|
64
|
-
return { x: 0, y: 0 };
|
|
65
|
-
const rect = canvas.getBoundingClientRect();
|
|
66
|
-
let clientX, clientY;
|
|
67
|
-
if ('touches' in event) {
|
|
68
|
-
clientX = event.touches[0].clientX;
|
|
69
|
-
clientY = event.touches[0].clientY;
|
|
70
|
-
}
|
|
71
|
-
else {
|
|
72
|
-
clientX = event.clientX;
|
|
73
|
-
clientY = event.clientY;
|
|
74
|
-
}
|
|
75
|
-
return {
|
|
76
|
-
x: clientX - rect.left,
|
|
77
|
-
y: clientY - rect.top
|
|
78
|
-
};
|
|
79
|
-
};
|
|
80
|
-
const startDrawing = (e) => {
|
|
81
|
-
e.preventDefault(); // Prevent scrolling on touch
|
|
82
|
-
setIsDrawing(true);
|
|
83
|
-
const { x, y } = getCoordinates(e);
|
|
84
|
-
const ctx = canvasRef.current?.getContext('2d');
|
|
85
|
-
if (ctx) {
|
|
86
|
-
ctx.beginPath();
|
|
87
|
-
ctx.moveTo(x, y);
|
|
88
|
-
}
|
|
89
|
-
};
|
|
90
|
-
const draw = (e) => {
|
|
91
|
-
e.preventDefault();
|
|
92
|
-
if (!isDrawing)
|
|
93
|
-
return;
|
|
94
|
-
const { x, y } = getCoordinates(e);
|
|
95
|
-
const ctx = canvasRef.current?.getContext('2d');
|
|
96
|
-
if (ctx) {
|
|
97
|
-
ctx.lineTo(x, y);
|
|
98
|
-
ctx.stroke();
|
|
99
|
-
if (!hasSignature)
|
|
100
|
-
setHasSignature(true);
|
|
101
|
-
}
|
|
102
|
-
};
|
|
103
|
-
const stopDrawing = () => {
|
|
104
|
-
if (isDrawing) {
|
|
105
|
-
setIsDrawing(false);
|
|
106
|
-
const canvas = canvasRef.current;
|
|
107
|
-
if (canvas && onEnd) {
|
|
108
|
-
onEnd(canvas.toDataURL());
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
};
|
|
112
|
-
const clear = () => {
|
|
113
|
-
const canvas = canvasRef.current;
|
|
114
|
-
const ctx = canvas?.getContext('2d');
|
|
115
|
-
if (canvas && ctx) {
|
|
116
|
-
ctx.fillStyle = backgroundColor;
|
|
117
|
-
ctx.fillRect(0, 0, canvas.width, canvas.height);
|
|
118
|
-
setHasSignature(false);
|
|
119
|
-
}
|
|
120
|
-
};
|
|
121
|
-
const download = () => {
|
|
122
|
-
const canvas = canvasRef.current;
|
|
123
|
-
if (canvas) {
|
|
124
|
-
const url = canvas.toDataURL('image/png');
|
|
125
|
-
const link = document.createElement('a');
|
|
126
|
-
link.download = `signature-${Date.now()}.png`;
|
|
127
|
-
link.href = url;
|
|
128
|
-
link.click();
|
|
129
|
-
}
|
|
130
|
-
};
|
|
131
|
-
return (_jsxs("div", { className: cn("flex flex-col gap-4 w-full max-w-md", className), ref: containerRef, children: [_jsxs("div", { className: "relative rounded-xl overflow-hidden border border-border-primary shadow-sm bg-white touch-none", children: [_jsx("canvas", { ref: canvasRef, width: width || 400, height: height, className: "cursor-crosshair block", onMouseDown: startDrawing, onMouseMove: draw, onMouseUp: stopDrawing, onMouseLeave: stopDrawing, onTouchStart: startDrawing, onTouchMove: draw, onTouchEnd: stopDrawing }), !hasSignature && (_jsx("div", { className: "absolute inset-0 flex items-center justify-center pointer-events-none text-text-tertiary/30 text-2xl font-handwriting select-none", children: "Sign here" }))] }), _jsxs("div", { className: "flex items-center justify-between gap-2", children: [_jsxs(Button, { variant: "ghost", size: "sm", onClick: clear, disabled: !hasSignature, className: "text-status-error hover:bg-status-error/10 hover:text-status-error", children: [_jsx(Eraser, { className: "w-4 h-4 mr-2" }), "Clear"] }), _jsxs(Button, { variant: "outline", size: "sm", onClick: download, disabled: !hasSignature, children: [_jsx(Download, { className: "w-4 h-4 mr-2" }), "Save"] })] })] }));
|
|
132
|
-
};
|
|
133
|
-
//# sourceMappingURL=SignaturePad.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SignaturePad.js","sourceRoot":"","sources":["../../components/SignaturePad.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
export interface SignupFormProps extends Omit<React.HTMLAttributes<HTMLFormElement>, 'onSubmit'> {
|
|
3
|
-
onSubmit?: (data: {
|
|
4
|
-
name: string;
|
|
5
|
-
email: string;
|
|
6
|
-
password: string;
|
|
7
|
-
confirmPassword: string;
|
|
8
|
-
acceptTerms: boolean;
|
|
9
|
-
}) => void | Promise<void>;
|
|
10
|
-
isLoading?: boolean;
|
|
11
|
-
error?: string;
|
|
12
|
-
className?: string;
|
|
13
|
-
}
|
|
14
|
-
export declare const SignupForm: React.ForwardRefExoticComponent<SignupFormProps & React.RefAttributes<HTMLFormElement>>;
|
|
15
|
-
//# sourceMappingURL=SignupForm.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SignupForm.d.ts","sourceRoot":"","sources":["../../components/SignupForm.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAmB,MAAM,OAAO,CAAC;AAYxC,MAAM,WAAW,eAAgB,SAAQ,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,eAAe,CAAC,EAAE,UAAU,CAAC;IAC5F,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAC;QAAC,eAAe,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,OAAO,CAAA;KAAE,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5I,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAMD,eAAO,MAAM,UAAU,yFAsJtB,CAAC"}
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
-
import React, { useState } from 'react';
|
|
4
|
-
import { cn } from '../lib/utils';
|
|
5
|
-
import { Input } from './Input';
|
|
6
|
-
import { Button } from './Button';
|
|
7
|
-
import { PasswordInput } from './PasswordInput';
|
|
8
|
-
import { Checkbox } from './Checkbox';
|
|
9
|
-
import { Mail, User, AlertCircle } from 'lucide-react';
|
|
10
|
-
/* ========================================
|
|
11
|
-
COMPONENT
|
|
12
|
-
======================================== */
|
|
13
|
-
export const SignupForm = React.forwardRef(({ onSubmit, isLoading = false, error, className, ...props }, ref) => {
|
|
14
|
-
const [name, setName] = useState('');
|
|
15
|
-
const [email, setEmail] = useState('');
|
|
16
|
-
const [password, setPassword] = useState('');
|
|
17
|
-
const [confirmPassword, setConfirmPassword] = useState('');
|
|
18
|
-
const [acceptTerms, setAcceptTerms] = useState(false);
|
|
19
|
-
const [formError, setFormError] = useState('');
|
|
20
|
-
const handleSubmit = async (e) => {
|
|
21
|
-
e.preventDefault();
|
|
22
|
-
setFormError('');
|
|
23
|
-
if (!name || !email || !password || !confirmPassword) {
|
|
24
|
-
setFormError('Please fill in all fields');
|
|
25
|
-
return;
|
|
26
|
-
}
|
|
27
|
-
if (password !== confirmPassword) {
|
|
28
|
-
setFormError('Passwords do not match');
|
|
29
|
-
return;
|
|
30
|
-
}
|
|
31
|
-
if (password.length < 8) {
|
|
32
|
-
setFormError('Password must be at least 8 characters');
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
|
-
if (!acceptTerms) {
|
|
36
|
-
setFormError('Please accept the terms and conditions');
|
|
37
|
-
return;
|
|
38
|
-
}
|
|
39
|
-
try {
|
|
40
|
-
await onSubmit?.({ name, email, password, confirmPassword, acceptTerms });
|
|
41
|
-
}
|
|
42
|
-
catch (err) {
|
|
43
|
-
setFormError(err instanceof Error ? err.message : 'An error occurred');
|
|
44
|
-
}
|
|
45
|
-
};
|
|
46
|
-
const displayError = error || formError;
|
|
47
|
-
return (_jsxs("form", { ref: ref, onSubmit: handleSubmit, className: cn("w-full max-w-xl space-y-10", className), ...props, children: [_jsxs("div", { className: "text-center space-y-4", children: [_jsx("h2", { className: "text-4xl font-bold text-text-primary", children: "Create account" }), _jsx("p", { className: "text-lg text-text-secondary", children: "Sign up to get started" })] }), displayError && (_jsxs("div", { className: "flex items-center gap-2 p-3 bg-status-error/10 border border-status-error/20 rounded-xl text-status-error text-sm", children: [_jsx(AlertCircle, { className: "w-4 h-4 flex-shrink-0" }), _jsx("span", { children: displayError })] })), _jsxs("div", { className: "space-y-6", children: [_jsx(Input, { type: "text", label: "Full Name", placeholder: "John Doe", value: name, onChange: (e) => setName(e.target.value), leftIcon: _jsx(User, { className: "w-4 h-4" }), required: true, disabled: isLoading }), _jsx(Input, { type: "email", label: "Email", placeholder: "you@example.com", value: email, onChange: (e) => setEmail(e.target.value), leftIcon: _jsx(Mail, { className: "w-4 h-4" }), required: true, disabled: isLoading }), _jsx(PasswordInput, { label: "Password", placeholder: "Create a password", value: password, onChange: (value) => setPassword(value), required: true, disabled: isLoading }), _jsx(PasswordInput, { label: "Confirm Password", placeholder: "Confirm your password", value: confirmPassword, onChange: (value) => setConfirmPassword(value), required: true, disabled: isLoading })] }), _jsxs("label", { className: "flex items-start gap-2 cursor-pointer", children: [_jsx(Checkbox, { id: "terms", checked: acceptTerms, onCheckedChange: (checked) => setAcceptTerms(checked === true) }), _jsxs("span", { className: "text-sm text-text-secondary select-none", children: ["I agree to the", ' ', _jsx("a", { href: "#", className: "text-accent-blue hover:underline", onClick: (e) => e.preventDefault(), children: "Terms and Conditions" }), ' ', "and", ' ', _jsx("a", { href: "#", className: "text-accent-blue hover:underline", onClick: (e) => e.preventDefault(), children: "Privacy Policy" })] })] }), _jsx(Button, { type: "submit", variant: "primary", size: "lg", fullWidth: true, loading: isLoading, disabled: isLoading, children: "Create Account" })] }));
|
|
48
|
-
});
|
|
49
|
-
SignupForm.displayName = 'SignupForm';
|
|
50
|
-
//# sourceMappingURL=SignupForm.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SignupForm.js","sourceRoot":"","sources":["../../components/SignupForm.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACxC,OAAO,EAAE,EAAE,EAAE,MAAM,cAAc,CAAC;AAClC,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,IAAI,EAAQ,IAAI,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAa7D;;8CAE8C;AAE9C,MAAM,CAAC,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,CACtC,CACI,EACI,QAAQ,EACR,SAAS,GAAG,KAAK,EACjB,KAAK,EACL,SAAS,EACT,GAAG,KAAK,EACX,EACD,GAAG,EACL,EAAE;IACA,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IACrC,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IACvC,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IAC7C,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IAC3D,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IACtD,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IAE/C,MAAM,YAAY,GAAG,KAAK,EAAE,CAAkB,EAAE,EAAE;QAC9C,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,YAAY,CAAC,EAAE,CAAC,CAAC;QAEjB,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,IAAI,CAAC,QAAQ,IAAI,CAAC,eAAe,EAAE,CAAC;YACnD,YAAY,CAAC,2BAA2B,CAAC,CAAC;YAC1C,OAAO;QACX,CAAC;QAED,IAAI,QAAQ,KAAK,eAAe,EAAE,CAAC;YAC/B,YAAY,CAAC,wBAAwB,CAAC,CAAC;YACvC,OAAO;QACX,CAAC;QAED,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACtB,YAAY,CAAC,wCAAwC,CAAC,CAAC;YACvD,OAAO;QACX,CAAC;QAED,IAAI,CAAC,WAAW,EAAE,CAAC;YACf,YAAY,CAAC,wCAAwC,CAAC,CAAC;YACvD,OAAO;QACX,CAAC;QAED,IAAI,CAAC;YACD,MAAM,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,eAAe,EAAE,WAAW,EAAE,CAAC,CAAC;QAC9E,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACX,YAAY,CAAC,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC;QAC3E,CAAC;IACL,CAAC,CAAC;IAEF,MAAM,YAAY,GAAG,KAAK,IAAI,SAAS,CAAC;IAExC,OAAO,CACH,gBACI,GAAG,EAAE,GAAG,EACR,QAAQ,EAAE,YAAY,EACtB,SAAS,EAAE,EAAE,CAAC,4BAA4B,EAAE,SAAS,CAAC,KAClD,KAAK,aAGT,eAAK,SAAS,EAAC,uBAAuB,aAClC,aAAI,SAAS,EAAC,sCAAsC,+BAAoB,EACxE,YAAG,SAAS,EAAC,6BAA6B,uCAEtC,IACF,EAGL,YAAY,IAAI,CACb,eAAK,SAAS,EAAC,mHAAmH,aAC9H,KAAC,WAAW,IAAC,SAAS,EAAC,uBAAuB,GAAG,EACjD,yBAAO,YAAY,GAAQ,IACzB,CACT,EAGD,eAAK,SAAS,EAAC,WAAW,aACtB,KAAC,KAAK,IACF,IAAI,EAAC,MAAM,EACX,KAAK,EAAC,WAAW,EACjB,WAAW,EAAC,UAAU,EACtB,KAAK,EAAE,IAAI,EACX,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EACxC,QAAQ,EAAE,KAAC,IAAI,IAAC,SAAS,EAAC,SAAS,GAAG,EACtC,QAAQ,QACR,QAAQ,EAAE,SAAS,GACrB,EAEF,KAAC,KAAK,IACF,IAAI,EAAC,OAAO,EACZ,KAAK,EAAC,OAAO,EACb,WAAW,EAAC,iBAAiB,EAC7B,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EACzC,QAAQ,EAAE,KAAC,IAAI,IAAC,SAAS,EAAC,SAAS,GAAG,EACtC,QAAQ,QACR,QAAQ,EAAE,SAAS,GACrB,EAEF,KAAC,aAAa,IACV,KAAK,EAAC,UAAU,EAChB,WAAW,EAAC,mBAAmB,EAC/B,KAAK,EAAE,QAAQ,EACf,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,WAAW,CAAC,KAAK,CAAC,EACvC,QAAQ,QACR,QAAQ,EAAE,SAAS,GACrB,EAEF,KAAC,aAAa,IACV,KAAK,EAAC,kBAAkB,EACxB,WAAW,EAAC,uBAAuB,EACnC,KAAK,EAAE,eAAe,EACtB,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,kBAAkB,CAAC,KAAK,CAAC,EAC9C,QAAQ,QACR,QAAQ,EAAE,SAAS,GACrB,IACA,EAGN,iBAAO,SAAS,EAAC,uCAAuC,aACpD,KAAC,QAAQ,IACL,EAAE,EAAC,OAAO,EACV,OAAO,EAAE,WAAW,EACpB,eAAe,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,cAAc,CAAC,OAAO,KAAK,IAAI,CAAC,GAChE,EACF,gBAAM,SAAS,EAAC,yCAAyC,+BACtC,GAAG,EAClB,YAAG,IAAI,EAAC,GAAG,EAAC,SAAS,EAAC,kCAAkC,EAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE,qCAEvF,EAAC,GAAG,SACJ,GAAG,EACP,YAAG,IAAI,EAAC,GAAG,EAAC,SAAS,EAAC,kCAAkC,EAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE,+BAEvF,IACD,IACH,EAGR,KAAC,MAAM,IACH,IAAI,EAAC,QAAQ,EACb,OAAO,EAAC,SAAS,EACjB,IAAI,EAAC,IAAI,EACT,SAAS,QACT,OAAO,EAAE,SAAS,EAClB,QAAQ,EAAE,SAAS,+BAGd,IACN,CACV,CAAC;AACN,CAAC,CACJ,CAAC;AAEF,UAAU,CAAC,WAAW,GAAG,YAAY,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Skeleton.d.ts","sourceRoot":"","sources":["../../components/Skeleton.tsx"],"names":[],"mappings":"AAKA,iBAAS,QAAQ,CAAC,EACd,SAAS,EACT,GAAG,KAAK,EACX,EAAE,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,2CAqBtC;AAED,OAAO,EAAE,QAAQ,EAAE,CAAC"}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
-
import { motion } from "framer-motion";
|
|
4
|
-
import { cn } from "../lib/utils";
|
|
5
|
-
function Skeleton({ className, ...props }) {
|
|
6
|
-
return (_jsx("div", { className: cn("relative overflow-hidden rounded-md bg-surface-secondary", className), ...props, children: _jsx(motion.div, { className: "absolute inset-0 bg-gradient-to-r from-transparent via-surface-primary/50 to-transparent", initial: { translateX: "-100%" }, animate: { translateX: "100%" }, transition: {
|
|
7
|
-
repeat: Infinity,
|
|
8
|
-
duration: 1.5,
|
|
9
|
-
ease: "linear",
|
|
10
|
-
} }) }));
|
|
11
|
-
}
|
|
12
|
-
export { Skeleton };
|
|
13
|
-
//# sourceMappingURL=Skeleton.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Skeleton.js","sourceRoot":"","sources":["../../components/Skeleton.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,EAAE,EAAE,MAAM,cAAc,CAAC;AAElC,SAAS,QAAQ,CAAC,EACd,SAAS,EACT,GAAG,KAAK,EAC2B;IACnC,OAAO,CACH,cACI,SAAS,EAAE,EAAE,CACT,0DAA0D,EAC1D,SAAS,CACZ,KACG,KAAK,YAET,KAAC,MAAM,CAAC,GAAG,IACP,SAAS,EAAC,0FAA0F,EACpG,OAAO,EAAE,EAAE,UAAU,EAAE,OAAO,EAAE,EAChC,OAAO,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,EAC/B,UAAU,EAAE;gBACR,MAAM,EAAE,QAAQ;gBAChB,QAAQ,EAAE,GAAG;gBACb,IAAI,EAAE,QAAQ;aACjB,GACH,GACA,CACT,CAAC;AACN,CAAC;AAED,OAAO,EAAE,QAAQ,EAAE,CAAC"}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import { type LucideIcon } from 'lucide-react';
|
|
3
|
-
export interface SlideToDeleteProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
4
|
-
children: React.ReactNode;
|
|
5
|
-
onDelete: () => void | Promise<void>;
|
|
6
|
-
onCancel?: () => void;
|
|
7
|
-
deleteLabel?: string;
|
|
8
|
-
cancelLabel?: string;
|
|
9
|
-
deleteIcon?: LucideIcon;
|
|
10
|
-
cancelIcon?: LucideIcon;
|
|
11
|
-
threshold?: number;
|
|
12
|
-
disabled?: boolean;
|
|
13
|
-
confirmDelete?: boolean;
|
|
14
|
-
confirmMessage?: string;
|
|
15
|
-
variant?: 'default' | 'danger' | 'warning';
|
|
16
|
-
className?: string;
|
|
17
|
-
}
|
|
18
|
-
export declare const SlideToDelete: React.ForwardRefExoticComponent<SlideToDeleteProps & React.RefAttributes<HTMLDivElement>>;
|
|
19
|
-
export interface SlideToDeleteItemProps extends SlideToDeleteProps {
|
|
20
|
-
title?: string;
|
|
21
|
-
subtitle?: string;
|
|
22
|
-
avatar?: React.ReactNode;
|
|
23
|
-
actions?: React.ReactNode;
|
|
24
|
-
}
|
|
25
|
-
export declare const SlideToDeleteItem: React.ForwardRefExoticComponent<SlideToDeleteItemProps & React.RefAttributes<HTMLDivElement>>;
|
|
26
|
-
//# sourceMappingURL=SlideToDelete.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SlideToDelete.d.ts","sourceRoot":"","sources":["../../components/SlideToDelete.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAmB,MAAM,OAAO,CAAC;AAGxC,OAAO,EAAa,KAAK,UAAU,EAAE,MAAM,cAAc,CAAC;AAO1D,MAAM,WAAW,kBAAmB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC5E,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,QAAQ,EAAE,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACrC,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,OAAO,CAAC,EAAE,SAAS,GAAG,QAAQ,GAAG,SAAS,CAAC;IAC3C,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAaD,eAAO,MAAM,aAAa,2FA+KzB,CAAC;AAQF,MAAM,WAAW,sBAAuB,SAAQ,kBAAkB;IAC9D,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC7B;AAED,eAAO,MAAM,iBAAiB,+FA+C7B,CAAC"}
|
|
@@ -1,88 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
-
import React, { useState } from 'react';
|
|
4
|
-
import { cn } from '../lib/utils';
|
|
5
|
-
import { motion, useMotionValue, useTransform } from 'framer-motion';
|
|
6
|
-
import { Trash2, X } from 'lucide-react';
|
|
7
|
-
import { ConfirmDialog } from './ConfirmDialog';
|
|
8
|
-
/* ========================================
|
|
9
|
-
CONSTANTS
|
|
10
|
-
======================================== */
|
|
11
|
-
const DELETE_THRESHOLD = 80; // pixels to swipe before delete is triggered
|
|
12
|
-
const CANCEL_THRESHOLD = -80; // pixels to swipe before cancel is triggered
|
|
13
|
-
/* ========================================
|
|
14
|
-
MAIN COMPONENT
|
|
15
|
-
======================================== */
|
|
16
|
-
export const SlideToDelete = React.forwardRef(({ children, onDelete, onCancel, deleteLabel = 'Delete', cancelLabel = 'Cancel', deleteIcon: DeleteIcon = Trash2, cancelIcon: CancelIcon = X, threshold = DELETE_THRESHOLD, disabled = false, confirmDelete = false, confirmMessage = 'Are you sure?', variant = 'danger', className, ...props }, ref) => {
|
|
17
|
-
const [isDeleting, setIsDeleting] = useState(false);
|
|
18
|
-
const [showConfirmDialog, setShowConfirmDialog] = useState(false);
|
|
19
|
-
const [isDragging, setIsDragging] = useState(false);
|
|
20
|
-
const x = useMotionValue(0);
|
|
21
|
-
const opacity = useTransform(x, [-threshold, 0, threshold], [1, 0, 1]);
|
|
22
|
-
const deleteOpacity = useTransform(x, [0, threshold], [0, 1]);
|
|
23
|
-
const cancelOpacity = useTransform(x, [0, -threshold], [0, 1]);
|
|
24
|
-
const variantStyles = {
|
|
25
|
-
default: 'bg-surface-secondary text-text-primary',
|
|
26
|
-
danger: 'bg-status-error text-white',
|
|
27
|
-
warning: 'bg-status-warning text-white',
|
|
28
|
-
};
|
|
29
|
-
const handleDragEnd = async (event, info) => {
|
|
30
|
-
setIsDragging(false);
|
|
31
|
-
const offset = info.offset.x;
|
|
32
|
-
const velocity = info.velocity.x;
|
|
33
|
-
// Swipe right (delete)
|
|
34
|
-
if (offset > threshold || velocity > 500) {
|
|
35
|
-
if (confirmDelete) {
|
|
36
|
-
setShowConfirmDialog(true);
|
|
37
|
-
x.set(0); // Return to center while showing dialog
|
|
38
|
-
return;
|
|
39
|
-
}
|
|
40
|
-
await handleDelete();
|
|
41
|
-
}
|
|
42
|
-
// Swipe left (cancel)
|
|
43
|
-
else if (offset < -threshold || velocity < -500) {
|
|
44
|
-
if (onCancel) {
|
|
45
|
-
onCancel();
|
|
46
|
-
}
|
|
47
|
-
x.set(0);
|
|
48
|
-
}
|
|
49
|
-
// Return to center
|
|
50
|
-
else {
|
|
51
|
-
x.set(0);
|
|
52
|
-
}
|
|
53
|
-
};
|
|
54
|
-
const handleDelete = async () => {
|
|
55
|
-
setIsDeleting(true);
|
|
56
|
-
try {
|
|
57
|
-
await onDelete();
|
|
58
|
-
// Animate out before removing
|
|
59
|
-
x.set(1000);
|
|
60
|
-
}
|
|
61
|
-
catch (error) {
|
|
62
|
-
console.error('Delete error:', error);
|
|
63
|
-
x.set(0);
|
|
64
|
-
setIsDeleting(false);
|
|
65
|
-
}
|
|
66
|
-
};
|
|
67
|
-
const handleConfirmDelete = async () => {
|
|
68
|
-
setShowConfirmDialog(false);
|
|
69
|
-
await handleDelete();
|
|
70
|
-
};
|
|
71
|
-
const handleCancelConfirm = () => {
|
|
72
|
-
setShowConfirmDialog(false);
|
|
73
|
-
};
|
|
74
|
-
if (isDeleting && x.get() > 500) {
|
|
75
|
-
return null; // Component is removed after deletion animation
|
|
76
|
-
}
|
|
77
|
-
return (_jsxs("div", { ref: ref, className: cn("relative overflow-hidden rounded-xl", className), ...props, children: [_jsxs("div", { className: "absolute inset-0 flex", children: [_jsx(motion.div, { className: cn("flex-1 flex items-center justify-end px-6", variantStyles[variant]), style: { opacity: deleteOpacity }, children: _jsxs("div", { className: "flex items-center gap-3", children: [_jsx("span", { className: "text-sm font-medium", children: deleteLabel }), _jsx(DeleteIcon, { className: "w-5 h-5" })] }) }), onCancel && (_jsx(motion.div, { className: "flex-1 flex items-center justify-start px-6 bg-surface-secondary text-text-primary", style: { opacity: cancelOpacity }, children: _jsxs("div", { className: "flex items-center gap-3", children: [_jsx(CancelIcon, { className: "w-5 h-5" }), _jsx("span", { className: "text-sm font-medium", children: cancelLabel })] }) }))] }), _jsx(motion.div, { drag: "x", dragConstraints: { left: onCancel ? -threshold : 0, right: threshold }, dragElastic: 0.2, onDragStart: () => setIsDragging(true), onDragEnd: handleDragEnd, style: { x }, className: cn("relative bg-surface-primary border border-border-primary rounded-xl", "cursor-grab active:cursor-grabbing", disabled && "opacity-50 cursor-not-allowed", isDragging && "shadow-lg"), whileTap: disabled ? {} : { scale: 0.98 }, transition: {
|
|
78
|
-
type: 'spring',
|
|
79
|
-
stiffness: 300,
|
|
80
|
-
damping: 30,
|
|
81
|
-
}, children: children }), !disabled && (_jsx(motion.div, { className: "absolute top-1/2 -translate-y-1/2 right-4 w-1 h-8 bg-border-primary rounded-full", style: { opacity }, initial: { opacity: 0 }, animate: { opacity: isDragging ? 0.3 : 0 } })), confirmDelete && (_jsx(ConfirmDialog, { open: showConfirmDialog, onOpenChange: setShowConfirmDialog, title: "Confirm Delete", description: confirmMessage || "Are you sure you want to delete this item? This action cannot be undone.", confirmLabel: "Delete", cancelLabel: "Cancel", onConfirm: handleConfirmDelete, onCancel: handleCancelConfirm, variant: variant === 'danger' ? 'destructive' : variant === 'warning' ? 'warning' : 'default' }))] }));
|
|
82
|
-
});
|
|
83
|
-
SlideToDelete.displayName = 'SlideToDelete';
|
|
84
|
-
export const SlideToDeleteItem = React.forwardRef(({ title, subtitle, avatar, actions, children, className, ...slideProps }, ref) => {
|
|
85
|
-
return (_jsx(SlideToDelete, { ref: ref, className: cn("mb-2", className), ...slideProps, children: _jsxs("div", { className: "flex items-center gap-4 p-4", children: [avatar && (_jsx("div", { className: "flex-shrink-0", children: avatar })), _jsxs("div", { className: "flex-1 min-w-0", children: [title && (_jsx("div", { className: "text-sm font-medium text-text-primary truncate", children: title })), subtitle && (_jsx("div", { className: "text-xs text-text-secondary truncate mt-0.5", children: subtitle })), children] }), actions && (_jsx("div", { className: "flex-shrink-0 flex items-center gap-2", children: actions }))] }) }));
|
|
86
|
-
});
|
|
87
|
-
SlideToDeleteItem.displayName = 'SlideToDeleteItem';
|
|
88
|
-
//# sourceMappingURL=SlideToDelete.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SlideToDelete.js","sourceRoot":"","sources":["../../components/SlideToDelete.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import * as React from "react";
|
|
2
|
-
type SliderProps = {
|
|
3
|
-
value?: number;
|
|
4
|
-
defaultValue?: number;
|
|
5
|
-
min?: number;
|
|
6
|
-
max?: number;
|
|
7
|
-
step?: number;
|
|
8
|
-
disabled?: boolean;
|
|
9
|
-
onValueChange?: (value: number) => void;
|
|
10
|
-
onValueCommit?: (value: number) => void;
|
|
11
|
-
className?: string;
|
|
12
|
-
trackClassName?: string;
|
|
13
|
-
rangeClassName?: string;
|
|
14
|
-
thumbClassName?: string;
|
|
15
|
-
};
|
|
16
|
-
declare const Slider: React.ForwardRefExoticComponent<SliderProps & React.RefAttributes<HTMLDivElement>>;
|
|
17
|
-
export { Slider };
|
|
18
|
-
//# sourceMappingURL=Slider.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Slider.d.ts","sourceRoot":"","sources":["../../components/Slider.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAG/B,KAAK,WAAW,GAAG;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACxC,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACxC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,cAAc,CAAC,EAAE,MAAM,CAAC;CAC3B,CAAC;AAYF,QAAA,MAAM,MAAM,oFAmJX,CAAC;AAGF,OAAO,EAAE,MAAM,EAAE,CAAC"}
|
|
@@ -1,99 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
-
import * as React from "react";
|
|
4
|
-
import { cn } from "../lib/utils";
|
|
5
|
-
function clamp(value, min, max) {
|
|
6
|
-
return Math.min(Math.max(value, min), max);
|
|
7
|
-
}
|
|
8
|
-
function snapToStep(value, step, min) {
|
|
9
|
-
if (step <= 0)
|
|
10
|
-
return value;
|
|
11
|
-
const snapped = Math.round((value - min) / step) * step + min;
|
|
12
|
-
return snapped;
|
|
13
|
-
}
|
|
14
|
-
const Slider = React.forwardRef(({ value, defaultValue, min = 0, max = 100, step = 1, disabled = false, onValueChange, onValueCommit, className, trackClassName, rangeClassName, thumbClassName, }, ref) => {
|
|
15
|
-
const [internalValue, setInternalValue] = React.useState(() => clamp(defaultValue ?? min, min, max));
|
|
16
|
-
const currentValue = value !== undefined ? clamp(value, min, max) : internalValue;
|
|
17
|
-
const trackRef = React.useRef(null);
|
|
18
|
-
const [isDragging, setIsDragging] = React.useState(false);
|
|
19
|
-
const getPercent = (val) => ((val - min) / (max - min)) * 100;
|
|
20
|
-
const updateValue = React.useCallback((next, commit) => {
|
|
21
|
-
const clamped = clamp(next, min, max);
|
|
22
|
-
if (value === undefined) {
|
|
23
|
-
setInternalValue(clamped);
|
|
24
|
-
}
|
|
25
|
-
onValueChange?.(clamped);
|
|
26
|
-
if (commit) {
|
|
27
|
-
onValueCommit?.(clamped);
|
|
28
|
-
}
|
|
29
|
-
}, [max, min, onValueChange, onValueCommit, value]);
|
|
30
|
-
const handlePointerMove = React.useCallback((event) => {
|
|
31
|
-
const track = trackRef.current;
|
|
32
|
-
if (!track || disabled)
|
|
33
|
-
return;
|
|
34
|
-
const point = "touches" in event ? event.touches[0] : event;
|
|
35
|
-
const rect = track.getBoundingClientRect();
|
|
36
|
-
const ratio = (point.clientX - rect.left) / rect.width;
|
|
37
|
-
const rawValue = min + ratio * (max - min);
|
|
38
|
-
const stepped = snapToStep(rawValue, step, min);
|
|
39
|
-
updateValue(stepped);
|
|
40
|
-
}, [disabled, max, min, step, updateValue]);
|
|
41
|
-
const endPointer = React.useCallback(() => {
|
|
42
|
-
if (!isDragging)
|
|
43
|
-
return;
|
|
44
|
-
setIsDragging(false);
|
|
45
|
-
onValueCommit?.(currentValue);
|
|
46
|
-
}, [currentValue, isDragging, onValueCommit]);
|
|
47
|
-
React.useEffect(() => {
|
|
48
|
-
if (!isDragging)
|
|
49
|
-
return;
|
|
50
|
-
const move = (e) => handlePointerMove(e);
|
|
51
|
-
const touchMove = (e) => handlePointerMove(e);
|
|
52
|
-
const up = () => endPointer();
|
|
53
|
-
document.addEventListener("mousemove", move);
|
|
54
|
-
document.addEventListener("touchmove", touchMove);
|
|
55
|
-
document.addEventListener("mouseup", up);
|
|
56
|
-
document.addEventListener("touchend", up);
|
|
57
|
-
document.addEventListener("touchcancel", up);
|
|
58
|
-
return () => {
|
|
59
|
-
document.removeEventListener("mousemove", move);
|
|
60
|
-
document.removeEventListener("touchmove", touchMove);
|
|
61
|
-
document.removeEventListener("mouseup", up);
|
|
62
|
-
document.removeEventListener("touchend", up);
|
|
63
|
-
document.removeEventListener("touchcancel", up);
|
|
64
|
-
};
|
|
65
|
-
}, [isDragging, handlePointerMove, endPointer]);
|
|
66
|
-
const startDrag = (event) => {
|
|
67
|
-
if (disabled)
|
|
68
|
-
return;
|
|
69
|
-
event.preventDefault();
|
|
70
|
-
setIsDragging(true);
|
|
71
|
-
if ("touches" in event && event.touches.length > 0) {
|
|
72
|
-
handlePointerMove(event.nativeEvent);
|
|
73
|
-
}
|
|
74
|
-
else {
|
|
75
|
-
handlePointerMove(event.nativeEvent);
|
|
76
|
-
}
|
|
77
|
-
};
|
|
78
|
-
const handleKeyDown = (event) => {
|
|
79
|
-
if (disabled)
|
|
80
|
-
return;
|
|
81
|
-
const incrementKeys = ["ArrowRight", "ArrowUp"];
|
|
82
|
-
const decrementKeys = ["ArrowLeft", "ArrowDown"];
|
|
83
|
-
let delta = 0;
|
|
84
|
-
if (incrementKeys.includes(event.key))
|
|
85
|
-
delta = step;
|
|
86
|
-
if (decrementKeys.includes(event.key))
|
|
87
|
-
delta = -step;
|
|
88
|
-
if (delta !== 0) {
|
|
89
|
-
event.preventDefault();
|
|
90
|
-
const nextVal = clamp(currentValue + delta, min, max);
|
|
91
|
-
updateValue(nextVal, true);
|
|
92
|
-
}
|
|
93
|
-
};
|
|
94
|
-
const percent = getPercent(currentValue);
|
|
95
|
-
return (_jsxs("div", { ref: ref, className: cn("relative flex w-full touch-none select-none items-center", className), "aria-disabled": disabled || undefined, children: [_jsx("div", { ref: trackRef, className: cn("relative h-1.5 w-full grow overflow-hidden rounded-full bg-surface-secondary", trackClassName), onMouseDown: startDrag, onTouchStart: startDrag, children: _jsx("div", { className: cn("absolute h-full bg-accent-blue", rangeClassName), style: { width: `${percent}%` } }) }), _jsx("button", { type: "button", role: "slider", "aria-valuemin": min, "aria-valuemax": max, "aria-valuenow": currentValue, "aria-disabled": disabled || undefined, tabIndex: disabled ? -1 : 0, onKeyDown: handleKeyDown, onMouseDown: startDrag, onTouchStart: startDrag, className: cn("absolute block h-6 w-6 -translate-x-1/2 rounded-full border border-border-primary/10 bg-white shadow-md ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 hover:scale-105 transition-transform duration-200", thumbClassName, disabled && "pointer-events-none opacity-60"), style: { left: `${percent}%` } })] }));
|
|
96
|
-
});
|
|
97
|
-
Slider.displayName = "Slider";
|
|
98
|
-
export { Slider };
|
|
99
|
-
//# sourceMappingURL=Slider.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Slider.js","sourceRoot":"","sources":["../../components/Slider.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
export type SnackbarVariant = 'default' | 'success' | 'error' | 'warning' | 'info';
|
|
3
|
-
export interface SnackbarAction {
|
|
4
|
-
label: string;
|
|
5
|
-
onClick: () => void;
|
|
6
|
-
}
|
|
7
|
-
export interface SnackbarProps {
|
|
8
|
-
message: string;
|
|
9
|
-
variant?: SnackbarVariant;
|
|
10
|
-
action?: SnackbarAction;
|
|
11
|
-
duration?: number;
|
|
12
|
-
onClose?: () => void;
|
|
13
|
-
show?: boolean;
|
|
14
|
-
}
|
|
15
|
-
export declare const Snackbar: React.FC<SnackbarProps>;
|
|
16
|
-
//# sourceMappingURL=Snackbar.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Snackbar.d.ts","sourceRoot":"","sources":["../../components/Snackbar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA8B,MAAM,OAAO,CAAC;AAUnD,MAAM,MAAM,eAAe,GAAG,SAAS,GAAG,SAAS,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;AAEnF,MAAM,WAAW,cAAc;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,IAAI,CAAC;CACvB;AAED,MAAM,WAAW,aAAa;IAC1B,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,eAAe,CAAC;IAC1B,MAAM,CAAC,EAAE,cAAc,CAAC;IACxB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,IAAI,CAAC,EAAE,OAAO,CAAC;CAClB;AAMD,eAAO,MAAM,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,aAAa,CAkF5C,CAAC"}
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { useEffect, useState } from 'react';
|
|
3
|
-
import { createPortal } from 'react-dom';
|
|
4
|
-
import { cn } from '../lib/utils';
|
|
5
|
-
import { motion, AnimatePresence } from 'framer-motion';
|
|
6
|
-
import { X } from 'lucide-react';
|
|
7
|
-
/* ========================================
|
|
8
|
-
SNACKBAR COMPONENT
|
|
9
|
-
======================================== */
|
|
10
|
-
export const Snackbar = ({ message, variant = 'default', action, duration = 5000, onClose, show = true, }) => {
|
|
11
|
-
const [mounted, setMounted] = useState(false);
|
|
12
|
-
useEffect(() => {
|
|
13
|
-
setMounted(true);
|
|
14
|
-
}, []);
|
|
15
|
-
useEffect(() => {
|
|
16
|
-
if (show && duration > 0) {
|
|
17
|
-
const timer = setTimeout(() => {
|
|
18
|
-
onClose?.();
|
|
19
|
-
}, duration);
|
|
20
|
-
return () => clearTimeout(timer);
|
|
21
|
-
}
|
|
22
|
-
}, [show, duration, onClose]);
|
|
23
|
-
const variants = {
|
|
24
|
-
default: "bg-surface-elevated text-text-primary border border-border-primary",
|
|
25
|
-
success: "bg-status-success/10 text-status-success border border-status-success/20",
|
|
26
|
-
error: "bg-status-error/10 text-status-error border border-status-error/20",
|
|
27
|
-
warning: "bg-status-warning/10 text-status-warning border border-status-warning/20",
|
|
28
|
-
info: "bg-status-info/10 text-status-info border border-status-info/20",
|
|
29
|
-
};
|
|
30
|
-
const content = (_jsx(AnimatePresence, { children: show && (_jsx(motion.div, { initial: { y: 100, opacity: 0 }, animate: { y: 0, opacity: 1 }, exit: { y: 100, opacity: 0 }, transition: { type: "spring", stiffness: 400, damping: 30 }, className: "fixed bottom-6 left-1/2 -translate-x-1/2 z-sticky max-w-md w-full mx-4", children: _jsxs("div", { className: cn("flex items-center gap-3 px-4 py-3 rounded-xl shadow-lg", variants[variant]), children: [_jsx("p", { className: "flex-1 text-sm font-medium", children: message }), _jsxs("div", { className: "flex items-center gap-2", children: [action && (_jsx("button", { onClick: () => {
|
|
31
|
-
action.onClick();
|
|
32
|
-
onClose?.();
|
|
33
|
-
}, className: "text-sm font-semibold hover:opacity-80 transition-opacity focus:outline-none", children: action.label })), onClose && (_jsx("button", { onClick: onClose, className: "p-1 rounded-lg hover:bg-black/10 transition-colors focus:outline-none", "aria-label": "Close", children: _jsx(X, { className: "w-4 h-4" }) }))] })] }) })) }));
|
|
34
|
-
if (!mounted)
|
|
35
|
-
return null;
|
|
36
|
-
return createPortal(content, document.body);
|
|
37
|
-
};
|
|
38
|
-
Snackbar.displayName = 'Snackbar';
|
|
39
|
-
//# sourceMappingURL=Snackbar.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Snackbar.js","sourceRoot":"","sources":["../../components/Snackbar.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,EAAE,EAAE,MAAM,cAAc,CAAC;AAClC,OAAO,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AACxD,OAAO,EAAE,CAAC,EAAE,MAAM,cAAc,CAAC;AAsBjC;;8CAE8C;AAE9C,MAAM,CAAC,MAAM,QAAQ,GAA4B,CAAC,EAC9C,OAAO,EACP,OAAO,GAAG,SAAS,EACnB,MAAM,EACN,QAAQ,GAAG,IAAI,EACf,OAAO,EACP,IAAI,GAAG,IAAI,GACd,EAAE,EAAE;IACD,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAE9C,SAAS,CAAC,GAAG,EAAE;QACX,UAAU,CAAC,IAAI,CAAC,CAAC;IACrB,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,SAAS,CAAC,GAAG,EAAE;QACX,IAAI,IAAI,IAAI,QAAQ,GAAG,CAAC,EAAE,CAAC;YACvB,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE;gBAC1B,OAAO,EAAE,EAAE,CAAC;YAChB,CAAC,EAAE,QAAQ,CAAC,CAAC;YAEb,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QACrC,CAAC;IACL,CAAC,EAAE,CAAC,IAAI,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC;IAE9B,MAAM,QAAQ,GAAG;QACb,OAAO,EAAE,oEAAoE;QAC7E,OAAO,EAAE,0EAA0E;QACnF,KAAK,EAAE,oEAAoE;QAC3E,OAAO,EAAE,0EAA0E;QACnF,IAAI,EAAE,iEAAiE;KAC1E,CAAC;IAEF,MAAM,OAAO,GAAG,CACZ,KAAC,eAAe,cACX,IAAI,IAAI,CACL,KAAC,MAAM,CAAC,GAAG,IACP,OAAO,EAAE,EAAE,CAAC,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC,EAAE,EAC/B,OAAO,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,EAC7B,IAAI,EAAE,EAAE,CAAC,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC,EAAE,EAC5B,UAAU,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,EAAE,OAAO,EAAE,EAAE,EAAE,EAC3D,SAAS,EAAC,wEAAwE,YAElF,eACI,SAAS,EAAE,EAAE,CACT,wDAAwD,EACxD,QAAQ,CAAC,OAAO,CAAC,CACpB,aAED,YAAG,SAAS,EAAC,4BAA4B,YAAE,OAAO,GAAK,EAEvD,eAAK,SAAS,EAAC,yBAAyB,aACnC,MAAM,IAAI,CACP,iBACI,OAAO,EAAE,GAAG,EAAE;oCACV,MAAM,CAAC,OAAO,EAAE,CAAC;oCACjB,OAAO,EAAE,EAAE,CAAC;gCAChB,CAAC,EACD,SAAS,EAAC,8EAA8E,YAEvF,MAAM,CAAC,KAAK,GACR,CACZ,EAEA,OAAO,IAAI,CACR,iBACI,OAAO,EAAE,OAAO,EAChB,SAAS,EAAC,uEAAuE,gBACtE,OAAO,YAElB,KAAC,CAAC,IAAC,SAAS,EAAC,SAAS,GAAG,GACpB,CACZ,IACC,IACJ,GACG,CAChB,GACa,CACrB,CAAC;IAEF,IAAI,CAAC,OAAO;QAAE,OAAO,IAAI,CAAC;IAE1B,OAAO,YAAY,CAAC,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;AAChD,CAAC,CAAC;AAEF,QAAQ,CAAC,WAAW,GAAG,UAAU,CAAC"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
export interface SpacerProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
3
|
-
/**
|
|
4
|
-
* The size of the space. Can be a preset or a custom number (pixels).
|
|
5
|
-
* @default "md"
|
|
6
|
-
*/
|
|
7
|
-
size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl' | '3xl' | number;
|
|
8
|
-
/**
|
|
9
|
-
* The axis of the spacer.
|
|
10
|
-
* @default "vertical"
|
|
11
|
-
*/
|
|
12
|
-
axis?: 'vertical' | 'horizontal';
|
|
13
|
-
/**
|
|
14
|
-
* Whether the spacer should expand to fill available space (flex-grow).
|
|
15
|
-
* If true, size is ignored.
|
|
16
|
-
* @default false
|
|
17
|
-
*/
|
|
18
|
-
flex?: boolean;
|
|
19
|
-
}
|
|
20
|
-
export declare const Spacer: React.ForwardRefExoticComponent<SpacerProps & React.RefAttributes<HTMLDivElement>>;
|
|
21
|
-
//# sourceMappingURL=Spacer.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Spacer.d.ts","sourceRoot":"","sources":["../../components/Spacer.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,MAAM,WAAW,WAAY,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IACrE;;;OAGG;IACH,IAAI,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,KAAK,GAAG,KAAK,GAAG,MAAM,CAAC;IACjE;;;OAGG;IACH,IAAI,CAAC,EAAE,UAAU,GAAG,YAAY,CAAC;IACjC;;;;OAIG;IACH,IAAI,CAAC,EAAE,OAAO,CAAC;CAClB;AAED,eAAO,MAAM,MAAM,oFAqDlB,CAAC"}
|