Skip to content

Commit 8add766

Browse files
use dom API directly so that the url is encoded properly
1 parent 8d0fd2a commit 8add766

File tree

1 file changed

+9
-14
lines changed

1 file changed

+9
-14
lines changed

src/vs/workbench/contrib/issue/browser/issueService.ts

Lines changed: 9 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -3,11 +3,10 @@
33
* Licensed under the MIT License. See License.txt in the project root for license information.
44
*--------------------------------------------------------------------------------------------*/
55

6-
import { URI } from 'vs/base/common/uri';
6+
import * as dom from 'vs/base/browser/dom';
77
import { normalizeGitHubUrl } from 'vs/platform/issue/common/issueReporterUtil';
88
import { IExtensionManagementService, ILocalExtension } from 'vs/platform/extensionManagement/common/extensionManagement';
99
import { ExtensionType } from 'vs/platform/extensions/common/extensions';
10-
import { IOpenerService } from 'vs/platform/opener/common/opener';
1110
import { IProductService } from 'vs/platform/product/common/productService';
1211
import { IWorkbenchIssueService } from 'vs/workbench/services/issue/common/issue';
1312
import { IssueReporterData } from 'vs/platform/issue/common/issue';
@@ -18,7 +17,6 @@ export class WebIssueService implements IWorkbenchIssueService {
1817

1918
constructor(
2019
@IExtensionManagementService private readonly extensionManagementService: IExtensionManagementService,
21-
@IOpenerService private readonly openerService: IOpenerService,
2220
@IProductService private readonly productService: IProductService
2321
) { }
2422

@@ -33,21 +31,21 @@ export class WebIssueService implements IWorkbenchIssueService {
3331
if (options.extensionId) {
3432
const extensions = await this.extensionManagementService.getInstalled(ExtensionType.User);
3533
selectedExtension = extensions.filter(ext => ext.identifier.id === options.extensionId)[0];
36-
const extensionGitHubUrl = await this.getExtensionGitHubUrl(selectedExtension);
34+
const extensionGitHubUrl = this.getExtensionGitHubUrl(selectedExtension);
3735
if (extensionGitHubUrl) {
3836
repositoryUrl = `${extensionGitHubUrl}/issues/new`;
3937
}
4038
}
4139

4240
if (repositoryUrl) {
4341
repositoryUrl = `${repositoryUrl}?body=${encodeURIComponent(await this.getIssueDescription(selectedExtension))}&labels=web`;
44-
return this.openerService.open(URI.parse(repositoryUrl)).then(_ => { });
42+
dom.windowOpenNoOpener(repositoryUrl);
4543
} else {
4644
throw new Error(`Unable to find issue reporting url for ${options.extensionId}`);
4745
}
4846
}
4947

50-
private async getExtensionGitHubUrl(extension: ILocalExtension): Promise<string> {
48+
private getExtensionGitHubUrl(extension: ILocalExtension): string {
5149
let repositoryUrl = '';
5250

5351
const bugsUrl = extension?.manifest.bugs?.url;
@@ -64,16 +62,13 @@ export class WebIssueService implements IWorkbenchIssueService {
6462
}
6563

6664
private async getIssueDescription(extension: ILocalExtension | undefined): Promise<string> {
67-
return `
68-
Issue Type (Please pick one): <b>Bug | Feature request</b>
65+
return `ADD ISSUE DESCRIPTION HERE
6966
70-
ADD ISSUE DESCRIPTION HERE
71-
72-
${extension?.manifest.version ? `\nExtension version: ${extension.manifest.version}` : ''}
73-
VS Code version: ${this.productService.version}
74-
VS Code commit: ${this.productService.commit ?? 'unknown'}
75-
User Agent: ${userAgent?.replace(';', ',') ?? 'unknown'}
67+
Version: ${this.productService.version}
68+
Commit: ${this.productService.commit ?? 'unknown'}
69+
User Agent: ${userAgent ?? 'unknown'}
7670
Embedder: ${this.productService.embedderIdentifier ?? 'unknown'}
71+
${extension?.manifest.version ? `\nExtension version: ${extension.manifest.version}` : ''}
7772
<!-- generated by web issue reporter -->`;
7873
}
7974
}

0 commit comments

Comments
 (0)