summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorAriane Emory <[email protected]>2025-11-24 03:02:04 -0500
committerGitHub <[email protected]>2025-11-24 02:02:04 -0600
commit75c0c0a0985400bb8470b55cfcafb94744130bc0 (patch)
treed9bf742082276a3176bb3ded8da68ad059aea5a4
parent840d2694b4f94c7cd81f929bc660a3b66f6ee4ec (diff)
downloadopencode-75c0c0a0985400bb8470b55cfcafb94744130bc0.tar.gz
opencode-75c0c0a0985400bb8470b55cfcafb94744130bc0.zip
tweak: display MCPs in alphabetic order in the sidebar. (#4680)
Co-authored-by: Github Action <[email protected]>
-rw-r--r--flake.lock6
-rw-r--r--nix/hashes.json2
-rw-r--r--packages/opencode/src/cli/cmd/tui/routes/session/sidebar.tsx13
3 files changed, 12 insertions, 9 deletions
diff --git a/flake.lock b/flake.lock
index 1150e2751..826bf4d86 100644
--- a/flake.lock
+++ b/flake.lock
@@ -2,11 +2,11 @@
"nodes": {
"nixpkgs": {
"locked": {
- "lastModified": 1763618868,
- "narHash": "sha256-v5afmLjn/uyD9EQuPBn7nZuaZVV9r+JerayK/4wvdWA=",
+ "lastModified": 1763806073,
+ "narHash": "sha256-FHsEKDvfWpzdADWj99z7vBk4D716Ujdyveo5+A048aI=",
"owner": "NixOS",
"repo": "nixpkgs",
- "rev": "a8d610af3f1a5fb71e23e08434d8d61a466fc942",
+ "rev": "878e468e02bfabeda08c79250f7ad583037f2227",
"type": "github"
},
"original": {
diff --git a/nix/hashes.json b/nix/hashes.json
index 6063a49bd..16424b3a0 100644
--- a/nix/hashes.json
+++ b/nix/hashes.json
@@ -1,3 +1,3 @@
{
- "nodeModules": "sha256-/ZkyVHgRMjhzBpnDNTR6X+TomtTMarVU7gmq9Z8Czr8="
+ "nodeModules": "sha256-m7hL9Uzqk+oa2/FtgkzEPgi+m/VZP1SvjpgYHNjiS1c="
}
diff --git a/packages/opencode/src/cli/cmd/tui/routes/session/sidebar.tsx b/packages/opencode/src/cli/cmd/tui/routes/session/sidebar.tsx
index d0241d422..8302bfefe 100644
--- a/packages/opencode/src/cli/cmd/tui/routes/session/sidebar.tsx
+++ b/packages/opencode/src/cli/cmd/tui/routes/session/sidebar.tsx
@@ -18,6 +18,9 @@ export function Sidebar(props: { sessionID: string }) {
const [todoExpanded, setTodoExpanded] = createSignal(true)
const [lspExpanded, setLspExpanded] = createSignal(true)
+ // Sort MCP servers alphabetically for consistent display order
+ const mcpEntries = createMemo(() => Object.entries(sync.data.mcp).sort(([a], [b]) => a.localeCompare(b)))
+
const cost = createMemo(() => {
const total = messages().reduce((sum, x) => sum + (x.role === "assistant" ? x.cost : 0), 0)
return new Intl.NumberFormat("en-US", {
@@ -58,22 +61,22 @@ export function Sidebar(props: { sessionID: string }) {
<text fg={theme.textMuted}>{context()?.percentage ?? 0}% used</text>
<text fg={theme.textMuted}>{cost()} spent</text>
</box>
- <Show when={Object.keys(sync.data.mcp).length > 0}>
+ <Show when={mcpEntries().length > 0}>
<box>
<box
flexDirection="row"
gap={1}
- onMouseDown={() => Object.keys(sync.data.mcp).length > 2 && setMcpExpanded(!mcpExpanded())}
+ onMouseDown={() => mcpEntries().length > 2 && setMcpExpanded(!mcpExpanded())}
>
- <Show when={Object.keys(sync.data.mcp).length > 2}>
+ <Show when={mcpEntries().length > 2}>
<text fg={theme.text}>{mcpExpanded() ? "▼" : "▶"}</text>
</Show>
<text fg={theme.text}>
<b>MCP</b>
</text>
</box>
- <Show when={Object.keys(sync.data.mcp).length <= 2 || mcpExpanded()}>
- <For each={Object.entries(sync.data.mcp)}>
+ <Show when={mcpEntries().length <= 2 || mcpExpanded()}>
+ <For each={mcpEntries()}>
{([key, item]) => (
<box flexDirection="row" gap={1}>
<text