diff --git a/extensions/github/package.json b/extensions/github/package.json index fb33fbaf3a57a..a5de87a74b765 100644 --- a/extensions/github/package.json +++ b/extensions/github/package.json @@ -26,7 +26,8 @@ } }, "enabledApiProposals": [ - "contribShareMenu" + "contribShareMenu", + "contribEditSessions" ], "contributes": { "commands": [ @@ -37,10 +38,20 @@ { "command": "github.copyVscodeDevLink", "title": "Copy vscode.dev Link" - }, - { - "command": "github.copyVscodeDevLinkFile", - "title": "Copy vscode.dev Link" + }, + { + "command": "github.copyVscodeDevLinkFile", + "title": "Copy vscode.dev Link" + }, + { + "command": "github.openOnVscodeDev", + "title": "Open on vscode.dev" + } + ], + "continueEditSession": [ + { + "command": "github.openOnVscodeDev", + "when": "github.hasGitHubRepo" } ], "menus": { @@ -56,6 +67,10 @@ { "command": "github.copyVscodeDevLinkFile", "when": "false" + }, + { + "command": "github.openOnVscodeDev", + "when": "false" } ], "file/share": [ diff --git a/extensions/github/src/commands.ts b/extensions/github/src/commands.ts index 8c68f36bfc65d..40a6927146dbc 100644 --- a/extensions/github/src/commands.ts +++ b/extensions/github/src/commands.ts @@ -20,6 +20,16 @@ async function copyVscodeDevLink(gitAPI: GitAPI, useSelection: boolean) { } } +async function openVscodeDevLink(gitAPI: GitAPI): Promise { + try { + const permalink = getPermalink(gitAPI, true, 'https://vscode.dev/github'); + return permalink ? vscode.Uri.parse(permalink) : undefined; + } catch (err) { + vscode.window.showErrorMessage(err.message); + return undefined; + } +} + export function registerCommands(gitAPI: GitAPI): vscode.Disposable { const disposables = new DisposableStore(); @@ -39,5 +49,9 @@ export function registerCommands(gitAPI: GitAPI): vscode.Disposable { return copyVscodeDevLink(gitAPI, false); })); + disposables.add(vscode.commands.registerCommand('github.openOnVscodeDev', async () => { + return openVscodeDevLink(gitAPI); + })); + return disposables; } diff --git a/src/vs/workbench/contrib/editSessions/browser/editSessions.contribution.ts b/src/vs/workbench/contrib/editSessions/browser/editSessions.contribution.ts index 34d89d716a288..9be6a5124f7af 100644 --- a/src/vs/workbench/contrib/editSessions/browser/editSessions.contribution.ts +++ b/src/vs/workbench/contrib/editSessions/browser/editSessions.contribution.ts @@ -113,7 +113,7 @@ export class EditSessionsContribution extends Disposable implements IWorkbenchCo } const commands = new Map((extension.description.contributes?.commands ?? []).map(c => [c.command, c])); for (const contribution of extension.value) { - if (!contribution.command || !contribution.group || !contribution.when) { + if (!contribution.command || !contribution.when) { continue; } const fullCommand = commands.get(contribution.command);