Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 | 1x 1x 1x 1x 1x 1x 1x 1x 1x | import { getGlobalPluginsPath } from "lib/pluginManager/globalPlugins"; import glob from "glob"; import { promisify } from "util"; import { join, relative, dirname } from "path"; import { readJSON } from "fs-extra"; const globAsync = promisify(glob); export interface TemplatePlugin { id: string; name: string; preview: string; description: string; } export const loadPlugin = async ( path: string ): Promise< (JSON & { name: string; _resourceType: unknown; description?: string }) | null > => { try { const template = await readJSON(path); Iif (!template.name) { throw new Error("Template is missing name"); } Iif (!template._resourceType || template._resourceType !== "project") { throw new Error('Invalid _resourceType in template, should be "project"'); } return template; } catch (e) { console.error("Unable to load template", e); } return null; }; export class TemplateManager { pluginTemplates: Record<string, TemplatePlugin>; constructor() { this.pluginTemplates = {}; } async loadPlugins() { this.pluginTemplates = {}; const globalPluginsPath = getGlobalPluginsPath(); const pluginPaths = await globAsync( join(globalPluginsPath, "**/project.gbsproj") ); for (const path of pluginPaths) { const template = await loadPlugin(path); Iif (template) { const id = relative(globalPluginsPath, path); this.pluginTemplates[id] = { id, name: template.name, preview: `gbs://global-plugin/${dirname(id)}/thumbnail.png`, description: template.description ?? "", }; } } } async loadPlugin(path: string) { const globalPluginsPath = getGlobalPluginsPath(); const template = await loadPlugin(path); Iif (template) { const id = relative(globalPluginsPath, path); this.pluginTemplates[id] = { id, name: template.name, preview: `gbs://global-plugin/${dirname(id)}/thumbnail.png`, description: template.description ?? "", }; return this.pluginTemplates[id]; } } getTemplate(templateId: string) { const pluginTemplate = this.pluginTemplates[templateId]; Iif (pluginTemplate) { return pluginTemplate; } return undefined; } getPluginTemplates(): TemplatePlugin[] { return Object.entries(this.pluginTemplates).map(([id, template]) => { return { id, name: template.name, preview: `gbs://global-plugin/${dirname(id)}/thumbnail.png`, description: template.description, }; }); } } |