@opensumi/ide-ai-native 3.8.1-next-1741250387.0 → 3.8.1-next-1741251026.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/browser/ai-core.contextkeys.d.ts +1 -1
- package/lib/browser/ai-core.contextkeys.d.ts.map +1 -1
- package/lib/browser/ai-core.contextkeys.js +1 -1
- package/lib/browser/ai-core.contextkeys.js.map +1 -1
- package/lib/browser/ai-core.contribution.d.ts +5 -0
- package/lib/browser/ai-core.contribution.d.ts.map +1 -1
- package/lib/browser/ai-core.contribution.js +71 -9
- package/lib/browser/ai-core.contribution.js.map +1 -1
- package/lib/browser/chat/chat-agent.service.d.ts +11 -3
- package/lib/browser/chat/chat-agent.service.d.ts.map +1 -1
- package/lib/browser/chat/chat-agent.service.js +43 -5
- package/lib/browser/chat/chat-agent.service.js.map +1 -1
- package/lib/browser/chat/chat-manager.service.d.ts +1 -0
- package/lib/browser/chat/chat-manager.service.d.ts.map +1 -1
- package/lib/browser/chat/chat-manager.service.js +6 -8
- package/lib/browser/chat/chat-manager.service.js.map +1 -1
- package/lib/browser/chat/chat-model.d.ts +4 -1
- package/lib/browser/chat/chat-model.d.ts.map +1 -1
- package/lib/browser/chat/chat-model.js +57 -2
- package/lib/browser/chat/chat-model.js.map +1 -1
- package/lib/browser/chat/chat-proxy.service.d.ts.map +1 -1
- package/lib/browser/chat/chat-proxy.service.js +13 -6
- package/lib/browser/chat/chat-proxy.service.js.map +1 -1
- package/lib/browser/chat/chat.api.service.d.ts +1 -2
- package/lib/browser/chat/chat.api.service.d.ts.map +1 -1
- package/lib/browser/chat/chat.api.service.js +0 -4
- package/lib/browser/chat/chat.api.service.js.map +1 -1
- package/lib/browser/chat/chat.internal.service.d.ts +2 -0
- package/lib/browser/chat/chat.internal.service.d.ts.map +1 -1
- package/lib/browser/chat/chat.internal.service.js +3 -0
- package/lib/browser/chat/chat.internal.service.js.map +1 -1
- package/lib/browser/chat/chat.module.less +1 -2
- package/lib/browser/chat/chat.view.d.ts.map +1 -1
- package/lib/browser/chat/chat.view.js +46 -29
- package/lib/browser/chat/chat.view.js.map +1 -1
- package/lib/browser/components/ChatContext/index.js +2 -2
- package/lib/browser/components/ChatContext/index.js.map +1 -1
- package/lib/browser/components/ChatInput.d.ts.map +1 -1
- package/lib/browser/components/ChatInput.js +29 -1
- package/lib/browser/components/ChatInput.js.map +1 -1
- package/lib/browser/components/ChatReply.js +6 -1
- package/lib/browser/components/ChatReply.js.map +1 -1
- package/lib/browser/components/ChatThinking.d.ts +0 -2
- package/lib/browser/components/ChatThinking.d.ts.map +1 -1
- package/lib/browser/components/ChatThinking.js +2 -10
- package/lib/browser/components/ChatThinking.js.map +1 -1
- package/lib/browser/components/ChatToolRender.d.ts.map +1 -1
- package/lib/browser/components/ChatToolRender.js +2 -3
- package/lib/browser/components/ChatToolRender.js.map +1 -1
- package/lib/browser/components/WelcomeMsg.js +1 -1
- package/lib/browser/components/WelcomeMsg.js.map +1 -1
- package/lib/browser/components/chat-history.module.less +2 -1
- package/lib/browser/components/components.module.less +22 -0
- package/lib/browser/context/llm-context.service.d.ts +18 -5
- package/lib/browser/context/llm-context.service.d.ts.map +1 -1
- package/lib/browser/context/llm-context.service.js +80 -47
- package/lib/browser/context/llm-context.service.js.map +1 -1
- package/lib/browser/contrib/inline-completions/inline-completions.controller.js +1 -1
- package/lib/browser/contrib/inline-completions/inline-completions.controller.js.map +1 -1
- package/lib/browser/contrib/inline-completions/prompt/matcher.js +2 -2
- package/lib/browser/contrib/inline-completions/prompt/similarSnippets.d.ts +1 -1
- package/lib/browser/contrib/inline-completions/prompt/similarSnippets.js +2 -2
- package/lib/browser/contrib/intelligent-completions/index.d.ts +2 -1
- package/lib/browser/contrib/intelligent-completions/index.d.ts.map +1 -1
- package/lib/browser/contrib/intelligent-completions/index.js +4 -1
- package/lib/browser/contrib/intelligent-completions/index.js.map +1 -1
- package/lib/browser/contrib/intelligent-completions/intelligent-completions.contribution.js +2 -2
- package/lib/browser/contrib/intelligent-completions/intelligent-completions.contribution.js.map +1 -1
- package/lib/browser/contrib/intelligent-completions/intelligent-completions.controller.d.ts.map +1 -1
- package/lib/browser/contrib/intelligent-completions/intelligent-completions.controller.js +6 -5
- package/lib/browser/contrib/intelligent-completions/intelligent-completions.controller.js.map +1 -1
- package/lib/browser/contrib/intelligent-completions/view/code-edits-previewer.d.ts.map +1 -1
- package/lib/browser/contrib/intelligent-completions/view/code-edits-previewer.js +4 -2
- package/lib/browser/contrib/intelligent-completions/view/code-edits-previewer.js.map +1 -1
- package/lib/browser/contrib/intelligent-completions/view/default.d.ts.map +1 -1
- package/lib/browser/contrib/intelligent-completions/view/default.js +23 -11
- package/lib/browser/contrib/intelligent-completions/view/default.js.map +1 -1
- package/lib/browser/index.d.ts.map +1 -1
- package/lib/browser/index.js +4 -0
- package/lib/browser/index.js.map +1 -1
- package/lib/browser/layout/layout.module.less +4 -4
- package/lib/browser/mcp/base-apply.service.d.ts +26 -11
- package/lib/browser/mcp/base-apply.service.d.ts.map +1 -1
- package/lib/browser/mcp/base-apply.service.js +255 -103
- package/lib/browser/mcp/base-apply.service.js.map +1 -1
- package/lib/browser/mcp/config/components/mcp-config.module.less +178 -0
- package/lib/browser/mcp/config/components/mcp-config.view.d.ts +3 -0
- package/lib/browser/mcp/config/components/mcp-config.view.d.ts.map +1 -0
- package/lib/browser/mcp/config/components/mcp-config.view.js +150 -0
- package/lib/browser/mcp/config/components/mcp-config.view.js.map +1 -0
- package/lib/browser/mcp/config/components/mcp-server-form.d.ts +16 -0
- package/lib/browser/mcp/config/components/mcp-server-form.d.ts.map +1 -0
- package/lib/browser/mcp/config/components/mcp-server-form.js +84 -0
- package/lib/browser/mcp/config/components/mcp-server-form.js.map +1 -0
- package/lib/browser/mcp/config/components/mcp-server-form.module.less +78 -0
- package/lib/browser/mcp/config/mcp-config.commands.d.ts +10 -0
- package/lib/browser/mcp/config/mcp-config.commands.d.ts.map +1 -0
- package/lib/browser/mcp/config/mcp-config.commands.js +35 -0
- package/lib/browser/mcp/config/mcp-config.commands.js.map +1 -0
- package/lib/browser/mcp/config/mcp-config.contribution.d.ts +16 -0
- package/lib/browser/mcp/config/mcp-config.contribution.d.ts.map +1 -0
- package/lib/browser/mcp/config/mcp-config.contribution.js +62 -0
- package/lib/browser/mcp/config/mcp-config.contribution.js.map +1 -0
- package/lib/browser/mcp/mcp-server-proxy.service.d.ts +6 -0
- package/lib/browser/mcp/mcp-server-proxy.service.d.ts.map +1 -1
- package/lib/browser/mcp/mcp-server-proxy.service.js +10 -1
- package/lib/browser/mcp/mcp-server-proxy.service.js.map +1 -1
- package/lib/browser/mcp/mcp-server.feature.registry.d.ts +8 -0
- package/lib/browser/mcp/mcp-server.feature.registry.d.ts.map +1 -1
- package/lib/browser/mcp/mcp-server.feature.registry.js +28 -3
- package/lib/browser/mcp/mcp-server.feature.registry.js.map +1 -1
- package/lib/browser/mcp/tools/components/EditFile.d.ts.map +1 -1
- package/lib/browser/mcp/tools/components/EditFile.js +15 -9
- package/lib/browser/mcp/tools/components/EditFile.js.map +1 -1
- package/lib/browser/mcp/tools/components/ExpandableFileList.d.ts +13 -0
- package/lib/browser/mcp/tools/components/ExpandableFileList.d.ts.map +1 -0
- package/lib/browser/mcp/tools/components/{SearchResult.js → ExpandableFileList.js} +29 -19
- package/lib/browser/mcp/tools/components/ExpandableFileList.js.map +1 -0
- package/lib/browser/mcp/tools/components/Terminal.d.ts.map +1 -1
- package/lib/browser/mcp/tools/components/Terminal.js +10 -2
- package/lib/browser/mcp/tools/components/Terminal.js.map +1 -1
- package/lib/browser/mcp/tools/components/index.module.less +4 -0
- package/lib/browser/mcp/tools/createNewFileWithText.d.ts +1 -0
- package/lib/browser/mcp/tools/createNewFileWithText.d.ts.map +1 -1
- package/lib/browser/mcp/tools/createNewFileWithText.js +19 -11
- package/lib/browser/mcp/tools/createNewFileWithText.js.map +1 -1
- package/lib/browser/mcp/tools/fileSearch.d.ts +1 -0
- package/lib/browser/mcp/tools/fileSearch.d.ts.map +1 -1
- package/lib/browser/mcp/tools/fileSearch.js +14 -5
- package/lib/browser/mcp/tools/fileSearch.js.map +1 -1
- package/lib/browser/mcp/tools/getDiagnosticsByPath.d.ts.map +1 -1
- package/lib/browser/mcp/tools/getDiagnosticsByPath.js +1 -0
- package/lib/browser/mcp/tools/getDiagnosticsByPath.js.map +1 -1
- package/lib/browser/mcp/tools/grepSearch.d.ts.map +1 -1
- package/lib/browser/mcp/tools/grepSearch.js +6 -3
- package/lib/browser/mcp/tools/grepSearch.js.map +1 -1
- package/lib/browser/mcp/tools/handlers/EditFile.js +1 -1
- package/lib/browser/mcp/tools/handlers/EditFile.js.map +1 -1
- package/lib/browser/mcp/tools/handlers/ListDir.d.ts +1 -0
- package/lib/browser/mcp/tools/handlers/ListDir.d.ts.map +1 -1
- package/lib/browser/mcp/tools/handlers/ListDir.js +3 -0
- package/lib/browser/mcp/tools/handlers/ListDir.js.map +1 -1
- package/lib/browser/mcp/tools/handlers/RunCommand.d.ts.map +1 -1
- package/lib/browser/mcp/tools/handlers/RunCommand.js +2 -0
- package/lib/browser/mcp/tools/handlers/RunCommand.js.map +1 -1
- package/lib/browser/mcp/tools/listDir.d.ts +1 -0
- package/lib/browser/mcp/tools/listDir.d.ts.map +1 -1
- package/lib/browser/mcp/tools/listDir.js +35 -4
- package/lib/browser/mcp/tools/listDir.js.map +1 -1
- package/lib/browser/mcp/tools/runTerminalCmd.d.ts.map +1 -1
- package/lib/browser/mcp/tools/runTerminalCmd.js +1 -0
- package/lib/browser/mcp/tools/runTerminalCmd.js.map +1 -1
- package/lib/browser/model/msg-history-manager.d.ts +2 -2
- package/lib/browser/model/msg-history-manager.d.ts.map +1 -1
- package/lib/browser/model/msg-history-manager.js +4 -10
- package/lib/browser/model/msg-history-manager.js.map +1 -1
- package/lib/browser/preferences/schema.d.ts.map +1 -1
- package/lib/browser/preferences/schema.js +22 -2
- package/lib/browser/preferences/schema.js.map +1 -1
- package/lib/browser/types.d.ts +4 -0
- package/lib/browser/types.d.ts.map +1 -1
- package/lib/browser/widget/inline-chat/inline-chat-controller.d.ts.map +1 -1
- package/lib/browser/widget/inline-chat/inline-chat-controller.js +6 -1
- package/lib/browser/widget/inline-chat/inline-chat-controller.js.map +1 -1
- package/lib/browser/widget/inline-diff/inline-diff-manager.d.ts.map +1 -1
- package/lib/browser/widget/inline-diff/inline-diff-manager.js +68 -8
- package/lib/browser/widget/inline-diff/inline-diff-manager.js.map +1 -1
- package/lib/browser/widget/inline-diff/inline-diff-previewer.d.ts +10 -4
- package/lib/browser/widget/inline-diff/inline-diff-previewer.d.ts.map +1 -1
- package/lib/browser/widget/inline-diff/inline-diff-previewer.js +14 -3
- package/lib/browser/widget/inline-diff/inline-diff-previewer.js.map +1 -1
- package/lib/browser/widget/inline-diff/inline-diff-widget.module.less +25 -4
- package/lib/browser/widget/inline-diff/inline-diff.controller.d.ts +3 -3
- package/lib/browser/widget/inline-diff/inline-diff.controller.d.ts.map +1 -1
- package/lib/browser/widget/inline-diff/inline-diff.controller.js +10 -5
- package/lib/browser/widget/inline-diff/inline-diff.controller.js.map +1 -1
- package/lib/browser/widget/inline-stream-diff/inline-stream-diff.handler.d.ts +46 -17
- package/lib/browser/widget/inline-stream-diff/inline-stream-diff.handler.d.ts.map +1 -1
- package/lib/browser/widget/inline-stream-diff/inline-stream-diff.handler.js +110 -53
- package/lib/browser/widget/inline-stream-diff/inline-stream-diff.handler.js.map +1 -1
- package/lib/browser/widget/inline-stream-diff/live-preview.decoration.d.ts +4 -0
- package/lib/browser/widget/inline-stream-diff/live-preview.decoration.d.ts.map +1 -1
- package/lib/browser/widget/inline-stream-diff/live-preview.decoration.js +26 -1
- package/lib/browser/widget/inline-stream-diff/live-preview.decoration.js.map +1 -1
- package/lib/common/index.d.ts +13 -4
- package/lib/common/index.d.ts.map +1 -1
- package/lib/common/index.js +5 -1
- package/lib/common/index.js.map +1 -1
- package/lib/common/llm-context.d.ts +13 -9
- package/lib/common/llm-context.d.ts.map +1 -1
- package/lib/common/llm-context.js.map +1 -1
- package/lib/common/mcp-server-manager.d.ts +17 -1
- package/lib/common/mcp-server-manager.d.ts.map +1 -1
- package/lib/common/mcp-server-manager.js.map +1 -1
- package/lib/common/model.d.ts +12 -0
- package/lib/common/model.d.ts.map +1 -0
- package/lib/common/model.js +83 -0
- package/lib/common/model.js.map +1 -0
- package/lib/common/prompts/context-prompt-provider.d.ts +4 -3
- package/lib/common/prompts/context-prompt-provider.d.ts.map +1 -1
- package/lib/common/prompts/context-prompt-provider.js +33 -22
- package/lib/common/prompts/context-prompt-provider.js.map +1 -1
- package/lib/common/tool-invocation-registry.d.ts +2 -2
- package/lib/common/tool-invocation-registry.d.ts.map +1 -1
- package/lib/common/tool-invocation-registry.js +1 -1
- package/lib/common/tool-invocation-registry.js.map +1 -1
- package/lib/common/types.d.ts +8 -0
- package/lib/common/types.d.ts.map +1 -1
- package/lib/common/utils.d.ts.map +1 -1
- package/lib/common/utils.js +2 -1
- package/lib/common/utils.js.map +1 -1
- package/lib/node/anthropic/anthropic-language-model.d.ts +3 -1
- package/lib/node/anthropic/anthropic-language-model.d.ts.map +1 -1
- package/lib/node/anthropic/anthropic-language-model.js +6 -2
- package/lib/node/anthropic/anthropic-language-model.js.map +1 -1
- package/lib/node/base-language-model.d.ts +6 -3
- package/lib/node/base-language-model.d.ts.map +1 -1
- package/lib/node/base-language-model.js +14 -31
- package/lib/node/base-language-model.js.map +1 -1
- package/lib/node/deepseek/deepseek-language-model.d.ts +3 -1
- package/lib/node/deepseek/deepseek-language-model.d.ts.map +1 -1
- package/lib/node/deepseek/deepseek-language-model.js +6 -2
- package/lib/node/deepseek/deepseek-language-model.js.map +1 -1
- package/lib/node/mcp/sumi-mcp-server.d.ts +17 -3
- package/lib/node/mcp/sumi-mcp-server.d.ts.map +1 -1
- package/lib/node/mcp/sumi-mcp-server.js +59 -6
- package/lib/node/mcp/sumi-mcp-server.js.map +1 -1
- package/lib/node/mcp-server-manager-impl.d.ts +4 -3
- package/lib/node/mcp-server-manager-impl.d.ts.map +1 -1
- package/lib/node/mcp-server-manager-impl.js +26 -6
- package/lib/node/mcp-server-manager-impl.js.map +1 -1
- package/lib/node/mcp-server.d.ts +5 -16
- package/lib/node/mcp-server.d.ts.map +1 -1
- package/lib/node/mcp-server.js +12 -6
- package/lib/node/mcp-server.js.map +1 -1
- package/lib/node/openai/openai-language-model.d.ts +4 -2
- package/lib/node/openai/openai-language-model.d.ts.map +1 -1
- package/lib/node/openai/openai-language-model.js +6 -4
- package/lib/node/openai/openai-language-model.js.map +1 -1
- package/lib/node/openai-compatible/openai-compatible-language-model.d.ts +10 -0
- package/lib/node/openai-compatible/openai-compatible-language-model.d.ts.map +1 -0
- package/lib/node/openai-compatible/openai-compatible-language-model.js +32 -0
- package/lib/node/openai-compatible/openai-compatible-language-model.js.map +1 -0
- package/package.json +27 -26
- package/src/browser/ai-core.contextkeys.ts +3 -3
- package/src/browser/ai-core.contribution.ts +89 -12
- package/src/browser/chat/chat-agent.service.ts +53 -9
- package/src/browser/chat/chat-manager.service.ts +10 -8
- package/src/browser/chat/chat-model.ts +63 -5
- package/src/browser/chat/chat-proxy.service.ts +16 -8
- package/src/browser/chat/chat.api.service.ts +1 -5
- package/src/browser/chat/chat.internal.service.ts +4 -0
- package/src/browser/chat/chat.module.less +1 -2
- package/src/browser/chat/chat.view.tsx +63 -69
- package/src/browser/components/ChatContext/index.tsx +2 -2
- package/src/browser/components/ChatInput.tsx +81 -6
- package/src/browser/components/ChatReply.tsx +6 -6
- package/src/browser/components/ChatThinking.tsx +3 -9
- package/src/browser/components/ChatToolRender.tsx +1 -2
- package/src/browser/components/WelcomeMsg.tsx +1 -1
- package/src/browser/components/chat-history.module.less +2 -1
- package/src/browser/components/components.module.less +22 -0
- package/src/browser/context/llm-context.service.ts +93 -54
- package/src/browser/contrib/inline-completions/inline-completions.controller.ts +1 -1
- package/src/browser/contrib/inline-completions/prompt/matcher.ts +2 -2
- package/src/browser/contrib/inline-completions/prompt/similarSnippets.ts +2 -2
- package/src/browser/contrib/intelligent-completions/index.ts +5 -1
- package/src/browser/contrib/intelligent-completions/intelligent-completions.contribution.ts +3 -3
- package/src/browser/contrib/intelligent-completions/intelligent-completions.controller.ts +7 -6
- package/src/browser/contrib/intelligent-completions/view/code-edits-previewer.ts +4 -2
- package/src/browser/contrib/intelligent-completions/view/default.ts +34 -19
- package/src/browser/index.ts +4 -0
- package/src/browser/layout/layout.module.less +4 -4
- package/src/browser/mcp/base-apply.service.ts +306 -109
- package/src/browser/mcp/config/components/mcp-config.module.less +178 -0
- package/src/browser/mcp/config/components/mcp-config.view.tsx +215 -0
- package/src/browser/mcp/config/components/mcp-server-form.module.less +78 -0
- package/src/browser/mcp/config/components/mcp-server-form.tsx +144 -0
- package/src/browser/mcp/config/mcp-config.commands.ts +29 -0
- package/src/browser/mcp/config/mcp-config.contribution.ts +65 -0
- package/src/browser/mcp/mcp-server-proxy.service.ts +14 -2
- package/src/browser/mcp/mcp-server.feature.registry.ts +35 -4
- package/src/browser/mcp/tools/components/EditFile.tsx +16 -9
- package/src/browser/mcp/tools/components/ExpandableFileList.tsx +133 -0
- package/src/browser/mcp/tools/components/Terminal.tsx +13 -2
- package/src/browser/mcp/tools/components/index.module.less +4 -0
- package/src/browser/mcp/tools/createNewFileWithText.ts +21 -12
- package/src/browser/mcp/tools/fileSearch.ts +14 -4
- package/src/browser/mcp/tools/getDiagnosticsByPath.ts +1 -0
- package/src/browser/mcp/tools/grepSearch.ts +6 -3
- package/src/browser/mcp/tools/handlers/EditFile.ts +1 -1
- package/src/browser/mcp/tools/handlers/ListDir.ts +4 -0
- package/src/browser/mcp/tools/handlers/RunCommand.ts +2 -0
- package/src/browser/mcp/tools/listDir.ts +36 -5
- package/src/browser/mcp/tools/runTerminalCmd.ts +1 -0
- package/src/browser/model/msg-history-manager.ts +5 -11
- package/src/browser/preferences/schema.ts +22 -2
- package/src/browser/types.ts +1 -0
- package/src/browser/widget/inline-chat/inline-chat-controller.ts +5 -1
- package/src/browser/widget/inline-diff/inline-diff-manager.tsx +143 -21
- package/src/browser/widget/inline-diff/inline-diff-previewer.ts +25 -7
- package/src/browser/widget/inline-diff/inline-diff-widget.module.less +25 -4
- package/src/browser/widget/inline-diff/inline-diff.controller.ts +16 -8
- package/src/browser/widget/inline-stream-diff/inline-stream-diff.handler.tsx +139 -68
- package/src/browser/widget/inline-stream-diff/live-preview.decoration.tsx +30 -1
- package/src/common/index.ts +15 -4
- package/src/common/llm-context.ts +10 -4
- package/src/common/mcp-server-manager.ts +17 -1
- package/src/common/model.ts +90 -0
- package/src/common/prompts/context-prompt-provider.ts +38 -29
- package/src/common/tool-invocation-registry.ts +2 -2
- package/src/common/types.ts +8 -0
- package/src/common/utils.ts +3 -1
- package/src/node/anthropic/anthropic-language-model.ts +7 -2
- package/src/node/base-language-model.ts +25 -38
- package/src/node/deepseek/deepseek-language-model.ts +7 -2
- package/src/node/mcp/sumi-mcp-server.ts +67 -9
- package/src/node/mcp-server-manager-impl.ts +30 -9
- package/src/node/mcp-server.ts +11 -14
- package/src/node/openai/openai-language-model.ts +8 -4
- package/src/node/openai-compatible/openai-compatible-language-model.ts +30 -0
- package/lib/browser/mcp/tools/components/SearchResult.d.ts +0 -11
- package/lib/browser/mcp/tools/components/SearchResult.d.ts.map +0 -1
- package/lib/browser/mcp/tools/components/SearchResult.js.map +0 -1
- package/src/browser/mcp/tools/components/SearchResult.tsx +0 -92
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
.container {
|
|
2
|
+
padding: 20px;
|
|
3
|
+
color: var(--foreground);
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
.header {
|
|
7
|
+
display: flex;
|
|
8
|
+
justify-content: space-between;
|
|
9
|
+
align-items: flex-start;
|
|
10
|
+
margin-bottom: 24px;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
.title {
|
|
14
|
+
margin: 0 0 8px 0;
|
|
15
|
+
font-size: 24px;
|
|
16
|
+
font-weight: 600;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.description {
|
|
20
|
+
margin: 0;
|
|
21
|
+
color: var(--descriptionForeground);
|
|
22
|
+
font-size: 14px;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
.addButton {
|
|
26
|
+
padding: 8px 16px;
|
|
27
|
+
border-radius: 4px;
|
|
28
|
+
background-color: var(--button-primary-background);
|
|
29
|
+
color: var(--button-primary-foreground);
|
|
30
|
+
border: none;
|
|
31
|
+
cursor: pointer;
|
|
32
|
+
font-size: 13px;
|
|
33
|
+
|
|
34
|
+
&:hover {
|
|
35
|
+
background-color: var(--button-primary-hover-background);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
.serversList {
|
|
40
|
+
display: flex;
|
|
41
|
+
flex-direction: column;
|
|
42
|
+
gap: 12px;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
.serverItem {
|
|
46
|
+
padding: 16px;
|
|
47
|
+
border-radius: 8px;
|
|
48
|
+
background-color: var(--editorWidget-background);
|
|
49
|
+
border: 1px solid var(--border-color);
|
|
50
|
+
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
|
|
51
|
+
transition: all 0.2s ease;
|
|
52
|
+
|
|
53
|
+
&:hover {
|
|
54
|
+
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
|
|
55
|
+
border-color: var(--focusBorder);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
.serverHeader {
|
|
60
|
+
display: flex;
|
|
61
|
+
justify-content: space-between;
|
|
62
|
+
align-items: center;
|
|
63
|
+
margin-bottom: 12px;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
.serverTitleRow {
|
|
67
|
+
display: flex;
|
|
68
|
+
align-items: center;
|
|
69
|
+
gap: 8px;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
.serverName {
|
|
73
|
+
margin: 0;
|
|
74
|
+
font-size: 14px;
|
|
75
|
+
font-weight: 500;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
.serverStatus,
|
|
79
|
+
.serverType {
|
|
80
|
+
font-size: 12px;
|
|
81
|
+
padding: 2px 8px;
|
|
82
|
+
border-radius: 12px;
|
|
83
|
+
font-weight: 500;
|
|
84
|
+
display: inline-flex;
|
|
85
|
+
align-items: center;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
.serverType {
|
|
89
|
+
background-color: var(--editor-background);
|
|
90
|
+
color: var(--descriptionForeground);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
.running {
|
|
94
|
+
background-color: var(--notification-info-background);
|
|
95
|
+
color: var(--notification-info-foreground);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
.stopped {
|
|
99
|
+
background-color: var(--notification-error-background);
|
|
100
|
+
color: var(--notification-error-foreground);
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
.serverActions {
|
|
104
|
+
display: flex;
|
|
105
|
+
gap: 4px;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
.iconButton {
|
|
109
|
+
padding: 4px;
|
|
110
|
+
border: none;
|
|
111
|
+
background: none;
|
|
112
|
+
color: var(--icon-foreground);
|
|
113
|
+
cursor: pointer;
|
|
114
|
+
border-radius: 4px;
|
|
115
|
+
|
|
116
|
+
&:hover {
|
|
117
|
+
background-color: var(--list-hover-background);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
.serverDetail {
|
|
122
|
+
margin-top: 12px;
|
|
123
|
+
padding: 12px;
|
|
124
|
+
border-radius: 6px;
|
|
125
|
+
background-color: var(--editor-background);
|
|
126
|
+
font-size: 13px;
|
|
127
|
+
|
|
128
|
+
&:not(:last-child) {
|
|
129
|
+
margin-bottom: 8px;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
.detailRow {
|
|
134
|
+
display: flex;
|
|
135
|
+
gap: 8px;
|
|
136
|
+
margin-bottom: 4px;
|
|
137
|
+
align-items: center;
|
|
138
|
+
|
|
139
|
+
&:last-child {
|
|
140
|
+
margin-bottom: 0;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
.detailLabel {
|
|
145
|
+
color: var(--descriptionForeground);
|
|
146
|
+
min-width: 70px;
|
|
147
|
+
height: 24px;
|
|
148
|
+
display: flex;
|
|
149
|
+
align-items: center;
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
.detailContent {
|
|
153
|
+
color: var(--foreground);
|
|
154
|
+
word-break: break-all;
|
|
155
|
+
flex: 1;
|
|
156
|
+
background-color: var(--editor-background);
|
|
157
|
+
padding: 4px 8px;
|
|
158
|
+
border-radius: 4px;
|
|
159
|
+
font-family: var(--monaco-monospace-font);
|
|
160
|
+
min-height: 24px;
|
|
161
|
+
display: flex;
|
|
162
|
+
align-items: center;
|
|
163
|
+
gap: 8px;
|
|
164
|
+
flex-wrap: wrap;
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
.toolTag {
|
|
168
|
+
display: inline-flex;
|
|
169
|
+
align-items: center;
|
|
170
|
+
padding: 2px 8px;
|
|
171
|
+
background-color: var(--editorWidget-background);
|
|
172
|
+
color: var(--button-secondary-foreground);
|
|
173
|
+
border-radius: 12px;
|
|
174
|
+
font-size: 12px;
|
|
175
|
+
font-weight: 500;
|
|
176
|
+
transition: all 0.2s ease;
|
|
177
|
+
border: 1px solid var(--border-color);
|
|
178
|
+
}
|
|
@@ -0,0 +1,215 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
|
|
3
|
+
import { AINativeSettingSectionsId, ILogger, useInjectable } from '@opensumi/ide-core-browser';
|
|
4
|
+
import { PreferenceService } from '@opensumi/ide-core-browser/lib/preferences';
|
|
5
|
+
|
|
6
|
+
import { BUILTIN_MCP_SERVER_NAME } from '../../../../common';
|
|
7
|
+
import { MCPServerDescription } from '../../../../common/mcp-server-manager';
|
|
8
|
+
import { MCPServerProxyService } from '../../mcp-server-proxy.service';
|
|
9
|
+
|
|
10
|
+
import styles from './mcp-config.module.less';
|
|
11
|
+
import { MCPServerForm, MCPServerFormData } from './mcp-server-form';
|
|
12
|
+
|
|
13
|
+
interface MCPServer {
|
|
14
|
+
name: string;
|
|
15
|
+
isStarted: boolean;
|
|
16
|
+
tools?: string[];
|
|
17
|
+
command?: string;
|
|
18
|
+
type?: string;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export const MCPConfigView: React.FC = () => {
|
|
22
|
+
const mcpServerProxyService = useInjectable<MCPServerProxyService>(MCPServerProxyService);
|
|
23
|
+
const preferenceService = useInjectable<PreferenceService>(PreferenceService);
|
|
24
|
+
const logger = useInjectable<ILogger>(ILogger);
|
|
25
|
+
const [servers, setServers] = React.useState<MCPServer[]>([]);
|
|
26
|
+
const [formVisible, setFormVisible] = React.useState(false);
|
|
27
|
+
const [editingServer, setEditingServer] = React.useState<MCPServerFormData | undefined>();
|
|
28
|
+
|
|
29
|
+
const loadServers = React.useCallback(async () => {
|
|
30
|
+
const allServers = await mcpServerProxyService.$getServers();
|
|
31
|
+
setServers(allServers);
|
|
32
|
+
}, [mcpServerProxyService]);
|
|
33
|
+
|
|
34
|
+
React.useEffect(() => {
|
|
35
|
+
loadServers();
|
|
36
|
+
const disposer = mcpServerProxyService.onChangeMCPServers(() => {
|
|
37
|
+
loadServers();
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
return () => {
|
|
41
|
+
disposer.dispose();
|
|
42
|
+
};
|
|
43
|
+
}, [mcpServerProxyService, loadServers]);
|
|
44
|
+
|
|
45
|
+
const handleServerControl = async (serverName: string, start: boolean) => {
|
|
46
|
+
try {
|
|
47
|
+
if (start) {
|
|
48
|
+
await mcpServerProxyService.$startServer(serverName);
|
|
49
|
+
} else {
|
|
50
|
+
await mcpServerProxyService.$stopServer(serverName);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
// Update enabled state in preferences
|
|
54
|
+
const servers = preferenceService.get<MCPServerDescription[]>(AINativeSettingSectionsId.MCPServers, []);
|
|
55
|
+
let updatedServers = servers;
|
|
56
|
+
|
|
57
|
+
// 处理内置服务器的特殊情况
|
|
58
|
+
if (serverName === BUILTIN_MCP_SERVER_NAME) {
|
|
59
|
+
const builtinServerExists = servers.some((server) => server.name === BUILTIN_MCP_SERVER_NAME);
|
|
60
|
+
if (!builtinServerExists && !start) {
|
|
61
|
+
// 如果是停止内置服务器且之前没有配置,添加一个新的配置项
|
|
62
|
+
// 内置服务器不需要 command,因为它是直接集成在 IDE 中的
|
|
63
|
+
updatedServers = [
|
|
64
|
+
...servers,
|
|
65
|
+
{
|
|
66
|
+
name: BUILTIN_MCP_SERVER_NAME,
|
|
67
|
+
enabled: false,
|
|
68
|
+
command: '', // 内置服务器的 command 为空字符串
|
|
69
|
+
},
|
|
70
|
+
];
|
|
71
|
+
} else {
|
|
72
|
+
// 如果已经存在配置,更新 enabled 状态
|
|
73
|
+
updatedServers = servers.map((server) => {
|
|
74
|
+
if (server.name === BUILTIN_MCP_SERVER_NAME) {
|
|
75
|
+
return { ...server, enabled: start };
|
|
76
|
+
}
|
|
77
|
+
return server;
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
} else {
|
|
81
|
+
// 处理其他外部服务器
|
|
82
|
+
updatedServers = servers.map((server) => {
|
|
83
|
+
if (server.name === serverName) {
|
|
84
|
+
return { ...server, enabled: start };
|
|
85
|
+
}
|
|
86
|
+
return server;
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
await preferenceService.set(AINativeSettingSectionsId.MCPServers, updatedServers);
|
|
91
|
+
await loadServers();
|
|
92
|
+
} catch (error) {
|
|
93
|
+
logger.error(`Failed to ${start ? 'start' : 'stop'} server ${serverName}:`, error);
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
|
|
97
|
+
const handleAddServer = () => {
|
|
98
|
+
setEditingServer(undefined);
|
|
99
|
+
setFormVisible(true);
|
|
100
|
+
};
|
|
101
|
+
|
|
102
|
+
const handleEditServer = (server: MCPServer) => {
|
|
103
|
+
const servers = preferenceService.get<MCPServerFormData[]>(AINativeSettingSectionsId.MCPServers, []);
|
|
104
|
+
const serverConfig = servers.find((s) => s.name === server.name);
|
|
105
|
+
|
|
106
|
+
if (serverConfig) {
|
|
107
|
+
setEditingServer(serverConfig);
|
|
108
|
+
setFormVisible(true);
|
|
109
|
+
}
|
|
110
|
+
};
|
|
111
|
+
|
|
112
|
+
const handleDeleteServer = async (serverName: string) => {
|
|
113
|
+
const servers = preferenceService.get<MCPServerFormData[]>(AINativeSettingSectionsId.MCPServers, []);
|
|
114
|
+
const updatedServers = servers.filter((s) => s.name !== serverName);
|
|
115
|
+
await preferenceService.set(AINativeSettingSectionsId.MCPServers, updatedServers);
|
|
116
|
+
await loadServers();
|
|
117
|
+
};
|
|
118
|
+
|
|
119
|
+
const handleSaveServer = async (data: MCPServerFormData) => {
|
|
120
|
+
const servers = preferenceService.get<MCPServerFormData[]>(AINativeSettingSectionsId.MCPServers, []);
|
|
121
|
+
const existingIndex = servers.findIndex((s) => s.name === data.name);
|
|
122
|
+
|
|
123
|
+
if (existingIndex >= 0) {
|
|
124
|
+
servers[existingIndex] = data;
|
|
125
|
+
} else {
|
|
126
|
+
servers.push(data);
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
await preferenceService.set(AINativeSettingSectionsId.MCPServers, servers);
|
|
130
|
+
setFormVisible(false);
|
|
131
|
+
await loadServers();
|
|
132
|
+
};
|
|
133
|
+
|
|
134
|
+
return (
|
|
135
|
+
<div className={styles.container}>
|
|
136
|
+
<div className={styles.header}>
|
|
137
|
+
<div>
|
|
138
|
+
<h2 className={styles.title}>MCP Servers</h2>
|
|
139
|
+
<p className={styles.description}>Manage your MCP server connections.</p>
|
|
140
|
+
</div>
|
|
141
|
+
<button className={styles.addButton} onClick={handleAddServer}>
|
|
142
|
+
+ Add new MCP server
|
|
143
|
+
</button>
|
|
144
|
+
</div>
|
|
145
|
+
<div className={styles.serversList}>
|
|
146
|
+
{servers.map((server) => (
|
|
147
|
+
<div key={server.name} className={styles.serverItem}>
|
|
148
|
+
<div className={styles.serverHeader}>
|
|
149
|
+
<div className={styles.serverTitleRow}>
|
|
150
|
+
<h3 className={styles.serverName}>{server.name}</h3>
|
|
151
|
+
</div>
|
|
152
|
+
<div className={styles.serverActions}>
|
|
153
|
+
<button className={styles.iconButton} title='Edit' onClick={() => handleEditServer(server)}>
|
|
154
|
+
<i className='codicon codicon-edit' />
|
|
155
|
+
</button>
|
|
156
|
+
<button
|
|
157
|
+
className={styles.iconButton}
|
|
158
|
+
title={server.isStarted ? 'Stop' : 'Start'}
|
|
159
|
+
onClick={() => handleServerControl(server.name, !server.isStarted)}
|
|
160
|
+
>
|
|
161
|
+
<i className={`codicon ${server.isStarted ? 'codicon-debug-stop' : 'codicon-debug-start'}`} />
|
|
162
|
+
</button>
|
|
163
|
+
<button className={styles.iconButton} title='Delete' onClick={() => handleDeleteServer(server.name)}>
|
|
164
|
+
<i className='codicon codicon-trash' />
|
|
165
|
+
</button>
|
|
166
|
+
</div>
|
|
167
|
+
</div>
|
|
168
|
+
<div className={styles.serverDetail}>
|
|
169
|
+
<div className={styles.detailRow}>
|
|
170
|
+
<span className={styles.detailLabel}>Status:</span>
|
|
171
|
+
<span className={`${styles.serverStatus} ${server.isStarted ? styles.running : styles.stopped}`}>
|
|
172
|
+
{server.isStarted ? 'Running' : 'Stopped'}
|
|
173
|
+
</span>
|
|
174
|
+
</div>
|
|
175
|
+
{server.type && (
|
|
176
|
+
<div className={styles.detailRow}>
|
|
177
|
+
<span className={styles.detailLabel}>Type:</span>
|
|
178
|
+
<span className={styles.serverType}>{server.type}</span>
|
|
179
|
+
</div>
|
|
180
|
+
)}
|
|
181
|
+
</div>
|
|
182
|
+
{server.tools && server.tools.length > 0 && (
|
|
183
|
+
<div className={styles.serverDetail}>
|
|
184
|
+
<div className={styles.detailRow}>
|
|
185
|
+
<span className={styles.detailLabel}>Tools:</span>
|
|
186
|
+
<span className={styles.detailContent}>
|
|
187
|
+
{server.tools.map((tool, index) => (
|
|
188
|
+
<span key={index} className={styles.toolTag}>
|
|
189
|
+
{tool}
|
|
190
|
+
</span>
|
|
191
|
+
))}
|
|
192
|
+
</span>
|
|
193
|
+
</div>
|
|
194
|
+
</div>
|
|
195
|
+
)}
|
|
196
|
+
{server.command && (
|
|
197
|
+
<div className={styles.serverDetail}>
|
|
198
|
+
<div className={styles.detailRow}>
|
|
199
|
+
<span className={styles.detailLabel}>Command:</span>
|
|
200
|
+
<span className={styles.detailContent}>{server.command}</span>
|
|
201
|
+
</div>
|
|
202
|
+
</div>
|
|
203
|
+
)}
|
|
204
|
+
</div>
|
|
205
|
+
))}
|
|
206
|
+
</div>
|
|
207
|
+
<MCPServerForm
|
|
208
|
+
visible={formVisible}
|
|
209
|
+
initialData={editingServer}
|
|
210
|
+
onSave={handleSaveServer}
|
|
211
|
+
onCancel={() => setFormVisible(false)}
|
|
212
|
+
/>
|
|
213
|
+
</div>
|
|
214
|
+
);
|
|
215
|
+
};
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
.form {
|
|
2
|
+
padding: 16px;
|
|
3
|
+
}
|
|
4
|
+
|
|
5
|
+
.formItem {
|
|
6
|
+
margin-bottom: 16px;
|
|
7
|
+
|
|
8
|
+
label {
|
|
9
|
+
display: block;
|
|
10
|
+
margin-bottom: 8px;
|
|
11
|
+
color: var(--foreground);
|
|
12
|
+
font-size: 13px;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
input,
|
|
16
|
+
textarea {
|
|
17
|
+
width: 100%;
|
|
18
|
+
padding: 8px;
|
|
19
|
+
border: 1px solid var(--input-border);
|
|
20
|
+
border-radius: 4px;
|
|
21
|
+
background-color: var(--input-background);
|
|
22
|
+
color: var(--input-foreground);
|
|
23
|
+
font-size: 13px;
|
|
24
|
+
font-family: var(--monaco-monospace-font);
|
|
25
|
+
|
|
26
|
+
&:focus {
|
|
27
|
+
border-color: var(--focusBorder);
|
|
28
|
+
outline: none;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
&::placeholder {
|
|
32
|
+
color: var(--descriptionForeground);
|
|
33
|
+
opacity: 0.6;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
textarea {
|
|
38
|
+
resize: vertical;
|
|
39
|
+
min-height: 60px;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
.formActions {
|
|
44
|
+
display: flex;
|
|
45
|
+
justify-content: flex-end;
|
|
46
|
+
gap: 8px;
|
|
47
|
+
margin-top: 24px;
|
|
48
|
+
padding-top: 16px;
|
|
49
|
+
border-top: 1px solid var(--border-color);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
.cancelButton {
|
|
53
|
+
padding: 6px 12px;
|
|
54
|
+
border: 1px solid var(--button-border);
|
|
55
|
+
border-radius: 4px;
|
|
56
|
+
background-color: var(--button-secondary-background);
|
|
57
|
+
color: var(--button-secondary-foreground);
|
|
58
|
+
cursor: pointer;
|
|
59
|
+
font-size: 13px;
|
|
60
|
+
|
|
61
|
+
&:hover {
|
|
62
|
+
background-color: var(--button-secondary-hover-background);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
.submitButton {
|
|
67
|
+
padding: 6px 12px;
|
|
68
|
+
border: none;
|
|
69
|
+
border-radius: 4px;
|
|
70
|
+
background-color: var(--button-primary-background);
|
|
71
|
+
color: var(--button-primary-foreground);
|
|
72
|
+
cursor: pointer;
|
|
73
|
+
font-size: 13px;
|
|
74
|
+
|
|
75
|
+
&:hover {
|
|
76
|
+
background-color: var(--button-primary-hover-background);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
|
|
3
|
+
import { Button } from '@opensumi/ide-components/lib/button';
|
|
4
|
+
import { Modal } from '@opensumi/ide-components/lib/modal';
|
|
5
|
+
|
|
6
|
+
import styles from './mcp-server-form.module.less';
|
|
7
|
+
|
|
8
|
+
export interface MCPServerFormData {
|
|
9
|
+
name: string;
|
|
10
|
+
command: string;
|
|
11
|
+
args: string[];
|
|
12
|
+
env?: Record<string, string>;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
interface Props {
|
|
16
|
+
visible: boolean;
|
|
17
|
+
initialData?: MCPServerFormData;
|
|
18
|
+
onSave: (data: MCPServerFormData) => void;
|
|
19
|
+
onCancel: () => void;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export const MCPServerForm: React.FC<Props> = ({ visible, initialData, onSave, onCancel }) => {
|
|
23
|
+
const [formData, setFormData] = React.useState<MCPServerFormData>(() => ({
|
|
24
|
+
name: '',
|
|
25
|
+
command: '',
|
|
26
|
+
args: [],
|
|
27
|
+
env: {},
|
|
28
|
+
type: 'stdio', // TODO: 支持 SSE
|
|
29
|
+
...initialData,
|
|
30
|
+
}));
|
|
31
|
+
|
|
32
|
+
const [argsText, setArgsText] = React.useState(() => initialData?.args?.join(' ') || '');
|
|
33
|
+
const [envText, setEnvText] = React.useState(() => {
|
|
34
|
+
if (!initialData?.env) {
|
|
35
|
+
return '';
|
|
36
|
+
}
|
|
37
|
+
return Object.entries(initialData.env)
|
|
38
|
+
.map(([key, value]) => `${key}=${value}`)
|
|
39
|
+
.join('\n');
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
// Update form data when initialData changes
|
|
43
|
+
React.useEffect(() => {
|
|
44
|
+
setFormData({
|
|
45
|
+
name: '',
|
|
46
|
+
command: '',
|
|
47
|
+
args: [],
|
|
48
|
+
env: {},
|
|
49
|
+
...initialData,
|
|
50
|
+
});
|
|
51
|
+
setArgsText(initialData?.args?.join(' ') || '');
|
|
52
|
+
setEnvText(
|
|
53
|
+
initialData?.env
|
|
54
|
+
? Object.entries(initialData.env)
|
|
55
|
+
.map(([key, value]) => `${key}=${value}`)
|
|
56
|
+
.join('\n')
|
|
57
|
+
: '',
|
|
58
|
+
);
|
|
59
|
+
}, [initialData]);
|
|
60
|
+
|
|
61
|
+
const handleSubmit = (e: React.FormEvent) => {
|
|
62
|
+
e.preventDefault();
|
|
63
|
+
const args = argsText.split(' ').filter(Boolean);
|
|
64
|
+
const env = envText
|
|
65
|
+
.split('\n')
|
|
66
|
+
.filter(Boolean)
|
|
67
|
+
.reduce((acc, line) => {
|
|
68
|
+
const [key, value] = line.split('=');
|
|
69
|
+
if (key && value) {
|
|
70
|
+
acc[key.trim()] = value.trim();
|
|
71
|
+
}
|
|
72
|
+
return acc;
|
|
73
|
+
}, {} as Record<string, string>);
|
|
74
|
+
|
|
75
|
+
onSave({
|
|
76
|
+
...formData,
|
|
77
|
+
args,
|
|
78
|
+
env,
|
|
79
|
+
});
|
|
80
|
+
};
|
|
81
|
+
|
|
82
|
+
return (
|
|
83
|
+
<Modal
|
|
84
|
+
title={initialData ? 'Edit MCP Server' : 'Add New MCP Server'}
|
|
85
|
+
visible={visible}
|
|
86
|
+
onCancel={onCancel}
|
|
87
|
+
centered
|
|
88
|
+
width={600}
|
|
89
|
+
footer={null}
|
|
90
|
+
style={{
|
|
91
|
+
background: 'var(--editor-background)',
|
|
92
|
+
}}
|
|
93
|
+
>
|
|
94
|
+
<form className={styles.form} onSubmit={(e) => e.preventDefault()}>
|
|
95
|
+
<div className={styles.formItem}>
|
|
96
|
+
<label>Name:</label>
|
|
97
|
+
<input
|
|
98
|
+
type='text'
|
|
99
|
+
value={formData.name}
|
|
100
|
+
onChange={(e) => setFormData({ ...formData, name: e.target.value })}
|
|
101
|
+
placeholder='Enter server name'
|
|
102
|
+
required
|
|
103
|
+
/>
|
|
104
|
+
</div>
|
|
105
|
+
<div className={styles.formItem}>
|
|
106
|
+
<label>Command:</label>
|
|
107
|
+
<input
|
|
108
|
+
type='text'
|
|
109
|
+
value={formData.command}
|
|
110
|
+
onChange={(e) => setFormData({ ...formData, command: e.target.value })}
|
|
111
|
+
placeholder='Enter command (e.g., npx)'
|
|
112
|
+
required
|
|
113
|
+
/>
|
|
114
|
+
</div>
|
|
115
|
+
<div className={styles.formItem}>
|
|
116
|
+
<label>Arguments:</label>
|
|
117
|
+
<textarea
|
|
118
|
+
value={argsText}
|
|
119
|
+
onChange={(e) => setArgsText(e.target.value)}
|
|
120
|
+
placeholder='Enter arguments separated by space'
|
|
121
|
+
rows={3}
|
|
122
|
+
/>
|
|
123
|
+
</div>
|
|
124
|
+
<div className={styles.formItem}>
|
|
125
|
+
<label>Environment Variables:</label>
|
|
126
|
+
<textarea
|
|
127
|
+
value={envText}
|
|
128
|
+
onChange={(e) => setEnvText(e.target.value)}
|
|
129
|
+
placeholder='KEY=value (one per line)'
|
|
130
|
+
rows={3}
|
|
131
|
+
/>
|
|
132
|
+
</div>
|
|
133
|
+
<div className={styles.formActions}>
|
|
134
|
+
<Button onClick={onCancel} type='secondary'>
|
|
135
|
+
Cancel
|
|
136
|
+
</Button>
|
|
137
|
+
<Button onClick={handleSubmit} type='primary'>
|
|
138
|
+
Save
|
|
139
|
+
</Button>
|
|
140
|
+
</div>
|
|
141
|
+
</form>
|
|
142
|
+
</Modal>
|
|
143
|
+
);
|
|
144
|
+
};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Autowired } from '@opensumi/di';
|
|
2
|
+
import { CommandContribution, CommandRegistry, URI } from '@opensumi/ide-core-browser';
|
|
3
|
+
import { Domain } from '@opensumi/ide-core-common';
|
|
4
|
+
import { WorkbenchEditorService } from '@opensumi/ide-editor';
|
|
5
|
+
|
|
6
|
+
import { MCP_CONFIG_COMPONENTS_SCHEME_ID } from './mcp-config.contribution';
|
|
7
|
+
|
|
8
|
+
export const OPEN_MCP_CONFIG_COMMAND = {
|
|
9
|
+
id: 'opensumi-mcp.openConfig',
|
|
10
|
+
label: 'Open MCP Configuration',
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
@Domain(CommandContribution)
|
|
14
|
+
export class MCPConfigCommandContribution implements CommandContribution {
|
|
15
|
+
@Autowired(WorkbenchEditorService)
|
|
16
|
+
private readonly editorService: WorkbenchEditorService;
|
|
17
|
+
|
|
18
|
+
registerCommands(registry: CommandRegistry) {
|
|
19
|
+
registry.registerCommand(OPEN_MCP_CONFIG_COMMAND, {
|
|
20
|
+
execute: () => {
|
|
21
|
+
const uri = new URI().withScheme(MCP_CONFIG_COMPONENTS_SCHEME_ID);
|
|
22
|
+
this.editorService.open(uri, {
|
|
23
|
+
preview: false,
|
|
24
|
+
focus: true,
|
|
25
|
+
});
|
|
26
|
+
},
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { Autowired } from '@opensumi/di';
|
|
2
|
+
import { LabelService } from '@opensumi/ide-core-browser/lib/services';
|
|
3
|
+
import { Domain, Schemes, URI } from '@opensumi/ide-core-common';
|
|
4
|
+
import {
|
|
5
|
+
BrowserEditorContribution,
|
|
6
|
+
EditorComponentRegistry,
|
|
7
|
+
EditorComponentRenderMode,
|
|
8
|
+
IResource,
|
|
9
|
+
ResourceService,
|
|
10
|
+
} from '@opensumi/ide-editor/lib/browser/types';
|
|
11
|
+
import { IconService } from '@opensumi/ide-theme/lib/browser';
|
|
12
|
+
import { IWorkspaceService } from '@opensumi/ide-workspace/lib/common';
|
|
13
|
+
|
|
14
|
+
import { MCPConfigView } from './components/mcp-config.view';
|
|
15
|
+
|
|
16
|
+
const COMPONENTS_ID = 'opensumi-mcp-config-viewer';
|
|
17
|
+
export const MCP_CONFIG_COMPONENTS_SCHEME_ID = 'mcp-config';
|
|
18
|
+
|
|
19
|
+
export type IMCPConfigResource = IResource<{ configType: string }>;
|
|
20
|
+
|
|
21
|
+
@Domain(BrowserEditorContribution)
|
|
22
|
+
export class MCPConfigContribution implements BrowserEditorContribution {
|
|
23
|
+
@Autowired(IWorkspaceService)
|
|
24
|
+
protected readonly workspaceService: IWorkspaceService;
|
|
25
|
+
|
|
26
|
+
@Autowired(IconService)
|
|
27
|
+
protected readonly iconService: IconService;
|
|
28
|
+
|
|
29
|
+
@Autowired()
|
|
30
|
+
labelService: LabelService;
|
|
31
|
+
|
|
32
|
+
registerEditorComponent(registry: EditorComponentRegistry) {
|
|
33
|
+
registry.registerEditorComponent({
|
|
34
|
+
uid: COMPONENTS_ID,
|
|
35
|
+
scheme: MCP_CONFIG_COMPONENTS_SCHEME_ID,
|
|
36
|
+
component: MCPConfigView,
|
|
37
|
+
renderMode: EditorComponentRenderMode.ONE_PER_WORKBENCH,
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
registry.registerEditorComponentResolver(MCP_CONFIG_COMPONENTS_SCHEME_ID, (resource, results) => {
|
|
41
|
+
results.push({
|
|
42
|
+
type: 'component',
|
|
43
|
+
componentId: COMPONENTS_ID,
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
registerResource(service: ResourceService) {
|
|
49
|
+
service.registerResourceProvider({
|
|
50
|
+
scheme: MCP_CONFIG_COMPONENTS_SCHEME_ID,
|
|
51
|
+
provideResource: async (uri: URI): Promise<IMCPConfigResource> => {
|
|
52
|
+
const { configType } = uri.getParsedQuery();
|
|
53
|
+
|
|
54
|
+
return {
|
|
55
|
+
uri,
|
|
56
|
+
name: 'MCP Configuration',
|
|
57
|
+
icon: 'settings',
|
|
58
|
+
metadata: {
|
|
59
|
+
configType,
|
|
60
|
+
},
|
|
61
|
+
};
|
|
62
|
+
},
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
}
|