@agent-native/core 0.47.1 → 0.48.1
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/bin/agent-native.js +41 -0
- package/dist/a2a/handlers.js +2 -2
- package/dist/a2a/handlers.js.map +1 -1
- package/dist/a2a/server.js +2 -2
- package/dist/a2a/server.js.map +1 -1
- package/dist/action.d.ts +43 -2
- package/dist/action.d.ts.map +1 -1
- package/dist/action.js.map +1 -1
- package/dist/agent/context-xray/actions/context-evict.d.ts +7 -1
- package/dist/agent/context-xray/actions/context-evict.d.ts.map +1 -1
- package/dist/agent/context-xray/actions/context-manifest-get.d.ts +4 -1
- package/dist/agent/context-xray/actions/context-manifest-get.d.ts.map +1 -1
- package/dist/agent/context-xray/actions/context-pin.d.ts +7 -1
- package/dist/agent/context-xray/actions/context-pin.d.ts.map +1 -1
- package/dist/agent/context-xray/actions/context-report.d.ts +12 -1
- package/dist/agent/context-xray/actions/context-report.d.ts.map +1 -1
- package/dist/agent/context-xray/actions/context-restore.d.ts +7 -1
- package/dist/agent/context-xray/actions/context-restore.d.ts.map +1 -1
- package/dist/agent/context-xray/apply-directives.d.ts.map +1 -1
- package/dist/agent/context-xray/apply-directives.js.map +1 -1
- package/dist/agent/context-xray/schema.d.ts +10 -10
- package/dist/agent/engine/ai-sdk-engine.d.ts.map +1 -1
- package/dist/agent/engine/ai-sdk-engine.js +26 -3
- package/dist/agent/engine/ai-sdk-engine.js.map +1 -1
- package/dist/agent/engine/anthropic-engine.d.ts +1 -1
- package/dist/agent/engine/anthropic-engine.d.ts.map +1 -1
- package/dist/agent/engine/builder-engine.d.ts +1 -1
- package/dist/agent/engine/builder-engine.d.ts.map +1 -1
- package/dist/agent/engine/builder-engine.js +47 -8
- package/dist/agent/engine/builder-engine.js.map +1 -1
- package/dist/agent/engine/builtin.js +1 -1
- package/dist/agent/engine/builtin.js.map +1 -1
- package/dist/agent/engine/output-tokens.d.ts +1 -1
- package/dist/agent/engine/output-tokens.d.ts.map +1 -1
- package/dist/agent/engine/output-tokens.js +6 -2
- package/dist/agent/engine/output-tokens.js.map +1 -1
- package/dist/agent/engine/registry.d.ts.map +1 -1
- package/dist/agent/engine/registry.js +7 -4
- package/dist/agent/engine/registry.js.map +1 -1
- package/dist/agent/engine/types.d.ts +19 -0
- package/dist/agent/engine/types.d.ts.map +1 -1
- package/dist/agent/engine/types.js +6 -0
- package/dist/agent/engine/types.js.map +1 -1
- package/dist/agent/model-config.d.ts +22 -14
- package/dist/agent/model-config.d.ts.map +1 -1
- package/dist/agent/model-config.js +113 -8
- package/dist/agent/model-config.js.map +1 -1
- package/dist/agent/production-agent.d.ts +19 -1
- package/dist/agent/production-agent.d.ts.map +1 -1
- package/dist/agent/production-agent.js +253 -39
- package/dist/agent/production-agent.js.map +1 -1
- package/dist/agent/run-loop-with-resume.d.ts.map +1 -1
- package/dist/agent/run-loop-with-resume.js +10 -0
- package/dist/agent/run-loop-with-resume.js.map +1 -1
- package/dist/agent/run-manager.d.ts +1 -0
- package/dist/agent/run-manager.d.ts.map +1 -1
- package/dist/agent/run-manager.js +36 -9
- package/dist/agent/run-manager.js.map +1 -1
- package/dist/agent/run-store.d.ts +47 -4
- package/dist/agent/run-store.d.ts.map +1 -1
- package/dist/agent/run-store.js +154 -4
- package/dist/agent/run-store.js.map +1 -1
- package/dist/agent/thread-data-builder.d.ts.map +1 -1
- package/dist/agent/thread-data-builder.js +57 -2
- package/dist/agent/thread-data-builder.js.map +1 -1
- package/dist/agent/types.d.ts +3 -0
- package/dist/agent/types.d.ts.map +1 -1
- package/dist/agent/types.js.map +1 -1
- package/dist/agent-web/generator.d.ts +3 -3
- package/dist/appearance/actions/change-appearance.d.ts +6 -1
- package/dist/appearance/actions/change-appearance.d.ts.map +1 -1
- package/dist/application-state/handlers.d.ts +2 -2
- package/dist/application-state/handlers.d.ts.map +1 -1
- package/dist/application-state/store.d.ts.map +1 -1
- package/dist/application-state/store.js +17 -0
- package/dist/application-state/store.js.map +1 -1
- package/dist/catalog.json +2 -1
- package/dist/cli/code-agent-commands.d.ts.map +1 -1
- package/dist/cli/code-agent-commands.js +2 -0
- package/dist/cli/code-agent-commands.js.map +1 -1
- package/dist/cli/code-agent-connector.js +7 -13
- package/dist/cli/code-agent-connector.js.map +1 -1
- package/dist/cli/code-agent-executor.d.ts +54 -2
- package/dist/cli/code-agent-executor.d.ts.map +1 -1
- package/dist/cli/code-agent-executor.js +504 -48
- package/dist/cli/code-agent-executor.js.map +1 -1
- package/dist/cli/code-agent-runs.d.ts +13 -0
- package/dist/cli/code-agent-runs.d.ts.map +1 -1
- package/dist/cli/code-agent-runs.js +36 -0
- package/dist/cli/code-agent-runs.js.map +1 -1
- package/dist/cli/code.js +59 -5
- package/dist/cli/code.js.map +1 -1
- package/dist/cli/connect.js +141 -3
- package/dist/cli/connect.js.map +1 -1
- package/dist/cli/index.js +0 -0
- package/dist/cli/pr-visual-recap-workflow.js +1 -1
- package/dist/cli/pr-visual-recap-workflow.js.map +1 -1
- package/dist/cli/recap.js +476 -46
- package/dist/cli/recap.js.map +1 -1
- package/dist/cli/skills.js +298 -179
- package/dist/cli/skills.js.map +1 -1
- package/dist/client/AgentPanel.d.ts.map +1 -1
- package/dist/client/AgentPanel.js +29 -2
- package/dist/client/AgentPanel.js.map +1 -1
- package/dist/client/AgentTaskCard.d.ts.map +1 -1
- package/dist/client/AgentTaskCard.js +17 -2
- package/dist/client/AgentTaskCard.js.map +1 -1
- package/dist/client/AssistantChat.d.ts +1 -1
- package/dist/client/AssistantChat.d.ts.map +1 -1
- package/dist/client/AssistantChat.js +310 -1732
- package/dist/client/AssistantChat.js.map +1 -1
- package/dist/client/CommandMenu.d.ts +1 -1
- package/dist/client/CommandMenu.d.ts.map +1 -1
- package/dist/client/CommandMenu.js +1 -1
- package/dist/client/CommandMenu.js.map +1 -1
- package/dist/client/HighlightedCodeBlock.d.ts +40 -0
- package/dist/client/HighlightedCodeBlock.d.ts.map +1 -0
- package/dist/client/HighlightedCodeBlock.js +110 -0
- package/dist/client/HighlightedCodeBlock.js.map +1 -0
- package/dist/client/MultiTabAssistantChat.d.ts.map +1 -1
- package/dist/client/MultiTabAssistantChat.js +8 -1
- package/dist/client/MultiTabAssistantChat.js.map +1 -1
- package/dist/client/PoweredByBadge.d.ts +2 -2
- package/dist/client/PoweredByBadge.d.ts.map +1 -1
- package/dist/client/RunStuckBanner.d.ts +1 -1
- package/dist/client/RunStuckBanner.d.ts.map +1 -1
- package/dist/client/StarfieldBackground.d.ts.map +1 -1
- package/dist/client/StarfieldBackground.js +10 -5
- package/dist/client/StarfieldBackground.js.map +1 -1
- package/dist/client/Turnstile.d.ts +1 -1
- package/dist/client/Turnstile.d.ts.map +1 -1
- package/dist/client/agent-chat-adapter.d.ts +3 -2
- package/dist/client/agent-chat-adapter.d.ts.map +1 -1
- package/dist/client/agent-chat-adapter.js +13 -9
- package/dist/client/agent-chat-adapter.js.map +1 -1
- package/dist/client/app-providers.d.ts +99 -0
- package/dist/client/app-providers.d.ts.map +1 -0
- package/dist/client/app-providers.js +19 -0
- package/dist/client/app-providers.js.map +1 -0
- package/dist/client/assistant-ui-recovery.d.ts +1 -1
- package/dist/client/auth-redirect-url.d.ts +1 -1
- package/dist/client/auth-redirect-url.d.ts.map +1 -1
- package/dist/client/blocks/library/AnnotatedCodeBlock.d.ts +0 -19
- package/dist/client/blocks/library/AnnotatedCodeBlock.d.ts.map +1 -1
- package/dist/client/blocks/library/AnnotatedCodeBlock.js +141 -55
- package/dist/client/blocks/library/AnnotatedCodeBlock.js.map +1 -1
- package/dist/client/blocks/library/DiffBlock.js +1 -1
- package/dist/client/blocks/library/DiffBlock.js.map +1 -1
- package/dist/client/blocks/library/FileTreeBlock.d.ts.map +1 -1
- package/dist/client/blocks/library/FileTreeBlock.js +1 -1
- package/dist/client/blocks/library/FileTreeBlock.js.map +1 -1
- package/dist/client/blocks/library/HighlightedCode.d.ts.map +1 -1
- package/dist/client/blocks/library/HighlightedCode.js +5 -3
- package/dist/client/blocks/library/HighlightedCode.js.map +1 -1
- package/dist/client/blocks/library/annotation-rail.d.ts +5 -4
- package/dist/client/blocks/library/annotation-rail.d.ts.map +1 -1
- package/dist/client/blocks/library/annotation-rail.js +22 -3
- package/dist/client/blocks/library/annotation-rail.js.map +1 -1
- package/dist/client/blocks/library/diagram.js +1 -1
- package/dist/client/blocks/library/diagram.js.map +1 -1
- package/dist/client/blocks/library/diff.config.d.ts +3 -2
- package/dist/client/blocks/library/diff.config.d.ts.map +1 -1
- package/dist/client/blocks/library/diff.config.js +4 -3
- package/dist/client/blocks/library/diff.config.js.map +1 -1
- package/dist/client/blocks/library/question-form.d.ts.map +1 -1
- package/dist/client/blocks/library/question-form.js +2 -1
- package/dist/client/blocks/library/question-form.js.map +1 -1
- package/dist/client/blocks/library/wireframe-kit.d.ts +1 -1
- package/dist/client/blocks/library/wireframe-kit.d.ts.map +1 -1
- package/dist/client/blocks/library/wireframe.js +1 -1
- package/dist/client/blocks/library/wireframe.js.map +1 -1
- package/dist/client/chat/attachment-adapters.d.ts +58 -0
- package/dist/client/chat/attachment-adapters.d.ts.map +1 -0
- package/dist/client/chat/attachment-adapters.js +331 -0
- package/dist/client/chat/attachment-adapters.js.map +1 -0
- package/dist/client/chat/index.d.ts +13 -0
- package/dist/client/chat/index.d.ts.map +1 -0
- package/dist/client/chat/index.js +13 -0
- package/dist/client/chat/index.js.map +1 -0
- package/dist/client/chat/markdown-renderer.d.ts +49 -0
- package/dist/client/chat/markdown-renderer.d.ts.map +1 -0
- package/dist/client/chat/markdown-renderer.js +391 -0
- package/dist/client/chat/markdown-renderer.js.map +1 -0
- package/dist/client/chat/message-components.d.ts +35 -0
- package/dist/client/chat/message-components.d.ts.map +1 -0
- package/dist/client/chat/message-components.js +452 -0
- package/dist/client/chat/message-components.js.map +1 -0
- package/dist/client/chat/repo-helpers.d.ts +41 -0
- package/dist/client/chat/repo-helpers.d.ts.map +1 -0
- package/dist/client/chat/repo-helpers.js +61 -0
- package/dist/client/chat/repo-helpers.js.map +1 -0
- package/dist/client/chat/run-recovery.d.ts +41 -0
- package/dist/client/chat/run-recovery.d.ts.map +1 -0
- package/dist/client/chat/run-recovery.js +348 -0
- package/dist/client/chat/run-recovery.js.map +1 -0
- package/dist/client/chat/tool-call-display.d.ts +34 -0
- package/dist/client/chat/tool-call-display.d.ts.map +1 -0
- package/dist/client/chat/tool-call-display.js +284 -0
- package/dist/client/chat/tool-call-display.js.map +1 -0
- package/dist/client/code-agent-chat-adapter.d.ts.map +1 -1
- package/dist/client/code-agent-chat-adapter.js +20 -0
- package/dist/client/code-agent-chat-adapter.js.map +1 -1
- package/dist/client/collab/index.d.ts +10 -0
- package/dist/client/collab/index.d.ts.map +1 -0
- package/dist/client/collab/index.js +10 -0
- package/dist/client/collab/index.js.map +1 -0
- package/dist/client/components/AgentPresenceChip.d.ts +1 -1
- package/dist/client/components/AgentPresenceChip.d.ts.map +1 -1
- package/dist/client/components/ApiKeySettings.d.ts +1 -1
- package/dist/client/components/ApiKeySettings.d.ts.map +1 -1
- package/dist/client/components/CodeAgentIndicator.d.ts +1 -1
- package/dist/client/components/CodeAgentIndicator.d.ts.map +1 -1
- package/dist/client/components/CodeRequiredDialog.d.ts +1 -1
- package/dist/client/components/CodeRequiredDialog.d.ts.map +1 -1
- package/dist/client/components/LiveCursorOverlay.d.ts.map +1 -1
- package/dist/client/components/LiveCursorOverlay.js.map +1 -1
- package/dist/client/components/PresenceBar.d.ts +1 -1
- package/dist/client/components/PresenceBar.d.ts.map +1 -1
- package/dist/client/composer/PromptComposer.d.ts.map +1 -1
- package/dist/client/composer/PromptComposer.js +6 -26
- package/dist/client/composer/PromptComposer.js.map +1 -1
- package/dist/client/composer/TiptapComposer.d.ts +8 -2
- package/dist/client/composer/TiptapComposer.d.ts.map +1 -1
- package/dist/client/composer/TiptapComposer.js +21 -9
- package/dist/client/composer/TiptapComposer.js.map +1 -1
- package/dist/client/composer/VoiceButton.d.ts +2 -2
- package/dist/client/composer/VoiceButton.d.ts.map +1 -1
- package/dist/client/composer/index.d.ts +1 -1
- package/dist/client/composer/index.d.ts.map +1 -1
- package/dist/client/composer/index.js +1 -1
- package/dist/client/composer/index.js.map +1 -1
- package/dist/client/composer/use-skills.d.ts +1 -1
- package/dist/client/context-xray/ContextMeter.d.ts +1 -1
- package/dist/client/context-xray/ContextMeter.d.ts.map +1 -1
- package/dist/client/context-xray/ContextMeter.js +3 -3
- package/dist/client/context-xray/ContextMeter.js.map +1 -1
- package/dist/client/context-xray/ContextXRayPanel.d.ts.map +1 -1
- package/dist/client/context-xray/ContextXRayPanel.js +4 -3
- package/dist/client/context-xray/ContextXRayPanel.js.map +1 -1
- package/dist/client/context-xray/format.d.ts +11 -0
- package/dist/client/context-xray/format.d.ts.map +1 -1
- package/dist/client/context-xray/format.js +16 -0
- package/dist/client/context-xray/format.js.map +1 -1
- package/dist/client/conversation/AgentConversation.d.ts.map +1 -1
- package/dist/client/conversation/AgentConversation.js +8 -53
- package/dist/client/conversation/AgentConversation.js.map +1 -1
- package/dist/client/conversation/use-near-bottom-autoscroll.d.ts +1 -1
- package/dist/client/conversation/use-near-bottom-autoscroll.d.ts.map +1 -1
- package/dist/client/conversation/use-near-bottom-autoscroll.js +14 -1
- package/dist/client/conversation/use-near-bottom-autoscroll.js.map +1 -1
- package/dist/client/create-query-client.d.ts +28 -0
- package/dist/client/create-query-client.d.ts.map +1 -0
- package/dist/client/create-query-client.js +78 -0
- package/dist/client/create-query-client.js.map +1 -0
- package/dist/client/db-admin/DevDatabaseLink.d.ts +1 -1
- package/dist/client/db-admin/DevDatabaseLink.d.ts.map +1 -1
- package/dist/client/db-admin/RowSidePanel.d.ts +1 -1
- package/dist/client/db-admin/RowSidePanel.d.ts.map +1 -1
- package/dist/client/db-admin/RowSidePanel.js +2 -2
- package/dist/client/db-admin/RowSidePanel.js.map +1 -1
- package/dist/client/db-admin/TableEditor.d.ts +1 -1
- package/dist/client/db-admin/TableEditor.d.ts.map +1 -1
- package/dist/client/db-admin/TableEditor.js +1 -1
- package/dist/client/db-admin/TableEditor.js.map +1 -1
- package/dist/client/db-admin/cell-format.d.ts +1 -1
- package/dist/client/db-admin/cell-format.d.ts.map +1 -1
- package/dist/client/dev-overlay/DevOverlay.d.ts +1 -1
- package/dist/client/dev-overlay/DevOverlay.d.ts.map +1 -1
- package/dist/client/editor/index.d.ts +2 -0
- package/dist/client/editor/index.d.ts.map +1 -0
- package/dist/client/editor/index.js +2 -0
- package/dist/client/editor/index.js.map +1 -0
- package/dist/client/error-format.d.ts.map +1 -1
- package/dist/client/error-format.js +4 -0
- package/dist/client/error-format.js.map +1 -1
- package/dist/client/extensions/AgentNativeExtensionFrame.d.ts +1 -1
- package/dist/client/extensions/AgentNativeExtensionFrame.d.ts.map +1 -1
- package/dist/client/extensions/EmbeddedExtension.d.ts +1 -1
- package/dist/client/extensions/EmbeddedExtension.d.ts.map +1 -1
- package/dist/client/extensions/ExtensionSlot.d.ts +1 -1
- package/dist/client/extensions/ExtensionSlot.d.ts.map +1 -1
- package/dist/client/extensions/ExtensionViewerPage.d.ts +1 -1
- package/dist/client/extensions/ExtensionViewerPage.d.ts.map +1 -1
- package/dist/client/guided-questions.d.ts +6 -6
- package/dist/client/host-bridge.d.ts.map +1 -1
- package/dist/client/host-bridge.js +2 -0
- package/dist/client/host-bridge.js.map +1 -1
- package/dist/client/index.d.ts +7 -6
- package/dist/client/index.d.ts.map +1 -1
- package/dist/client/index.js +5 -3
- package/dist/client/index.js.map +1 -1
- package/dist/client/onboarding/OnboardingBanner.d.ts +1 -1
- package/dist/client/onboarding/OnboardingBanner.d.ts.map +1 -1
- package/dist/client/onboarding/OnboardingPanel.d.ts +1 -1
- package/dist/client/onboarding/OnboardingPanel.d.ts.map +1 -1
- package/dist/client/onboarding/SetupButton.d.ts +1 -1
- package/dist/client/onboarding/SetupButton.d.ts.map +1 -1
- package/dist/client/org/InvitationBanner.d.ts +1 -1
- package/dist/client/org/InvitationBanner.d.ts.map +1 -1
- package/dist/client/org/OrgSwitcher.d.ts +1 -1
- package/dist/client/org/OrgSwitcher.d.ts.map +1 -1
- package/dist/client/org/RequireActiveOrg.d.ts +1 -1
- package/dist/client/org/RequireActiveOrg.d.ts.map +1 -1
- package/dist/client/org/hooks.d.ts +3 -3
- package/dist/client/org/hooks.d.ts.map +1 -1
- package/dist/client/progress/RunsTray.d.ts +2 -2
- package/dist/client/progress/RunsTray.d.ts.map +1 -1
- package/dist/client/progress/RunsTray.js +34 -9
- package/dist/client/progress/RunsTray.js.map +1 -1
- package/dist/client/resources/ResourceEditor.d.ts.map +1 -1
- package/dist/client/resources/ResourceEditor.js +1 -1
- package/dist/client/resources/ResourceEditor.js.map +1 -1
- package/dist/client/resources/ResourcesPanel.d.ts.map +1 -1
- package/dist/client/resources/ResourcesPanel.js +2 -0
- package/dist/client/resources/ResourcesPanel.js.map +1 -1
- package/dist/client/rich-markdown-editor/BubbleToolbar.d.ts +1 -1
- package/dist/client/rich-markdown-editor/BubbleToolbar.d.ts.map +1 -1
- package/dist/client/rich-markdown-editor/CodeBlockNode.d.ts.map +1 -1
- package/dist/client/rich-markdown-editor/CodeBlockNode.js +2 -1
- package/dist/client/rich-markdown-editor/CodeBlockNode.js.map +1 -1
- package/dist/client/rich-markdown-editor/ImageExtension.d.ts.map +1 -1
- package/dist/client/rich-markdown-editor/ImageExtension.js +2 -1
- package/dist/client/rich-markdown-editor/ImageExtension.js.map +1 -1
- package/dist/client/rich-markdown-editor/RegistryBlockNode.d.ts +1 -1
- package/dist/client/rich-markdown-editor/RegistryBlockNode.d.ts.map +1 -1
- package/dist/client/rich-markdown-editor/RegistryBlockNode.js +1 -1
- package/dist/client/rich-markdown-editor/RegistryBlockNode.js.map +1 -1
- package/dist/client/rich-markdown-editor/RichMarkdownEditor.d.ts +1 -1
- package/dist/client/rich-markdown-editor/SharedRichEditor.d.ts.map +1 -1
- package/dist/client/rich-markdown-editor/SharedRichEditor.js +2 -3
- package/dist/client/rich-markdown-editor/SharedRichEditor.js.map +1 -1
- package/dist/client/rich-markdown-editor/SlashCommandMenu.d.ts +1 -1
- package/dist/client/rich-markdown-editor/SlashCommandMenu.d.ts.map +1 -1
- package/dist/client/route-state.d.ts +12 -2
- package/dist/client/route-state.d.ts.map +1 -1
- package/dist/client/route-state.js +1 -1
- package/dist/client/route-state.js.map +1 -1
- package/dist/client/route-warmup.d.ts +1 -1
- package/dist/client/route-warmup.d.ts.map +1 -1
- package/dist/client/settings/VoiceTranscriptionSection.js +1 -1
- package/dist/client/settings/VoiceTranscriptionSection.js.map +1 -1
- package/dist/client/settings/useBuilderStatus.d.ts +2 -2
- package/dist/client/sharing/ShareDialog.d.ts +1 -1
- package/dist/client/sharing/ShareDialog.d.ts.map +1 -1
- package/dist/client/sse-event-processor.d.ts +8 -0
- package/dist/client/sse-event-processor.d.ts.map +1 -1
- package/dist/client/sse-event-processor.js +33 -10
- package/dist/client/sse-event-processor.js.map +1 -1
- package/dist/client/terminal/AgentTerminal.d.ts +1 -1
- package/dist/client/terminal/AgentTerminal.d.ts.map +1 -1
- package/dist/client/terminal/AgentTerminal.js +4 -2
- package/dist/client/terminal/AgentTerminal.js.map +1 -1
- package/dist/client/tool-cells/BashCell.d.ts +25 -0
- package/dist/client/tool-cells/BashCell.d.ts.map +1 -0
- package/dist/client/tool-cells/BashCell.js +49 -0
- package/dist/client/tool-cells/BashCell.js.map +1 -0
- package/dist/client/tool-cells/EditCell.d.ts +24 -0
- package/dist/client/tool-cells/EditCell.d.ts.map +1 -0
- package/dist/client/tool-cells/EditCell.js +126 -0
- package/dist/client/tool-cells/EditCell.js.map +1 -0
- package/dist/client/tool-cells/FilesChangedSummary.d.ts +13 -0
- package/dist/client/tool-cells/FilesChangedSummary.d.ts.map +1 -0
- package/dist/client/tool-cells/FilesChangedSummary.js +98 -0
- package/dist/client/tool-cells/FilesChangedSummary.js.map +1 -0
- package/dist/client/tool-cells/WriteCell.d.ts +17 -0
- package/dist/client/tool-cells/WriteCell.d.ts.map +1 -0
- package/dist/client/tool-cells/WriteCell.js +26 -0
- package/dist/client/tool-cells/WriteCell.js.map +1 -0
- package/dist/client/tool-cells/index.d.ts +8 -0
- package/dist/client/tool-cells/index.d.ts.map +1 -0
- package/dist/client/tool-cells/index.js +5 -0
- package/dist/client/tool-cells/index.js.map +1 -0
- package/dist/client/transcription/BuilderTranscriptionCta.d.ts +1 -1
- package/dist/client/transcription/BuilderTranscriptionCta.d.ts.map +1 -1
- package/dist/client/use-chat-threads.d.ts +1 -1
- package/dist/client/use-chat-threads.d.ts.map +1 -1
- package/dist/client/use-chat-threads.js +11 -8
- package/dist/client/use-chat-threads.js.map +1 -1
- package/dist/client/use-db-sync.d.ts +2 -0
- package/dist/client/use-db-sync.d.ts.map +1 -1
- package/dist/client/use-db-sync.js +329 -302
- package/dist/client/use-db-sync.js.map +1 -1
- package/dist/code-agents/transcript-normalizer.d.ts +15 -1
- package/dist/code-agents/transcript-normalizer.d.ts.map +1 -1
- package/dist/code-agents/transcript-normalizer.js +47 -0
- package/dist/code-agents/transcript-normalizer.js.map +1 -1
- package/dist/coding-tools/index.d.ts +75 -0
- package/dist/coding-tools/index.d.ts.map +1 -1
- package/dist/coding-tools/index.js +137 -10
- package/dist/coding-tools/index.js.map +1 -1
- package/dist/collab/client.d.ts.map +1 -1
- package/dist/collab/client.js +15 -9
- package/dist/collab/client.js.map +1 -1
- package/dist/collab/ydoc-manager.d.ts +1 -1
- package/dist/collab/ydoc-manager.d.ts.map +1 -1
- package/dist/collab/ydoc-manager.js +1 -1
- package/dist/collab/ydoc-manager.js.map +1 -1
- package/dist/db/client.d.ts +9 -1
- package/dist/db/client.d.ts.map +1 -1
- package/dist/db/client.js +204 -48
- package/dist/db/client.js.map +1 -1
- package/dist/db/create-get-db.d.ts +38 -0
- package/dist/db/create-get-db.d.ts.map +1 -1
- package/dist/db/create-get-db.js +204 -4
- package/dist/db/create-get-db.js.map +1 -1
- package/dist/db/migrations.d.ts.map +1 -1
- package/dist/db/migrations.js +159 -67
- package/dist/db/migrations.js.map +1 -1
- package/dist/demo/actions/toggle-demo-mode.d.ts +6 -1
- package/dist/demo/actions/toggle-demo-mode.d.ts.map +1 -1
- package/dist/deploy/build.d.ts.map +1 -1
- package/dist/deploy/build.js +80 -39
- package/dist/deploy/build.js.map +1 -1
- package/dist/deploy/workspace-deploy.js +20 -10
- package/dist/deploy/workspace-deploy.js.map +1 -1
- package/dist/extensions/schema.d.ts +51 -51
- package/dist/extensions/slots/schema.d.ts +13 -13
- package/dist/file-upload/actions/upload-image.d.ts +26 -1
- package/dist/file-upload/actions/upload-image.d.ts.map +1 -1
- package/dist/file-upload/index.d.ts +1 -1
- package/dist/file-upload/index.d.ts.map +1 -1
- package/dist/file-upload/index.js +1 -1
- package/dist/file-upload/index.js.map +1 -1
- package/dist/file-upload/pre-upload-attachments.d.ts +37 -0
- package/dist/file-upload/pre-upload-attachments.d.ts.map +1 -1
- package/dist/file-upload/pre-upload-attachments.js +79 -19
- package/dist/file-upload/pre-upload-attachments.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/integrations/adapters/slack.js +1 -1
- package/dist/integrations/adapters/slack.js.map +1 -1
- package/dist/integrations/plugin.js +1 -1
- package/dist/integrations/plugin.js.map +1 -1
- package/dist/jobs/scheduler.js +70 -21
- package/dist/jobs/scheduler.js.map +1 -1
- package/dist/mcp/actions/create-org-service-token.d.ts +14 -0
- package/dist/mcp/actions/create-org-service-token.d.ts.map +1 -0
- package/dist/mcp/actions/create-org-service-token.js +74 -0
- package/dist/mcp/actions/create-org-service-token.js.map +1 -0
- package/dist/mcp/actions/list-org-service-tokens.d.ts +17 -0
- package/dist/mcp/actions/list-org-service-tokens.d.ts.map +1 -0
- package/dist/mcp/actions/list-org-service-tokens.js +42 -0
- package/dist/mcp/actions/list-org-service-tokens.js.map +1 -0
- package/dist/mcp/actions/revoke-org-service-token.d.ts +7 -0
- package/dist/mcp/actions/revoke-org-service-token.d.ts.map +1 -0
- package/dist/mcp/actions/revoke-org-service-token.js +28 -0
- package/dist/mcp/actions/revoke-org-service-token.js.map +1 -0
- package/dist/mcp/actions/service-token-access.d.ts +24 -0
- package/dist/mcp/actions/service-token-access.d.ts.map +1 -0
- package/dist/mcp/actions/service-token-access.js +63 -0
- package/dist/mcp/actions/service-token-access.js.map +1 -0
- package/dist/mcp/build-server.d.ts +42 -11
- package/dist/mcp/build-server.d.ts.map +1 -1
- package/dist/mcp/build-server.js +53 -3
- package/dist/mcp/build-server.js.map +1 -1
- package/dist/mcp/connect-route.d.ts +35 -0
- package/dist/mcp/connect-route.d.ts.map +1 -1
- package/dist/mcp/connect-route.js +57 -2
- package/dist/mcp/connect-route.js.map +1 -1
- package/dist/mcp/connect-store.d.ts +43 -0
- package/dist/mcp/connect-store.d.ts.map +1 -1
- package/dist/mcp/connect-store.js +129 -12
- package/dist/mcp/connect-store.js.map +1 -1
- package/dist/mcp/oauth-token.d.ts +10 -0
- package/dist/mcp/oauth-token.d.ts.map +1 -1
- package/dist/mcp/oauth-token.js +2 -0
- package/dist/mcp/oauth-token.js.map +1 -1
- package/dist/mcp/server.d.ts.map +1 -1
- package/dist/mcp/server.js +3 -0
- package/dist/mcp/server.js.map +1 -1
- package/dist/mcp-client/routes.js +1 -1
- package/dist/mcp-client/routes.js.map +1 -1
- package/dist/org/context.d.ts +4 -0
- package/dist/org/context.d.ts.map +1 -1
- package/dist/org/context.js +10 -0
- package/dist/org/context.js.map +1 -1
- package/dist/org/handlers.d.ts +11 -7
- package/dist/org/handlers.d.ts.map +1 -1
- package/dist/org/handlers.js +0 -8
- package/dist/org/handlers.js.map +1 -1
- package/dist/org/migrations.d.ts.map +1 -1
- package/dist/org/migrations.js +8 -0
- package/dist/org/migrations.js.map +1 -1
- package/dist/org/schema.d.ts +15 -15
- package/dist/progress/actions.d.ts.map +1 -1
- package/dist/progress/actions.js +13 -5
- package/dist/progress/actions.js.map +1 -1
- package/dist/provider-api/actions/delete-staged-dataset.d.ts +9 -0
- package/dist/provider-api/actions/delete-staged-dataset.d.ts.map +1 -0
- package/dist/provider-api/actions/delete-staged-dataset.js +35 -0
- package/dist/provider-api/actions/delete-staged-dataset.js.map +1 -0
- package/dist/provider-api/actions/list-staged-datasets.d.ts +15 -0
- package/dist/provider-api/actions/list-staged-datasets.d.ts.map +1 -0
- package/dist/provider-api/actions/list-staged-datasets.js +41 -0
- package/dist/provider-api/actions/list-staged-datasets.js.map +1 -0
- package/dist/provider-api/actions/query-staged-dataset.d.ts +29 -0
- package/dist/provider-api/actions/query-staged-dataset.d.ts.map +1 -0
- package/dist/provider-api/actions/query-staged-dataset.js +116 -0
- package/dist/provider-api/actions/query-staged-dataset.js.map +1 -0
- package/dist/provider-api/custom-registry.d.ts.map +1 -1
- package/dist/provider-api/custom-registry.js.map +1 -1
- package/dist/provider-api/index.d.ts +10 -10
- package/dist/provider-api/index.js +0 -5
- package/dist/provider-api/index.js.map +1 -1
- package/dist/provider-api/staged-datasets-aggregate.d.ts +46 -0
- package/dist/provider-api/staged-datasets-aggregate.d.ts.map +1 -0
- package/dist/provider-api/staged-datasets-aggregate.js +209 -0
- package/dist/provider-api/staged-datasets-aggregate.js.map +1 -0
- package/dist/provider-api/staged-datasets-store.d.ts +76 -0
- package/dist/provider-api/staged-datasets-store.d.ts.map +1 -0
- package/dist/provider-api/staged-datasets-store.js +319 -0
- package/dist/provider-api/staged-datasets-store.js.map +1 -0
- package/dist/provider-api/staging.d.ts +100 -0
- package/dist/provider-api/staging.d.ts.map +1 -0
- package/dist/provider-api/staging.js +281 -0
- package/dist/provider-api/staging.js.map +1 -0
- package/dist/resources/handlers.d.ts.map +1 -1
- package/dist/resources/handlers.js +13 -1
- package/dist/resources/handlers.js.map +1 -1
- package/dist/scripts/call-agent.d.ts.map +1 -1
- package/dist/scripts/call-agent.js +1 -2
- package/dist/scripts/call-agent.js.map +1 -1
- package/dist/scripts/resources/migrate-learnings.d.ts +1 -1
- package/dist/scripts/resources/migrate-learnings.d.ts.map +1 -1
- package/dist/scripts/resources/migrate-learnings.js +1 -1
- package/dist/scripts/resources/migrate-learnings.js.map +1 -1
- package/dist/secrets/schema.d.ts +7 -7
- package/dist/server/action-discovery.d.ts.map +1 -1
- package/dist/server/action-discovery.js +14 -0
- package/dist/server/action-discovery.js.map +1 -1
- package/dist/server/action-routes.d.ts.map +1 -1
- package/dist/server/action-routes.js +3 -2
- package/dist/server/action-routes.js.map +1 -1
- package/dist/server/agent-chat-plugin.d.ts +33 -0
- package/dist/server/agent-chat-plugin.d.ts.map +1 -1
- package/dist/server/agent-chat-plugin.js +251 -180
- package/dist/server/agent-chat-plugin.js.map +1 -1
- package/dist/server/agent-discovery.d.ts.map +1 -1
- package/dist/server/agent-discovery.js +13 -16
- package/dist/server/agent-discovery.js.map +1 -1
- package/dist/server/agent-teams-run-queue.d.ts +31 -8
- package/dist/server/agent-teams-run-queue.d.ts.map +1 -1
- package/dist/server/agent-teams-run-queue.js +61 -18
- package/dist/server/agent-teams-run-queue.js.map +1 -1
- package/dist/server/agent-teams.d.ts +27 -1
- package/dist/server/agent-teams.d.ts.map +1 -1
- package/dist/server/agent-teams.js +214 -14
- package/dist/server/agent-teams.js.map +1 -1
- package/dist/server/app-base-path.d.ts +20 -0
- package/dist/server/app-base-path.d.ts.map +1 -1
- package/dist/server/app-base-path.js +36 -0
- package/dist/server/app-base-path.js.map +1 -1
- package/dist/server/attachment-actions.d.ts +43 -0
- package/dist/server/attachment-actions.d.ts.map +1 -0
- package/dist/server/attachment-actions.js +214 -0
- package/dist/server/attachment-actions.js.map +1 -0
- package/dist/server/auth.js +1 -1
- package/dist/server/auth.js.map +1 -1
- package/dist/server/complete-text.d.ts +56 -0
- package/dist/server/complete-text.d.ts.map +1 -0
- package/dist/server/complete-text.js +147 -0
- package/dist/server/complete-text.js.map +1 -0
- package/dist/server/core-routes-plugin.d.ts +1 -0
- package/dist/server/core-routes-plugin.d.ts.map +1 -1
- package/dist/server/core-routes-plugin.js +37 -27
- package/dist/server/core-routes-plugin.js.map +1 -1
- package/dist/server/cors-origins.d.ts.map +1 -1
- package/dist/server/cors-origins.js +6 -1
- package/dist/server/cors-origins.js.map +1 -1
- package/dist/server/create-server.d.ts.map +1 -1
- package/dist/server/create-server.js +2 -1
- package/dist/server/create-server.js.map +1 -1
- package/dist/server/csrf.d.ts +1 -1
- package/dist/server/csrf.d.ts.map +1 -1
- package/dist/server/email-actions.d.ts +19 -0
- package/dist/server/email-actions.d.ts.map +1 -0
- package/dist/server/email-actions.js +191 -0
- package/dist/server/email-actions.js.map +1 -0
- package/dist/server/embed-route.js +1 -1
- package/dist/server/embed-route.js.map +1 -1
- package/dist/server/embed-session.d.ts.map +1 -1
- package/dist/server/embed-session.js +5 -1
- package/dist/server/embed-session.js.map +1 -1
- package/dist/server/entry-server.d.ts +24 -0
- package/dist/server/entry-server.d.ts.map +1 -0
- package/dist/server/entry-server.js +54 -0
- package/dist/server/entry-server.js.map +1 -0
- package/dist/server/framework-request-handler.d.ts.map +1 -1
- package/dist/server/framework-request-handler.js +2 -10
- package/dist/server/framework-request-handler.js.map +1 -1
- package/dist/server/google-oauth.d.ts.map +1 -1
- package/dist/server/google-oauth.js +2 -9
- package/dist/server/google-oauth.js.map +1 -1
- package/dist/server/google-realtime-session.d.ts.map +1 -1
- package/dist/server/google-realtime-session.js +6 -4
- package/dist/server/google-realtime-session.js.map +1 -1
- package/dist/server/h3-helpers.d.ts +39 -0
- package/dist/server/h3-helpers.d.ts.map +1 -1
- package/dist/server/h3-helpers.js +104 -1
- package/dist/server/h3-helpers.js.map +1 -1
- package/dist/server/index.d.ts +2 -1
- package/dist/server/index.d.ts.map +1 -1
- package/dist/server/index.js +2 -1
- package/dist/server/index.js.map +1 -1
- package/dist/server/onboarding-html.d.ts.map +1 -1
- package/dist/server/onboarding-html.js +1 -8
- package/dist/server/onboarding-html.js.map +1 -1
- package/dist/server/open-route.d.ts.map +1 -1
- package/dist/server/open-route.js +1 -0
- package/dist/server/open-route.js.map +1 -1
- package/dist/server/prompts/framework-core-compact.d.ts +19 -0
- package/dist/server/prompts/framework-core-compact.d.ts.map +1 -0
- package/dist/server/prompts/framework-core-compact.js +69 -0
- package/dist/server/prompts/framework-core-compact.js.map +1 -0
- package/dist/server/prompts/framework-core.d.ts +26 -0
- package/dist/server/prompts/framework-core.d.ts.map +1 -0
- package/dist/server/prompts/framework-core.js +130 -0
- package/dist/server/prompts/framework-core.js.map +1 -0
- package/dist/server/prompts/index.d.ts +9 -0
- package/dist/server/prompts/index.d.ts.map +1 -0
- package/dist/server/prompts/index.js +9 -0
- package/dist/server/prompts/index.js.map +1 -0
- package/dist/server/prompts/model-overlays.d.ts +18 -0
- package/dist/server/prompts/model-overlays.d.ts.map +1 -0
- package/dist/server/prompts/model-overlays.js +46 -0
- package/dist/server/prompts/model-overlays.js.map +1 -0
- package/dist/server/prompts/shared-rules.d.ts +29 -0
- package/dist/server/prompts/shared-rules.d.ts.map +1 -0
- package/dist/server/prompts/shared-rules.js +54 -0
- package/dist/server/prompts/shared-rules.js.map +1 -0
- package/dist/server/security-headers.d.ts +7 -1
- package/dist/server/security-headers.d.ts.map +1 -1
- package/dist/server/security-headers.js +11 -0
- package/dist/server/security-headers.js.map +1 -1
- package/dist/server/ssr-handler.d.ts.map +1 -1
- package/dist/server/ssr-handler.js +135 -46
- package/dist/server/ssr-handler.js.map +1 -1
- package/dist/server/transcribe-voice.d.ts.map +1 -1
- package/dist/server/transcribe-voice.js +7 -4
- package/dist/server/transcribe-voice.js.map +1 -1
- package/dist/settings/store.d.ts.map +1 -1
- package/dist/settings/store.js +9 -0
- package/dist/settings/store.js.map +1 -1
- package/dist/shared/markdown-block-split.d.ts +39 -0
- package/dist/shared/markdown-block-split.d.ts.map +1 -0
- package/dist/shared/markdown-block-split.js +97 -0
- package/dist/shared/markdown-block-split.js.map +1 -0
- package/dist/shared/reasoning-effort.js +13 -1
- package/dist/shared/reasoning-effort.js.map +1 -1
- package/dist/shared/streaming-text-smoothing.d.ts +18 -0
- package/dist/shared/streaming-text-smoothing.d.ts.map +1 -1
- package/dist/shared/streaming-text-smoothing.js +70 -4
- package/dist/shared/streaming-text-smoothing.js.map +1 -1
- package/dist/sharing/actions/list-resource-shares.d.ts +24 -1
- package/dist/sharing/actions/list-resource-shares.d.ts.map +1 -1
- package/dist/sharing/actions/set-resource-visibility.d.ts +8 -1
- package/dist/sharing/actions/set-resource-visibility.d.ts.map +1 -1
- package/dist/sharing/actions/share-resource.d.ts +12 -1
- package/dist/sharing/actions/share-resource.d.ts.map +1 -1
- package/dist/sharing/actions/unshare-resource.d.ts +8 -1
- package/dist/sharing/actions/unshare-resource.d.ts.map +1 -1
- package/dist/sharing/schema.d.ts +10 -10
- package/dist/styles/agent-conversation.css +239 -0
- package/dist/templates/default/.agents/skills/delegate-to-agent/SKILL.md +50 -2
- package/dist/templates/default/AGENTS.md +1 -1
- package/dist/templates/default/DEVELOPING.md +19 -0
- package/dist/templates/default/app/entry.client.tsx +4 -1
- package/dist/templates/default/app/entry.server.tsx +4 -56
- package/dist/templates/default/app/global.css +3 -2
- package/dist/templates/default/app/root.tsx +8 -24
- package/dist/templates/default/app/routes/_index.tsx +0 -13
- package/dist/templates/default/package.json +6 -5
- package/dist/templates/default/tsconfig.json +2 -1
- package/dist/templates/starter-shell-sync.spec.ts +118 -0
- package/dist/templates/ui-primitives-sync.spec.ts +399 -0
- package/dist/templates/workspace-core/.agents/skills/delegate-to-agent/SKILL.md +50 -2
- package/dist/terminal/pty-server.js +1 -1
- package/dist/terminal/pty-server.js.map +1 -1
- package/dist/triggers/dispatcher.js +1 -1
- package/dist/triggers/dispatcher.js.map +1 -1
- package/dist/usage/store.d.ts.map +1 -1
- package/dist/usage/store.js +60 -7
- package/dist/usage/store.js.map +1 -1
- package/dist/vite/client.d.ts.map +1 -1
- package/dist/vite/client.js +44 -12
- package/dist/vite/client.js.map +1 -1
- package/dist/workspace-files/schema.d.ts +8 -8
- package/dist/workspace-files/tool.d.ts.map +1 -1
- package/dist/workspace-files/tool.js +0 -1
- package/dist/workspace-files/tool.js.map +1 -1
- package/docs/content/a2a-protocol.md +18 -12
- package/docs/content/actions.md +42 -10
- package/docs/content/agent-mentions.md +7 -8
- package/docs/content/agent-teams.md +23 -37
- package/docs/content/agent-web-surfaces.md +18 -9
- package/docs/content/authentication.md +6 -17
- package/docs/content/automations.md +43 -15
- package/docs/content/cli-adapters.md +25 -24
- package/docs/content/client.md +66 -17
- package/docs/content/cloneable-saas.md +19 -23
- package/docs/content/code-agents-ui.md +3 -31
- package/docs/content/components.md +308 -0
- package/docs/content/context-awareness.md +4 -0
- package/docs/content/creating-templates.md +4 -2
- package/docs/content/cross-app-sso.md +45 -19
- package/docs/content/database.md +26 -1
- package/docs/content/deployment.md +3 -1
- package/docs/content/dispatch.md +9 -37
- package/docs/content/drop-in-agent.md +123 -2
- package/docs/content/embedding-sdk.md +35 -0
- package/docs/content/extensions.md +2 -2
- package/docs/content/external-agents.md +86 -171
- package/docs/content/faq.md +6 -27
- package/docs/content/frames.md +9 -12
- package/docs/content/getting-started.md +80 -77
- package/docs/content/key-concepts.md +29 -19
- package/docs/content/mcp-apps.md +103 -0
- package/docs/content/mcp-clients.md +2 -2
- package/docs/content/mcp-protocol.md +40 -17
- package/docs/content/messaging.md +11 -4
- package/docs/content/migration-workbench.md +4 -47
- package/docs/content/multi-app-workspace.md +48 -17
- package/docs/content/multi-tenancy.md +1 -1
- package/docs/content/notifications.md +8 -6
- package/docs/content/observability.md +26 -15
- package/docs/content/onboarding.md +7 -1
- package/docs/content/pr-visual-recap.md +203 -23
- package/docs/content/progress.md +5 -5
- package/docs/content/pure-agent-apps.md +3 -1
- package/docs/content/real-time-collaboration.md +106 -0
- package/docs/content/recurring-jobs.md +17 -1
- package/docs/content/security.md +17 -3
- package/docs/content/server.md +39 -3
- package/docs/content/sharing.md +20 -1
- package/docs/content/skills-guide.md +151 -125
- package/docs/content/template-analytics.md +8 -0
- package/docs/content/template-assets.md +2 -0
- package/docs/content/template-brain.md +59 -3
- package/docs/content/template-calendar.md +8 -0
- package/docs/content/template-clips.md +11 -2
- package/docs/content/template-content.md +24 -4
- package/docs/content/template-design.md +19 -17
- package/docs/content/template-dispatch.md +2 -0
- package/docs/content/template-forms.md +28 -1
- package/docs/content/template-mail.md +17 -0
- package/docs/content/template-plan.md +177 -10
- package/docs/content/template-slides.md +51 -12
- package/docs/content/template-videos.md +17 -0
- package/docs/content/tracking.md +17 -13
- package/docs/content/using-your-agent.md +15 -5
- package/docs/content/voice-input.md +1 -1
- package/docs/content/what-is-agent-native.md +5 -6
- package/docs/content/workspace-connections.md +138 -424
- package/docs/content/workspace-management.md +12 -128
- package/docs/content/workspace.md +125 -199
- package/docs/content/writing-agent-instructions.md +17 -1
- package/package.json +25 -6
- package/src/templates/default/.agents/skills/delegate-to-agent/SKILL.md +50 -2
- package/src/templates/default/AGENTS.md +1 -1
- package/src/templates/default/DEVELOPING.md +19 -0
- package/src/templates/default/app/entry.client.tsx +4 -1
- package/src/templates/default/app/entry.server.tsx +4 -56
- package/src/templates/default/app/global.css +3 -2
- package/src/templates/default/app/root.tsx +8 -24
- package/src/templates/default/app/routes/_index.tsx +0 -13
- package/src/templates/default/package.json +6 -5
- package/src/templates/default/tsconfig.json +2 -1
- package/src/templates/starter-shell-sync.spec.ts +118 -0
- package/src/templates/ui-primitives-sync.spec.ts +399 -0
- package/src/templates/workspace-core/.agents/skills/delegate-to-agent/SKILL.md +50 -2
- package/tsconfig.base.json +2 -10
- package/dist/cli/app-skill.d.ts +0 -157
- package/dist/cli/app-skill.d.ts.map +0 -1
- package/dist/cli/audit-agent-web.d.ts +0 -2
- package/dist/cli/audit-agent-web.d.ts.map +0 -1
- package/dist/cli/code-agent-connector.d.ts +0 -17
- package/dist/cli/code-agent-connector.d.ts.map +0 -1
- package/dist/cli/code.d.ts +0 -66
- package/dist/cli/code.d.ts.map +0 -1
- package/dist/cli/connect.d.ts +0 -140
- package/dist/cli/connect.d.ts.map +0 -1
- package/dist/cli/context-xray-local.d.ts +0 -16
- package/dist/cli/context-xray-local.d.ts.map +0 -1
- package/dist/cli/create-workspace.d.ts +0 -8
- package/dist/cli/create-workspace.d.ts.map +0 -1
- package/dist/cli/index.d.ts +0 -3
- package/dist/cli/index.d.ts.map +0 -1
- package/dist/cli/info.d.ts +0 -2
- package/dist/cli/info.d.ts.map +0 -1
- package/dist/cli/mcp-config-writers.d.ts +0 -82
- package/dist/cli/mcp-config-writers.d.ts.map +0 -1
- package/dist/cli/mcp.d.ts +0 -16
- package/dist/cli/mcp.d.ts.map +0 -1
- package/dist/cli/migrate.d.ts +0 -38
- package/dist/cli/migrate.d.ts.map +0 -1
- package/dist/cli/plan-local.d.ts +0 -43
- package/dist/cli/plan-local.d.ts.map +0 -1
- package/dist/cli/plan-publish-store.d.ts +0 -62
- package/dist/cli/plan-publish-store.d.ts.map +0 -1
- package/dist/cli/pr-visual-recap-workflow.d.ts +0 -11
- package/dist/cli/pr-visual-recap-workflow.d.ts.map +0 -1
- package/dist/cli/recap.d.ts +0 -297
- package/dist/cli/recap.d.ts.map +0 -1
- package/dist/cli/skills.d.ts +0 -162
- package/dist/cli/skills.d.ts.map +0 -1
- package/dist/cli/workspace-dev.d.ts +0 -96
- package/dist/cli/workspace-dev.d.ts.map +0 -1
|
@@ -38,15 +38,6 @@ function normalizeEventPayload(payload) {
|
|
|
38
38
|
}
|
|
39
39
|
return [payload];
|
|
40
40
|
}
|
|
41
|
-
function eventVersion(event) {
|
|
42
|
-
return typeof event.version === "number" ? event.version : 0;
|
|
43
|
-
}
|
|
44
|
-
function hasAppStateEvent(events, key) {
|
|
45
|
-
return events.some((event) => event.source === "app-state" &&
|
|
46
|
-
(event.key === key ||
|
|
47
|
-
event.key === "*" ||
|
|
48
|
-
(typeof event.key === "string" && event.key.startsWith(`${key}:`))));
|
|
49
|
-
}
|
|
50
41
|
function isAuthFailure(error) {
|
|
51
42
|
return (!!error &&
|
|
52
43
|
typeof error === "object" &&
|
|
@@ -72,6 +63,287 @@ async function fetchPollJson(pollUrl, since, interval) {
|
|
|
72
63
|
clearTimeout(timeout);
|
|
73
64
|
}
|
|
74
65
|
}
|
|
66
|
+
class SyncTransport {
|
|
67
|
+
pollUrl;
|
|
68
|
+
sseUrl;
|
|
69
|
+
subscribers = new Map();
|
|
70
|
+
versionRef = 0;
|
|
71
|
+
timer = null;
|
|
72
|
+
stopped = false;
|
|
73
|
+
inFlight = false;
|
|
74
|
+
eventSource = null;
|
|
75
|
+
sseConnected = false;
|
|
76
|
+
authFailureUntil = 0;
|
|
77
|
+
constructor(pollUrl, sseUrl) {
|
|
78
|
+
this.pollUrl = pollUrl;
|
|
79
|
+
this.sseUrl = sseUrl;
|
|
80
|
+
}
|
|
81
|
+
// -------------------------------------------------------------------------
|
|
82
|
+
// Subscriber management
|
|
83
|
+
// -------------------------------------------------------------------------
|
|
84
|
+
add(id, sub) {
|
|
85
|
+
const wasEmpty = this.subscribers.size === 0;
|
|
86
|
+
this.subscribers.set(id, sub);
|
|
87
|
+
if (wasEmpty) {
|
|
88
|
+
this.stopped = false;
|
|
89
|
+
this.start();
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
remove(id) {
|
|
93
|
+
this.subscribers.delete(id);
|
|
94
|
+
if (this.subscribers.size === 0) {
|
|
95
|
+
this.teardown();
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
// Recalculate poll interval in case the leaving subscriber was the
|
|
99
|
+
// fastest caller; reschedule with the updated cadence.
|
|
100
|
+
this.reschedule();
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
// -------------------------------------------------------------------------
|
|
104
|
+
// Derived settings (aggregate over active subscribers)
|
|
105
|
+
// -------------------------------------------------------------------------
|
|
106
|
+
get effectivePauseWhenHidden() {
|
|
107
|
+
// Pause only if every subscriber has opted in.
|
|
108
|
+
for (const sub of this.subscribers.values()) {
|
|
109
|
+
if (!sub.pauseWhenHidden)
|
|
110
|
+
return false;
|
|
111
|
+
}
|
|
112
|
+
return true;
|
|
113
|
+
}
|
|
114
|
+
get effectiveInterval() {
|
|
115
|
+
let min = Infinity;
|
|
116
|
+
for (const sub of this.subscribers.values()) {
|
|
117
|
+
if (sub.interval < min)
|
|
118
|
+
min = sub.interval;
|
|
119
|
+
}
|
|
120
|
+
return isFinite(min) ? min : 2000;
|
|
121
|
+
}
|
|
122
|
+
get effectiveFallbackInterval() {
|
|
123
|
+
let min = Infinity;
|
|
124
|
+
for (const sub of this.subscribers.values()) {
|
|
125
|
+
if (sub.fallbackInterval < min)
|
|
126
|
+
min = sub.fallbackInterval;
|
|
127
|
+
}
|
|
128
|
+
return isFinite(min) ? min : SSE_FALLBACK_INTERVAL_MS;
|
|
129
|
+
}
|
|
130
|
+
// -------------------------------------------------------------------------
|
|
131
|
+
// Event fan-out
|
|
132
|
+
// -------------------------------------------------------------------------
|
|
133
|
+
fan(events, version) {
|
|
134
|
+
for (const sub of this.subscribers.values()) {
|
|
135
|
+
sub.onEvents(events, version);
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
// -------------------------------------------------------------------------
|
|
139
|
+
// SSE + poll loop (mirrors the original per-hook logic exactly)
|
|
140
|
+
// -------------------------------------------------------------------------
|
|
141
|
+
authFailureDelayMs() {
|
|
142
|
+
return Math.max(0, this.authFailureUntil - Date.now());
|
|
143
|
+
}
|
|
144
|
+
schedulePoll() {
|
|
145
|
+
if (this.stopped)
|
|
146
|
+
return;
|
|
147
|
+
if (this.effectivePauseWhenHidden && isDocumentHidden())
|
|
148
|
+
return;
|
|
149
|
+
if (this.timer)
|
|
150
|
+
clearTimeout(this.timer);
|
|
151
|
+
const authDelay = this.authFailureDelayMs();
|
|
152
|
+
if (authDelay > 0) {
|
|
153
|
+
this.timer = setTimeout(() => {
|
|
154
|
+
this.timer = null;
|
|
155
|
+
void this.poll();
|
|
156
|
+
}, authDelay);
|
|
157
|
+
return;
|
|
158
|
+
}
|
|
159
|
+
this.timer = setTimeout(() => {
|
|
160
|
+
this.timer = null;
|
|
161
|
+
void this.poll();
|
|
162
|
+
}, this.sseConnected
|
|
163
|
+
? this.effectiveFallbackInterval
|
|
164
|
+
: this.effectiveInterval);
|
|
165
|
+
}
|
|
166
|
+
reschedule() {
|
|
167
|
+
// Only need to act if a timer is already pending; next natural tick will
|
|
168
|
+
// pick up the new effective interval otherwise.
|
|
169
|
+
if (this.timer !== null) {
|
|
170
|
+
clearTimeout(this.timer);
|
|
171
|
+
this.timer = null;
|
|
172
|
+
this.schedulePoll();
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
closeEvents() {
|
|
176
|
+
if (!this.eventSource)
|
|
177
|
+
return;
|
|
178
|
+
this.eventSource.close();
|
|
179
|
+
this.eventSource = null;
|
|
180
|
+
this.sseConnected = false;
|
|
181
|
+
}
|
|
182
|
+
connectEvents() {
|
|
183
|
+
if (this.stopped ||
|
|
184
|
+
!this.sseUrl ||
|
|
185
|
+
this.eventSource ||
|
|
186
|
+
typeof EventSource === "undefined" ||
|
|
187
|
+
(this.effectivePauseWhenHidden && isDocumentHidden())) {
|
|
188
|
+
return;
|
|
189
|
+
}
|
|
190
|
+
const source = new EventSource(this.sseUrl);
|
|
191
|
+
this.eventSource = source;
|
|
192
|
+
source.onopen = () => {
|
|
193
|
+
this.sseConnected = true;
|
|
194
|
+
this.schedulePoll();
|
|
195
|
+
};
|
|
196
|
+
source.onerror = () => {
|
|
197
|
+
this.sseConnected = false;
|
|
198
|
+
// When the browser gives up permanently (HTTP error → readyState
|
|
199
|
+
// CLOSED), it won't auto-reconnect. Drop the ref so a later
|
|
200
|
+
// connectEvents() (on focus/visibility) can establish a fresh stream;
|
|
201
|
+
// otherwise the non-null closed `eventSource` blocks reconnection and
|
|
202
|
+
// we'd be stuck on polling-only forever.
|
|
203
|
+
if (source.readyState === EventSource.CLOSED) {
|
|
204
|
+
this.eventSource = null;
|
|
205
|
+
}
|
|
206
|
+
this.schedulePoll();
|
|
207
|
+
};
|
|
208
|
+
source.onmessage = (message) => {
|
|
209
|
+
try {
|
|
210
|
+
const payload = JSON.parse(message.data);
|
|
211
|
+
const events = normalizeEventPayload(payload);
|
|
212
|
+
const version = typeof payload?.version === "number" ? payload.version : undefined;
|
|
213
|
+
this.applyVersion(events, version);
|
|
214
|
+
this.fan(events, version);
|
|
215
|
+
}
|
|
216
|
+
catch {
|
|
217
|
+
// Ignore malformed SSE frames; polling is the safety net.
|
|
218
|
+
}
|
|
219
|
+
};
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* Advance the transport's shared version cursor. Subscribers receive the
|
|
223
|
+
* raw events and decide independently which ones are "fresh" relative to
|
|
224
|
+
* their own cursor, but the transport-level cursor ensures the poll
|
|
225
|
+
* `?since=` parameter always advances.
|
|
226
|
+
*/
|
|
227
|
+
applyVersion(events, version) {
|
|
228
|
+
let max = typeof version === "number" ? version : 0;
|
|
229
|
+
for (const evt of events) {
|
|
230
|
+
const v = typeof evt.version === "number" ? evt.version : 0;
|
|
231
|
+
if (v > max)
|
|
232
|
+
max = v;
|
|
233
|
+
}
|
|
234
|
+
if (max > this.versionRef)
|
|
235
|
+
this.versionRef = max;
|
|
236
|
+
}
|
|
237
|
+
async poll() {
|
|
238
|
+
if (this.stopped || this.inFlight)
|
|
239
|
+
return;
|
|
240
|
+
this.inFlight = true;
|
|
241
|
+
try {
|
|
242
|
+
const data = await fetchPollJson(this.pollUrl, this.versionRef, this.effectiveInterval);
|
|
243
|
+
if (this.stopped)
|
|
244
|
+
return;
|
|
245
|
+
const events = data.events ?? [];
|
|
246
|
+
this.applyVersion(events, data.version);
|
|
247
|
+
this.fan(events, data.version);
|
|
248
|
+
}
|
|
249
|
+
catch (err) {
|
|
250
|
+
if (this.stopped)
|
|
251
|
+
return;
|
|
252
|
+
if (isAuthFailure(err)) {
|
|
253
|
+
this.authFailureUntil = Date.now() + POLL_AUTH_FAILURE_COOLDOWN_MS;
|
|
254
|
+
this.closeEvents();
|
|
255
|
+
}
|
|
256
|
+
// Network error — will retry on next interval.
|
|
257
|
+
}
|
|
258
|
+
finally {
|
|
259
|
+
this.inFlight = false;
|
|
260
|
+
this.schedulePoll();
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
pollNow() {
|
|
264
|
+
if (this.effectivePauseWhenHidden && isDocumentHidden())
|
|
265
|
+
return;
|
|
266
|
+
if (this.authFailureDelayMs() > 0) {
|
|
267
|
+
this.schedulePoll();
|
|
268
|
+
return;
|
|
269
|
+
}
|
|
270
|
+
if (this.timer) {
|
|
271
|
+
clearTimeout(this.timer);
|
|
272
|
+
this.timer = null;
|
|
273
|
+
}
|
|
274
|
+
this.connectEvents();
|
|
275
|
+
void this.poll();
|
|
276
|
+
}
|
|
277
|
+
handleVisibilityChange = () => {
|
|
278
|
+
if (document.visibilityState === "visible") {
|
|
279
|
+
this.connectEvents();
|
|
280
|
+
this.pollNow();
|
|
281
|
+
}
|
|
282
|
+
else if (this.effectivePauseWhenHidden) {
|
|
283
|
+
this.closeEvents();
|
|
284
|
+
if (this.timer) {
|
|
285
|
+
clearTimeout(this.timer);
|
|
286
|
+
this.timer = null;
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
};
|
|
290
|
+
handleFocus = () => {
|
|
291
|
+
this.pollNow();
|
|
292
|
+
};
|
|
293
|
+
start() {
|
|
294
|
+
// Universal demo-mode redaction for the UI. Idempotent + browser-only +
|
|
295
|
+
// a no-op until demo mode is on. Lives here because every template root
|
|
296
|
+
// already mounts useDbSync, so this needs zero per-template wiring.
|
|
297
|
+
ensureEmbedAuthFetchInterceptor();
|
|
298
|
+
ensureDemoModeFetchInterceptor();
|
|
299
|
+
if (!this.effectivePauseWhenHidden || !isDocumentHidden()) {
|
|
300
|
+
this.connectEvents();
|
|
301
|
+
void this.poll();
|
|
302
|
+
}
|
|
303
|
+
window.addEventListener("focus", this.handleFocus);
|
|
304
|
+
document.addEventListener("visibilitychange", this.handleVisibilityChange);
|
|
305
|
+
}
|
|
306
|
+
teardown() {
|
|
307
|
+
this.stopped = true;
|
|
308
|
+
this.closeEvents();
|
|
309
|
+
if (this.timer) {
|
|
310
|
+
clearTimeout(this.timer);
|
|
311
|
+
this.timer = null;
|
|
312
|
+
}
|
|
313
|
+
window.removeEventListener("focus", this.handleFocus);
|
|
314
|
+
document.removeEventListener("visibilitychange", this.handleVisibilityChange);
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
/**
|
|
318
|
+
* Registry of active transports keyed by "<pollUrl>\0<sseUrl>".
|
|
319
|
+
* Module-level singleton: survives React render cycles, shared across all
|
|
320
|
+
* hook instances in the same browser tab.
|
|
321
|
+
*/
|
|
322
|
+
const transportRegistry = new Map();
|
|
323
|
+
function getOrCreateTransport(pollUrl, sseUrl) {
|
|
324
|
+
const key = `${pollUrl}\0${String(sseUrl)}`;
|
|
325
|
+
let transport = transportRegistry.get(key);
|
|
326
|
+
if (!transport) {
|
|
327
|
+
transport = new SyncTransport(pollUrl, sseUrl);
|
|
328
|
+
transportRegistry.set(key, transport);
|
|
329
|
+
}
|
|
330
|
+
return transport;
|
|
331
|
+
}
|
|
332
|
+
/** Remove a transport from the registry once torn down (last subscriber left). */
|
|
333
|
+
function releaseTransport(pollUrl, sseUrl) {
|
|
334
|
+
const key = `${pollUrl}\0${String(sseUrl)}`;
|
|
335
|
+
// Leave the entry in place: SSE/poll is already stopped inside the class;
|
|
336
|
+
// the next subscriber will re-start it via `add()`. Clearing the map entry
|
|
337
|
+
// prevents any dangling reference from the old SyncTransport instance.
|
|
338
|
+
transportRegistry.delete(key);
|
|
339
|
+
}
|
|
340
|
+
// ---------------------------------------------------------------------------
|
|
341
|
+
// Internal test helper — reset transport registry between tests.
|
|
342
|
+
// ---------------------------------------------------------------------------
|
|
343
|
+
/** @internal */
|
|
344
|
+
export function _resetSyncTransportRegistryForTests() {
|
|
345
|
+
transportRegistry.clear();
|
|
346
|
+
}
|
|
75
347
|
/**
|
|
76
348
|
* Hook that listens to /_agent-native/events for DB change events and
|
|
77
349
|
* invalidates react-query caches when changes are detected. Falls back to
|
|
@@ -106,40 +378,15 @@ export function useDbSync(options = {}) {
|
|
|
106
378
|
const ignoreSourceRef = useRef(options.ignoreSource);
|
|
107
379
|
ignoreSourceRef.current = options.ignoreSource;
|
|
108
380
|
useEffect(() => {
|
|
109
|
-
|
|
110
|
-
//
|
|
111
|
-
//
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
let eventSource = null;
|
|
119
|
-
let sseConnected = false;
|
|
120
|
-
let authFailureUntil = 0;
|
|
121
|
-
function authFailureDelayMs() {
|
|
122
|
-
return Math.max(0, authFailureUntil - Date.now());
|
|
123
|
-
}
|
|
124
|
-
function schedulePoll() {
|
|
125
|
-
if (stopped)
|
|
126
|
-
return;
|
|
127
|
-
if (pauseWhenHidden && isDocumentHidden())
|
|
128
|
-
return;
|
|
129
|
-
if (timer)
|
|
130
|
-
clearTimeout(timer);
|
|
131
|
-
const authDelay = authFailureDelayMs();
|
|
132
|
-
if (authDelay > 0) {
|
|
133
|
-
timer = setTimeout(() => {
|
|
134
|
-
timer = null;
|
|
135
|
-
void poll();
|
|
136
|
-
}, authDelay);
|
|
137
|
-
return;
|
|
138
|
-
}
|
|
139
|
-
timer = setTimeout(() => {
|
|
140
|
-
timer = null;
|
|
141
|
-
void poll();
|
|
142
|
-
}, sseConnected ? fallbackInterval : interval);
|
|
381
|
+
const id = Symbol("useDbSync");
|
|
382
|
+
// Per-subscriber version cursor: tracks which events have already been
|
|
383
|
+
// processed by THIS subscriber so stale poll re-deliveries are ignored.
|
|
384
|
+
let subscriberVersion = 0;
|
|
385
|
+
function hasAppStateEvent(events, key) {
|
|
386
|
+
return events.some((event) => event.source === "app-state" &&
|
|
387
|
+
(event.key === key ||
|
|
388
|
+
event.key === "*" ||
|
|
389
|
+
(typeof event.key === "string" && event.key.startsWith(`${key}:`))));
|
|
143
390
|
}
|
|
144
391
|
function invalidateForEvents(events) {
|
|
145
392
|
const ignore = ignoreSourceRef.current;
|
|
@@ -199,128 +446,33 @@ export function useDbSync(options = {}) {
|
|
|
199
446
|
onEventRef.current?.(evt);
|
|
200
447
|
}
|
|
201
448
|
}
|
|
202
|
-
function
|
|
449
|
+
function onEvents(events, version) {
|
|
203
450
|
const freshEvents = events.filter((event) => {
|
|
204
|
-
const
|
|
205
|
-
return
|
|
451
|
+
const v = typeof event.version === "number" ? event.version : 0;
|
|
452
|
+
return v === 0 || v > subscriberVersion;
|
|
206
453
|
});
|
|
207
454
|
if (freshEvents.length > 0) {
|
|
208
455
|
invalidateForEvents(freshEvents);
|
|
209
456
|
}
|
|
210
|
-
const maxEventVersion = freshEvents.reduce((max, event) => Math.max(max,
|
|
211
|
-
|
|
212
|
-
}
|
|
213
|
-
function closeEvents() {
|
|
214
|
-
if (!eventSource)
|
|
215
|
-
return;
|
|
216
|
-
eventSource.close();
|
|
217
|
-
eventSource = null;
|
|
218
|
-
sseConnected = false;
|
|
457
|
+
const maxEventVersion = freshEvents.reduce((max, event) => Math.max(max, typeof event.version === "number" ? event.version : 0), 0);
|
|
458
|
+
subscriberVersion = Math.max(subscriberVersion, version ?? 0, maxEventVersion);
|
|
219
459
|
}
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
}
|
|
228
|
-
const source = new EventSource(sseUrl);
|
|
229
|
-
eventSource = source;
|
|
230
|
-
source.onopen = () => {
|
|
231
|
-
sseConnected = true;
|
|
232
|
-
schedulePoll();
|
|
233
|
-
};
|
|
234
|
-
source.onerror = () => {
|
|
235
|
-
sseConnected = false;
|
|
236
|
-
// When the browser gives up permanently (HTTP error → readyState
|
|
237
|
-
// CLOSED), it won't auto-reconnect. Drop the ref so a later
|
|
238
|
-
// connectEvents() (on focus/visibility) can establish a fresh stream;
|
|
239
|
-
// otherwise the non-null closed `eventSource` blocks reconnection and
|
|
240
|
-
// we'd be stuck on polling-only forever.
|
|
241
|
-
if (source.readyState === EventSource.CLOSED) {
|
|
242
|
-
eventSource = null;
|
|
243
|
-
}
|
|
244
|
-
schedulePoll();
|
|
245
|
-
};
|
|
246
|
-
source.onmessage = (message) => {
|
|
247
|
-
try {
|
|
248
|
-
const payload = JSON.parse(message.data);
|
|
249
|
-
const events = normalizeEventPayload(payload);
|
|
250
|
-
const version = typeof payload?.version === "number" ? payload.version : undefined;
|
|
251
|
-
applyEvents(events, version);
|
|
252
|
-
}
|
|
253
|
-
catch {
|
|
254
|
-
// Ignore malformed SSE frames; polling is the safety net.
|
|
255
|
-
}
|
|
256
|
-
};
|
|
257
|
-
}
|
|
258
|
-
async function poll() {
|
|
259
|
-
if (stopped || inFlight)
|
|
260
|
-
return;
|
|
261
|
-
inFlight = true;
|
|
262
|
-
try {
|
|
263
|
-
const data = await fetchPollJson(pollUrl, versionRef, interval);
|
|
264
|
-
if (stopped)
|
|
265
|
-
return;
|
|
266
|
-
applyEvents(data.events ?? [], data.version);
|
|
267
|
-
}
|
|
268
|
-
catch (err) {
|
|
269
|
-
if (stopped)
|
|
270
|
-
return;
|
|
271
|
-
if (isAuthFailure(err)) {
|
|
272
|
-
authFailureUntil = Date.now() + POLL_AUTH_FAILURE_COOLDOWN_MS;
|
|
273
|
-
closeEvents();
|
|
274
|
-
}
|
|
275
|
-
// Network error — will retry on next interval
|
|
276
|
-
}
|
|
277
|
-
finally {
|
|
278
|
-
inFlight = false;
|
|
279
|
-
schedulePoll();
|
|
280
|
-
}
|
|
281
|
-
}
|
|
282
|
-
function pollNow() {
|
|
283
|
-
if (pauseWhenHidden && isDocumentHidden()) {
|
|
284
|
-
return;
|
|
285
|
-
}
|
|
286
|
-
if (authFailureDelayMs() > 0) {
|
|
287
|
-
schedulePoll();
|
|
288
|
-
return;
|
|
289
|
-
}
|
|
290
|
-
if (timer) {
|
|
291
|
-
clearTimeout(timer);
|
|
292
|
-
timer = null;
|
|
293
|
-
}
|
|
294
|
-
connectEvents();
|
|
295
|
-
void poll();
|
|
296
|
-
}
|
|
297
|
-
function handleVisibilityChange() {
|
|
298
|
-
if (document.visibilityState === "visible") {
|
|
299
|
-
connectEvents();
|
|
300
|
-
pollNow();
|
|
301
|
-
}
|
|
302
|
-
else if (pauseWhenHidden) {
|
|
303
|
-
closeEvents();
|
|
304
|
-
if (timer) {
|
|
305
|
-
clearTimeout(timer);
|
|
306
|
-
timer = null;
|
|
307
|
-
}
|
|
308
|
-
}
|
|
309
|
-
}
|
|
310
|
-
// Initial poll immediately when visible. Hidden tabs catch up on focus.
|
|
311
|
-
if (!pauseWhenHidden || !isDocumentHidden()) {
|
|
312
|
-
connectEvents();
|
|
313
|
-
void poll();
|
|
314
|
-
}
|
|
315
|
-
window.addEventListener("focus", pollNow);
|
|
316
|
-
document.addEventListener("visibilitychange", handleVisibilityChange);
|
|
460
|
+
const transport = getOrCreateTransport(pollUrl, sseUrl);
|
|
461
|
+
transport.add(id, {
|
|
462
|
+
onEvents,
|
|
463
|
+
pauseWhenHidden,
|
|
464
|
+
interval,
|
|
465
|
+
fallbackInterval,
|
|
466
|
+
});
|
|
317
467
|
return () => {
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
468
|
+
transport.remove(id);
|
|
469
|
+
// If the registry still holds this transport, and the transport is now
|
|
470
|
+
// empty, evict it so the next mount gets a fresh instance rather than a
|
|
471
|
+
// stopped-but-still-registered one (the registry entry being cleared by
|
|
472
|
+
// releaseTransport is the signal to rebuild state).
|
|
473
|
+
if (!transport["subscribers"].size) {
|
|
474
|
+
releaseTransport(pollUrl, sseUrl);
|
|
475
|
+
}
|
|
324
476
|
};
|
|
325
477
|
}, [
|
|
326
478
|
pollUrl,
|
|
@@ -356,157 +508,32 @@ export function useScreenRefreshKey(options = {}) {
|
|
|
356
508
|
const { pollUrl = agentNativePath(options.pollUrl ?? "/_agent-native/poll"), sseUrl = resolveSseUrl(options.sseUrl), interval = 2000, fallbackInterval = Math.max(options.fallbackInterval ?? SSE_FALLBACK_INTERVAL_MS, interval), pauseWhenHidden = true, } = options;
|
|
357
509
|
const [key, setKey] = useState(0);
|
|
358
510
|
useEffect(() => {
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
let
|
|
362
|
-
|
|
363
|
-
let eventSource = null;
|
|
364
|
-
let sseConnected = false;
|
|
365
|
-
let authFailureUntil = 0;
|
|
366
|
-
function authFailureDelayMs() {
|
|
367
|
-
return Math.max(0, authFailureUntil - Date.now());
|
|
368
|
-
}
|
|
369
|
-
function schedulePoll() {
|
|
370
|
-
if (stopped)
|
|
371
|
-
return;
|
|
372
|
-
if (pauseWhenHidden && isDocumentHidden())
|
|
373
|
-
return;
|
|
374
|
-
if (timer)
|
|
375
|
-
clearTimeout(timer);
|
|
376
|
-
const authDelay = authFailureDelayMs();
|
|
377
|
-
if (authDelay > 0) {
|
|
378
|
-
timer = setTimeout(() => {
|
|
379
|
-
timer = null;
|
|
380
|
-
void poll();
|
|
381
|
-
}, authDelay);
|
|
382
|
-
return;
|
|
383
|
-
}
|
|
384
|
-
timer = setTimeout(() => {
|
|
385
|
-
timer = null;
|
|
386
|
-
void poll();
|
|
387
|
-
}, sseConnected ? fallbackInterval : interval);
|
|
388
|
-
}
|
|
389
|
-
function applyEvents(events, version) {
|
|
511
|
+
const id = Symbol("useScreenRefreshKey");
|
|
512
|
+
// Per-subscriber version cursor (same freshness logic as useDbSync).
|
|
513
|
+
let subscriberVersion = 0;
|
|
514
|
+
function onEvents(events, version) {
|
|
390
515
|
const freshEvents = events.filter((event) => {
|
|
391
|
-
const
|
|
392
|
-
return
|
|
516
|
+
const v = typeof event.version === "number" ? event.version : 0;
|
|
517
|
+
return v === 0 || v > subscriberVersion;
|
|
393
518
|
});
|
|
394
519
|
if (freshEvents.some((e) => e.source === "screen-refresh")) {
|
|
395
520
|
setKey((k) => k + 1);
|
|
396
521
|
}
|
|
397
|
-
const maxEventVersion = freshEvents.reduce((max, event) => Math.max(max,
|
|
398
|
-
|
|
399
|
-
}
|
|
400
|
-
function closeEvents() {
|
|
401
|
-
if (!eventSource)
|
|
402
|
-
return;
|
|
403
|
-
eventSource.close();
|
|
404
|
-
eventSource = null;
|
|
405
|
-
sseConnected = false;
|
|
522
|
+
const maxEventVersion = freshEvents.reduce((max, event) => Math.max(max, typeof event.version === "number" ? event.version : 0), 0);
|
|
523
|
+
subscriberVersion = Math.max(subscriberVersion, version ?? 0, maxEventVersion);
|
|
406
524
|
}
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
}
|
|
415
|
-
const source = new EventSource(sseUrl);
|
|
416
|
-
eventSource = source;
|
|
417
|
-
source.onopen = () => {
|
|
418
|
-
sseConnected = true;
|
|
419
|
-
schedulePoll();
|
|
420
|
-
};
|
|
421
|
-
source.onerror = () => {
|
|
422
|
-
sseConnected = false;
|
|
423
|
-
// When the browser gives up permanently (HTTP error → readyState
|
|
424
|
-
// CLOSED), it won't auto-reconnect. Drop the ref so a later
|
|
425
|
-
// connectEvents() (on focus/visibility) can establish a fresh stream;
|
|
426
|
-
// otherwise the non-null closed `eventSource` blocks reconnection and
|
|
427
|
-
// we'd be stuck on polling-only forever.
|
|
428
|
-
if (source.readyState === EventSource.CLOSED) {
|
|
429
|
-
eventSource = null;
|
|
430
|
-
}
|
|
431
|
-
schedulePoll();
|
|
432
|
-
};
|
|
433
|
-
source.onmessage = (message) => {
|
|
434
|
-
try {
|
|
435
|
-
const payload = JSON.parse(message.data);
|
|
436
|
-
const events = normalizeEventPayload(payload);
|
|
437
|
-
const version = typeof payload?.version === "number" ? payload.version : undefined;
|
|
438
|
-
applyEvents(events, version);
|
|
439
|
-
}
|
|
440
|
-
catch {
|
|
441
|
-
// Polling will catch missed screen-refresh events.
|
|
442
|
-
}
|
|
443
|
-
};
|
|
444
|
-
}
|
|
445
|
-
async function poll() {
|
|
446
|
-
if (stopped || inFlight)
|
|
447
|
-
return;
|
|
448
|
-
inFlight = true;
|
|
449
|
-
try {
|
|
450
|
-
const data = await fetchPollJson(pollUrl, versionRef, interval);
|
|
451
|
-
if (stopped)
|
|
452
|
-
return;
|
|
453
|
-
applyEvents(data.events ?? [], data.version);
|
|
454
|
-
}
|
|
455
|
-
catch (err) {
|
|
456
|
-
if (stopped)
|
|
457
|
-
return;
|
|
458
|
-
if (isAuthFailure(err)) {
|
|
459
|
-
authFailureUntil = Date.now() + POLL_AUTH_FAILURE_COOLDOWN_MS;
|
|
460
|
-
closeEvents();
|
|
461
|
-
}
|
|
462
|
-
// Network error — retry on next interval.
|
|
463
|
-
}
|
|
464
|
-
finally {
|
|
465
|
-
inFlight = false;
|
|
466
|
-
schedulePoll();
|
|
467
|
-
}
|
|
468
|
-
}
|
|
469
|
-
function pollNow() {
|
|
470
|
-
if (pauseWhenHidden && isDocumentHidden()) {
|
|
471
|
-
return;
|
|
472
|
-
}
|
|
473
|
-
if (authFailureDelayMs() > 0) {
|
|
474
|
-
schedulePoll();
|
|
475
|
-
return;
|
|
476
|
-
}
|
|
477
|
-
if (timer) {
|
|
478
|
-
clearTimeout(timer);
|
|
479
|
-
timer = null;
|
|
480
|
-
}
|
|
481
|
-
connectEvents();
|
|
482
|
-
void poll();
|
|
483
|
-
}
|
|
484
|
-
function handleVisibilityChange() {
|
|
485
|
-
if (document.visibilityState === "visible") {
|
|
486
|
-
connectEvents();
|
|
487
|
-
pollNow();
|
|
488
|
-
}
|
|
489
|
-
else if (pauseWhenHidden) {
|
|
490
|
-
closeEvents();
|
|
491
|
-
if (timer) {
|
|
492
|
-
clearTimeout(timer);
|
|
493
|
-
timer = null;
|
|
494
|
-
}
|
|
495
|
-
}
|
|
496
|
-
}
|
|
497
|
-
if (!pauseWhenHidden || !isDocumentHidden()) {
|
|
498
|
-
connectEvents();
|
|
499
|
-
void poll();
|
|
500
|
-
}
|
|
501
|
-
window.addEventListener("focus", pollNow);
|
|
502
|
-
document.addEventListener("visibilitychange", handleVisibilityChange);
|
|
525
|
+
const transport = getOrCreateTransport(pollUrl, sseUrl);
|
|
526
|
+
transport.add(id, {
|
|
527
|
+
onEvents,
|
|
528
|
+
pauseWhenHidden,
|
|
529
|
+
interval,
|
|
530
|
+
fallbackInterval,
|
|
531
|
+
});
|
|
503
532
|
return () => {
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
window.removeEventListener("focus", pollNow);
|
|
509
|
-
document.removeEventListener("visibilitychange", handleVisibilityChange);
|
|
533
|
+
transport.remove(id);
|
|
534
|
+
if (!transport["subscribers"].size) {
|
|
535
|
+
releaseTransport(pollUrl, sseUrl);
|
|
536
|
+
}
|
|
510
537
|
};
|
|
511
538
|
}, [pollUrl, sseUrl, interval, fallbackInterval, pauseWhenHidden]);
|
|
512
539
|
return key;
|