summaryrefslogtreecommitdiff
path: root/packages/cli/src/ui/components/InputPrompt.tsx
diff options
context:
space:
mode:
authorBilly Biggs <[email protected]>2025-06-15 11:40:39 -0700
committerGitHub <[email protected]>2025-06-15 11:40:39 -0700
commitb67806ae9a99e5a3c449c60457933b47d14ba66c (patch)
treef1334ae7d120c3ba39e5725d5e1f56db8ad443ff /packages/cli/src/ui/components/InputPrompt.tsx
parent6d772a30c0540ad83c99a794c820af635961694a (diff)
Support completion of checkpoint names in /resume (#1063)
Diffstat (limited to 'packages/cli/src/ui/components/InputPrompt.tsx')
-rw-r--r--packages/cli/src/ui/components/InputPrompt.tsx23
1 files changed, 19 insertions, 4 deletions
diff --git a/packages/cli/src/ui/components/InputPrompt.tsx b/packages/cli/src/ui/components/InputPrompt.tsx
index c4177c00..d31b7106 100644
--- a/packages/cli/src/ui/components/InputPrompt.tsx
+++ b/packages/cli/src/ui/components/InputPrompt.tsx
@@ -109,11 +109,20 @@ export const InputPrompt: React.FC<InputPromptProps> = ({
const selectedSuggestion = completionSuggestions[indexToUse];
if (query.trimStart().startsWith('/')) {
+ const parts = query.trimStart().substring(1).split(' ');
+ const commandName = parts[0];
const slashIndex = query.indexOf('/');
const base = query.substring(0, slashIndex + 1);
- const newValue = base + selectedSuggestion.value;
- buffer.setText(newValue);
- handleSubmitAndClear(newValue);
+
+ const command = slashCommands.find((cmd) => cmd.name === commandName);
+ if (command && command.completion) {
+ const newValue = `${base}${commandName} ${selectedSuggestion.value}`;
+ buffer.setText(newValue);
+ } else {
+ const newValue = base + selectedSuggestion.value;
+ buffer.setText(newValue);
+ handleSubmitAndClear(newValue);
+ }
} else {
const atIndex = query.lastIndexOf('@');
if (atIndex === -1) return;
@@ -131,7 +140,13 @@ export const InputPrompt: React.FC<InputPromptProps> = ({
}
resetCompletionState();
},
- [resetCompletionState, handleSubmitAndClear, buffer, completionSuggestions],
+ [
+ resetCompletionState,
+ handleSubmitAndClear,
+ buffer,
+ completionSuggestions,
+ slashCommands,
+ ],
);
useInput(