diff --git a/src/plus/launchpad/launchpad.ts b/src/plus/launchpad/launchpad.ts index 31e4dd37e9e54..22e9197e29f37 100644 --- a/src/plus/launchpad/launchpad.ts +++ b/src/plus/launchpad/launchpad.ts @@ -954,6 +954,11 @@ export class LaunchpadCommand extends QuickCommand { createQuickPickSeparator('Actions'), ]; + const checkoutable = + state.item.type === 'pullrequest' && + state.item.headRef != null && + state.item.repoIdentity?.remote?.url != null; + for (const action of state.item.suggestedActions) { switch (action) { case 'merge': { @@ -1001,41 +1006,50 @@ export class LaunchpadCommand extends QuickCommand { ), ); break; - case 'switch': - confirmations.push( - createQuickPickItemOfT( - { - label: 'Switch to Branch', - detail: 'Will checkout the branch, create or open a worktree', - }, - action, - ), - ); + case 'switch': { + if (checkoutable) { + confirmations.push( + createQuickPickItemOfT( + { + label: 'Switch to Branch', + detail: 'Will checkout the branch, create or open a worktree', + }, + action, + ), + ); + } break; - case 'open-worktree': - confirmations.push( - createQuickPickItemOfT( - { - label: 'Open in Worktree', - detail: 'Will create or open a worktree in a new window', - }, - action, - ), - ); + } + case 'open-worktree': { + if (checkoutable) { + confirmations.push( + createQuickPickItemOfT( + { + label: 'Open in Worktree', + detail: 'Will create or open a worktree in a new window', + }, + action, + ), + ); + } break; - case 'switch-and-code-suggest': - confirmations.push( - createQuickPickItemOfT( - { - label: `Switch & Suggest ${ - state.item.viewer.isAuthor ? 'Additional ' : '' - }Code Changes`, - detail: 'Will checkout and start suggesting code changes', - }, - action, - ), - ); + } + case 'switch-and-code-suggest': { + if (checkoutable) { + confirmations.push( + createQuickPickItemOfT( + { + label: `Switch & Suggest ${ + state.item.viewer.isAuthor ? 'Additional ' : '' + }Code Changes`, + detail: 'Will checkout and start suggesting code changes', + }, + action, + ), + ); + } break; + } case 'code-suggest': confirmations.push( createQuickPickItemOfT( @@ -1069,16 +1083,19 @@ export class LaunchpadCommand extends QuickCommand { ), ); break; - case 'open-in-graph': - confirmations.push( - createQuickPickItemOfT( - { - label: 'Open in Commit Graph', - }, - action, - ), - ); + case 'open-in-graph': { + if (checkoutable) { + confirmations.push( + createQuickPickItemOfT( + { + label: 'Open in Commit Graph', + }, + action, + ), + ); + } break; + } } }