@admin-layout/tailwind-ui 12.2.4-alpha.4 → 12.2.4-alpha.42
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/lib/components/AIToolbar/components/AIToolBar.d.ts +22 -0
- package/lib/components/AIToolbar/components/AIToolBar.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/AIToolBar.js +83 -0
- package/lib/components/AIToolbar/components/AIToolBar.js.map +1 -0
- package/lib/components/AIToolbar/components/AIToolbarPrimitives.d.ts +14 -0
- package/lib/components/AIToolbar/components/AIToolbarPrimitives.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/AIToolbarPrimitives.js +60 -0
- package/lib/components/AIToolbar/components/AIToolbarPrimitives.js.map +1 -0
- package/lib/components/AIToolbar/components/CustomCursor.d.ts +2 -0
- package/lib/components/AIToolbar/components/CustomCursor.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/CustomCursor.js +66 -0
- package/lib/components/AIToolbar/components/CustomCursor.js.map +1 -0
- package/lib/components/AIToolbar/components/DragButton.d.ts +9 -0
- package/lib/components/AIToolbar/components/DragButton.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/DragButton.js +57 -0
- package/lib/components/AIToolbar/components/DragButton.js.map +1 -0
- package/lib/components/AIToolbar/components/Markdown/copy-button.d.ts +7 -0
- package/lib/components/AIToolbar/components/Markdown/copy-button.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/Markdown/copy-button.js +30 -0
- package/lib/components/AIToolbar/components/Markdown/copy-button.js.map +1 -0
- package/lib/components/AIToolbar/components/Markdown/index.d.ts +7 -0
- package/lib/components/AIToolbar/components/Markdown/index.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/Markdown/index.js +46 -0
- package/lib/components/AIToolbar/components/Markdown/index.js.map +1 -0
- package/lib/components/AIToolbar/components/completion/AssistantMessageActions.d.ts +28 -0
- package/lib/components/AIToolbar/components/completion/AssistantMessageActions.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/completion/AssistantMessageActions.js +209 -0
- package/lib/components/AIToolbar/components/completion/AssistantMessageActions.js.map +1 -0
- package/lib/components/AIToolbar/components/completion/Audio.d.ts +3 -0
- package/lib/components/AIToolbar/components/completion/Audio.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/completion/Audio.js +65 -0
- package/lib/components/AIToolbar/components/completion/Audio.js.map +1 -0
- package/lib/components/AIToolbar/components/completion/AutoSpeechVad.d.ts +11 -0
- package/lib/components/AIToolbar/components/completion/AutoSpeechVad.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/completion/AutoSpeechVad.js +66 -0
- package/lib/components/AIToolbar/components/completion/AutoSpeechVad.js.map +1 -0
- package/lib/components/AIToolbar/components/completion/Files.d.ts +6 -0
- package/lib/components/AIToolbar/components/completion/Files.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/completion/Files.js +134 -0
- package/lib/components/AIToolbar/components/completion/Files.js.map +1 -0
- package/lib/components/AIToolbar/components/completion/Input.d.ts +5 -0
- package/lib/components/AIToolbar/components/completion/Input.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/completion/Input.js +202 -0
- package/lib/components/AIToolbar/components/completion/Input.js.map +1 -0
- package/lib/components/AIToolbar/components/completion/MessageHistory.d.ts +11 -0
- package/lib/components/AIToolbar/components/completion/MessageHistory.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/completion/MessageHistory.js +90 -0
- package/lib/components/AIToolbar/components/completion/MessageHistory.js.map +1 -0
- package/lib/components/AIToolbar/components/completion/Screenshot.d.ts +6 -0
- package/lib/components/AIToolbar/components/completion/Screenshot.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/completion/Screenshot.js +28 -0
- package/lib/components/AIToolbar/components/completion/Screenshot.js.map +1 -0
- package/lib/components/AIToolbar/components/completion/index.d.ts +11 -0
- package/lib/components/AIToolbar/components/completion/index.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/completion/index.js +20 -0
- package/lib/components/AIToolbar/components/completion/index.js.map +1 -0
- package/lib/components/AIToolbar/components/index.d.ts +17 -0
- package/lib/components/AIToolbar/components/index.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/speech/Header.d.ts +14 -0
- package/lib/components/AIToolbar/components/speech/Header.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/speech/Header.js +82 -0
- package/lib/components/AIToolbar/components/speech/Header.js.map +1 -0
- package/lib/components/AIToolbar/components/speech/ModeSwitcher.d.ts +8 -0
- package/lib/components/AIToolbar/components/speech/ModeSwitcher.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/speech/ModeSwitcher.js +44 -0
- package/lib/components/AIToolbar/components/speech/ModeSwitcher.js.map +1 -0
- package/lib/components/AIToolbar/components/speech/PermissionFlow.d.ts +13 -0
- package/lib/components/AIToolbar/components/speech/PermissionFlow.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/speech/PermissionFlow.js +168 -0
- package/lib/components/AIToolbar/components/speech/PermissionFlow.js.map +1 -0
- package/lib/components/AIToolbar/components/speech/QuickActions.d.ts +13 -0
- package/lib/components/AIToolbar/components/speech/QuickActions.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/speech/QuickActions.js +100 -0
- package/lib/components/AIToolbar/components/speech/QuickActions.js.map +1 -0
- package/lib/components/AIToolbar/components/speech/RecordingPanel.d.ts +14 -0
- package/lib/components/AIToolbar/components/speech/RecordingPanel.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/speech/RecordingPanel.js +101 -0
- package/lib/components/AIToolbar/components/speech/RecordingPanel.js.map +1 -0
- package/lib/components/AIToolbar/components/speech/ResultsSection.d.ts +12 -0
- package/lib/components/AIToolbar/components/speech/ResultsSection.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/speech/ResultsSection.js +132 -0
- package/lib/components/AIToolbar/components/speech/ResultsSection.js.map +1 -0
- package/lib/components/AIToolbar/components/speech/SettingsPanel.d.ts +12 -0
- package/lib/components/AIToolbar/components/speech/SettingsPanel.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/speech/SettingsPanel.js +289 -0
- package/lib/components/AIToolbar/components/speech/SettingsPanel.js.map +1 -0
- package/lib/components/AIToolbar/components/speech/StatusIndicator.d.ts +10 -0
- package/lib/components/AIToolbar/components/speech/StatusIndicator.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/speech/StatusIndicator.js +48 -0
- package/lib/components/AIToolbar/components/speech/StatusIndicator.js.map +1 -0
- package/lib/components/AIToolbar/components/speech/Warning.d.ts +6 -0
- package/lib/components/AIToolbar/components/speech/Warning.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/speech/Warning.js +154 -0
- package/lib/components/AIToolbar/components/speech/Warning.js.map +1 -0
- package/lib/components/AIToolbar/components/speech/audio-visualizer.d.ts +7 -0
- package/lib/components/AIToolbar/components/speech/audio-visualizer.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/speech/audio-visualizer.js +194 -0
- package/lib/components/AIToolbar/components/speech/audio-visualizer.js.map +1 -0
- package/lib/components/AIToolbar/components/speech/floatArrayToWav.d.ts +2 -0
- package/lib/components/AIToolbar/components/speech/floatArrayToWav.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/speech/floatArrayToWav.js +32 -0
- package/lib/components/AIToolbar/components/speech/floatArrayToWav.js.map +1 -0
- package/lib/components/AIToolbar/components/speech/index.d.ts +4 -0
- package/lib/components/AIToolbar/components/speech/index.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/speech/index.js +292 -0
- package/lib/components/AIToolbar/components/speech/index.js.map +1 -0
- package/lib/components/AIToolbar/components/speech/promptTemplates.d.ts +12 -0
- package/lib/components/AIToolbar/components/speech/promptTemplates.d.ts.map +1 -0
- package/lib/components/AIToolbar/components/speech/promptTemplates.js +114 -0
- package/lib/components/AIToolbar/components/speech/promptTemplates.js.map +1 -0
- package/lib/components/AIToolbar/components/types.d.ts +182 -0
- package/lib/components/AIToolbar/components/types.d.ts.map +1 -0
- package/lib/components/AIToolbar/index.d.ts +5 -0
- package/lib/components/AIToolbar/index.d.ts.map +1 -0
- package/lib/components/Button/Button.d.ts +1 -1
- package/lib/components/Button/Button.d.ts.map +1 -1
- package/lib/components/Button/Button.js +7 -6
- package/lib/components/Button/Button.js.map +1 -1
- package/lib/components/DatePicker/DatePicker.js +158 -140
- package/lib/components/DatePicker/DatePicker.js.map +1 -1
- package/lib/components/Dialog/Dialog.d.ts +20 -0
- package/lib/components/Dialog/Dialog.d.ts.map +1 -0
- package/lib/components/Dialog/Dialog.js +111 -0
- package/lib/components/Dialog/Dialog.js.map +1 -0
- package/lib/components/Dialog/index.d.ts +3 -0
- package/lib/components/Dialog/index.d.ts.map +1 -0
- package/lib/components/ErrorHandlers/ApplicationErrorHandler.d.ts +1 -2
- package/lib/components/ErrorHandlers/ApplicationErrorHandler.d.ts.map +1 -1
- package/lib/components/ErrorHandlers/ApplicationErrorHandler.js +2 -2
- package/lib/components/ErrorHandlers/ErrorBoundary.d.ts +1 -2
- package/lib/components/ErrorHandlers/ErrorBoundary.d.ts.map +1 -1
- package/lib/components/ErrorHandlers/ErrorBoundary.js +35 -28
- package/lib/components/ErrorHandlers/ErrorBoundary.js.map +1 -1
- package/lib/components/ErrorHandlers/LayoutErrorBoundary.d.ts +1 -2
- package/lib/components/ErrorHandlers/LayoutErrorBoundary.d.ts.map +1 -1
- package/lib/components/ErrorHandlers/LayoutErrorBoundary.js +20 -15
- package/lib/components/ErrorHandlers/LayoutErrorBoundary.js.map +1 -1
- package/lib/components/ErrorHandlers/RemixErrorBoundary.d.ts +4 -2
- package/lib/components/ErrorHandlers/RemixErrorBoundary.d.ts.map +1 -1
- package/lib/components/ErrorHandlers/RemixErrorBoundary.js +222 -100
- package/lib/components/ErrorHandlers/RemixErrorBoundary.js.map +1 -1
- package/lib/components/ErrorHandlers/SPAErrorBoundary.d.ts +4 -2
- package/lib/components/ErrorHandlers/SPAErrorBoundary.d.ts.map +1 -1
- package/lib/components/ErrorHandlers/SPAErrorBoundary.js +247 -82
- package/lib/components/ErrorHandlers/SPAErrorBoundary.js.map +1 -1
- package/lib/components/ErrorPages/403.d.ts +1 -2
- package/lib/components/ErrorPages/403.d.ts.map +1 -1
- package/lib/components/ErrorPages/403.js +26 -18
- package/lib/components/ErrorPages/403.js.map +1 -1
- package/lib/components/ErrorPages/404.d.ts +1 -2
- package/lib/components/ErrorPages/404.d.ts.map +1 -1
- package/lib/components/ErrorPages/404.js +26 -18
- package/lib/components/ErrorPages/404.js.map +1 -1
- package/lib/components/ErrorPages/500.d.ts +1 -2
- package/lib/components/ErrorPages/500.d.ts.map +1 -1
- package/lib/components/ErrorPages/500.js +26 -18
- package/lib/components/ErrorPages/500.js.map +1 -1
- package/lib/components/InputToolBar/InputToolBar.d.ts +8 -0
- package/lib/components/InputToolBar/InputToolBar.d.ts.map +1 -0
- package/lib/components/InputToolBar/InputToolBar.js +469 -0
- package/lib/components/InputToolBar/InputToolBar.js.map +1 -0
- package/lib/components/InputToolBar/defaults.d.ts +15 -0
- package/lib/components/InputToolBar/defaults.d.ts.map +1 -0
- package/lib/components/InputToolBar/defaults.js +59 -0
- package/lib/components/InputToolBar/defaults.js.map +1 -0
- package/lib/components/InputToolBar/index.d.ts +5 -0
- package/lib/components/InputToolBar/index.d.ts.map +1 -0
- package/lib/components/InputToolBar/types.d.ts +153 -0
- package/lib/components/InputToolBar/types.d.ts.map +1 -0
- package/lib/components/LanguageMenuDropdown/LanguageMenuDropdown.d.ts +1 -2
- package/lib/components/LanguageMenuDropdown/LanguageMenuDropdown.d.ts.map +1 -1
- package/lib/components/LanguageMenuDropdown/LanguageMenuDropdown.js +24 -19
- package/lib/components/LanguageMenuDropdown/LanguageMenuDropdown.js.map +1 -1
- package/lib/components/Markdown/MarkdownBreadcrumbs.d.ts +13 -0
- package/lib/components/Markdown/MarkdownBreadcrumbs.d.ts.map +1 -0
- package/lib/components/Markdown/MarkdownBreadcrumbs.js +34 -0
- package/lib/components/Markdown/MarkdownBreadcrumbs.js.map +1 -0
- package/lib/components/Markdown/MarkdownCopyButton.d.ts +10 -0
- package/lib/components/Markdown/MarkdownCopyButton.d.ts.map +1 -0
- package/lib/components/Markdown/MarkdownCopyButton.js +229 -0
- package/lib/components/Markdown/MarkdownCopyButton.js.map +1 -0
- package/lib/components/Markdown/MarkdownHeader.d.ts +13 -0
- package/lib/components/Markdown/MarkdownHeader.d.ts.map +1 -0
- package/lib/components/Markdown/MarkdownHeader.js +44 -0
- package/lib/components/Markdown/MarkdownHeader.js.map +1 -0
- package/lib/components/Markdown/MarkdownNavigation.d.ts +15 -0
- package/lib/components/Markdown/MarkdownNavigation.d.ts.map +1 -0
- package/lib/components/Markdown/MarkdownNavigation.js +38 -0
- package/lib/components/Markdown/MarkdownNavigation.js.map +1 -0
- package/lib/components/Markdown/MarkdownPage.d.ts +41 -0
- package/lib/components/Markdown/MarkdownPage.d.ts.map +1 -0
- package/lib/components/Markdown/MarkdownPage.js +238 -0
- package/lib/components/Markdown/MarkdownPage.js.map +1 -0
- package/lib/components/Markdown/MarkdownTableOfContents.d.ts +15 -0
- package/lib/components/Markdown/MarkdownTableOfContents.d.ts.map +1 -0
- package/lib/components/Markdown/MarkdownTableOfContents.js +57 -0
- package/lib/components/Markdown/MarkdownTableOfContents.js.map +1 -0
- package/lib/components/Markdown/index.d.ts +7 -0
- package/lib/components/Markdown/index.d.ts.map +1 -0
- package/lib/components/OTP/OTPInput.js +32 -30
- package/lib/components/OTP/OTPInput.js.map +1 -1
- package/lib/components/OTP/OTPVerification.js +75 -55
- package/lib/components/OTP/OTPVerification.js.map +1 -1
- package/lib/components/OTP/SingleInput.js +2 -2
- package/lib/components/OTP/SingleInput.js.map +1 -1
- package/lib/components/PageContainer/PageContainer.js +29 -22
- package/lib/components/PageContainer/PageContainer.js.map +1 -1
- package/lib/components/PageLoading/index.js +8 -7
- package/lib/components/PageLoading/index.js.map +1 -1
- package/lib/components/RJSFPreview/PreviewAsyncDropdown.d.ts +1 -2
- package/lib/components/RJSFPreview/PreviewAsyncDropdown.d.ts.map +1 -1
- package/lib/components/ReactTable/Table.d.ts +1 -2
- package/lib/components/ReactTable/Table.d.ts.map +1 -1
- package/lib/components/ReactTable/Table.js +92 -71
- package/lib/components/ReactTable/Table.js.map +1 -1
- package/lib/components/ReactTable/TableFilters.d.ts +2 -3
- package/lib/components/ReactTable/TableFilters.d.ts.map +1 -1
- package/lib/components/ReactTable/TableFilters.js +40 -34
- package/lib/components/ReactTable/TableFilters.js.map +1 -1
- package/lib/components/Search/SearchInput.d.ts +1 -2
- package/lib/components/Search/SearchInput.d.ts.map +1 -1
- package/lib/components/Search/SearchInput.js +14 -13
- package/lib/components/Search/SearchInput.js.map +1 -1
- package/lib/components/Select/Select.d.ts +6 -6
- package/lib/components/Select/Select.d.ts.map +1 -1
- package/lib/components/Select/Select.js +60 -45
- package/lib/components/Select/Select.js.map +1 -1
- package/lib/components/Spin/index.js +14 -11
- package/lib/components/Spin/index.js.map +1 -1
- package/lib/components/ThemeProvider/ThemeProvider.d.ts +1 -1
- package/lib/components/ThemeProvider/ThemeProvider.d.ts.map +1 -1
- package/lib/components/ThemeProvider/ThemeProvider.js +29 -17
- package/lib/components/ThemeProvider/ThemeProvider.js.map +1 -1
- package/lib/components/ThemeProvider/ThemeToggle.js +28 -25
- package/lib/components/ThemeProvider/ThemeToggle.js.map +1 -1
- package/lib/components/ThemeProvider/types.d.ts +3 -3
- package/lib/components/ThemeProvider/types.d.ts.map +1 -1
- package/lib/components/index.d.ts +5 -0
- package/lib/components/index.d.ts.map +1 -1
- package/lib/hooks/useToast.d.ts +1 -1
- package/lib/hooks/useToast.d.ts.map +1 -1
- package/lib/hooks/useToast.js +46 -37
- package/lib/hooks/useToast.js.map +1 -1
- package/lib/index.js +1 -1
- package/lib/shardui/accordion.js +20 -16
- package/lib/shardui/accordion.js.map +1 -1
- package/lib/shardui/alert-dialog.d.ts +2 -2
- package/lib/shardui/alert-dialog.js +15 -13
- package/lib/shardui/alert-dialog.js.map +1 -1
- package/lib/shardui/alert.js +4 -4
- package/lib/shardui/alert.js.map +1 -1
- package/lib/shardui/avatar.js +4 -4
- package/lib/shardui/avatar.js.map +1 -1
- package/lib/shardui/badge.d.ts +1 -1
- package/lib/shardui/badge.d.ts.map +1 -1
- package/lib/shardui/badge.js +2 -2
- package/lib/shardui/badge.js.map +1 -1
- package/lib/shardui/breadcrumb.d.ts +2 -2
- package/lib/shardui/breadcrumb.js +19 -16
- package/lib/shardui/breadcrumb.js.map +1 -1
- package/lib/shardui/button.js +2 -2
- package/lib/shardui/button.js.map +1 -1
- package/lib/shardui/calendar.d.ts +1 -1
- package/lib/shardui/calendar.d.ts.map +1 -1
- package/lib/shardui/calendar.js +4 -4
- package/lib/shardui/card.js +7 -7
- package/lib/shardui/card.js.map +1 -1
- package/lib/shardui/carousel.js +40 -33
- package/lib/shardui/carousel.js.map +1 -1
- package/lib/shardui/chart.d.ts +1 -1
- package/lib/shardui/chart.d.ts.map +1 -1
- package/lib/shardui/chart.js +81 -66
- package/lib/shardui/chart.js.map +1 -1
- package/lib/shardui/checkbox.js +10 -8
- package/lib/shardui/checkbox.js.map +1 -1
- package/lib/shardui/command.d.ts +2 -2
- package/lib/shardui/command.d.ts.map +1 -1
- package/lib/shardui/command.js +28 -24
- package/lib/shardui/command.js.map +1 -1
- package/lib/shardui/context-menu.d.ts +1 -1
- package/lib/shardui/context-menu.js +41 -30
- package/lib/shardui/context-menu.js.map +1 -1
- package/lib/shardui/dialog.d.ts +2 -2
- package/lib/shardui/dialog.js +22 -17
- package/lib/shardui/dialog.js.map +1 -1
- package/lib/shardui/drawer.d.ts +3 -3
- package/lib/shardui/drawer.js +17 -14
- package/lib/shardui/drawer.js.map +1 -1
- package/lib/shardui/dropdown-menu.d.ts +1 -1
- package/lib/shardui/dropdown-menu.js +42 -31
- package/lib/shardui/dropdown-menu.js.map +1 -1
- package/lib/shardui/form.d.ts +1 -1
- package/lib/shardui/form.d.ts.map +1 -1
- package/lib/shardui/form.js +22 -19
- package/lib/shardui/form.js.map +1 -1
- package/lib/shardui/hover-card.js +2 -2
- package/lib/shardui/hover-card.js.map +1 -1
- package/lib/shardui/input-otp.js +16 -13
- package/lib/shardui/input-otp.js.map +1 -1
- package/lib/shardui/input.js +2 -2
- package/lib/shardui/input.js.map +1 -1
- package/lib/shardui/label.js +2 -2
- package/lib/shardui/label.js.map +1 -1
- package/lib/shardui/menubar.d.ts +1 -1
- package/lib/shardui/menubar.js +46 -35
- package/lib/shardui/menubar.js.map +1 -1
- package/lib/shardui/navigation-menu.js +28 -24
- package/lib/shardui/navigation-menu.js.map +1 -1
- package/lib/shardui/pagination.d.ts +5 -5
- package/lib/shardui/pagination.js +30 -22
- package/lib/shardui/pagination.js.map +1 -1
- package/lib/shardui/popover.js +10 -8
- package/lib/shardui/popover.js.map +1 -1
- package/lib/shardui/progress.js +10 -9
- package/lib/shardui/progress.js.map +1 -1
- package/lib/shardui/radio-group.js +11 -9
- package/lib/shardui/radio-group.js.map +1 -1
- package/lib/shardui/resizable.d.ts +3 -3
- package/lib/shardui/resizable.d.ts.map +1 -1
- package/lib/shardui/resizable.js +11 -9
- package/lib/shardui/resizable.js.map +1 -1
- package/lib/shardui/scroll-area.js +14 -11
- package/lib/shardui/scroll-area.js.map +1 -1
- package/lib/shardui/select.js +49 -35
- package/lib/shardui/select.js.map +1 -1
- package/lib/shardui/separator.js +2 -2
- package/lib/shardui/separator.js.map +1 -1
- package/lib/shardui/sheet.d.ts +2 -2
- package/lib/shardui/sheet.js +24 -19
- package/lib/shardui/sheet.js.map +1 -1
- package/lib/shardui/sidebar.js +104 -88
- package/lib/shardui/sidebar.js.map +1 -1
- package/lib/shardui/skeleton.d.ts +1 -1
- package/lib/shardui/skeleton.d.ts.map +1 -1
- package/lib/shardui/skeleton.js +2 -2
- package/lib/shardui/skeleton.js.map +1 -1
- package/lib/shardui/slider.js +12 -10
- package/lib/shardui/slider.js.map +1 -1
- package/lib/shardui/sonner.d.ts +1 -1
- package/lib/shardui/sonner.d.ts.map +1 -1
- package/lib/shardui/sonner.js +2 -2
- package/lib/shardui/sonner.js.map +1 -1
- package/lib/shardui/switch.js +7 -6
- package/lib/shardui/switch.js.map +1 -1
- package/lib/shardui/table.js +16 -15
- package/lib/shardui/table.js.map +1 -1
- package/lib/shardui/tabs.js +4 -4
- package/lib/shardui/tabs.js.map +1 -1
- package/lib/shardui/textarea.js +2 -2
- package/lib/shardui/textarea.js.map +1 -1
- package/lib/shardui/toast.js +12 -11
- package/lib/shardui/toast.js.map +1 -1
- package/lib/shardui/toaster.d.ts +1 -2
- package/lib/shardui/toaster.d.ts.map +1 -1
- package/lib/shardui/toaster.js +21 -14
- package/lib/shardui/toaster.js.map +1 -1
- package/lib/shardui/toggle-group.js +15 -12
- package/lib/shardui/toggle-group.js.map +1 -1
- package/lib/shardui/toggle.js +2 -2
- package/lib/shardui/toggle.js.map +1 -1
- package/lib/shardui/tooltip.js +2 -2
- package/lib/shardui/tooltip.js.map +1 -1
- package/package.json +7 -3
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
import {jsx,jsxs}from'react/jsx-runtime';import {useMemo}from'react';import {AIToolbarInputSurface}from'../AIToolbarPrimitives.js';import {XIcon,Loader2}from'lucide-react';import'../../../../shardui/accordion.js';import'../../../../shardui/alert.js';import'../../../../shardui/alert-dialog.js';import'@radix-ui/react-aspect-ratio';import'../../../../shardui/avatar.js';import'../../../../shardui/badge.js';import'../../../../shardui/breadcrumb.js';import {Button}from'../../../../shardui/button.js';import'../../../../shardui/calendar.js';import'../../../../shardui/card.js';import'../../../../shardui/carousel.js';import'../../../../shardui/chart.js';import'../../../../shardui/checkbox.js';import'@radix-ui/react-collapsible';import'../../../../shardui/command.js';import'../../../../shardui/context-menu.js';import'../../../../shardui/dialog.js';import'../../../../shardui/drawer.js';import'../../../../shardui/dropdown-menu.js';import'../../../../shardui/form.js';import'../../../../shardui/hover-card.js';import {Input as Input$1}from'../../../../shardui/input.js';import'../../../../shardui/input-otp.js';import'../../../../shardui/label.js';import'../../../../shardui/menubar.js';import'../../../../shardui/navigation-menu.js';import'../../../../shardui/pagination.js';import {Popover,PopoverContent,PopoverTrigger}from'../../../../shardui/popover.js';import'../../../../shardui/progress.js';import'../../../../shardui/radio-group.js';import'react-resizable-panels';import'../../../../utils/isBrowser/index.js';import {cn}from'../../../../utils/util.js';import'fast-deep-equal/react.js';import'../../../../shardui/scroll-area.js';import'../../../../shardui/select.js';import'../../../../shardui/separator.js';import'../../../../shardui/sheet.js';import'../../../../shardui/sidebar.js';import'../../../../shardui/slider.js';import'../../../ThemeProvider/ThemeProvider.js';import'sonner';import {Switch}from'../../../../shardui/switch.js';import'../../../../shardui/table.js';import'../../../../shardui/tabs.js';import'../../../../shardui/textarea.js';import'../../../../shardui/toast.js';import'../../../../shardui/toggle.js';import'../../../../shardui/toggle-group.js';import'../../../../shardui/tooltip.js';import {Markdown}from'../Markdown/index.js';import {AssistantMessageActions}from'./AssistantMessageActions.js';import {CopyButton}from'../Markdown/copy-button.js';import {MessageHistory}from'./MessageHistory.js';const Input = ({
|
|
2
|
+
isPopoverOpen,
|
|
3
|
+
isLoading,
|
|
4
|
+
reset,
|
|
5
|
+
input,
|
|
6
|
+
setInput,
|
|
7
|
+
handleKeyPress,
|
|
8
|
+
handlePaste,
|
|
9
|
+
currentConversationId,
|
|
10
|
+
conversationHistory,
|
|
11
|
+
startNewConversation,
|
|
12
|
+
messageHistoryOpen,
|
|
13
|
+
setMessageHistoryOpen,
|
|
14
|
+
error,
|
|
15
|
+
response,
|
|
16
|
+
cancel,
|
|
17
|
+
scrollAreaRef,
|
|
18
|
+
inputRef,
|
|
19
|
+
isHidden,
|
|
20
|
+
keepEngaged,
|
|
21
|
+
setKeepEngaged,
|
|
22
|
+
regenerateAssistantMessage
|
|
23
|
+
}) => {
|
|
24
|
+
const sortedAsc = useMemo(() => [...conversationHistory].sort((a, b) => (a.timestamp ?? 0) - (b.timestamp ?? 0)), [conversationHistory]);
|
|
25
|
+
/** In-flight assistant bubble: hide when history already contains the same assistant text (avoids double render if `response` lingers). */
|
|
26
|
+
const streamingAssistantVisible = useMemo(() => {
|
|
27
|
+
if (isLoading) return true;
|
|
28
|
+
if (!response) return false;
|
|
29
|
+
const last = sortedAsc[sortedAsc.length - 1];
|
|
30
|
+
if (last?.role === 'assistant' && last.content === response) {
|
|
31
|
+
return false;
|
|
32
|
+
}
|
|
33
|
+
return true;
|
|
34
|
+
}, [isLoading, response, sortedAsc]);
|
|
35
|
+
const copyPayload = useMemo(() => {
|
|
36
|
+
const lines = sortedAsc.map(m => m.role === 'user' ? `You:\n${m.content}` : `AI:\n${m.content}`);
|
|
37
|
+
const last = sortedAsc[sortedAsc.length - 1];
|
|
38
|
+
if (response && !(last?.role === 'assistant' && last.content === response)) {
|
|
39
|
+
lines.push(`AI:\n${response}`);
|
|
40
|
+
}
|
|
41
|
+
return lines.join('\n\n');
|
|
42
|
+
}, [sortedAsc, response]);
|
|
43
|
+
return jsx("div", {
|
|
44
|
+
className: "relative flex-1",
|
|
45
|
+
children: jsxs(Popover, {
|
|
46
|
+
open: isPopoverOpen,
|
|
47
|
+
onOpenChange: open => {
|
|
48
|
+
if (!open && !isLoading && !keepEngaged) {
|
|
49
|
+
reset();
|
|
50
|
+
}
|
|
51
|
+
},
|
|
52
|
+
children: [jsxs(PopoverContent, {
|
|
53
|
+
align: "center",
|
|
54
|
+
side: "top",
|
|
55
|
+
sideOffset: 8,
|
|
56
|
+
collisionPadding: 12,
|
|
57
|
+
className: "z-[200] flex h-[min(90vh,calc(100dvh-1rem))] w-screen max-w-[min(100vw,48rem)] flex-col overflow-hidden border bg-popover p-0 text-popover-foreground shadow-lg",
|
|
58
|
+
children: [jsxs("div", {
|
|
59
|
+
className: "flex shrink-0 items-center justify-between border-b bg-muted/30 px-4 py-2",
|
|
60
|
+
children: [jsxs("div", {
|
|
61
|
+
className: "flex flex-row items-center gap-1",
|
|
62
|
+
children: [jsx("h3", {
|
|
63
|
+
className: "select-none text-xs font-semibold",
|
|
64
|
+
children: keepEngaged ? 'Conversation Mode' : 'AI Response'
|
|
65
|
+
}), jsx("div", {
|
|
66
|
+
className: "text-[10px] text-muted-foreground/70",
|
|
67
|
+
children: "(Use arrow keys to scroll)"
|
|
68
|
+
})]
|
|
69
|
+
}), jsxs("div", {
|
|
70
|
+
className: "flex select-none items-center gap-2",
|
|
71
|
+
children: [jsxs("div", {
|
|
72
|
+
className: "mr-2 flex flex-row items-center gap-2",
|
|
73
|
+
children: [jsx("p", {
|
|
74
|
+
className: "text-[10px]",
|
|
75
|
+
children: `Toggle ${keepEngaged ? 'AI response' : 'conversation mode'}`
|
|
76
|
+
}), jsxs("span", {
|
|
77
|
+
className: "rounded border border-input/50 bg-muted/30 px-1 py-0 text-[10px] text-muted-foreground/60",
|
|
78
|
+
children: [navigator.platform.toLowerCase().includes('mac') ? '⌘' : 'Ctrl', " + K"]
|
|
79
|
+
}), jsx(Switch, {
|
|
80
|
+
checked: keepEngaged,
|
|
81
|
+
onCheckedChange: checked => {
|
|
82
|
+
setKeepEngaged(checked);
|
|
83
|
+
setTimeout(() => {
|
|
84
|
+
inputRef?.current?.focus();
|
|
85
|
+
}, 100);
|
|
86
|
+
}
|
|
87
|
+
})]
|
|
88
|
+
}), jsx(CopyButton, {
|
|
89
|
+
content: copyPayload
|
|
90
|
+
}), jsx(Button, {
|
|
91
|
+
size: "icon",
|
|
92
|
+
variant: "ghost",
|
|
93
|
+
onClick: () => {
|
|
94
|
+
if (isLoading) {
|
|
95
|
+
cancel();
|
|
96
|
+
} else if (keepEngaged) {
|
|
97
|
+
setKeepEngaged(false);
|
|
98
|
+
startNewConversation();
|
|
99
|
+
} else {
|
|
100
|
+
reset();
|
|
101
|
+
}
|
|
102
|
+
},
|
|
103
|
+
className: "cursor-pointer",
|
|
104
|
+
title: isLoading ? 'Cancel loading' : keepEngaged ? 'Close and start new conversation' : 'Clear conversation',
|
|
105
|
+
children: jsx(XIcon, {})
|
|
106
|
+
})]
|
|
107
|
+
})]
|
|
108
|
+
}), jsx("div", {
|
|
109
|
+
ref: scrollAreaRef,
|
|
110
|
+
className: cn('min-h-0 flex-1 basis-0 overflow-x-hidden overflow-y-scroll overscroll-contain', 'pr-1 [scrollbar-gutter:stable]'),
|
|
111
|
+
children: jsxs("div", {
|
|
112
|
+
className: "space-y-3 p-4 pb-8",
|
|
113
|
+
children: [error ? jsxs("div", {
|
|
114
|
+
className: "rounded border border-destructive/20 bg-destructive/10 p-3 text-sm text-destructive",
|
|
115
|
+
children: [jsx("strong", {
|
|
116
|
+
children: "Error:"
|
|
117
|
+
}), " ", error]
|
|
118
|
+
}) : null, sortedAsc.map(msg => jsx("div", {
|
|
119
|
+
className: cn('flex w-full', msg.role === 'user' ? 'justify-end' : 'justify-start'),
|
|
120
|
+
children: jsxs("div", {
|
|
121
|
+
className: cn('max-w-[min(100%,40rem)] rounded-xl px-3 py-2 text-sm shadow-sm', msg.role === 'user' ? 'border border-primary/25 bg-primary/15 text-foreground' : 'border border-border/60 bg-muted/70'),
|
|
122
|
+
children: [jsxs("div", {
|
|
123
|
+
className: "mb-1.5 flex items-center gap-2",
|
|
124
|
+
children: [jsx("span", {
|
|
125
|
+
className: "text-[10px] font-semibold uppercase text-muted-foreground",
|
|
126
|
+
children: msg.role === 'user' ? 'You' : 'AI'
|
|
127
|
+
}), jsx("span", {
|
|
128
|
+
className: "text-[10px] text-muted-foreground",
|
|
129
|
+
children: new Date(msg.timestamp).toLocaleTimeString([], {
|
|
130
|
+
hour: '2-digit',
|
|
131
|
+
minute: '2-digit'
|
|
132
|
+
})
|
|
133
|
+
})]
|
|
134
|
+
}), jsx(Markdown, {
|
|
135
|
+
children: msg.content
|
|
136
|
+
}), msg.role === 'assistant' ? jsx(AssistantMessageActions, {
|
|
137
|
+
messageId: msg.id,
|
|
138
|
+
content: msg.content,
|
|
139
|
+
onRegenerate: regenerateAssistantMessage ? id => void regenerateAssistantMessage(id) : undefined
|
|
140
|
+
}) : null]
|
|
141
|
+
})
|
|
142
|
+
}, msg.id)), streamingAssistantVisible ? jsx("div", {
|
|
143
|
+
className: "flex w-full justify-start",
|
|
144
|
+
children: jsxs("div", {
|
|
145
|
+
className: "max-w-[min(100%,40rem)] rounded-xl border border-border/60 bg-muted/70 px-3 py-2 text-sm shadow-sm",
|
|
146
|
+
children: [jsxs("div", {
|
|
147
|
+
className: "mb-1.5 flex items-center gap-2",
|
|
148
|
+
children: [jsx("span", {
|
|
149
|
+
className: "text-[10px] font-semibold uppercase text-muted-foreground",
|
|
150
|
+
children: "AI"
|
|
151
|
+
}), isLoading && !response ? jsx(Loader2, {
|
|
152
|
+
className: "h-3 w-3 animate-spin text-muted-foreground"
|
|
153
|
+
}) : null]
|
|
154
|
+
}), response ? jsx(Markdown, {
|
|
155
|
+
children: response
|
|
156
|
+
}) : isLoading ? jsx("p", {
|
|
157
|
+
className: "text-sm text-muted-foreground",
|
|
158
|
+
children: "Generating response\u2026"
|
|
159
|
+
}) : null, response ? jsx(AssistantMessageActions, {
|
|
160
|
+
messageId: "streaming",
|
|
161
|
+
content: response,
|
|
162
|
+
visibility: {
|
|
163
|
+
regenerate: false
|
|
164
|
+
}
|
|
165
|
+
}) : null]
|
|
166
|
+
})
|
|
167
|
+
}) : null]
|
|
168
|
+
})
|
|
169
|
+
})]
|
|
170
|
+
}), jsx(PopoverTrigger, {
|
|
171
|
+
asChild: true,
|
|
172
|
+
children: jsxs(AIToolbarInputSurface, {
|
|
173
|
+
className: "relative select-none",
|
|
174
|
+
children: [jsx(Input$1, {
|
|
175
|
+
ref: inputRef,
|
|
176
|
+
placeholder: "Ask me anything...",
|
|
177
|
+
value: input,
|
|
178
|
+
onChange: e => setInput(e.target.value),
|
|
179
|
+
onKeyPress: handleKeyPress,
|
|
180
|
+
onPaste: handlePaste,
|
|
181
|
+
disabled: isLoading || isHidden,
|
|
182
|
+
className: cn('h-9 flex-1 border-0 bg-transparent shadow-none outline-none ring-0 ring-offset-0 focus-visible:outline-none focus-visible:ring-0 focus-visible:ring-offset-0 dark:bg-transparent', currentConversationId && conversationHistory.length > 0 ? 'pr-14' : isLoading ? 'pr-10' : isHidden ? 'pr-2' : 'pr-10')
|
|
183
|
+
}), currentConversationId && conversationHistory.length > 0 && !isLoading ? jsx("div", {
|
|
184
|
+
className: "absolute right-1 top-1/2 flex -translate-y-1/2 select-none items-center gap-1",
|
|
185
|
+
children: jsx(MessageHistory, {
|
|
186
|
+
conversationHistory: conversationHistory,
|
|
187
|
+
currentConversationId: currentConversationId,
|
|
188
|
+
onStartNewConversation: startNewConversation,
|
|
189
|
+
messageHistoryOpen: messageHistoryOpen,
|
|
190
|
+
setMessageHistoryOpen: setMessageHistoryOpen
|
|
191
|
+
})
|
|
192
|
+
}) : null, isLoading ? jsx("div", {
|
|
193
|
+
className: "absolute right-3 top-1/2 -translate-y-1/2 animate-pulse",
|
|
194
|
+
children: jsx(Loader2, {
|
|
195
|
+
className: "h-4 w-4 animate-spin text-muted-foreground"
|
|
196
|
+
})
|
|
197
|
+
}) : null]
|
|
198
|
+
})
|
|
199
|
+
})]
|
|
200
|
+
})
|
|
201
|
+
});
|
|
202
|
+
};export{Input};//# sourceMappingURL=Input.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Input.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { ChatMessage } from '../types';
|
|
2
|
+
interface MessageHistoryProps {
|
|
3
|
+
conversationHistory: ChatMessage[];
|
|
4
|
+
currentConversationId: string | null;
|
|
5
|
+
onStartNewConversation: () => void;
|
|
6
|
+
messageHistoryOpen: boolean;
|
|
7
|
+
setMessageHistoryOpen: (open: boolean) => void;
|
|
8
|
+
}
|
|
9
|
+
export declare const MessageHistory: ({ conversationHistory, onStartNewConversation, messageHistoryOpen, setMessageHistoryOpen, }: MessageHistoryProps) => import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=MessageHistory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MessageHistory.d.ts","sourceRoot":"","sources":["../../../../../src/components/AIToolbar/components/completion/MessageHistory.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAG5C,UAAU,mBAAmB;IACzB,mBAAmB,EAAE,WAAW,EAAE,CAAC;IACnC,qBAAqB,EAAE,MAAM,GAAG,IAAI,CAAC;IACrC,sBAAsB,EAAE,MAAM,IAAI,CAAC;IACnC,kBAAkB,EAAE,OAAO,CAAC;IAC5B,qBAAqB,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;CAClD;AAED,eAAO,MAAM,cAAc,GAAI,6FAK5B,mBAAmB,4CA2FrB,CAAC"}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import {jsxs,jsx}from'react/jsx-runtime';import {MessageSquareText,ChevronUp,ChevronDown}from'lucide-react';import'../../../../shardui/accordion.js';import'../../../../shardui/alert.js';import'../../../../shardui/alert-dialog.js';import'@radix-ui/react-aspect-ratio';import'../../../../shardui/avatar.js';import'../../../../shardui/badge.js';import'../../../../shardui/breadcrumb.js';import {Button}from'../../../../shardui/button.js';import'../../../../shardui/calendar.js';import'../../../../shardui/card.js';import'../../../../shardui/carousel.js';import'../../../../shardui/chart.js';import'../../../../shardui/checkbox.js';import'@radix-ui/react-collapsible';import'../../../../shardui/command.js';import'../../../../shardui/context-menu.js';import'../../../../shardui/dialog.js';import'../../../../shardui/drawer.js';import'../../../../shardui/dropdown-menu.js';import'../../../../shardui/form.js';import'../../../../shardui/hover-card.js';import'../../../../shardui/input.js';import'../../../../shardui/input-otp.js';import'../../../../shardui/label.js';import'../../../../shardui/menubar.js';import'../../../../shardui/navigation-menu.js';import'../../../../shardui/pagination.js';import {Popover,PopoverTrigger,PopoverContent}from'../../../../shardui/popover.js';import'../../../../shardui/progress.js';import'../../../../shardui/radio-group.js';import'react-resizable-panels';import'../../../../utils/isBrowser/index.js';import'clsx';import'tailwind-merge';import'react';import'fast-deep-equal/react.js';import {ScrollArea}from'../../../../shardui/scroll-area.js';import'../../../../shardui/select.js';import'../../../../shardui/separator.js';import'../../../../shardui/sheet.js';import'../../../../shardui/sidebar.js';import'../../../../shardui/slider.js';import'../../../ThemeProvider/ThemeProvider.js';import'sonner';import'../../../../shardui/switch.js';import'../../../../shardui/table.js';import'../../../../shardui/tabs.js';import'../../../../shardui/textarea.js';import'../../../../shardui/toast.js';import'../../../../shardui/toggle.js';import'../../../../shardui/toggle-group.js';import'../../../../shardui/tooltip.js';import {Markdown}from'../Markdown/index.js';const MessageHistory = ({
|
|
2
|
+
conversationHistory,
|
|
3
|
+
onStartNewConversation,
|
|
4
|
+
messageHistoryOpen,
|
|
5
|
+
setMessageHistoryOpen
|
|
6
|
+
}) => {
|
|
7
|
+
return jsxs(Popover, {
|
|
8
|
+
open: messageHistoryOpen,
|
|
9
|
+
onOpenChange: setMessageHistoryOpen,
|
|
10
|
+
children: [jsx(PopoverTrigger, {
|
|
11
|
+
asChild: true,
|
|
12
|
+
children: jsxs(Button, {
|
|
13
|
+
size: "icon",
|
|
14
|
+
variant: "outline",
|
|
15
|
+
"aria-label": "View Current Conversation",
|
|
16
|
+
className: "relative cursor-pointer w-12 h-7 px-2 bg-transparent flex gap-1 items-center justify-center",
|
|
17
|
+
children: [jsx("div", {
|
|
18
|
+
className: "flex items-center justify-center text-xs font-medium",
|
|
19
|
+
children: conversationHistory.length
|
|
20
|
+
}), jsx(MessageSquareText, {
|
|
21
|
+
className: "h-5 w-5"
|
|
22
|
+
})]
|
|
23
|
+
})
|
|
24
|
+
}), jsxs(PopoverContent, {
|
|
25
|
+
align: "end",
|
|
26
|
+
side: "bottom",
|
|
27
|
+
className: "z-[200] select-none w-screen max-h-[min(90vh,calc(100vh-1rem))] p-0 mt-3 border overflow-hidden border-input/50",
|
|
28
|
+
children: [jsx("div", {
|
|
29
|
+
className: "border-b border-input/50 p-4",
|
|
30
|
+
children: jsxs("div", {
|
|
31
|
+
className: "flex items-center justify-between",
|
|
32
|
+
children: [jsxs("div", {
|
|
33
|
+
className: "flex items-center flex-col",
|
|
34
|
+
children: [jsx("h2", {
|
|
35
|
+
className: "text-lg font-bold bg-gradient-to-r from-primary to-primary/70 bg-clip-text text-transparent",
|
|
36
|
+
children: "Current Conversation"
|
|
37
|
+
}), jsxs("p", {
|
|
38
|
+
className: "text-xs text-muted-foreground",
|
|
39
|
+
children: [conversationHistory.length, " messages in this conversation"]
|
|
40
|
+
})]
|
|
41
|
+
}), jsxs("div", {
|
|
42
|
+
className: "flex items-center gap-2",
|
|
43
|
+
children: [jsx(Button, {
|
|
44
|
+
size: "sm",
|
|
45
|
+
onClick: () => {
|
|
46
|
+
onStartNewConversation();
|
|
47
|
+
setMessageHistoryOpen(false);
|
|
48
|
+
},
|
|
49
|
+
className: "text-xs",
|
|
50
|
+
children: "New Chat"
|
|
51
|
+
}), jsx(Button, {
|
|
52
|
+
size: "sm",
|
|
53
|
+
variant: "ghost",
|
|
54
|
+
onClick: () => setMessageHistoryOpen(false),
|
|
55
|
+
className: "text-xs",
|
|
56
|
+
children: messageHistoryOpen ? jsx(ChevronUp, {
|
|
57
|
+
className: "h-4 w-4"
|
|
58
|
+
}) : jsx(ChevronDown, {
|
|
59
|
+
className: "h-4 w-4"
|
|
60
|
+
})
|
|
61
|
+
})]
|
|
62
|
+
})]
|
|
63
|
+
})
|
|
64
|
+
}), jsx(ScrollArea, {
|
|
65
|
+
className: "h-[calc(100vh-10rem)]",
|
|
66
|
+
children: jsx("div", {
|
|
67
|
+
className: "p-4 space-y-4",
|
|
68
|
+
children: conversationHistory.sort((a, b) => b?.timestamp - a?.timestamp).map(message => jsxs("div", {
|
|
69
|
+
className: `p-3 rounded-lg ${message.role === 'user' ? 'bg-primary/10 border-l-4 border-primary' : 'bg-muted/50'}`,
|
|
70
|
+
children: [jsxs("div", {
|
|
71
|
+
className: "flex items-center gap-2 mb-2",
|
|
72
|
+
children: [jsx("span", {
|
|
73
|
+
className: "text-xs font-medium text-muted-foreground uppercase",
|
|
74
|
+
children: message.role === 'user' ? 'You' : 'AI'
|
|
75
|
+
}), jsx("span", {
|
|
76
|
+
className: "text-xs text-muted-foreground",
|
|
77
|
+
children: new Date(message.timestamp).toLocaleTimeString([], {
|
|
78
|
+
hour: '2-digit',
|
|
79
|
+
minute: '2-digit'
|
|
80
|
+
})
|
|
81
|
+
})]
|
|
82
|
+
}), jsx(Markdown, {
|
|
83
|
+
children: message.content
|
|
84
|
+
})]
|
|
85
|
+
}, message.id))
|
|
86
|
+
})
|
|
87
|
+
})]
|
|
88
|
+
})]
|
|
89
|
+
});
|
|
90
|
+
};export{MessageHistory};//# sourceMappingURL=MessageHistory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MessageHistory.js","sources":["../../../../../src/components/AIToolbar/components/completion/MessageHistory.tsx"],"sourcesContent":[null],"names":[],"mappings":"uoEAQI,MAAA,cAAsB,GAAE,CAAA;qBACxB;AACA,EAAA,sBAAA;AACH,EAAA,kBAAA;AAED,EAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { UseCompletionReturn } from '../types';
|
|
2
|
+
export declare const Screenshot: ({ screenshotConfiguration, attachedFiles, isLoading, captureScreenshot, isScreenshotLoading, supportsImages, maxFiles, }: UseCompletionReturn & {
|
|
3
|
+
supportsImages?: boolean;
|
|
4
|
+
maxFiles?: number;
|
|
5
|
+
}) => import("react/jsx-runtime").JSX.Element;
|
|
6
|
+
//# sourceMappingURL=Screenshot.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Screenshot.d.ts","sourceRoot":"","sources":["../../../../../src/components/AIToolbar/components/completion/Screenshot.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAI/C,eAAO,MAAM,UAAU,GAAI,0HAQxB,mBAAmB,GAAG;IAAE,cAAc,CAAC,EAAE,OAAO,CAAC;IAAC,QAAQ,CAAC,EAAE,MAAM,CAAA;CAAE,4CA2BvE,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import {jsx}from'react/jsx-runtime';import'../../../../shardui/accordion.js';import'../../../../shardui/alert.js';import'../../../../shardui/alert-dialog.js';import'@radix-ui/react-aspect-ratio';import'../../../../shardui/avatar.js';import'../../../../shardui/badge.js';import'../../../../shardui/breadcrumb.js';import {Button}from'../../../../shardui/button.js';import'../../../../shardui/calendar.js';import'../../../../shardui/card.js';import'../../../../shardui/carousel.js';import'../../../../shardui/chart.js';import'../../../../shardui/checkbox.js';import'@radix-ui/react-collapsible';import'../../../../shardui/command.js';import'../../../../shardui/context-menu.js';import'../../../../shardui/dialog.js';import'../../../../shardui/drawer.js';import'../../../../shardui/dropdown-menu.js';import'../../../../shardui/form.js';import'../../../../shardui/hover-card.js';import'../../../../shardui/input.js';import'../../../../shardui/input-otp.js';import'../../../../shardui/label.js';import'../../../../shardui/menubar.js';import'../../../../shardui/navigation-menu.js';import'../../../../shardui/pagination.js';import'../../../../shardui/popover.js';import'../../../../shardui/progress.js';import'../../../../shardui/radio-group.js';import {Loader2,LaptopMinimalIcon,MousePointer2Icon}from'lucide-react';import'react-resizable-panels';import'../../../../utils/isBrowser/index.js';import'clsx';import'tailwind-merge';import'react';import'fast-deep-equal/react.js';import'../../../../shardui/scroll-area.js';import'../../../../shardui/select.js';import'../../../../shardui/separator.js';import'../../../../shardui/sheet.js';import'../../../../shardui/sidebar.js';import'../../../../shardui/slider.js';import'../../../ThemeProvider/ThemeProvider.js';import'sonner';import'../../../../shardui/switch.js';import'../../../../shardui/table.js';import'../../../../shardui/tabs.js';import'../../../../shardui/textarea.js';import'../../../../shardui/toast.js';import'../../../../shardui/toggle.js';import'../../../../shardui/toggle-group.js';import'../../../../shardui/tooltip.js';const DEFAULT_MAX_FILES = 10;
|
|
2
|
+
const Screenshot = ({
|
|
3
|
+
screenshotConfiguration,
|
|
4
|
+
attachedFiles,
|
|
5
|
+
isLoading,
|
|
6
|
+
captureScreenshot,
|
|
7
|
+
isScreenshotLoading,
|
|
8
|
+
supportsImages,
|
|
9
|
+
maxFiles = DEFAULT_MAX_FILES
|
|
10
|
+
}) => {
|
|
11
|
+
const captureMode = screenshotConfiguration.enabled ? 'Screenshot' : 'Selection';
|
|
12
|
+
const processingMode = screenshotConfiguration.mode;
|
|
13
|
+
const isDisabled = attachedFiles.length >= maxFiles || isLoading || isScreenshotLoading || supportsImages === false;
|
|
14
|
+
return jsx(Button, {
|
|
15
|
+
size: "icon",
|
|
16
|
+
className: "cursor-pointer",
|
|
17
|
+
title: supportsImages === false ? 'Screenshot not supported by current AI provider' : `${captureMode} mode (${processingMode}) - ${attachedFiles.length}/${maxFiles} files`,
|
|
18
|
+
onClick: captureScreenshot,
|
|
19
|
+
disabled: isDisabled,
|
|
20
|
+
children: isScreenshotLoading ? jsx(Loader2, {
|
|
21
|
+
className: "h-4 w-4 animate-spin"
|
|
22
|
+
}) : screenshotConfiguration.enabled ? jsx(LaptopMinimalIcon, {
|
|
23
|
+
className: "h-4 w-4"
|
|
24
|
+
}) : jsx(MousePointer2Icon, {
|
|
25
|
+
className: "h-4 w-4"
|
|
26
|
+
})
|
|
27
|
+
});
|
|
28
|
+
};export{Screenshot};//# sourceMappingURL=Screenshot.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Screenshot.js","sources":["../../../../../src/components/AIToolbar/components/completion/Screenshot.tsx"],"sourcesContent":[null],"names":[],"mappings":"miEAcqD,iBAAiB,GAAA,EAAA;AAAE,MAAA,UAAA,GAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { UseCompletionReturn } from '../types';
|
|
2
|
+
export { AssistantMessageActions, type AssistantMessageActionsProps, type AssistantMessageVote, } from './AssistantMessageActions';
|
|
3
|
+
export type CompletionProps = {
|
|
4
|
+
/** Wired from the host completion hook. */
|
|
5
|
+
completion: UseCompletionReturn;
|
|
6
|
+
isHidden: boolean;
|
|
7
|
+
/** When true, paperclip + screenshot attach UI are enabled (from host; default true in {@link AIToolBar}). */
|
|
8
|
+
supportsImages?: boolean;
|
|
9
|
+
};
|
|
10
|
+
export declare const Completion: ({ completion, isHidden, supportsImages }: CompletionProps) => import("react/jsx-runtime").JSX.Element;
|
|
11
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/AIToolbar/components/completion/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAMpD,OAAO,EACH,uBAAuB,EACvB,KAAK,4BAA4B,EACjC,KAAK,oBAAoB,GAC5B,MAAM,2BAA2B,CAAC;AAEnC,MAAM,MAAM,eAAe,GAAG;IAC1B,2CAA2C;IAC3C,UAAU,EAAE,mBAAmB,CAAC;IAChC,QAAQ,EAAE,OAAO,CAAC;IAClB,8GAA8G;IAC9G,cAAc,CAAC,EAAE,OAAO,CAAC;CAC5B,CAAC;AAEF,eAAO,MAAM,UAAU,GAAI,0CAAiD,eAAe,4CAS1F,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import {jsxs,Fragment,jsx}from'react/jsx-runtime';import {Screenshot}from'./Screenshot.js';import {Files}from'./Files.js';import {Audio}from'./Audio.js';import {Input}from'./Input.js';import'react';import'lucide-react';import'../../../../shardui/accordion.js';import'../../../../shardui/alert.js';import'../../../../shardui/alert-dialog.js';import'@radix-ui/react-aspect-ratio';import'../../../../shardui/avatar.js';import'../../../../shardui/badge.js';import'../../../../shardui/breadcrumb.js';import'../../../../shardui/button.js';import'../../../../shardui/calendar.js';import'../../../../shardui/card.js';import'../../../../shardui/carousel.js';import'../../../../shardui/chart.js';import'../../../../shardui/checkbox.js';import'@radix-ui/react-collapsible';import'../../../../shardui/command.js';import'../../../../shardui/context-menu.js';import'../../../../shardui/dialog.js';import'../../../../shardui/drawer.js';import'../../../../shardui/dropdown-menu.js';import'../../../../shardui/form.js';import'../../../../shardui/hover-card.js';import'../../../../shardui/input.js';import'../../../../shardui/input-otp.js';import'../../../../shardui/label.js';import'../../../../shardui/menubar.js';import'../../../../shardui/navigation-menu.js';import'../../../../shardui/pagination.js';import'../../../../shardui/popover.js';import'../../../../shardui/progress.js';import'../../../../shardui/radio-group.js';import'react-resizable-panels';import'../../../../utils/isBrowser/index.js';import'clsx';import'tailwind-merge';import'fast-deep-equal/react.js';import'../../../../shardui/scroll-area.js';import'../../../../shardui/select.js';import'../../../../shardui/separator.js';import'../../../../shardui/sheet.js';import'../../../../shardui/sidebar.js';import'../../../../shardui/slider.js';import'../../../ThemeProvider/ThemeProvider.js';import'sonner';import'../../../../shardui/switch.js';import'../../../../shardui/table.js';import'../../../../shardui/tabs.js';import'../../../../shardui/textarea.js';import'../../../../shardui/toast.js';import'../../../../shardui/toggle.js';import'../../../../shardui/toggle-group.js';import'../../../../shardui/tooltip.js';const Completion = ({
|
|
2
|
+
completion,
|
|
3
|
+
isHidden,
|
|
4
|
+
supportsImages = true
|
|
5
|
+
}) => {
|
|
6
|
+
return jsxs(Fragment, {
|
|
7
|
+
children: [jsx(Audio, {
|
|
8
|
+
...completion
|
|
9
|
+
}), jsx(Input, {
|
|
10
|
+
...completion,
|
|
11
|
+
isHidden: isHidden
|
|
12
|
+
}), jsx(Screenshot, {
|
|
13
|
+
...completion,
|
|
14
|
+
supportsImages: supportsImages
|
|
15
|
+
}), jsx(Files, {
|
|
16
|
+
...completion,
|
|
17
|
+
supportsImages: supportsImages
|
|
18
|
+
})]
|
|
19
|
+
});
|
|
20
|
+
};export{Completion};//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../../src/components/AIToolbar/components/completion/index.tsx"],"sourcesContent":[null],"names":[],"mappings":"knEAgBI,MAAA,UAAA,GAAA,CAAA;YACA;EACF,QAAA;AAEF,EAAA;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export * from './completion';
|
|
2
|
+
export * from './speech';
|
|
3
|
+
export * from './speech/audio-visualizer';
|
|
4
|
+
export * from './speech/StatusIndicator';
|
|
5
|
+
export { AIToolBar, DragButton, type DragButtonProps } from './AIToolBar';
|
|
6
|
+
export { CustomCursor } from './CustomCursor';
|
|
7
|
+
export { Completion } from './completion';
|
|
8
|
+
export { SystemAudio } from './speech';
|
|
9
|
+
export { AudioVisualizer } from './speech/audio-visualizer';
|
|
10
|
+
export { StatusIndicator } from './speech/StatusIndicator';
|
|
11
|
+
export { MessageHistory } from './completion/MessageHistory';
|
|
12
|
+
export { Screenshot } from './completion/Screenshot';
|
|
13
|
+
export { Header } from './speech/Header';
|
|
14
|
+
export { ModeSwitcher } from './speech/ModeSwitcher';
|
|
15
|
+
export { PermissionFlow } from './speech/PermissionFlow';
|
|
16
|
+
export type { PermissionFlowProps } from './speech/PermissionFlow';
|
|
17
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/AIToolbar/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAC;AAC7B,cAAc,UAAU,CAAC;AACzB,cAAc,2BAA2B,CAAC;AAC1C,cAAc,0BAA0B,CAAC;AACzC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,eAAe,EAAE,MAAM,aAAa,CAAC;AAC1E,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AACvC,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,YAAY,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
type Props = {
|
|
2
|
+
setupRequired: boolean;
|
|
3
|
+
setIsPopoverOpen: React.Dispatch<React.SetStateAction<boolean>>;
|
|
4
|
+
resizeWindow: (expanded: boolean) => Promise<void>;
|
|
5
|
+
capturing: boolean;
|
|
6
|
+
isVadMode: boolean;
|
|
7
|
+
isRecording: boolean;
|
|
8
|
+
isProcessing: boolean;
|
|
9
|
+
isAIProcessing: boolean;
|
|
10
|
+
error?: string;
|
|
11
|
+
};
|
|
12
|
+
export declare const Header: ({ setupRequired, capturing, isVadMode, isRecording, isProcessing, isAIProcessing, error, }: Props) => import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=Header.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Header.d.ts","sourceRoot":"","sources":["../../../../../src/components/AIToolbar/components/speech/Header.tsx"],"names":[],"mappings":"AAKA,KAAK,KAAK,GAAG;IACT,aAAa,EAAE,OAAO,CAAC;IACvB,gBAAgB,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC;IAChE,YAAY,EAAE,CAAC,QAAQ,EAAE,OAAO,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACnD,SAAS,EAAE,OAAO,CAAC;IACnB,SAAS,EAAE,OAAO,CAAC;IACnB,WAAW,EAAE,OAAO,CAAC;IACrB,YAAY,EAAE,OAAO,CAAC;IACtB,cAAc,EAAE,OAAO,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAwDF,eAAO,MAAM,MAAM,GAAI,4FAQpB,KAAK,4CA0BP,CAAC"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import {jsx,jsxs}from'react/jsx-runtime';import {AlertCircleIcon,LoaderIcon,MicIcon,AudioWaveformIcon}from'lucide-react';import'../../../../utils/isBrowser/index.js';import {cn}from'../../../../utils/util.js';import'react';import'fast-deep-equal/react.js';const getStatus = (capturing, isVadMode, isRecording, isProcessing, isAIProcessing, error) => {
|
|
2
|
+
if (error) return 'error';
|
|
3
|
+
if (isAIProcessing) return 'ai-processing';
|
|
4
|
+
if (isProcessing) return 'processing';
|
|
5
|
+
if (isRecording) return 'recording';
|
|
6
|
+
if (capturing && isVadMode) return 'listening';
|
|
7
|
+
return 'ready';
|
|
8
|
+
};
|
|
9
|
+
const STATUS_CONFIG = {
|
|
10
|
+
ready: {
|
|
11
|
+
label: 'Ready',
|
|
12
|
+
color: 'text-muted-foreground',
|
|
13
|
+
bgColor: 'bg-muted'
|
|
14
|
+
},
|
|
15
|
+
listening: {
|
|
16
|
+
label: 'Listening',
|
|
17
|
+
color: 'text-teal-600',
|
|
18
|
+
bgColor: 'bg-teal-100',
|
|
19
|
+
icon: jsx(AudioWaveformIcon, {
|
|
20
|
+
className: "w-3 h-3"
|
|
21
|
+
})
|
|
22
|
+
},
|
|
23
|
+
recording: {
|
|
24
|
+
label: 'Recording',
|
|
25
|
+
color: 'text-red-600',
|
|
26
|
+
bgColor: 'bg-red-100',
|
|
27
|
+
icon: jsx(MicIcon, {
|
|
28
|
+
className: "w-3 h-3"
|
|
29
|
+
})
|
|
30
|
+
},
|
|
31
|
+
processing: {
|
|
32
|
+
label: 'Transcribing',
|
|
33
|
+
color: 'text-orange-600',
|
|
34
|
+
bgColor: 'bg-orange-100',
|
|
35
|
+
icon: jsx(LoaderIcon, {
|
|
36
|
+
className: "w-3 h-3 animate-spin"
|
|
37
|
+
})
|
|
38
|
+
},
|
|
39
|
+
'ai-processing': {
|
|
40
|
+
label: 'AI Responding',
|
|
41
|
+
color: 'text-purple-600',
|
|
42
|
+
bgColor: 'bg-purple-100',
|
|
43
|
+
icon: jsx(LoaderIcon, {
|
|
44
|
+
className: "w-3 h-3 animate-spin"
|
|
45
|
+
})
|
|
46
|
+
},
|
|
47
|
+
error: {
|
|
48
|
+
label: 'Error',
|
|
49
|
+
color: 'text-red-600',
|
|
50
|
+
bgColor: 'bg-red-100',
|
|
51
|
+
icon: jsx(AlertCircleIcon, {
|
|
52
|
+
className: "w-3 h-3"
|
|
53
|
+
})
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
const Header = ({
|
|
57
|
+
setupRequired,
|
|
58
|
+
capturing,
|
|
59
|
+
isVadMode,
|
|
60
|
+
isRecording,
|
|
61
|
+
isProcessing,
|
|
62
|
+
isAIProcessing,
|
|
63
|
+
error
|
|
64
|
+
}) => {
|
|
65
|
+
const status = getStatus(capturing, isVadMode, isRecording, isProcessing, isAIProcessing, error);
|
|
66
|
+
const statusConfig = STATUS_CONFIG[status];
|
|
67
|
+
return jsxs("div", {
|
|
68
|
+
children: [jsx("h2", {
|
|
69
|
+
className: "font-semibold text-sm",
|
|
70
|
+
children: setupRequired ? 'Setup Required' : 'Speech Assistant'
|
|
71
|
+
}), !setupRequired && jsxs("div", {
|
|
72
|
+
className: "flex items-center gap-1.5 mt-1",
|
|
73
|
+
children: [jsxs("span", {
|
|
74
|
+
className: cn('inline-flex items-center gap-1 px-2 py-0.5 rounded-full text-[10px] font-medium', statusConfig.bgColor, statusConfig.color),
|
|
75
|
+
children: [statusConfig.icon, statusConfig.label]
|
|
76
|
+
}), jsxs("span", {
|
|
77
|
+
className: "text-[10px] text-muted-foreground",
|
|
78
|
+
children: [isVadMode ? 'Auto-detect' : 'Manual', " mode"]
|
|
79
|
+
})]
|
|
80
|
+
})]
|
|
81
|
+
});
|
|
82
|
+
};export{Header};//# sourceMappingURL=Header.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Header.js","sources":["../../../../../src/components/AIToolbar/components/speech/Header.tsx"],"sourcesContent":[null],"names":[],"mappings":"sQAQI,SAAA,GAAc,CAAC,SAAQ,EAAE,WAAY,WAAQ,EAAK,YAAC,EAAA,cAAA,EAAA,KAAA,KAAA;MACnD,KAAA,EAAS,cAAU;MACnB,gBAAkB,OAAC,eAAA;MACnB,qBAAqB,YAAA;MACrB,WAAY,SAAU,WAAA;MACtB,SAAA,IAAc,SAAU,EAAA,OAAA,WAAA;SACnB,OAAG;CACX;AAwDD,MAAA,gBAAa;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
interface ModeSwitcherProps {
|
|
2
|
+
isVadMode: boolean;
|
|
3
|
+
onModeChange: (vadEnabled: boolean) => void;
|
|
4
|
+
disabled?: boolean;
|
|
5
|
+
}
|
|
6
|
+
export declare const ModeSwitcher: ({ isVadMode, onModeChange, disabled }: ModeSwitcherProps) => import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
export {};
|
|
8
|
+
//# sourceMappingURL=ModeSwitcher.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ModeSwitcher.d.ts","sourceRoot":"","sources":["../../../../../src/components/AIToolbar/components/speech/ModeSwitcher.tsx"],"names":[],"mappings":"AAGA,UAAU,iBAAiB;IACvB,SAAS,EAAE,OAAO,CAAC;IACnB,YAAY,EAAE,CAAC,UAAU,EAAE,OAAO,KAAK,IAAI,CAAC;IAC5C,QAAQ,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,eAAO,MAAM,YAAY,GAAI,uCAA+C,iBAAiB,4CA4C5F,CAAC"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import {jsxs,jsx}from'react/jsx-runtime';import'../../../../utils/isBrowser/index.js';import {cn}from'../../../../utils/util.js';import'react';import'fast-deep-equal/react.js';import {AudioWaveformIcon,MicIcon}from'lucide-react';const ModeSwitcher = ({
|
|
2
|
+
isVadMode,
|
|
3
|
+
onModeChange,
|
|
4
|
+
disabled = false
|
|
5
|
+
}) => {
|
|
6
|
+
return jsxs("div", {
|
|
7
|
+
className: cn('flex bg-muted rounded-lg w-full p-0.5 gap-0.5', disabled && 'opacity-50 pointer-events-none'),
|
|
8
|
+
children: [jsxs("button", {
|
|
9
|
+
type: "button",
|
|
10
|
+
onClick: () => onModeChange(true),
|
|
11
|
+
disabled: disabled,
|
|
12
|
+
className: cn('flex-1 flex items-center justify-center gap-2 px-2.5 py-1.5 rounded-md transition-all', isVadMode ? 'bg-background shadow-sm text-foreground' : 'text-muted-foreground hover:text-foreground'),
|
|
13
|
+
children: [jsx(AudioWaveformIcon, {
|
|
14
|
+
className: "w-4 h-4 flex-shrink-0"
|
|
15
|
+
}), jsxs("div", {
|
|
16
|
+
className: "flex flex-col items-start",
|
|
17
|
+
children: [jsx("span", {
|
|
18
|
+
className: "text-xs font-medium leading-tight",
|
|
19
|
+
children: "Auto-detect"
|
|
20
|
+
}), jsx("span", {
|
|
21
|
+
className: "text-[9px] font-normal opacity-60 leading-tight",
|
|
22
|
+
children: "(voice activity)"
|
|
23
|
+
})]
|
|
24
|
+
})]
|
|
25
|
+
}), jsxs("button", {
|
|
26
|
+
type: "button",
|
|
27
|
+
onClick: () => onModeChange(false),
|
|
28
|
+
disabled: disabled,
|
|
29
|
+
className: cn('flex-1 flex items-center justify-center gap-2 px-2.5 py-1.5 rounded-md transition-all', !isVadMode ? 'bg-background shadow-sm text-foreground' : 'text-muted-foreground hover:text-foreground'),
|
|
30
|
+
children: [jsx(MicIcon, {
|
|
31
|
+
className: "w-4 h-4 flex-shrink-0"
|
|
32
|
+
}), jsxs("div", {
|
|
33
|
+
className: "flex flex-col items-start",
|
|
34
|
+
children: [jsx("span", {
|
|
35
|
+
className: "text-xs font-medium leading-tight",
|
|
36
|
+
children: "Manual"
|
|
37
|
+
}), jsx("span", {
|
|
38
|
+
className: "text-[9px] font-normal opacity-60 leading-tight",
|
|
39
|
+
children: "(press to record)"
|
|
40
|
+
})]
|
|
41
|
+
})]
|
|
42
|
+
})]
|
|
43
|
+
});
|
|
44
|
+
};export{ModeSwitcher};//# sourceMappingURL=ModeSwitcher.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ModeSwitcher.js","sources":["../../../../../src/components/AIToolbar/components/speech/ModeSwitcher.tsx"],"sourcesContent":[null],"names":[],"mappings":"qOAMY,MAAC,YAAU,GAAA,CAAA;AACtB,EAAA,SAAA;AAED,EAAA,YAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export interface PermissionFlowProps {
|
|
2
|
+
onPermissionGranted: () => void;
|
|
3
|
+
onPermissionDenied: () => void;
|
|
4
|
+
checkAccess: () => Promise<boolean>;
|
|
5
|
+
requestAccess: () => Promise<void>;
|
|
6
|
+
/**
|
|
7
|
+
* When false (legacy): show “Grant Permission” after check fails.
|
|
8
|
+
* When true (default): call `requestAccess` immediately so the OS/browser sheet opens without an extra tap.
|
|
9
|
+
*/
|
|
10
|
+
requestPermissionImmediately?: boolean;
|
|
11
|
+
}
|
|
12
|
+
export declare const PermissionFlow: ({ onPermissionGranted, onPermissionDenied, checkAccess, requestAccess, requestPermissionImmediately, }: PermissionFlowProps) => import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
//# sourceMappingURL=PermissionFlow.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PermissionFlow.d.ts","sourceRoot":"","sources":["../../../../../src/components/AIToolbar/components/speech/PermissionFlow.tsx"],"names":[],"mappings":"AAKA,MAAM,WAAW,mBAAmB;IAChC,mBAAmB,EAAE,MAAM,IAAI,CAAC;IAChC,kBAAkB,EAAE,MAAM,IAAI,CAAC;IAC/B,WAAW,EAAE,MAAM,OAAO,CAAC,OAAO,CAAC,CAAC;IACpC,aAAa,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IACnC;;;OAGG;IACH,4BAA4B,CAAC,EAAE,OAAO,CAAC;CAC1C;AAID,eAAO,MAAM,cAAc,GAAI,wGAM5B,mBAAmB,4CA2JrB,CAAC"}
|