mirror of
https://github.com/danny-avila/LibreChat.git
synced 2026-01-10 20:48:54 +01:00
* refactor: MCP UI Separation for Agents (Dustin WIP)
feat: separate MCPs into their own lists away from tools + actions and add the status indicator functionality from chat to their dropdown ui
fix: spotify mcp was not persisting on agent creation
feat: show disconnected saved servers and their tools in agent mcp list in created agents
fix: select-all regression fixed (caused by deleting tools we were drawing from for rendering list)
fix: dont show all mcps, only those installed in agent in list
feat: separate ToolSelectDialog for MCPServerTools
fix: uninitialized mcp servers not showing as added in toolselectdialog
refactor: reduce looping in AgentPanelContext for categorizing groups and mcps
refactor: split ToolSelectDialog and MCPToolSelectDialog functionality (still needs customization for custom user vars)
chore: address ESLint comments
chore: address ESLint comments
feat: one-click initialization on MCP servers in agent builder
fix: stop propagation triggering reinit on caret click
refactor: split uninitialized MCPs component from initialized MCPs
feat: new mcp tool select dialog ui with custom user vars
feat: show initialization state for CUV configurable MCPs too
chore: remove unused localization string
fix: deselecting all tools caused a re-render
fix: remove subtools so removal from MCPToolSelectDialog works more consistently
feat: added servers have all tools enabled by default
feat: mcp server list now alphabetical to prevent annoying ui behavior of servers jumping around depending on tool selection
fix: filter out placeholder group mcp tools from any actual tool calls / definitions
feat: indicator now takes you to config dialog for uninitialized servers
feat: show previously configured mcp servers that are now missing from the yaml
feat: select all enabled by default on first add to mcp server list
chore: address ESLint comments
* refactor: MCP UI Separation for Agents (Danny WIP)
chore: remove use of `{serverName}_mcp_{serverName}`
chore: import order
WIP: separate component concerns
refactor: streamline agent mcp tools
refactor: unify MCP server handling and improve tool visibility logic, remove unnecessary normalization or sorting, remove nesting button, make variable names clear
refactor: rename mcpServerIds to mcpServerNames for clarity and consistency across components
refactor: remove groupedMCPTools and toolToServerMap, streamline MCP server handling in context and components to effectively utilize mcpServersMap
refactor: optimize tool selection logic by replacing array includes with Set for improved performance
chore: add error logging for failed auth URL parsing in ToolCall component
refactor: enhance MCP tool handling by improving server name management and updating UI elements for better clarity
* refactor: decouple connection status from useMCPServerManager with useMCPConnectionStatus
* fix: improve MCP tool validation logic to handle unconfigured servers
* chore: enhance log message clarity for MCP server disconnection in updateUserPluginsController
* refactor: simplify connection status extraction in useMCPConnectionStatus hook
* refactor: improve initializing UX
* chore: replace string literal with ResourceType constant in useResourcePermissions
* refactor: cleanup code, remove redundancies, rename variables for clarity
* chore: add back filtering and sorting for mcp tools dialog
* refactor: initializeServer to return response and early return
* refactor: enhance server initialization logic and improve UI for OAuth interaction
* chore: clarify warning message for unconfigured MCP server in handleTools
* refactor: prevent CustomUserVarsSection from submitting tools dialog form
* fix: nested button of button issue in UninitializedMCPTool
* feat: add functionality to revoke custom user variables in MCPToolSelectDialog
---------
Co-authored-by: Danny Avila <danny@librechat.ai>
71 lines
2.1 KiB
TypeScript
71 lines
2.1 KiB
TypeScript
import React from 'react';
|
|
import UninitializedMCPTool from './UninitializedMCPTool';
|
|
import UnconfiguredMCPTool from './UnconfiguredMCPTool';
|
|
import { useAgentPanelContext } from '~/Providers';
|
|
import { useLocalize } from '~/hooks';
|
|
import MCPTool from './MCPTool';
|
|
|
|
export default function MCPTools({
|
|
agentId,
|
|
mcpServerNames,
|
|
setShowMCPToolDialog,
|
|
}: {
|
|
agentId: string;
|
|
mcpServerNames?: string[];
|
|
setShowMCPToolDialog: React.Dispatch<React.SetStateAction<boolean>>;
|
|
}) {
|
|
const localize = useLocalize();
|
|
const { mcpServersMap } = useAgentPanelContext();
|
|
|
|
return (
|
|
<div className="mb-4">
|
|
<label className="text-token-text-primary mb-2 block font-medium">
|
|
{localize('com_ui_mcp_servers')}
|
|
</label>
|
|
<div>
|
|
<div className="mb-1">
|
|
{/* Render servers with selected tools */}
|
|
{mcpServerNames?.map((mcpServerName) => {
|
|
const serverInfo = mcpServersMap.get(mcpServerName);
|
|
if (!serverInfo?.isConfigured) {
|
|
return (
|
|
<UnconfiguredMCPTool
|
|
key={`${mcpServerName}-${agentId}`}
|
|
serverName={mcpServerName}
|
|
/>
|
|
);
|
|
}
|
|
if (!serverInfo) {
|
|
return null;
|
|
}
|
|
|
|
if (serverInfo.isConnected) {
|
|
return (
|
|
<MCPTool key={`${serverInfo.serverName}-${agentId}`} serverInfo={serverInfo} />
|
|
);
|
|
}
|
|
|
|
return (
|
|
<UninitializedMCPTool
|
|
key={`${serverInfo.serverName}-${agentId}`}
|
|
serverInfo={serverInfo}
|
|
/>
|
|
);
|
|
})}
|
|
</div>
|
|
<div className="mt-2">
|
|
<button
|
|
type="button"
|
|
onClick={() => setShowMCPToolDialog(true)}
|
|
className="btn btn-neutral border-token-border-light relative h-9 w-full rounded-lg font-medium"
|
|
aria-haspopup="dialog"
|
|
>
|
|
<div className="flex w-full items-center justify-center gap-2">
|
|
{localize('com_assistants_add_mcp_server_tools')}
|
|
</div>
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|