UNPKG

@sussudio/platform

Version:

Internal APIs for VS Code's service injection the base services.

103 lines (102 loc) 3.74 kB
/*--------------------------------------------------------------------------------------------- * Copyright (c) Microsoft Corporation. All rights reserved. * Licensed under the MIT License. See License.txt in the project root for license information. *--------------------------------------------------------------------------------------------*/ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? (desc = Object.getOwnPropertyDescriptor(target, key)) : desc, d; if (typeof Reflect === 'object' && typeof Reflect.decorate === 'function') r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if ((d = decorators[i])) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __param = (this && this.__param) || function (paramIndex, decorator) { return function (target, key) { decorator(target, key, paramIndex); }; }; import { isNonEmptyArray } from '@sussudio/base/common/arrays.mjs'; import { Disposable } from '@sussudio/base/common/lifecycle.mjs'; import { joinPath } from '@sussudio/base/common/resources.mjs'; import { getDomainsOfRemotes } from './configRemotes.mjs'; import { IFileService } from '../../files/common/files.mjs'; import { IProductService } from '../../product/common/productService.mjs'; let ExtensionTipsService = class ExtensionTipsService extends Disposable { fileService; productService; _serviceBrand; allConfigBasedTips = new Map(); constructor(fileService, productService) { super(); this.fileService = fileService; this.productService = productService; if (this.productService.configBasedExtensionTips) { Object.entries(this.productService.configBasedExtensionTips).forEach(([, value]) => this.allConfigBasedTips.set(value.configPath, value), ); } } getConfigBasedTips(folder) { return this.getValidConfigBasedTips(folder); } async getImportantExecutableBasedTips() { return []; } async getOtherExecutableBasedTips() { return []; } async getValidConfigBasedTips(folder) { const result = []; for (const [configPath, tip] of this.allConfigBasedTips) { if (tip.configScheme && tip.configScheme !== folder.scheme) { continue; } try { const content = await this.fileService.readFile(joinPath(folder, configPath)); const recommendationByRemote = new Map(); Object.entries(tip.recommendations).forEach(([key, value]) => { if (isNonEmptyArray(value.remotes)) { for (const remote of value.remotes) { recommendationByRemote.set(remote, { extensionId: key, extensionName: value.name, configName: tip.configName, important: !!value.important, isExtensionPack: !!value.isExtensionPack, whenNotInstalled: value.whenNotInstalled, }); } } else { result.push({ extensionId: key, extensionName: value.name, configName: tip.configName, important: !!value.important, isExtensionPack: !!value.isExtensionPack, whenNotInstalled: value.whenNotInstalled, }); } }); const domains = getDomainsOfRemotes(content.value.toString(), [...recommendationByRemote.keys()]); for (const domain of domains) { const remote = recommendationByRemote.get(domain); if (remote) { result.push(remote); } } } catch (error) { /* Ignore */ } } return result; } }; ExtensionTipsService = __decorate([__param(0, IFileService), __param(1, IProductService)], ExtensionTipsService); export { ExtensionTipsService };