@parhelia/core 0.1.12788 → 0.1.12790
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/dist/agents-view/AgentCard.d.ts +6 -2
- package/dist/agents-view/AgentCard.js +79 -147
- package/dist/agents-view/AgentCard.js.map +1 -1
- package/dist/agents-view/AgentsSidebar.d.ts +4 -9
- package/dist/agents-view/AgentsSidebar.js +10 -13
- package/dist/agents-view/AgentsSidebar.js.map +1 -1
- package/dist/agents-view/AgentsTitlebar.d.ts +3 -3
- package/dist/agents-view/AgentsTitlebar.js +10 -7
- package/dist/agents-view/AgentsTitlebar.js.map +1 -1
- package/dist/agents-view/AgentsView.d.ts +20 -7
- package/dist/agents-view/AgentsView.js +79 -255
- package/dist/agents-view/AgentsView.js.map +1 -1
- package/dist/agents-view/AgentsWorkspaceView.d.ts +1 -1
- package/dist/agents-view/AgentsWorkspaceView.js +66 -53
- package/dist/agents-view/AgentsWorkspaceView.js.map +1 -1
- package/dist/agents-view/DateAgentsGroup.d.ts +17 -0
- package/dist/agents-view/DateAgentsGroup.js +8 -0
- package/dist/agents-view/DateAgentsGroup.js.map +1 -0
- package/dist/agents-view/ProfileAgentsGroup.d.ts +2 -2
- package/dist/agents-view/ProfileAgentsGroup.js +9 -5
- package/dist/agents-view/ProfileAgentsGroup.js.map +1 -1
- package/dist/agents-view/agentsNavStore.d.ts +8 -0
- package/dist/agents-view/agentsNavStore.js +24 -0
- package/dist/agents-view/agentsNavStore.js.map +1 -0
- package/dist/components/PageHeader.d.ts +5 -1
- package/dist/components/PageHeader.js +2 -2
- package/dist/components/PageHeader.js.map +1 -1
- package/dist/components/ui/LanguageSelector.d.ts +3 -1
- package/dist/components/ui/LanguageSelector.js +8 -4
- package/dist/components/ui/LanguageSelector.js.map +1 -1
- package/dist/components/ui/PlaceholderInput.d.ts +0 -8
- package/dist/components/ui/PlaceholderInput.js +1 -42
- package/dist/components/ui/PlaceholderInput.js.map +1 -1
- package/dist/components/ui/PlaceholderInputParser.d.ts +9 -0
- package/dist/components/ui/PlaceholderInputParser.js +98 -0
- package/dist/components/ui/PlaceholderInputParser.js.map +1 -0
- package/dist/components/ui/PlaceholderInputTypes.d.ts +1 -1
- package/dist/components/ui/UserPicker.d.ts +34 -0
- package/dist/components/ui/UserPicker.js +73 -0
- package/dist/components/ui/UserPicker.js.map +1 -0
- package/dist/components/ui/copy-button.js +2 -1
- package/dist/components/ui/copy-button.js.map +1 -1
- package/dist/components/ui/popover.js +22 -4
- package/dist/components/ui/popover.js.map +1 -1
- package/dist/components/ui/select.js +1 -2
- package/dist/components/ui/select.js.map +1 -1
- package/dist/config/config.js +15 -2
- package/dist/config/config.js.map +1 -1
- package/dist/editor/ContentTree.d.ts +14 -1
- package/dist/editor/ContentTree.js +69 -19
- package/dist/editor/ContentTree.js.map +1 -1
- package/dist/editor/Editor.js +5 -8
- package/dist/editor/Editor.js.map +1 -1
- package/dist/editor/EditorLoadingOverlay.d.ts +1 -0
- package/dist/editor/EditorLoadingOverlay.js +7 -0
- package/dist/editor/EditorLoadingOverlay.js.map +1 -0
- package/dist/editor/FieldActionsOverlay.js +31 -4
- package/dist/editor/FieldActionsOverlay.js.map +1 -1
- package/dist/editor/FieldListField.js +6 -1
- package/dist/editor/FieldListField.js.map +1 -1
- package/dist/editor/GlobalMenuBar.js +9 -6
- package/dist/editor/GlobalMenuBar.js.map +1 -1
- package/dist/editor/ai/AgentSharingSection.js +15 -2
- package/dist/editor/ai/AgentSharingSection.js.map +1 -1
- package/dist/editor/ai/Agents.js +2 -3
- package/dist/editor/ai/Agents.js.map +1 -1
- package/dist/editor/ai/InlineAiDialog.d.ts +5 -0
- package/dist/editor/ai/InlineAiDialog.js +77 -64
- package/dist/editor/ai/InlineAiDialog.js.map +1 -1
- package/dist/editor/ai/InlineAiTrigger.js +4 -0
- package/dist/editor/ai/InlineAiTrigger.js.map +1 -1
- package/dist/editor/ai/agentTodoExtraction.d.ts +7 -1
- package/dist/editor/ai/agentTodoExtraction.js +33 -0
- package/dist/editor/ai/agentTodoExtraction.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentDocumentList.d.ts +13 -0
- package/dist/editor/ai/terminal/components/AgentDocumentList.js +61 -46
- package/dist/editor/ai/terminal/components/AgentDocumentList.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentProfileModelSettingsSection.d.ts +4 -3
- package/dist/editor/ai/terminal/components/AgentProfileModelSettingsSection.js +6 -9
- package/dist/editor/ai/terminal/components/AgentProfileModelSettingsSection.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentPromptInputArea.d.ts +10 -2
- package/dist/editor/ai/terminal/components/AgentPromptInputArea.js +42 -9
- package/dist/editor/ai/terminal/components/AgentPromptInputArea.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentPromptTrayPopovers.d.ts +19 -0
- package/dist/editor/ai/terminal/components/AgentPromptTrayPopovers.js +71 -0
- package/dist/editor/ai/terminal/components/AgentPromptTrayPopovers.js.map +1 -0
- package/dist/editor/ai/terminal/components/AgentSettingsContent.d.ts +4 -3
- package/dist/editor/ai/terminal/components/AgentSettingsContent.js +2 -2
- package/dist/editor/ai/terminal/components/AgentSettingsContent.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentTerminalContextChrome.d.ts +2 -0
- package/dist/editor/ai/terminal/components/AgentTerminalContextChrome.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentTerminalContextPanels.js +4 -2
- package/dist/editor/ai/terminal/components/AgentTerminalContextPanels.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentTerminalFullLayout.d.ts +3 -1
- package/dist/editor/ai/terminal/components/AgentTerminalFullLayout.js +2 -2
- package/dist/editor/ai/terminal/components/AgentTerminalFullLayout.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentTerminalFullPromptControls.d.ts +1 -1
- package/dist/editor/ai/terminal/components/AgentTerminalFullPromptControls.js +2 -2
- package/dist/editor/ai/terminal/components/AgentTerminalFullPromptControls.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentTerminalFullUpperContent.d.ts +5 -1
- package/dist/editor/ai/terminal/components/AgentTerminalFullUpperContent.js +2 -2
- package/dist/editor/ai/terminal/components/AgentTerminalFullUpperContent.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentTerminalStatusBar.d.ts +2 -1
- package/dist/editor/ai/terminal/components/AgentTerminalStatusBar.js +2 -2
- package/dist/editor/ai/terminal/components/AgentTerminalStatusBar.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentTerminalView.d.ts +2 -1
- package/dist/editor/ai/terminal/components/AgentTerminalView.js +7 -2
- package/dist/editor/ai/terminal/components/AgentTerminalView.js.map +1 -1
- package/dist/editor/ai/terminal/components/ContextInfoBar.d.ts +3 -1
- package/dist/editor/ai/terminal/components/ContextInfoBar.js +12 -3
- package/dist/editor/ai/terminal/components/ContextInfoBar.js.map +1 -1
- package/dist/editor/ai/terminal/components/EditOperationsPanel.d.ts +3 -1
- package/dist/editor/ai/terminal/components/EditOperationsPanel.js +13 -2
- package/dist/editor/ai/terminal/components/EditOperationsPanel.js.map +1 -1
- package/dist/editor/ai/terminal/components/QueuedPromptsPanel.d.ts +5 -1
- package/dist/editor/ai/terminal/components/QueuedPromptsPanel.js +12 -12
- package/dist/editor/ai/terminal/components/QueuedPromptsPanel.js.map +1 -1
- package/dist/editor/ai/terminal/components/SpawnedAgentsPanel.d.ts +2 -1
- package/dist/editor/ai/terminal/components/SpawnedAgentsPanel.js +18 -14
- package/dist/editor/ai/terminal/components/SpawnedAgentsPanel.js.map +1 -1
- package/dist/editor/ai/terminal/components/TodoListPanel.d.ts +2 -1
- package/dist/editor/ai/terminal/components/TodoListPanel.js +10 -6
- package/dist/editor/ai/terminal/components/TodoListPanel.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentPromptComposerSurface.d.ts +3 -2
- package/dist/editor/ai/terminal/useAgentSessionSync.d.ts +9 -1
- package/dist/editor/ai/terminal/useAgentSessionSync.js +7 -1
- package/dist/editor/ai/terminal/useAgentSessionSync.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentSettingsNavigation.d.ts +3 -2
- package/dist/editor/ai/terminal/useAgentSettingsNavigation.js +3 -21
- package/dist/editor/ai/terminal/useAgentSettingsNavigation.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentSettingsPanel.d.ts +3 -2
- package/dist/editor/ai/terminal/useAgentSettingsPanel.js +1 -2
- package/dist/editor/ai/terminal/useAgentSettingsPanel.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentSettingsSelectOptions.js +2 -2
- package/dist/editor/ai/terminal/useAgentSettingsSelectOptions.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentStatusBarContent.js +1 -1
- package/dist/editor/ai/terminal/useAgentStatusBarContent.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentSubmitHandlers.d.ts +2 -1
- package/dist/editor/ai/terminal/useAgentSubmitHandlers.js +122 -2
- package/dist/editor/ai/terminal/useAgentSubmitHandlers.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentSubmitLifecycle.d.ts +1 -0
- package/dist/editor/ai/terminal/useAgentSubmitLifecycle.js +2 -1
- package/dist/editor/ai/terminal/useAgentSubmitLifecycle.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentSubmitResponseHandler.js +1 -0
- package/dist/editor/ai/terminal/useAgentSubmitResponseHandler.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentTerminalActions.d.ts +6 -5
- package/dist/editor/ai/terminal/useAgentTerminalActions.js +3 -10
- package/dist/editor/ai/terminal/useAgentTerminalActions.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentTerminalController.js +45 -6
- package/dist/editor/ai/terminal/useAgentTerminalController.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentTerminalViewProps.d.ts +1 -0
- package/dist/editor/ai/terminal/useAgentTerminalViewProps.js +2 -1
- package/dist/editor/ai/terminal/useAgentTerminalViewProps.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentTextareaDropHandlers.d.ts +25 -0
- package/dist/editor/ai/terminal/useAgentTextareaDropHandlers.js +187 -0
- package/dist/editor/ai/terminal/useAgentTextareaDropHandlers.js.map +1 -0
- package/dist/editor/client/AboutDialog.js +2 -1
- package/dist/editor/client/AboutDialog.js.map +1 -1
- package/dist/editor/client/EditorShell.js +118 -30
- package/dist/editor/client/EditorShell.js.map +1 -1
- package/dist/editor/client/editContext.d.ts +4 -1
- package/dist/editor/client/editContext.js.map +1 -1
- package/dist/editor/client/fieldModificationStore.d.ts +5 -2
- package/dist/editor/client/fieldModificationStore.js +31 -21
- package/dist/editor/client/fieldModificationStore.js.map +1 -1
- package/dist/editor/client/hooks/useEditorWebSocket.js +0 -47
- package/dist/editor/client/hooks/useEditorWebSocket.js.map +1 -1
- package/dist/editor/client/hooks/useSocketMessageHandler.d.ts +1 -0
- package/dist/editor/client/hooks/useSocketMessageHandler.js +47 -49
- package/dist/editor/client/hooks/useSocketMessageHandler.js.map +1 -1
- package/dist/editor/client/itemsRepository.d.ts +8 -5
- package/dist/editor/client/itemsRepository.js +30 -37
- package/dist/editor/client/itemsRepository.js.map +1 -1
- package/dist/editor/client/operations.d.ts +8 -1
- package/dist/editor/client/operations.js +29 -9
- package/dist/editor/client/operations.js.map +1 -1
- package/dist/editor/client/ui/EditorChrome.js +7 -1
- package/dist/editor/client/ui/EditorChrome.js.map +1 -1
- package/dist/editor/commands/createVersionCommand.js +8 -2
- package/dist/editor/commands/createVersionCommand.js.map +1 -1
- package/dist/editor/field-types/DropLinkEditor.js +4 -1
- package/dist/editor/field-types/DropLinkEditor.js.map +1 -1
- package/dist/editor/field-types/MultiLineText.js +3 -1
- package/dist/editor/field-types/MultiLineText.js.map +1 -1
- package/dist/editor/field-types/NameValueListEditor.js +4 -1
- package/dist/editor/field-types/NameValueListEditor.js.map +1 -1
- package/dist/editor/field-types/PictureFieldEditor.js +8 -4
- package/dist/editor/field-types/PictureFieldEditor.js.map +1 -1
- package/dist/editor/field-types/RichTextEditorComponent.js +6 -2
- package/dist/editor/field-types/RichTextEditorComponent.js.map +1 -1
- package/dist/editor/field-types/SingleLineText.js +3 -1
- package/dist/editor/field-types/SingleLineText.js.map +1 -1
- package/dist/editor/field-types/TreeListEditor.js +6 -1
- package/dist/editor/field-types/TreeListEditor.js.map +1 -1
- package/dist/editor/field-types/richtext/contextMenuFactory.d.ts +2 -1
- package/dist/editor/field-types/richtext/contextMenuFactory.js +7 -5
- package/dist/editor/field-types/richtext/contextMenuFactory.js.map +1 -1
- package/dist/editor/hooks/useNavigationPanelLogic.d.ts +3 -3
- package/dist/editor/hooks/useNavigationPanelLogic.js +5 -5
- package/dist/editor/hooks/useNavigationPanelLogic.js.map +1 -1
- package/dist/editor/menubar/ItemLanguageVersion.d.ts +4 -1
- package/dist/editor/menubar/ItemLanguageVersion.js +11 -3
- package/dist/editor/menubar/ItemLanguageVersion.js.map +1 -1
- package/dist/editor/menubar/VersionPreviewCard.js +26 -6
- package/dist/editor/menubar/VersionPreviewCard.js.map +1 -1
- package/dist/editor/menubar/VersionSelector.js +17 -6
- package/dist/editor/menubar/VersionSelector.js.map +1 -1
- package/dist/editor/menubar/toolbar-sections/DeviceSwitchToolbar.d.ts +7 -0
- package/dist/editor/menubar/toolbar-sections/DeviceSwitchToolbar.js +37 -0
- package/dist/editor/menubar/toolbar-sections/DeviceSwitchToolbar.js.map +1 -0
- package/dist/editor/menubar/toolbar-sections/ManualBrowser.js +2 -2
- package/dist/editor/menubar/toolbar-sections/ManualBrowser.js.map +1 -1
- package/dist/editor/menubar/toolbar-sections/ViewportControls.js +7 -11
- package/dist/editor/menubar/toolbar-sections/ViewportControls.js.map +1 -1
- package/dist/editor/menubar/toolbar-sections/index.d.ts +1 -0
- package/dist/editor/menubar/toolbar-sections/index.js +1 -0
- package/dist/editor/menubar/toolbar-sections/index.js.map +1 -1
- package/dist/editor/notifications/useNotifications.js +11 -4
- package/dist/editor/notifications/useNotifications.js.map +1 -1
- package/dist/editor/page-editor-chrome/FieldEditedIndicator.js +3 -1
- package/dist/editor/page-editor-chrome/FieldEditedIndicator.js.map +1 -1
- package/dist/editor/page-editor-chrome/FrameMenu.d.ts +4 -2
- package/dist/editor/page-editor-chrome/FrameMenu.js +33 -9
- package/dist/editor/page-editor-chrome/FrameMenu.js.map +1 -1
- package/dist/editor/page-editor-chrome/InlineEditor.d.ts +4 -2
- package/dist/editor/page-editor-chrome/InlineEditor.js +125 -20
- package/dist/editor/page-editor-chrome/InlineEditor.js.map +1 -1
- package/dist/editor/page-editor-chrome/PageEditorChrome.d.ts +4 -2
- package/dist/editor/page-editor-chrome/PageEditorChrome.js +16 -3
- package/dist/editor/page-editor-chrome/PageEditorChrome.js.map +1 -1
- package/dist/editor/page-editor-chrome/PictureEditorOverlay.js +36 -13
- package/dist/editor/page-editor-chrome/PictureEditorOverlay.js.map +1 -1
- package/dist/editor/page-editor-chrome/VersionDiffHighlightings.js +24 -4
- package/dist/editor/page-editor-chrome/VersionDiffHighlightings.js.map +1 -1
- package/dist/editor/page-editor-chrome/useInlineAICompletion.js +52 -22
- package/dist/editor/page-editor-chrome/useInlineAICompletion.js.map +1 -1
- package/dist/editor/page-viewer/MiniMap.js +29 -21
- package/dist/editor/page-viewer/MiniMap.js.map +1 -1
- package/dist/editor/page-viewer/PageViewer.d.ts +4 -2
- package/dist/editor/page-viewer/PageViewer.js +14 -6
- package/dist/editor/page-viewer/PageViewer.js.map +1 -1
- package/dist/editor/page-viewer/PageViewerFrame.d.ts +4 -2
- package/dist/editor/page-viewer/PageViewerFrame.js +171 -52
- package/dist/editor/page-viewer/PageViewerFrame.js.map +1 -1
- package/dist/editor/reviews/Comment.js +24 -0
- package/dist/editor/reviews/Comment.js.map +1 -1
- package/dist/editor/services/agentService.d.ts +18 -1
- package/dist/editor/services/agentService.js +34 -3
- package/dist/editor/services/agentService.js.map +1 -1
- package/dist/editor/services/aiService.d.ts +0 -36
- package/dist/editor/services/aiService.js +7 -64
- package/dist/editor/services/aiService.js.map +1 -1
- package/dist/editor/services/manualService.d.ts +31 -0
- package/dist/editor/services/manualService.js +77 -0
- package/dist/editor/services/manualService.js.map +1 -0
- package/dist/editor/services/serviceHelper.js +0 -14
- package/dist/editor/services/serviceHelper.js.map +1 -1
- package/dist/editor/services/systemService.d.ts +4 -0
- package/dist/editor/services/systemService.js +3 -0
- package/dist/editor/services/systemService.js.map +1 -1
- package/dist/editor/services/userService.d.ts +6 -0
- package/dist/editor/services/userService.js +13 -0
- package/dist/editor/services/userService.js.map +1 -0
- package/dist/editor/settings/About.js +178 -1
- package/dist/editor/settings/About.js.map +1 -1
- package/dist/editor/settings/QuotaInfo.js +7 -7
- package/dist/editor/settings/QuotaInfo.js.map +1 -1
- package/dist/editor/settings/QuotaUserPicker.js +15 -55
- package/dist/editor/settings/QuotaUserPicker.js.map +1 -1
- package/dist/editor/settings/SettingsBreadcrumb.js +1 -1
- package/dist/editor/settings/SettingsBreadcrumb.js.map +1 -1
- package/dist/editor/settings/SettingsView.js +1 -1
- package/dist/editor/settings/SettingsView.js.map +1 -1
- package/dist/editor/settings/panels/AgentProfileConfigPanel.d.ts +2 -1
- package/dist/editor/settings/panels/AgentProfileConfigPanel.js +4 -2
- package/dist/editor/settings/panels/AgentProfileConfigPanel.js.map +1 -1
- package/dist/editor/settings/panels/AgentProfileEditorPanel.d.ts +1 -0
- package/dist/editor/settings/panels/AgentProfileEditorPanel.js +1 -1
- package/dist/editor/settings/panels/AgentProfileEditorPanel.js.map +1 -1
- package/dist/editor/settings/panels/AgentsPanel.js +15 -10
- package/dist/editor/settings/panels/AgentsPanel.js.map +1 -1
- package/dist/editor/settings/panels/ClusterInstancesPanel.js +37 -10
- package/dist/editor/settings/panels/ClusterInstancesPanel.js.map +1 -1
- package/dist/editor/settings/panels/CreateMcpServerDialog.d.ts +7 -0
- package/dist/editor/settings/panels/CreateMcpServerDialog.js +71 -0
- package/dist/editor/settings/panels/CreateMcpServerDialog.js.map +1 -0
- package/dist/editor/settings/panels/JavaScriptToolsPanel.js +13 -17
- package/dist/editor/settings/panels/JavaScriptToolsPanel.js.map +1 -1
- package/dist/editor/settings/panels/McpToolsPanel.js +17 -8
- package/dist/editor/settings/panels/McpToolsPanel.js.map +1 -1
- package/dist/editor/settings/panels/ModelsPanel.js +92 -56
- package/dist/editor/settings/panels/ModelsPanel.js.map +1 -1
- package/dist/editor/settings/panels/ProvidersPanel.js +46 -47
- package/dist/editor/settings/panels/ProvidersPanel.js.map +1 -1
- package/dist/editor/settings/panels/SearchConfigPanel.js +2 -2
- package/dist/editor/settings/panels/SearchConfigPanel.js.map +1 -1
- package/dist/editor/settings/panels/UserPreferencesPanel.d.ts +2 -0
- package/dist/editor/settings/panels/UserPreferencesPanel.js +17 -0
- package/dist/editor/settings/panels/UserPreferencesPanel.js.map +1 -0
- package/dist/editor/settings/panels/index.d.ts +1 -0
- package/dist/editor/settings/panels/index.js +1 -0
- package/dist/editor/settings/panels/index.js.map +1 -1
- package/dist/editor/sidebar/EditHistory.js +18 -3
- package/dist/editor/sidebar/EditHistory.js.map +1 -1
- package/dist/editor/sidebar/LabelButton.d.ts +3 -3
- package/dist/editor/sidebar/LabelButton.js +4 -4
- package/dist/editor/sidebar/LabelButton.js.map +1 -1
- package/dist/editor/sidebar/MobileWorkspacePopover.d.ts +2 -2
- package/dist/editor/sidebar/MobileWorkspacePopover.js +2 -2
- package/dist/editor/sidebar/MobileWorkspacePopover.js.map +1 -1
- package/dist/editor/sidebar/NavigationPanelItem.js +3 -3
- package/dist/editor/sidebar/NavigationPanelItem.js.map +1 -1
- package/dist/editor/sidebar/WorkspaceButton.d.ts +3 -1
- package/dist/editor/sidebar/WorkspaceButton.js +15 -7
- package/dist/editor/sidebar/WorkspaceButton.js.map +1 -1
- package/dist/editor/sidebar/WorkspaceRail.js +6 -5
- package/dist/editor/sidebar/WorkspaceRail.js.map +1 -1
- package/dist/editor/sidebar/WorkspaceRailMobile.js +2 -2
- package/dist/editor/sidebar/WorkspaceRailMobile.js.map +1 -1
- package/dist/editor/ui/ItemCollectionEditor.d.ts +27 -3
- package/dist/editor/ui/ItemCollectionEditor.js +44 -5
- package/dist/editor/ui/ItemCollectionEditor.js.map +1 -1
- package/dist/editor/ui/PerfectTree.js +1 -1
- package/dist/editor/ui/PerfectTree.js.map +1 -1
- package/dist/editor/utils.js +33 -11
- package/dist/editor/utils.js.map +1 -1
- package/dist/editor/version-diff/versionDiffTargets.js +7 -1
- package/dist/editor/version-diff/versionDiffTargets.js.map +1 -1
- package/dist/editor/views/EditorSlot.js +3 -2
- package/dist/editor/views/EditorSlot.js.map +1 -1
- package/dist/editor/views/ItemEditorPane.d.ts +11 -0
- package/dist/editor/views/ItemEditorPane.js +19 -0
- package/dist/editor/views/ItemEditorPane.js.map +1 -0
- package/dist/editor/views/editorSlotContext.d.ts +2 -0
- package/dist/editor/views/editorSlotContext.js +3 -0
- package/dist/editor/views/editorSlotContext.js.map +1 -1
- package/dist/index.d.ts +10 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -1
- package/dist/revision.d.ts +2 -2
- package/dist/revision.js +2 -2
- package/dist/setup/services/setupWizardService.d.ts +10 -0
- package/dist/setup/services/setupWizardService.js +7 -0
- package/dist/setup/services/setupWizardService.js.map +1 -1
- package/dist/task-board/TaskBoardWorkspace.js +1 -0
- package/dist/task-board/TaskBoardWorkspace.js.map +1 -1
- package/dist/task-board/components/ProjectExecutionUserPicker.js +15 -61
- package/dist/task-board/components/ProjectExecutionUserPicker.js.map +1 -1
- package/dist/task-board/components/ProjectListContent.d.ts +1 -0
- package/dist/task-board/components/ProjectListContent.js.map +1 -1
- package/dist/task-board/components/ProjectSelector.d.ts +1 -0
- package/dist/task-board/components/ProjectSelector.js +7 -1
- package/dist/task-board/components/ProjectSelector.js.map +1 -1
- package/dist/task-board/components/TaskBoardTitlebar.js +1 -1
- package/dist/task-board/components/TaskBoardTitlebar.js.map +1 -1
- package/dist/task-board/taskBoardNavStore.d.ts +1 -0
- package/dist/task-board/taskBoardNavStore.js +1 -0
- package/dist/task-board/taskBoardNavStore.js.map +1 -1
- package/dist/types.d.ts +2 -1
- package/package.json +1 -1
- package/dist/agents-view/AgentsInbox.d.ts +0 -26
- package/dist/agents-view/AgentsInbox.js +0 -31
- package/dist/agents-view/AgentsInbox.js.map +0 -1
- package/dist/editor/ai/agentDiagnostics.test.d.ts +0 -1
- package/dist/editor/ai/agentDiagnostics.test.js +0 -298
- package/dist/editor/ai/agentDiagnostics.test.js.map +0 -1
- package/dist/editor/ai/terminal/agentQuestionnaireTranscriptRecovery.test.d.ts +0 -1
- package/dist/editor/ai/terminal/agentQuestionnaireTranscriptRecovery.test.js +0 -109
- package/dist/editor/ai/terminal/agentQuestionnaireTranscriptRecovery.test.js.map +0 -1
- package/dist/editor/ai/terminal/agentSessionSelectors.test.d.ts +0 -1
- package/dist/editor/ai/terminal/agentSessionSelectors.test.js +0 -219
- package/dist/editor/ai/terminal/agentSessionSelectors.test.js.map +0 -1
- package/dist/editor/ai/terminal/agentSessionSnapshot.test.d.ts +0 -1
- package/dist/editor/ai/terminal/agentSessionSnapshot.test.js +0 -136
- package/dist/editor/ai/terminal/agentSessionSnapshot.test.js.map +0 -1
- package/dist/editor/ai/terminal/agentSessionState.test.d.ts +0 -1
- package/dist/editor/ai/terminal/agentSessionState.test.js +0 -476
- package/dist/editor/ai/terminal/agentSessionState.test.js.map +0 -1
- package/dist/editor/ai/terminal/useAgentInitialPrompt.test.d.ts +0 -1
- package/dist/editor/ai/terminal/useAgentInitialPrompt.test.js +0 -63
- package/dist/editor/ai/terminal/useAgentInitialPrompt.test.js.map +0 -1
- package/dist/editor/ai/terminal/useAgentPendingDialogRecovery.test.d.ts +0 -1
- package/dist/editor/ai/terminal/useAgentPendingDialogRecovery.test.js +0 -80
- package/dist/editor/ai/terminal/useAgentPendingDialogRecovery.test.js.map +0 -1
- package/dist/editor/ai/terminal/useAgentQuestionnaireDialogRecovery.test.d.ts +0 -1
- package/dist/editor/ai/terminal/useAgentQuestionnaireDialogRecovery.test.js +0 -135
- package/dist/editor/ai/terminal/useAgentQuestionnaireDialogRecovery.test.js.map +0 -1
- package/dist/editor/ai/terminal/useAgentSession.test.d.ts +0 -1
- package/dist/editor/ai/terminal/useAgentSession.test.js +0 -181
- package/dist/editor/ai/terminal/useAgentSession.test.js.map +0 -1
- package/dist/editor/ai/terminal/useAgentSubmitHandlers.test.d.ts +0 -1
- package/dist/editor/ai/terminal/useAgentSubmitHandlers.test.js +0 -88
- package/dist/editor/ai/terminal/useAgentSubmitHandlers.test.js.map +0 -1
- package/dist/editor/ai/useAgentPanes.test.d.ts +0 -1
- package/dist/editor/ai/useAgentPanes.test.js +0 -198
- package/dist/editor/ai/useAgentPanes.test.js.map +0 -1
- package/dist/editor/debugSessionLog.d.ts +0 -9
- package/dist/editor/debugSessionLog.js +0 -19
- package/dist/editor/debugSessionLog.js.map +0 -1
- package/dist/editor/services/agentDialogService.test.d.ts +0 -1
- package/dist/editor/services/agentDialogService.test.js +0 -56
- package/dist/editor/services/agentDialogService.test.js.map +0 -1
- package/dist/editor/services/agentSubscriptionRegistry.test.d.ts +0 -1
- package/dist/editor/services/agentSubscriptionRegistry.test.js +0 -104
- package/dist/editor/services/agentSubscriptionRegistry.test.js.map +0 -1
- package/dist/test/setup.d.ts +0 -0
- package/dist/test/setup.js +0 -37
- package/dist/test/setup.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useAgentPendingDialogRecovery.test.js","sourceRoot":"","sources":["../../../../src/editor/ai/terminal/useAgentPendingDialogRecovery.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,135 +0,0 @@
|
|
|
1
|
-
import { act, renderHook } from "@testing-library/react";
|
|
2
|
-
import { beforeEach, describe, expect, it, vi } from "vitest";
|
|
3
|
-
import { useAgentQuestionnaireDialogRecovery } from "./useAgentQuestionnaireDialogRecovery";
|
|
4
|
-
import { submitAgentSessionDialogResponse } from "./useAgentSessionSync";
|
|
5
|
-
vi.mock("./useAgentSessionSync", () => ({
|
|
6
|
-
submitAgentSessionDialogResponse: vi.fn().mockResolvedValue(undefined),
|
|
7
|
-
}));
|
|
8
|
-
describe("useAgentQuestionnaireDialogRecovery", () => {
|
|
9
|
-
beforeEach(() => {
|
|
10
|
-
vi.clearAllMocks();
|
|
11
|
-
});
|
|
12
|
-
it("rebuilds a questionnaire dialog and submits completion responses", () => {
|
|
13
|
-
let activeDialog = null;
|
|
14
|
-
const setActiveInlineDialog = vi.fn((dialog) => {
|
|
15
|
-
activeDialog = dialog;
|
|
16
|
-
});
|
|
17
|
-
const onInteractionSubmitted = vi.fn();
|
|
18
|
-
const { result } = renderHook(() => useAgentQuestionnaireDialogRecovery({
|
|
19
|
-
messagesRef: {
|
|
20
|
-
current: [
|
|
21
|
-
message({
|
|
22
|
-
functionName: "ask-questionnaire",
|
|
23
|
-
functionArguments: JSON.stringify({
|
|
24
|
-
title: "PDF details",
|
|
25
|
-
questions: [{ id: "q1", prompt: "Which PDF?" }],
|
|
26
|
-
}),
|
|
27
|
-
}),
|
|
28
|
-
],
|
|
29
|
-
},
|
|
30
|
-
agentId: "agent-1",
|
|
31
|
-
sessionId: "session-1",
|
|
32
|
-
setActiveInlineDialog,
|
|
33
|
-
appendToolUiEvent: vi.fn(),
|
|
34
|
-
onInteractionSubmitted,
|
|
35
|
-
}));
|
|
36
|
-
const recovered = result.current({
|
|
37
|
-
callbackId: "callback-1",
|
|
38
|
-
dialogType: "questionnaire",
|
|
39
|
-
title: "Pending",
|
|
40
|
-
createdAt: "2026-01-01T00:00:00.000Z",
|
|
41
|
-
replayableToCurrentSession: true,
|
|
42
|
-
});
|
|
43
|
-
expect(recovered).toBe(true);
|
|
44
|
-
const recoveredDialog = activeDialog;
|
|
45
|
-
expect(recoveredDialog.request).toMatchObject({
|
|
46
|
-
callbackId: "callback-1",
|
|
47
|
-
agentId: "agent-1",
|
|
48
|
-
title: "PDF details",
|
|
49
|
-
});
|
|
50
|
-
act(() => {
|
|
51
|
-
activeDialog?.onComplete({ q1: "file.pdf" });
|
|
52
|
-
});
|
|
53
|
-
expect(submitAgentSessionDialogResponse).toHaveBeenCalledWith({
|
|
54
|
-
callbackId: "callback-1",
|
|
55
|
-
sessionId: "session-1",
|
|
56
|
-
cancelled: false,
|
|
57
|
-
resultJson: JSON.stringify({ q1: "file.pdf" }),
|
|
58
|
-
});
|
|
59
|
-
expect(onInteractionSubmitted).toHaveBeenCalledTimes(1);
|
|
60
|
-
});
|
|
61
|
-
it("submits cancellation responses for recovered dialogs", () => {
|
|
62
|
-
let activeDialog = null;
|
|
63
|
-
const { result } = renderHook(() => useAgentQuestionnaireDialogRecovery({
|
|
64
|
-
messagesRef: {
|
|
65
|
-
current: [
|
|
66
|
-
message({
|
|
67
|
-
functionName: "ask-questionnaire",
|
|
68
|
-
functionArguments: JSON.stringify({
|
|
69
|
-
questions: [{ id: "q1", prompt: "Question?" }],
|
|
70
|
-
}),
|
|
71
|
-
}),
|
|
72
|
-
],
|
|
73
|
-
},
|
|
74
|
-
agentId: "agent-1",
|
|
75
|
-
sessionId: "session-1",
|
|
76
|
-
setActiveInlineDialog: (dialog) => {
|
|
77
|
-
activeDialog = dialog;
|
|
78
|
-
},
|
|
79
|
-
appendToolUiEvent: vi.fn(),
|
|
80
|
-
}));
|
|
81
|
-
result.current({
|
|
82
|
-
callbackId: "callback-2",
|
|
83
|
-
dialogType: "questionnaire",
|
|
84
|
-
title: "Pending",
|
|
85
|
-
createdAt: "2026-01-01T00:00:00.000Z",
|
|
86
|
-
replayableToCurrentSession: true,
|
|
87
|
-
});
|
|
88
|
-
act(() => {
|
|
89
|
-
activeDialog?.onCancel();
|
|
90
|
-
});
|
|
91
|
-
expect(submitAgentSessionDialogResponse).toHaveBeenCalledWith({
|
|
92
|
-
callbackId: "callback-2",
|
|
93
|
-
sessionId: "session-1",
|
|
94
|
-
cancelled: true,
|
|
95
|
-
});
|
|
96
|
-
});
|
|
97
|
-
});
|
|
98
|
-
function message(toolCall) {
|
|
99
|
-
return {
|
|
100
|
-
id: "message-1",
|
|
101
|
-
agentId: "agent-1",
|
|
102
|
-
messageIndex: 0,
|
|
103
|
-
role: "assistant",
|
|
104
|
-
content: "",
|
|
105
|
-
name: "agent",
|
|
106
|
-
messageType: "streaming",
|
|
107
|
-
isCompleted: false,
|
|
108
|
-
model: "",
|
|
109
|
-
tokensUsed: 0,
|
|
110
|
-
inputTokens: 0,
|
|
111
|
-
outputTokens: 0,
|
|
112
|
-
cachedInputTokens: 0,
|
|
113
|
-
inputTokenCost: 0,
|
|
114
|
-
outputTokenCost: 0,
|
|
115
|
-
cachedInputTokenCost: 0,
|
|
116
|
-
totalCost: 0,
|
|
117
|
-
currency: "USD",
|
|
118
|
-
createdDate: "2026-01-01T00:00:00.000Z",
|
|
119
|
-
toolCalls: [
|
|
120
|
-
{
|
|
121
|
-
id: "tool-1",
|
|
122
|
-
messageId: "message-1",
|
|
123
|
-
toolCallId: "tool-1",
|
|
124
|
-
functionName: "",
|
|
125
|
-
functionArguments: "",
|
|
126
|
-
functionResult: "",
|
|
127
|
-
functionError: "",
|
|
128
|
-
isCompleted: false,
|
|
129
|
-
createdDate: "2026-01-01T00:00:00.000Z",
|
|
130
|
-
...toolCall,
|
|
131
|
-
},
|
|
132
|
-
],
|
|
133
|
-
};
|
|
134
|
-
}
|
|
135
|
-
//# sourceMappingURL=useAgentQuestionnaireDialogRecovery.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useAgentQuestionnaireDialogRecovery.test.js","sourceRoot":"","sources":["../../../../src/editor/ai/terminal/useAgentQuestionnaireDialogRecovery.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,181 +0,0 @@
|
|
|
1
|
-
import { act, renderHook } from "@testing-library/react";
|
|
2
|
-
import { describe, expect, it, vi } from "vitest";
|
|
3
|
-
import { useAgentSession } from "./useAgentSession";
|
|
4
|
-
describe("useAgentSession", () => {
|
|
5
|
-
it("routes stable session commands through bound handlers", async () => {
|
|
6
|
-
const { result } = renderHook(() => useAgentSession({ agentStub: agentStub() }));
|
|
7
|
-
const commands = result.current.commands;
|
|
8
|
-
const submitPrompt = vi.fn(async (_input) => { });
|
|
9
|
-
const stopRun = vi.fn(async () => { });
|
|
10
|
-
result.current.bindCommands({ submitPrompt, stopRun });
|
|
11
|
-
await commands.submitPrompt({ text: "Ship it", source: "composer" });
|
|
12
|
-
await commands.stopRun();
|
|
13
|
-
expect(result.current.commands).toBe(commands);
|
|
14
|
-
expect(submitPrompt).toHaveBeenCalledWith({
|
|
15
|
-
text: "Ship it",
|
|
16
|
-
source: "composer",
|
|
17
|
-
});
|
|
18
|
-
expect(stopRun).toHaveBeenCalledTimes(1);
|
|
19
|
-
});
|
|
20
|
-
it("applies stream transcript actions through the reducer", () => {
|
|
21
|
-
const { result } = renderHook(() => useAgentSession({ agentStub: agentStub() }));
|
|
22
|
-
act(() => {
|
|
23
|
-
result.current.actions.assistantContentChunk({
|
|
24
|
-
messageId: "assistant-1",
|
|
25
|
-
deltaContent: "Hello",
|
|
26
|
-
isIncremental: false,
|
|
27
|
-
createMessage: () => assistantMessage("assistant-1"),
|
|
28
|
-
});
|
|
29
|
-
});
|
|
30
|
-
expect(result.current.state.transcript[0]?.content).toBe("Hello");
|
|
31
|
-
act(() => {
|
|
32
|
-
result.current.actions.toolCall({
|
|
33
|
-
messageId: "assistant-1",
|
|
34
|
-
createMessage: () => assistantMessage("assistant-1"),
|
|
35
|
-
toolCall: {
|
|
36
|
-
id: "tool-1",
|
|
37
|
-
messageId: "assistant-1",
|
|
38
|
-
toolCallId: "tool-1",
|
|
39
|
-
functionName: "writeFile",
|
|
40
|
-
functionArguments: "{}",
|
|
41
|
-
isCompleted: false,
|
|
42
|
-
createdDate: "2026-01-01T00:00:00.000Z",
|
|
43
|
-
},
|
|
44
|
-
});
|
|
45
|
-
result.current.actions.toolResult({
|
|
46
|
-
messageId: "assistant-1",
|
|
47
|
-
toolCallId: "tool-1",
|
|
48
|
-
fallbackToolCall: {
|
|
49
|
-
id: "tool-1",
|
|
50
|
-
messageId: "assistant-1",
|
|
51
|
-
toolCallId: "tool-1",
|
|
52
|
-
functionName: "writeFile",
|
|
53
|
-
functionArguments: "{}",
|
|
54
|
-
functionResult: "ok",
|
|
55
|
-
isCompleted: true,
|
|
56
|
-
createdDate: "2026-01-01T00:00:00.000Z",
|
|
57
|
-
},
|
|
58
|
-
});
|
|
59
|
-
});
|
|
60
|
-
expect(result.current.state.transcript[0]?.toolCalls?.[0]?.functionResult).toBe("ok");
|
|
61
|
-
act(() => {
|
|
62
|
-
result.current.actions.heartbeatMessage({
|
|
63
|
-
...assistantMessage("heartbeat-1"),
|
|
64
|
-
role: "system",
|
|
65
|
-
messageType: "heartbeat",
|
|
66
|
-
isCompleted: true,
|
|
67
|
-
});
|
|
68
|
-
result.current.actions.clearHeartbeatMessages();
|
|
69
|
-
});
|
|
70
|
-
expect(result.current.state.transcript.some((message) => message.messageType === "heartbeat")).toBe(false);
|
|
71
|
-
});
|
|
72
|
-
it("applies mirrored backend domain actions through the reducer", () => {
|
|
73
|
-
const { result } = renderHook(() => useAgentSession({ agentStub: agentStub() }));
|
|
74
|
-
act(() => {
|
|
75
|
-
result.current.actions.replaceAgent({
|
|
76
|
-
...agentStub(),
|
|
77
|
-
userId: "user-1",
|
|
78
|
-
profileName: "",
|
|
79
|
-
model: "model-a",
|
|
80
|
-
createdDate: "2026-01-01T00:00:00.000Z",
|
|
81
|
-
totalTokensUsed: 0,
|
|
82
|
-
totalInputTokens: 0,
|
|
83
|
-
totalOutputTokens: 0,
|
|
84
|
-
totalCachedInputTokens: 0,
|
|
85
|
-
totalInputTokenCost: 0,
|
|
86
|
-
totalOutputTokenCost: 0,
|
|
87
|
-
totalCachedInputTokenCost: 0,
|
|
88
|
-
totalImageCost: 0,
|
|
89
|
-
totalCost: 0,
|
|
90
|
-
currency: "USD",
|
|
91
|
-
messageCount: 0,
|
|
92
|
-
messages: [],
|
|
93
|
-
});
|
|
94
|
-
result.current.actions.replaceMetadata({
|
|
95
|
-
additionalData: { todoList: [{ text: "Review", done: false }] },
|
|
96
|
-
});
|
|
97
|
-
result.current.actions.replaceError("Something happened");
|
|
98
|
-
result.current.actions.replaceCostLimitExceeded({
|
|
99
|
-
totalCost: 12,
|
|
100
|
-
costLimit: 10,
|
|
101
|
-
initialCostLimit: 10,
|
|
102
|
-
});
|
|
103
|
-
result.current.actions.replaceContextWindowStatus({
|
|
104
|
-
contextWindowTokens: 1000,
|
|
105
|
-
estimatedInputTokens: 250,
|
|
106
|
-
contextUsedPercent: 25,
|
|
107
|
-
model: "model-a",
|
|
108
|
-
});
|
|
109
|
-
result.current.actions.replaceLiveTotals({
|
|
110
|
-
input: 100,
|
|
111
|
-
output: 50,
|
|
112
|
-
cached: 10,
|
|
113
|
-
inputCost: 0.01,
|
|
114
|
-
outputCost: 0.02,
|
|
115
|
-
cachedCost: 0.001,
|
|
116
|
-
imageCost: 0,
|
|
117
|
-
totalCost: 0.031,
|
|
118
|
-
});
|
|
119
|
-
result.current.actions.patchRunState({
|
|
120
|
-
isConnecting: true,
|
|
121
|
-
isWaitingForResponse: true,
|
|
122
|
-
lastStatusReason: "Booting",
|
|
123
|
-
});
|
|
124
|
-
result.current.actions.setBrowserClaimMutationPending(true);
|
|
125
|
-
result.current.actions.setActiveInlineDialog({
|
|
126
|
-
request: {
|
|
127
|
-
callbackId: "callback-1",
|
|
128
|
-
dialogType: "questionnaire",
|
|
129
|
-
title: "Questionnaire",
|
|
130
|
-
parameters: {},
|
|
131
|
-
},
|
|
132
|
-
onComplete: vi.fn(),
|
|
133
|
-
onCancel: vi.fn(),
|
|
134
|
-
});
|
|
135
|
-
});
|
|
136
|
-
expect(result.current.state.agent?.model).toBe("model-a");
|
|
137
|
-
expect(result.current.state.metadata?.additionalData?.todoList).toHaveLength(1);
|
|
138
|
-
expect(result.current.state.error).toBe("Something happened");
|
|
139
|
-
expect(result.current.state.costLimitExceeded?.totalCost).toBe(12);
|
|
140
|
-
expect(result.current.state.contextWindowStatus?.model).toBe("model-a");
|
|
141
|
-
expect(result.current.state.liveTotals?.totalCost).toBe(0.031);
|
|
142
|
-
expect(result.current.state.run.isConnecting).toBe(true);
|
|
143
|
-
expect(result.current.state.run.lastStatusReason).toBe("Booting");
|
|
144
|
-
expect(result.current.state.browserClaimMutationPending).toBe(true);
|
|
145
|
-
expect(result.current.state.activeInlineDialog?.request.callbackId).toBe("callback-1");
|
|
146
|
-
});
|
|
147
|
-
});
|
|
148
|
-
function agentStub() {
|
|
149
|
-
return {
|
|
150
|
-
id: "agent-1",
|
|
151
|
-
name: "Agent",
|
|
152
|
-
description: "",
|
|
153
|
-
status: "idle",
|
|
154
|
-
updatedDate: "2026-01-01T00:00:00.000Z",
|
|
155
|
-
};
|
|
156
|
-
}
|
|
157
|
-
function assistantMessage(id) {
|
|
158
|
-
return {
|
|
159
|
-
id,
|
|
160
|
-
agentId: "agent-1",
|
|
161
|
-
messageIndex: -1,
|
|
162
|
-
role: "assistant",
|
|
163
|
-
content: "",
|
|
164
|
-
name: "agent",
|
|
165
|
-
messageType: "streaming",
|
|
166
|
-
isCompleted: false,
|
|
167
|
-
model: "",
|
|
168
|
-
tokensUsed: 0,
|
|
169
|
-
inputTokens: 0,
|
|
170
|
-
outputTokens: 0,
|
|
171
|
-
cachedInputTokens: 0,
|
|
172
|
-
inputTokenCost: 0,
|
|
173
|
-
outputTokenCost: 0,
|
|
174
|
-
cachedInputTokenCost: 0,
|
|
175
|
-
totalCost: 0,
|
|
176
|
-
currency: "USD",
|
|
177
|
-
createdDate: "2026-01-01T00:00:00.000Z",
|
|
178
|
-
toolCalls: [],
|
|
179
|
-
};
|
|
180
|
-
}
|
|
181
|
-
//# sourceMappingURL=useAgentSession.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useAgentSession.test.js","sourceRoot":"","sources":["../../../../src/editor/ai/terminal/useAgentSession.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,88 +0,0 @@
|
|
|
1
|
-
import { act, renderHook } from "@testing-library/react";
|
|
2
|
-
import { describe, expect, it, vi } from "vitest";
|
|
3
|
-
import { useRef, useState } from "react";
|
|
4
|
-
import { useAgentSubmitHandlers } from "./useAgentSubmitHandlers";
|
|
5
|
-
const mocks = vi.hoisted(() => ({
|
|
6
|
-
startAgentSessionRun: vi.fn(async () => ({ agent: { status: "running" } })),
|
|
7
|
-
}));
|
|
8
|
-
vi.mock("./useAgentSessionSync", async () => {
|
|
9
|
-
const actual = await vi.importActual("./useAgentSessionSync");
|
|
10
|
-
return {
|
|
11
|
-
...actual,
|
|
12
|
-
clearStaleRunningLoadSuppression: vi.fn(),
|
|
13
|
-
startAgentSessionRun: mocks.startAgentSessionRun,
|
|
14
|
-
};
|
|
15
|
-
});
|
|
16
|
-
describe("useAgentSubmitHandlers", () => {
|
|
17
|
-
it("submits filled prompt placeholder text from the external send button", async () => {
|
|
18
|
-
const filledPrompt = "Create a new template named Test to use for prompts.";
|
|
19
|
-
let submitFilledPrompt = null;
|
|
20
|
-
const { result } = renderHook(() => {
|
|
21
|
-
const promptPlaceholderInputRef = useRef(null);
|
|
22
|
-
const [isSubmitting, setIsSubmitting] = useState(false);
|
|
23
|
-
const handlers = useAgentSubmitHandlers({
|
|
24
|
-
readOnly: false,
|
|
25
|
-
isSubmitting,
|
|
26
|
-
editContext: { sessionId: "session-1" },
|
|
27
|
-
agent: {
|
|
28
|
-
id: "agent-1",
|
|
29
|
-
status: "idle",
|
|
30
|
-
},
|
|
31
|
-
agentStub: {
|
|
32
|
-
id: "agent-1",
|
|
33
|
-
status: "idle",
|
|
34
|
-
},
|
|
35
|
-
prompt: "Create a new template named {{name}} to use for prompts.",
|
|
36
|
-
activePlaceholderInput: null,
|
|
37
|
-
allPlaceholdersFilled: true,
|
|
38
|
-
placeholderInputRef: useRef(null),
|
|
39
|
-
promptPlaceholderInputRef: promptPlaceholderInputRef,
|
|
40
|
-
shouldSubmitFilledPlaceholderInputRef: useRef(false),
|
|
41
|
-
activeInlineDialogRef: useRef(null),
|
|
42
|
-
isWaitingRef: useRef(false),
|
|
43
|
-
lastNonHeartbeatUpdateAtRef: useRef(0),
|
|
44
|
-
clearStopGuard: vi.fn(),
|
|
45
|
-
supersedePendingApprovals: vi.fn(async () => true),
|
|
46
|
-
hasPendingApprovals: vi.fn(() => false),
|
|
47
|
-
registerSuppressedQueuedPrompt: vi.fn(() => null),
|
|
48
|
-
clearSuppressedQueuedPrompt: vi.fn(),
|
|
49
|
-
cancelActiveInlineDialog: vi.fn(),
|
|
50
|
-
addOptimisticTranscriptMessage: vi.fn(),
|
|
51
|
-
removeOptimisticTranscriptMessage: vi.fn(),
|
|
52
|
-
getPendingRequestSettings: vi.fn(() => ({
|
|
53
|
-
profileName: "Parhelia",
|
|
54
|
-
})),
|
|
55
|
-
buildSubmitContext: vi.fn(async () => null),
|
|
56
|
-
handleSubmitResponse: vi.fn(),
|
|
57
|
-
persistPendingSettingsIfNeeded: vi.fn(async () => undefined),
|
|
58
|
-
setError: vi.fn(),
|
|
59
|
-
setPrompt: vi.fn(),
|
|
60
|
-
setIsSubmitting,
|
|
61
|
-
setIsWaitingForResponse: vi.fn(),
|
|
62
|
-
setIsAgentThinking: vi.fn(),
|
|
63
|
-
setShouldAutoScroll: vi.fn(),
|
|
64
|
-
setPromptHistory: vi.fn(),
|
|
65
|
-
setCurrentHistoryIndex: vi.fn(),
|
|
66
|
-
});
|
|
67
|
-
promptPlaceholderInputRef.current = {
|
|
68
|
-
submit: () => {
|
|
69
|
-
submitFilledPrompt = () => {
|
|
70
|
-
void handlers.handleSubmit(filledPrompt);
|
|
71
|
-
};
|
|
72
|
-
submitFilledPrompt();
|
|
73
|
-
},
|
|
74
|
-
};
|
|
75
|
-
return handlers;
|
|
76
|
-
});
|
|
77
|
-
await act(async () => {
|
|
78
|
-
await result.current.handleSubmit();
|
|
79
|
-
});
|
|
80
|
-
expect(submitFilledPrompt).toBeTruthy();
|
|
81
|
-
expect(mocks.startAgentSessionRun).toHaveBeenCalledTimes(1);
|
|
82
|
-
expect(mocks.startAgentSessionRun).toHaveBeenCalledWith(expect.objectContaining({
|
|
83
|
-
agentId: "agent-1",
|
|
84
|
-
message: filledPrompt,
|
|
85
|
-
}));
|
|
86
|
-
});
|
|
87
|
-
});
|
|
88
|
-
//# sourceMappingURL=useAgentSubmitHandlers.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useAgentSubmitHandlers.test.js","sourceRoot":"","sources":["../../../../src/editor/ai/terminal/useAgentSubmitHandlers.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,198 +0,0 @@
|
|
|
1
|
-
import { act, renderHook } from "@testing-library/react";
|
|
2
|
-
import { afterEach, beforeEach, describe, expect, it } from "vitest";
|
|
3
|
-
import { useAgentPanes } from "./useAgentPanes";
|
|
4
|
-
import { AGENT_PANES_LAYOUT_STORAGE_KEY, LEGACY_ACTIVE_AGENT_STORAGE_KEY, } from "./agentPanesTypes";
|
|
5
|
-
const STORAGE_PREFIX = "parhelia.";
|
|
6
|
-
function clearStorage() {
|
|
7
|
-
window.localStorage.removeItem(STORAGE_PREFIX + AGENT_PANES_LAYOUT_STORAGE_KEY);
|
|
8
|
-
window.localStorage.removeItem(STORAGE_PREFIX + LEGACY_ACTIVE_AGENT_STORAGE_KEY);
|
|
9
|
-
}
|
|
10
|
-
function setLegacyActive(value) {
|
|
11
|
-
window.localStorage.setItem(STORAGE_PREFIX + LEGACY_ACTIVE_AGENT_STORAGE_KEY, value);
|
|
12
|
-
}
|
|
13
|
-
describe("useAgentPanes", () => {
|
|
14
|
-
beforeEach(() => {
|
|
15
|
-
clearStorage();
|
|
16
|
-
});
|
|
17
|
-
afterEach(() => {
|
|
18
|
-
clearStorage();
|
|
19
|
-
});
|
|
20
|
-
it("starts with a single overview pane when no storage exists", () => {
|
|
21
|
-
const { result } = renderHook(() => useAgentPanes([], { migrateLegacy: true }));
|
|
22
|
-
expect(result.current.layout.rows).toHaveLength(1);
|
|
23
|
-
expect(result.current.layout.rows[0]).toHaveLength(1);
|
|
24
|
-
expect(result.current.layout.rows[0][0].view.kind).toBe("overview");
|
|
25
|
-
expect(result.current.layout.focusedPaneId).toBe(result.current.layout.rows[0][0].id);
|
|
26
|
-
});
|
|
27
|
-
it("migrates legacy editor.activeAgentId into a single-pane agent layout", () => {
|
|
28
|
-
setLegacyActive("agent-123");
|
|
29
|
-
const { result } = renderHook(() => useAgentPanes([], { migrateLegacy: true }));
|
|
30
|
-
expect(result.current.layout.rows[0][0].view).toEqual({
|
|
31
|
-
kind: "agent",
|
|
32
|
-
agentId: "agent-123",
|
|
33
|
-
});
|
|
34
|
-
});
|
|
35
|
-
it('migrates legacy "" sentinel into a profile-selector pane', () => {
|
|
36
|
-
setLegacyActive("");
|
|
37
|
-
const { result } = renderHook(() => useAgentPanes([], { migrateLegacy: true }));
|
|
38
|
-
expect(result.current.layout.rows[0][0].view.kind).toBe("profile-selector");
|
|
39
|
-
});
|
|
40
|
-
it("removes the legacy key after first save of the new layout", () => {
|
|
41
|
-
setLegacyActive("agent-x");
|
|
42
|
-
renderHook(() => useAgentPanes([], { migrateLegacy: true }));
|
|
43
|
-
expect(window.localStorage.getItem(STORAGE_PREFIX + LEGACY_ACTIVE_AGENT_STORAGE_KEY)).toBeNull();
|
|
44
|
-
expect(window.localStorage.getItem(STORAGE_PREFIX + AGENT_PANES_LAYOUT_STORAGE_KEY)).not.toBeNull();
|
|
45
|
-
});
|
|
46
|
-
it("splitPane right creates a new pane in the same row and focuses it", () => {
|
|
47
|
-
setLegacyActive("agent-A");
|
|
48
|
-
const { result } = renderHook(() => useAgentPanes([], { migrateLegacy: true }));
|
|
49
|
-
const sourceId = result.current.layout.rows[0][0].id;
|
|
50
|
-
act(() => {
|
|
51
|
-
result.current.splitPane(sourceId, "agent-B", "right");
|
|
52
|
-
});
|
|
53
|
-
expect(result.current.layout.rows).toHaveLength(1);
|
|
54
|
-
expect(result.current.layout.rows[0]).toHaveLength(2);
|
|
55
|
-
expect(result.current.layout.orientation).toBe("horizontal");
|
|
56
|
-
expect(result.current.layout.rows[0][1].view).toEqual({
|
|
57
|
-
kind: "agent",
|
|
58
|
-
agentId: "agent-B",
|
|
59
|
-
});
|
|
60
|
-
expect(result.current.layout.focusedPaneId).toBe(result.current.layout.rows[0][1].id);
|
|
61
|
-
});
|
|
62
|
-
it("splitPane down creates a new row and switches orientation to vertical", () => {
|
|
63
|
-
setLegacyActive("agent-A");
|
|
64
|
-
const { result } = renderHook(() => useAgentPanes([], { migrateLegacy: true }));
|
|
65
|
-
const sourceId = result.current.layout.rows[0][0].id;
|
|
66
|
-
act(() => {
|
|
67
|
-
result.current.splitPane(sourceId, "agent-B", "down");
|
|
68
|
-
});
|
|
69
|
-
expect(result.current.layout.rows).toHaveLength(2);
|
|
70
|
-
expect(result.current.layout.orientation).toBe("vertical");
|
|
71
|
-
expect(result.current.layout.rows[1][0].view).toEqual({
|
|
72
|
-
kind: "agent",
|
|
73
|
-
agentId: "agent-B",
|
|
74
|
-
});
|
|
75
|
-
});
|
|
76
|
-
it("splitting right after splitting down produces a grid layout", () => {
|
|
77
|
-
setLegacyActive("agent-A");
|
|
78
|
-
const { result } = renderHook(() => useAgentPanes([], { migrateLegacy: true }));
|
|
79
|
-
const sourceId = result.current.layout.rows[0][0].id;
|
|
80
|
-
act(() => {
|
|
81
|
-
result.current.splitPane(sourceId, "agent-B", "down");
|
|
82
|
-
});
|
|
83
|
-
const bottomPaneId = result.current.layout.rows[1][0].id;
|
|
84
|
-
act(() => {
|
|
85
|
-
result.current.splitPane(bottomPaneId, "agent-C", "right");
|
|
86
|
-
});
|
|
87
|
-
expect(result.current.layout.orientation).toBe("grid");
|
|
88
|
-
expect(result.current.layout.rows).toHaveLength(2);
|
|
89
|
-
expect(result.current.layout.rows[1]).toHaveLength(2);
|
|
90
|
-
});
|
|
91
|
-
it("closePane on a non-last pane removes it and reassigns focus", () => {
|
|
92
|
-
setLegacyActive("agent-A");
|
|
93
|
-
const { result } = renderHook(() => useAgentPanes([], { migrateLegacy: true }));
|
|
94
|
-
const sourceId = result.current.layout.rows[0][0].id;
|
|
95
|
-
act(() => {
|
|
96
|
-
result.current.splitPane(sourceId, "agent-B", "right");
|
|
97
|
-
});
|
|
98
|
-
const newPaneId = result.current.layout.rows[0][1].id;
|
|
99
|
-
act(() => {
|
|
100
|
-
result.current.closePane(newPaneId);
|
|
101
|
-
});
|
|
102
|
-
expect(result.current.layout.rows).toHaveLength(1);
|
|
103
|
-
expect(result.current.layout.rows[0]).toHaveLength(1);
|
|
104
|
-
expect(result.current.layout.focusedPaneId).toBe(sourceId);
|
|
105
|
-
});
|
|
106
|
-
it("closePane on the last remaining pane resets it to overview instead of removing it", () => {
|
|
107
|
-
setLegacyActive("agent-A");
|
|
108
|
-
const { result } = renderHook(() => useAgentPanes([], { migrateLegacy: true }));
|
|
109
|
-
const onlyPaneId = result.current.layout.rows[0][0].id;
|
|
110
|
-
act(() => {
|
|
111
|
-
result.current.closePane(onlyPaneId);
|
|
112
|
-
});
|
|
113
|
-
expect(result.current.layout.rows).toHaveLength(1);
|
|
114
|
-
expect(result.current.layout.rows[0]).toHaveLength(1);
|
|
115
|
-
expect(result.current.layout.rows[0][0].view.kind).toBe("overview");
|
|
116
|
-
expect(result.current.layout.focusedPaneId).toBe(onlyPaneId);
|
|
117
|
-
});
|
|
118
|
-
it("closeAgentEverywhere replaces every pane showing that agent with profile-selector", () => {
|
|
119
|
-
setLegacyActive("agent-A");
|
|
120
|
-
const { result } = renderHook(() => useAgentPanes([], { migrateLegacy: true }));
|
|
121
|
-
const sourceId = result.current.layout.rows[0][0].id;
|
|
122
|
-
act(() => {
|
|
123
|
-
result.current.splitPane(sourceId, "agent-A", "right");
|
|
124
|
-
});
|
|
125
|
-
expect(result.current.panesByAgentId.get("agent-A")).toHaveLength(2);
|
|
126
|
-
act(() => {
|
|
127
|
-
result.current.closeAgentEverywhere("agent-A");
|
|
128
|
-
});
|
|
129
|
-
for (const row of result.current.layout.rows) {
|
|
130
|
-
for (const pane of row) {
|
|
131
|
-
expect(pane.view.kind).toBe("profile-selector");
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
});
|
|
135
|
-
it("pruneMissingAgents drops vanished agents and fixes stale focus", () => {
|
|
136
|
-
setLegacyActive("agent-A");
|
|
137
|
-
const { result } = renderHook(() => useAgentPanes([], { migrateLegacy: true }));
|
|
138
|
-
const sourceId = result.current.layout.rows[0][0].id;
|
|
139
|
-
act(() => {
|
|
140
|
-
result.current.splitPane(sourceId, "agent-B", "right");
|
|
141
|
-
});
|
|
142
|
-
// Focus is on agent-B (the new split). agent-A still exists.
|
|
143
|
-
const focusedAgentBPaneId = result.current.layout.focusedPaneId;
|
|
144
|
-
expect(focusedAgentBPaneId).not.toBe(sourceId);
|
|
145
|
-
act(() => {
|
|
146
|
-
// Only agent-A still exists.
|
|
147
|
-
result.current.pruneMissingAgents(["agent-A"]);
|
|
148
|
-
});
|
|
149
|
-
// agent-B's pane is replaced with profile-selector. Focus is preserved
|
|
150
|
-
// (the pane still exists; only its view changed).
|
|
151
|
-
const flatPanes = result.current.layout.rows.flat();
|
|
152
|
-
const stillAgentA = flatPanes.find((p) => p.view.kind === "agent" && p.view.agentId === "agent-A");
|
|
153
|
-
expect(stillAgentA).toBeTruthy();
|
|
154
|
-
const droppedB = flatPanes.find((p) => p.id === focusedAgentBPaneId);
|
|
155
|
-
expect(droppedB?.view.kind).toBe("profile-selector");
|
|
156
|
-
});
|
|
157
|
-
it("setFocusedPane is a no-op for a non-existent pane id", () => {
|
|
158
|
-
const { result } = renderHook(() => useAgentPanes([], { migrateLegacy: true }));
|
|
159
|
-
const original = result.current.layout.focusedPaneId;
|
|
160
|
-
act(() => {
|
|
161
|
-
result.current.setFocusedPane("does-not-exist");
|
|
162
|
-
});
|
|
163
|
-
expect(result.current.layout.focusedPaneId).toBe(original);
|
|
164
|
-
});
|
|
165
|
-
it("panesByAgentId memoization is consistent with layout", () => {
|
|
166
|
-
setLegacyActive("agent-A");
|
|
167
|
-
const { result } = renderHook(() => useAgentPanes([], { migrateLegacy: true }));
|
|
168
|
-
const sourceId = result.current.layout.rows[0][0].id;
|
|
169
|
-
act(() => {
|
|
170
|
-
result.current.splitPane(sourceId, "agent-A", "right");
|
|
171
|
-
});
|
|
172
|
-
const ids = result.current.panesByAgentId.get("agent-A");
|
|
173
|
-
expect(ids).toHaveLength(2);
|
|
174
|
-
expect(new Set(ids)).toEqual(new Set(result.current.layout.rows[0].map((p) => p.id)));
|
|
175
|
-
});
|
|
176
|
-
it("focusedAgentId returns the agent in the focused pane, or null", () => {
|
|
177
|
-
setLegacyActive("agent-A");
|
|
178
|
-
const { result } = renderHook(() => useAgentPanes([], { migrateLegacy: true }));
|
|
179
|
-
expect(result.current.focusedAgentId).toBe("agent-A");
|
|
180
|
-
act(() => {
|
|
181
|
-
result.current.showOverviewInFocusedPane();
|
|
182
|
-
});
|
|
183
|
-
expect(result.current.focusedAgentId).toBeNull();
|
|
184
|
-
});
|
|
185
|
-
it("persists layout JSON under the prefixed key", () => {
|
|
186
|
-
setLegacyActive("agent-A");
|
|
187
|
-
renderHook(() => useAgentPanes([], { migrateLegacy: true }));
|
|
188
|
-
const raw = window.localStorage.getItem(STORAGE_PREFIX + AGENT_PANES_LAYOUT_STORAGE_KEY);
|
|
189
|
-
expect(raw).not.toBeNull();
|
|
190
|
-
const parsed = JSON.parse(raw);
|
|
191
|
-
expect(parsed.orientation).toBe("horizontal");
|
|
192
|
-
expect(parsed.rows[0][0].view).toEqual({
|
|
193
|
-
kind: "agent",
|
|
194
|
-
agentId: "agent-A",
|
|
195
|
-
});
|
|
196
|
-
});
|
|
197
|
-
});
|
|
198
|
-
//# sourceMappingURL=useAgentPanes.test.js.map
|