feat: Show command hint for agents with non-default system prompts (#1314)

This commit is contained in:
Devansh Jain
2026-03-09 18:31:15 -07:00
committed by GitHub
parent 963274bb75
commit bdadd14410
3 changed files with 77 additions and 1 deletions

View File

@@ -279,6 +279,18 @@ export async function validateSystemPromptPreset(
);
}
/**
* Returns true if the agent is not on the current default preset
* and would benefit from switching to `/system default`.
*/
export function shouldRecommendDefaultPrompt(
currentPrompt: string,
memoryMode: MemoryPromptMode,
): boolean {
const defaultPrompt = buildSystemPrompt("default", memoryMode);
return currentPrompt !== defaultPrompt;
}
/**
* Resolve a prompt ID and build the full system prompt with memory addon.
* Known presets are rebuilt deterministically; unknown IDs (subagent names)

View File

@@ -59,7 +59,10 @@ import {
getModelShortName,
type ModelReasoningEffort,
} from "../agent/model";
import { INTERRUPT_RECOVERY_ALERT } from "../agent/promptAssets";
import {
INTERRUPT_RECOVERY_ALERT,
shouldRecommendDefaultPrompt,
} from "../agent/promptAssets";
import { recordSessionEnd } from "../agent/sessionHistory";
import { SessionStats } from "../agent/stats";
import {
@@ -1022,6 +1025,15 @@ export default function App({
setAgentState((prev) => (prev ? { ...prev, name } : prev));
}, []);
// Check if the current agent would benefit from switching to the default prompt
const shouldShowDefaultPromptTip = useCallback(() => {
if (!agentState?.id || !agentState.system) return false;
const memMode = settingsManager.isMemfsEnabled(agentState.id)
? "memfs"
: ("standard" as const);
return shouldRecommendDefaultPrompt(agentState.system, memMode);
}, [agentState]);
const projectDirectory = process.cwd();
// Track current conversation (always created fresh on startup)
@@ -3093,6 +3105,8 @@ export default function App({
? `Resuming conversation with **${agentName}**`
: `Starting new conversation with **${agentName}**`;
const showPromptTip = shouldShowDefaultPromptTip();
// Command hints - vary based on agent state:
// - Resuming: show /new (they may want a fresh conversation)
// - New session + unpinned: show /pin (they should save their agent)
@@ -3104,6 +3118,9 @@ export default function App({
"→ **/new** start a new conversation",
"→ **/init** initialize your agent's memory",
"→ **/remember** teach your agent",
...(showPromptTip
? ["→ **/system** upgrade to the latest default prompt"]
: []),
]
: isPinned
? [
@@ -3112,6 +3129,9 @@ export default function App({
"→ **/memory** view your agent's memory",
"→ **/init** initialize your agent's memory",
"→ **/remember** teach your agent",
...(showPromptTip
? ["→ **/system** upgrade to the latest default prompt"]
: []),
]
: [
"→ **/agents** list all agents",
@@ -3119,6 +3139,9 @@ export default function App({
"→ **/pin** save + name your agent",
"→ **/init** initialize your agent's memory",
"→ **/remember** teach your agent",
...(showPromptTip
? ["→ **/system** upgrade to the latest default prompt"]
: []),
];
// Build status lines with optional release notes above header
@@ -3154,6 +3177,7 @@ export default function App({
agentProvenance,
resumedExistingConversation,
releaseNotes,
shouldShowDefaultPromptTip,
]);
// Fetch llmConfig when agent is ready
@@ -12840,6 +12864,9 @@ If using apply_patch, use this exact relative patch path: ${applyPatchRelativePa
? `Starting new conversation with **${agentName}**`
: "Creating a new agent";
// Only show prompt tip for existing agents, not brand new ones
const showPromptTip = continueSession && shouldShowDefaultPromptTip();
// Command hints - for pinned agents show /memory, for unpinned show /pin
const commandHints = isPinned
? [
@@ -12848,6 +12875,9 @@ If using apply_patch, use this exact relative patch path: ${applyPatchRelativePa
"→ **/memory** view your agent's memory",
"→ **/init** initialize your agent's memory",
"→ **/remember** teach your agent",
...(showPromptTip
? ["→ **/system** upgrade to the latest default prompt"]
: []),
]
: [
"→ **/agents** list all agents",
@@ -12855,6 +12885,9 @@ If using apply_patch, use this exact relative patch path: ${applyPatchRelativePa
"→ **/pin** save + name your agent",
"→ **/init** initialize your agent's memory",
"→ **/remember** teach your agent",
...(showPromptTip
? ["→ **/system** upgrade to the latest default prompt"]
: []),
];
// Build status lines with optional release notes above header
@@ -12889,6 +12922,7 @@ If using apply_patch, use this exact relative patch path: ${applyPatchRelativePa
agentState,
refreshDerived,
releaseNotes,
shouldShowDefaultPromptTip,
]);
const liveTrajectorySnapshot =

View File

@@ -5,6 +5,7 @@ import {
isKnownPreset,
SYSTEM_PROMPT_MEMFS_ADDON,
SYSTEM_PROMPT_MEMORY_ADDON,
shouldRecommendDefaultPrompt,
swapMemoryAddon,
} from "../../agent/promptAssets";
@@ -151,3 +152,32 @@ describe("swapMemoryAddon", () => {
expect(countOccurrences(twice, "# See what changed")).toBe(1);
});
});
describe("shouldRecommendDefaultPrompt", () => {
test("returns false when prompt matches current default (standard)", () => {
const current = buildSystemPrompt("default", "standard");
expect(shouldRecommendDefaultPrompt(current, "standard")).toBe(false);
});
test("returns false when prompt matches current default (memfs)", () => {
const current = buildSystemPrompt("default", "memfs");
expect(shouldRecommendDefaultPrompt(current, "memfs")).toBe(false);
});
test("returns true for a different preset", () => {
const current = buildSystemPrompt("letta-claude", "standard");
expect(shouldRecommendDefaultPrompt(current, "standard")).toBe(true);
});
test("returns true for a fully custom prompt", () => {
expect(
shouldRecommendDefaultPrompt("You are a custom agent.", "standard"),
).toBe(true);
});
test("returns true for a modified default prompt", () => {
const current = buildSystemPrompt("default", "standard");
const modified = `${current}\n\nExtra instructions added by user.`;
expect(shouldRecommendDefaultPrompt(modified, "standard")).toBe(true);
});
});