MCPReconnect.tsx
components/mcp/MCPReconnect.tsx
167
Lines
16195
Bytes
1
Exports
8
Imports
10
Keywords
What this is
This page documents one file from the repository and includes its full source so you can read it without leaving the docs site.
Beginner explanation
This file is one piece of the larger system. Its name, directory, imports, and exports show where it fits. Start by reading the exports and related files first.
How it is used
Start from the exports list and related files. Those are the easiest clues for where this file fits into the system.
Expert explanation
Architecturally, this file intersects with ui-flow, mcp. It contains 167 lines, 8 detected imports, and 1 detected exports.
Important relationships
Detected exports
MCPReconnect
Keywords
servernametextoncompleteelsesetisreconnectingstorereconnectmcpserverseterrorservercase
Detected imports
react/compiler-runtimefiguresreact../../commands.js../../ink.js../../services/mcp/MCPConnectionManager.js../../state/AppState.js../Spinner.js
Source notes
This page embeds the full file contents. Small or leaf files are still indexed honestly instead of being over-explained.
Full source
import { c as _c } from "react/compiler-runtime";
import figures from 'figures';
import React, { useEffect, useState } from 'react';
import type { CommandResultDisplay } from '../../commands.js';
import { Box, color, Text, useTheme } from '../../ink.js';
import { useMcpReconnect } from '../../services/mcp/MCPConnectionManager.js';
import { useAppStateStore } from '../../state/AppState.js';
import { Spinner } from '../Spinner.js';
type Props = {
serverName: string;
onComplete: (result?: string, options?: {
display?: CommandResultDisplay;
}) => void;
};
export function MCPReconnect(t0) {
const $ = _c(25);
const {
serverName,
onComplete
} = t0;
const [theme] = useTheme();
const store = useAppStateStore();
const reconnectMcpServer = useMcpReconnect();
const [isReconnecting, setIsReconnecting] = useState(true);
const [error, setError] = useState(null);
let t1;
let t2;
if ($[0] !== onComplete || $[1] !== reconnectMcpServer || $[2] !== serverName || $[3] !== store) {
t1 = () => {
const attemptReconnect = async function attemptReconnect() {
;
try {
const server = store.getState().mcp.clients.find(c => c.name === serverName);
if (!server) {
setError(`MCP server "${serverName}" not found`);
setIsReconnecting(false);
onComplete(`MCP server "${serverName}" not found`);
return;
}
const result = await reconnectMcpServer(serverName);
bb43: switch (result.client.type) {
case "connected":
{
setIsReconnecting(false);
onComplete(`Successfully reconnected to ${serverName}`);
break bb43;
}
case "needs-auth":
{
setError(`${serverName} requires authentication`);
setIsReconnecting(false);
onComplete(`${serverName} requires authentication. Use /mcp to authenticate.`);
break bb43;
}
case "pending":
case "failed":
case "disabled":
{
setError(`Failed to reconnect to ${serverName}`);
setIsReconnecting(false);
onComplete(`Failed to reconnect to ${serverName}`);
}
}
} catch (t3) {
const err = t3;
const errorMessage = err instanceof Error ? err.message : String(err);
setError(errorMessage);
setIsReconnecting(false);
onComplete(`Error: ${errorMessage}`);
}
};
attemptReconnect();
};
t2 = [serverName, reconnectMcpServer, store, onComplete];
$[0] = onComplete;
$[1] = reconnectMcpServer;
$[2] = serverName;
$[3] = store;
$[4] = t1;
$[5] = t2;
} else {
t1 = $[4];
t2 = $[5];
}
useEffect(t1, t2);
if (isReconnecting) {
let t3;
if ($[6] !== serverName) {
t3 = <Text color="text">Reconnecting to <Text bold={true}>{serverName}</Text></Text>;
$[6] = serverName;
$[7] = t3;
} else {
t3 = $[7];
}
let t4;
if ($[8] === Symbol.for("react.memo_cache_sentinel")) {
t4 = <Box><Spinner /><Text> Establishing connection to MCP server</Text></Box>;
$[8] = t4;
} else {
t4 = $[8];
}
let t5;
if ($[9] !== t3) {
t5 = <Box flexDirection="column" gap={1} padding={1}>{t3}{t4}</Box>;
$[9] = t3;
$[10] = t5;
} else {
t5 = $[10];
}
return t5;
}
if (error) {
let t3;
if ($[11] !== theme) {
t3 = color("error", theme)(figures.cross);
$[11] = theme;
$[12] = t3;
} else {
t3 = $[12];
}
let t4;
if ($[13] !== t3) {
t4 = <Text>{t3} </Text>;
$[13] = t3;
$[14] = t4;
} else {
t4 = $[14];
}
let t5;
if ($[15] !== serverName) {
t5 = <Text color="error">Failed to reconnect to {serverName}</Text>;
$[15] = serverName;
$[16] = t5;
} else {
t5 = $[16];
}
let t6;
if ($[17] !== t4 || $[18] !== t5) {
t6 = <Box>{t4}{t5}</Box>;
$[17] = t4;
$[18] = t5;
$[19] = t6;
} else {
t6 = $[19];
}
let t7;
if ($[20] !== error) {
t7 = <Text dimColor={true}>Error: {error}</Text>;
$[20] = error;
$[21] = t7;
} else {
t7 = $[21];
}
let t8;
if ($[22] !== t6 || $[23] !== t7) {
t8 = <Box flexDirection="column" gap={1} padding={1}>{t6}{t7}</Box>;
$[22] = t6;
$[23] = t7;
$[24] = t8;
} else {
t8 = $[24];
}
return t8;
}
return null;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["figures","React","useEffect","useState","CommandResultDisplay","Box","color","Text","useTheme","useMcpReconnect","useAppStateStore","Spinner","Props","serverName","onComplete","result","options","display","MCPReconnect","t0","$","_c","theme","store","reconnectMcpServer","isReconnecting","setIsReconnecting","error","setError","t1","t2","attemptReconnect","server","getState","mcp","clients","find","c","name","bb43","client","type","t3","err","errorMessage","Error","message","String","t4","Symbol","for","t5","cross","t6","t7","t8"],"sources":["MCPReconnect.tsx"],"sourcesContent":["import figures from 'figures'\nimport React, { useEffect, useState } from 'react'\nimport type { CommandResultDisplay } from '../../commands.js'\nimport { Box, color, Text, useTheme } from '../../ink.js'\nimport { useMcpReconnect } from '../../services/mcp/MCPConnectionManager.js'\nimport { useAppStateStore } from '../../state/AppState.js'\nimport { Spinner } from '../Spinner.js'\n\ntype Props = {\n  serverName: string\n  onComplete: (\n    result?: string,\n    options?: { display?: CommandResultDisplay },\n  ) => void\n}\n\nexport function MCPReconnect({\n  serverName,\n  onComplete,\n}: Props): React.ReactNode {\n  const [theme] = useTheme()\n  const store = useAppStateStore()\n  const reconnectMcpServer = useMcpReconnect()\n  const [isReconnecting, setIsReconnecting] = useState(true)\n  const [error, setError] = useState<string | null>(null)\n\n  useEffect(() => {\n    async function attemptReconnect() {\n      try {\n        // Check if server exists. Read via store.getState() instead of a\n        // reactive selector so this effect does not re-fire when\n        // reconnectMcpServer updates mcp.clients via onConnectionAttempt.\n        const server = store\n          .getState()\n          .mcp.clients.find(c => c.name === serverName)\n        if (!server) {\n          setError(`MCP server \"${serverName}\" not found`)\n          setIsReconnecting(false)\n          onComplete(`MCP server \"${serverName}\" not found`)\n          return\n        }\n\n        // Attempt reconnection\n        const result = await reconnectMcpServer(serverName)\n\n        switch (result.client.type) {\n          case 'connected':\n            setIsReconnecting(false)\n            onComplete(`Successfully reconnected to ${serverName}`)\n            break\n          case 'needs-auth':\n            setError(`${serverName} requires authentication`)\n            setIsReconnecting(false)\n            onComplete(\n              `${serverName} requires authentication. Use /mcp to authenticate.`,\n            )\n            break\n          case 'pending':\n          case 'failed':\n          case 'disabled':\n            setError(`Failed to reconnect to ${serverName}`)\n            setIsReconnecting(false)\n            onComplete(`Failed to reconnect to ${serverName}`)\n            break\n        }\n      } catch (err) {\n        // Only catch actual errors (like server not found)\n        const errorMessage = err instanceof Error ? err.message : String(err)\n        setError(errorMessage)\n        setIsReconnecting(false)\n        onComplete(`Error: ${errorMessage}`)\n      }\n    }\n\n    void attemptReconnect()\n  }, [serverName, reconnectMcpServer, store, onComplete])\n\n  if (isReconnecting) {\n    return (\n      <Box flexDirection=\"column\" gap={1} padding={1}>\n        <Text color=\"text\">\n          Reconnecting to <Text bold>{serverName}</Text>\n        </Text>\n        <Box>\n          <Spinner />\n          <Text> Establishing connection to MCP server</Text>\n        </Box>\n      </Box>\n    )\n  }\n\n  if (error) {\n    return (\n      <Box flexDirection=\"column\" gap={1} padding={1}>\n        <Box>\n          <Text>{color('error', theme)(figures.cross)} </Text>\n          <Text color=\"error\">Failed to reconnect to {serverName}</Text>\n        </Box>\n        <Text dimColor>Error: {error}</Text>\n      </Box>\n    )\n  }\n\n  return null\n}\n"],"mappings":";AAAA,OAAOA,OAAO,MAAM,SAAS;AAC7B,OAAOC,KAAK,IAAIC,SAAS,EAAEC,QAAQ,QAAQ,OAAO;AAClD,cAAcC,oBAAoB,QAAQ,mBAAmB;AAC7D,SAASC,GAAG,EAAEC,KAAK,EAAEC,IAAI,EAAEC,QAAQ,QAAQ,cAAc;AACzD,SAASC,eAAe,QAAQ,4CAA4C;AAC5E,SAASC,gBAAgB,QAAQ,yBAAyB;AAC1D,SAASC,OAAO,QAAQ,eAAe;AAEvC,KAAKC,KAAK,GAAG;EACXC,UAAU,EAAE,MAAM;EAClBC,UAAU,EAAE,CACVC,MAAe,CAAR,EAAE,MAAM,EACfC,OAA4C,CAApC,EAAE;IAAEC,OAAO,CAAC,EAAEb,oBAAoB;EAAC,CAAC,EAC5C,GAAG,IAAI;AACX,CAAC;AAED,OAAO,SAAAc,aAAAC,EAAA;EAAA,MAAAC,CAAA,GAAAC,EAAA;EAAsB;IAAAR,UAAA;IAAAC;EAAA,IAAAK,EAGrB;EACN,OAAAG,KAAA,IAAgBd,QAAQ,CAAC,CAAC;EAC1B,MAAAe,KAAA,GAAcb,gBAAgB,CAAC,CAAC;EAChC,MAAAc,kBAAA,GAA2Bf,eAAe,CAAC,CAAC;EAC5C,OAAAgB,cAAA,EAAAC,iBAAA,IAA4CvB,QAAQ,CAAC,IAAI,CAAC;EAC1D,OAAAwB,KAAA,EAAAC,QAAA,IAA0BzB,QAAQ,CAAgB,IAAI,CAAC;EAAA,IAAA0B,EAAA;EAAA,IAAAC,EAAA;EAAA,IAAAV,CAAA,QAAAN,UAAA,IAAAM,CAAA,QAAAI,kBAAA,IAAAJ,CAAA,QAAAP,UAAA,IAAAO,CAAA,QAAAG,KAAA;IAE7CM,EAAA,GAAAA,CAAA;MACR,MAAAE,gBAAA,kBAAAA,iBAAA;QAAA;QACE;UAIE,MAAAC,MAAA,GAAeT,KAAK,CAAAU,QACT,CAAC,CAAC,CAAAC,GACP,CAAAC,OAAQ,CAAAC,IAAK,CAACC,CAAA,IAAKA,CAAC,CAAAC,IAAK,KAAKzB,UAAU,CAAC;UAC/C,IAAI,CAACmB,MAAM;YACTJ,QAAQ,CAAC,eAAef,UAAU,aAAa,CAAC;YAChDa,iBAAiB,CAAC,KAAK,CAAC;YACxBZ,UAAU,CAAC,eAAeD,UAAU,aAAa,CAAC;YAAA;UAAA;UAKpD,MAAAE,MAAA,GAAe,MAAMS,kBAAkB,CAACX,UAAU,CAAC;UAAA0B,IAAA,EAEnD,QAAQxB,MAAM,CAAAyB,MAAO,CAAAC,IAAK;YAAA,KACnB,WAAW;cAAA;gBACdf,iBAAiB,CAAC,KAAK,CAAC;gBACxBZ,UAAU,CAAC,+BAA+BD,UAAU,EAAE,CAAC;gBACvD,MAAA0B,IAAA;cAAK;YAAA,KACF,YAAY;cAAA;gBACfX,QAAQ,CAAC,GAAGf,UAAU,0BAA0B,CAAC;gBACjDa,iBAAiB,CAAC,KAAK,CAAC;gBACxBZ,UAAU,CACR,GAAGD,UAAU,qDACf,CAAC;gBACD,MAAA0B,IAAA;cAAK;YAAA,KACF,SAAS;YAAA,KACT,QAAQ;YAAA,KACR,UAAU;cAAA;gBACbX,QAAQ,CAAC,0BAA0Bf,UAAU,EAAE,CAAC;gBAChDa,iBAAiB,CAAC,KAAK,CAAC;gBACxBZ,UAAU,CAAC,0BAA0BD,UAAU,EAAE,CAAC;cAAA;UAEtD;QAAC,SAAA6B,EAAA;UACMC,KAAA,CAAAA,GAAA,CAAAA,CAAA,CAAAA,EAAG;UAEV,MAAAC,YAAA,GAAqBD,GAAG,YAAYE,KAAiC,GAAzBF,GAAG,CAAAG,OAAsB,GAAXC,MAAM,CAACJ,GAAG,CAAC;UACrEf,QAAQ,CAACgB,YAAY,CAAC;UACtBlB,iBAAiB,CAAC,KAAK,CAAC;UACxBZ,UAAU,CAAC,UAAU8B,YAAY,EAAE,CAAC;QAAA;MACrC,CACF;MAEIb,gBAAgB,CAAC,CAAC;IAAA,CACxB;IAAED,EAAA,IAACjB,UAAU,EAAEW,kBAAkB,EAAED,KAAK,EAAET,UAAU,CAAC;IAAAM,CAAA,MAAAN,UAAA;IAAAM,CAAA,MAAAI,kBAAA;IAAAJ,CAAA,MAAAP,UAAA;IAAAO,CAAA,MAAAG,KAAA;IAAAH,CAAA,MAAAS,EAAA;IAAAT,CAAA,MAAAU,EAAA;EAAA;IAAAD,EAAA,GAAAT,CAAA;IAAAU,EAAA,GAAAV,CAAA;EAAA;EAjDtDlB,SAAS,CAAC2B,EAiDT,EAAEC,EAAmD,CAAC;EAEvD,IAAIL,cAAc;IAAA,IAAAiB,EAAA;IAAA,IAAAtB,CAAA,QAAAP,UAAA;MAGZ6B,EAAA,IAAC,IAAI,CAAO,KAAM,CAAN,MAAM,CAAC,gBACD,CAAC,IAAI,CAAC,IAAI,CAAJ,KAAG,CAAC,CAAE7B,WAAS,CAAE,EAAtB,IAAI,CACvB,EAFC,IAAI,CAEE;MAAAO,CAAA,MAAAP,UAAA;MAAAO,CAAA,MAAAsB,EAAA;IAAA;MAAAA,EAAA,GAAAtB,CAAA;IAAA;IAAA,IAAA4B,EAAA;IAAA,IAAA5B,CAAA,QAAA6B,MAAA,CAAAC,GAAA;MACPF,EAAA,IAAC,GAAG,CACF,CAAC,OAAO,GACR,CAAC,IAAI,CAAC,sCAAsC,EAA3C,IAAI,CACP,EAHC,GAAG,CAGE;MAAA5B,CAAA,MAAA4B,EAAA;IAAA;MAAAA,EAAA,GAAA5B,CAAA;IAAA;IAAA,IAAA+B,EAAA;IAAA,IAAA/B,CAAA,QAAAsB,EAAA;MAPRS,EAAA,IAAC,GAAG,CAAe,aAAQ,CAAR,QAAQ,CAAM,GAAC,CAAD,GAAC,CAAW,OAAC,CAAD,GAAC,CAC5C,CAAAT,EAEM,CACN,CAAAM,EAGK,CACP,EARC,GAAG,CAQE;MAAA5B,CAAA,MAAAsB,EAAA;MAAAtB,CAAA,OAAA+B,EAAA;IAAA;MAAAA,EAAA,GAAA/B,CAAA;IAAA;IAAA,OARN+B,EAQM;EAAA;EAIV,IAAIxB,KAAK;IAAA,IAAAe,EAAA;IAAA,IAAAtB,CAAA,SAAAE,KAAA;MAIMoB,EAAA,GAAApC,KAAK,CAAC,OAAO,EAAEgB,KAAK,CAAC,CAACtB,OAAO,CAAAoD,KAAM,CAAC;MAAAhC,CAAA,OAAAE,KAAA;MAAAF,CAAA,OAAAsB,EAAA;IAAA;MAAAA,EAAA,GAAAtB,CAAA;IAAA;IAAA,IAAA4B,EAAA;IAAA,IAAA5B,CAAA,SAAAsB,EAAA;MAA3CM,EAAA,IAAC,IAAI,CAAE,CAAAN,EAAmC,CAAE,CAAC,EAA5C,IAAI,CAA+C;MAAAtB,CAAA,OAAAsB,EAAA;MAAAtB,CAAA,OAAA4B,EAAA;IAAA;MAAAA,EAAA,GAAA5B,CAAA;IAAA;IAAA,IAAA+B,EAAA;IAAA,IAAA/B,CAAA,SAAAP,UAAA;MACpDsC,EAAA,IAAC,IAAI,CAAO,KAAO,CAAP,OAAO,CAAC,uBAAwBtC,WAAS,CAAE,EAAtD,IAAI,CAAyD;MAAAO,CAAA,OAAAP,UAAA;MAAAO,CAAA,OAAA+B,EAAA;IAAA;MAAAA,EAAA,GAAA/B,CAAA;IAAA;IAAA,IAAAiC,EAAA;IAAA,IAAAjC,CAAA,SAAA4B,EAAA,IAAA5B,CAAA,SAAA+B,EAAA;MAFhEE,EAAA,IAAC,GAAG,CACF,CAAAL,EAAmD,CACnD,CAAAG,EAA6D,CAC/D,EAHC,GAAG,CAGE;MAAA/B,CAAA,OAAA4B,EAAA;MAAA5B,CAAA,OAAA+B,EAAA;MAAA/B,CAAA,OAAAiC,EAAA;IAAA;MAAAA,EAAA,GAAAjC,CAAA;IAAA;IAAA,IAAAkC,EAAA;IAAA,IAAAlC,CAAA,SAAAO,KAAA;MACN2B,EAAA,IAAC,IAAI,CAAC,QAAQ,CAAR,KAAO,CAAC,CAAC,OAAQ3B,MAAI,CAAE,EAA5B,IAAI,CAA+B;MAAAP,CAAA,OAAAO,KAAA;MAAAP,CAAA,OAAAkC,EAAA;IAAA;MAAAA,EAAA,GAAAlC,CAAA;IAAA;IAAA,IAAAmC,EAAA;IAAA,IAAAnC,CAAA,SAAAiC,EAAA,IAAAjC,CAAA,SAAAkC,EAAA;MALtCC,EAAA,IAAC,GAAG,CAAe,aAAQ,CAAR,QAAQ,CAAM,GAAC,CAAD,GAAC,CAAW,OAAC,CAAD,GAAC,CAC5C,CAAAF,EAGK,CACL,CAAAC,EAAmC,CACrC,EANC,GAAG,CAME;MAAAlC,CAAA,OAAAiC,EAAA;MAAAjC,CAAA,OAAAkC,EAAA;MAAAlC,CAAA,OAAAmC,EAAA;IAAA;MAAAA,EAAA,GAAAnC,CAAA;IAAA;IAAA,OANNmC,EAMM;EAAA;EAET,OAEM,IAAI;AAAA","ignoreList":[]}