Install recharts, prepare for burndown chart
This commit is contained in:
		| @ -1,21 +1,21 @@ | ||||
| import * as path from 'path'; | ||||
| import * as vscode from 'vscode'; | ||||
| import * as path from "path"; | ||||
| import * as vscode from "vscode"; | ||||
|  | ||||
| export default class KanbnBurndownPanel { | ||||
|   public static currentPanel: KanbnBurndownPanel | undefined; | ||||
|  | ||||
|   private static readonly viewType = 'react'; | ||||
|   private static readonly viewType = "react"; | ||||
|  | ||||
|   private readonly _panel: vscode.WebviewPanel; | ||||
|   private readonly _extensionPath: string; | ||||
|   private readonly _workspacePath: string; | ||||
|   private readonly _kanbn: typeof import('@basementuniverse/kanbn/src/main'); | ||||
|   private readonly _kanbn: typeof import("@basementuniverse/kanbn/src/main"); | ||||
|   private _disposables: vscode.Disposable[] = []; | ||||
|  | ||||
|   public static createOrShow( | ||||
|     extensionPath: string, | ||||
|     workspacePath: string, | ||||
|     kanbn: typeof import('@basementuniverse/kanbn/src/main') | ||||
|     kanbn: typeof import("@basementuniverse/kanbn/src/main") | ||||
|   ) { | ||||
|     const column = vscode.window.activeTextEditor ? vscode.window.activeTextEditor.viewColumn : undefined; | ||||
|  | ||||
| @ -41,10 +41,20 @@ export default class KanbnBurndownPanel { | ||||
|         vscode.window.showErrorMessage(error instanceof Error ? error.message : error); | ||||
|         return; | ||||
|       } | ||||
|       let tasks: any[]; | ||||
|       try { | ||||
|         tasks = (await KanbnBurndownPanel.currentPanel._kanbn.loadAllTrackedTasks(index)).map( | ||||
|           task => KanbnBurndownPanel.currentPanel!._kanbn.hydrateTask(index, task) | ||||
|         ); | ||||
|       } catch (error) { | ||||
|         vscode.window.showErrorMessage(error instanceof Error ? error.message : error); | ||||
|         return; | ||||
|       } | ||||
|       KanbnBurndownPanel.currentPanel._panel.webview.postMessage({ | ||||
|         type: 'burndown', | ||||
|         type: "burndown", | ||||
|         index, | ||||
|         dateFormat: KanbnBurndownPanel.currentPanel._kanbn.getDateFormat(index) | ||||
|         tasks, | ||||
|         dateFormat: KanbnBurndownPanel.currentPanel._kanbn.getDateFormat(index), | ||||
|       }); | ||||
|     } | ||||
|   } | ||||
| @ -53,14 +63,14 @@ export default class KanbnBurndownPanel { | ||||
|     extensionPath: string, | ||||
|     workspacePath: string, | ||||
|     column: vscode.ViewColumn, | ||||
|     kanbn: typeof import('@basementuniverse/kanbn/src/main') | ||||
|     kanbn: typeof import("@basementuniverse/kanbn/src/main") | ||||
|   ) { | ||||
|     this._extensionPath = extensionPath; | ||||
|     this._workspacePath = workspacePath; | ||||
|     this._kanbn = kanbn; | ||||
|  | ||||
|     // Create and show a new webview panel | ||||
|     this._panel = vscode.window.createWebviewPanel(KanbnBurndownPanel.viewType, 'Burndown Chart', column, { | ||||
|     this._panel = vscode.window.createWebviewPanel(KanbnBurndownPanel.viewType, "Burndown Chart", column, { | ||||
|       // Enable javascript in the webview | ||||
|       enableScripts: true, | ||||
|  | ||||
| @ -69,18 +79,18 @@ export default class KanbnBurndownPanel { | ||||
|  | ||||
|       // Restrict the webview to only loading content from allowed paths | ||||
|       localResourceRoots: [ | ||||
|         vscode.Uri.file(path.join(this._extensionPath, 'build')), | ||||
|         vscode.Uri.file(path.join(this._extensionPath, "build")), | ||||
|         vscode.Uri.file(path.join(this._workspacePath, this._kanbn.getFolderName())), | ||||
|         vscode.Uri.file(path.join(this._extensionPath, 'node_modules', 'vscode-codicons', 'dist')) | ||||
|       ] | ||||
|         vscode.Uri.file(path.join(this._extensionPath, "node_modules", "vscode-codicons", "dist")), | ||||
|       ], | ||||
|     }); | ||||
|     (this._panel as any).iconPath = { | ||||
|       light: vscode.Uri.file(path.join(this._extensionPath, 'resources', 'burndown_light.svg')), | ||||
|       dark: vscode.Uri.file(path.join(this._extensionPath, 'resources', 'burndown_dark.svg')) | ||||
|       light: vscode.Uri.file(path.join(this._extensionPath, "resources", "burndown_light.svg")), | ||||
|       dark: vscode.Uri.file(path.join(this._extensionPath, "resources", "burndown_dark.svg")), | ||||
|     }; | ||||
|  | ||||
|     // Set the webview's title to the kanbn project name | ||||
|     this._kanbn.getIndex().then(index => { | ||||
|     this._kanbn.getIndex().then((index) => { | ||||
|       this._panel.title = index.name; | ||||
|     }); | ||||
|  | ||||
| @ -92,15 +102,18 @@ export default class KanbnBurndownPanel { | ||||
|     this._panel.onDidDispose(() => this.dispose(), null, this._disposables); | ||||
|  | ||||
|     // Handle messages from the webview | ||||
|     this._panel.webview.onDidReceiveMessage(async message => { | ||||
|       switch (message.command) { | ||||
|  | ||||
|         // Display error message | ||||
|         case 'error': | ||||
|           vscode.window.showErrorMessage(message.text); | ||||
|           return; | ||||
|       } | ||||
|     }, null, this._disposables); | ||||
|     this._panel.webview.onDidReceiveMessage( | ||||
|       async (message) => { | ||||
|         switch (message.command) { | ||||
|           // Display error message | ||||
|           case "error": | ||||
|             vscode.window.showErrorMessage(message.text); | ||||
|             return; | ||||
|         } | ||||
|       }, | ||||
|       null, | ||||
|       this._disposables | ||||
|     ); | ||||
|   } | ||||
|  | ||||
|   public dispose() { | ||||
| @ -117,21 +130,21 @@ export default class KanbnBurndownPanel { | ||||
|   } | ||||
|  | ||||
|   private _getHtmlForWebview() { | ||||
|     const manifest = require(path.join(this._extensionPath, 'build', 'asset-manifest.json')); | ||||
|     const mainScript = manifest['main.js']; | ||||
|     const mainStyle = manifest['main.css']; | ||||
|     const scriptUri = vscode.Uri | ||||
|       .file(path.join(this._extensionPath, 'build', mainScript)) | ||||
|       .with({ scheme: 'vscode-resource' }); | ||||
|     const styleUri = vscode.Uri | ||||
|       .file(path.join(this._extensionPath, 'build', mainStyle)) | ||||
|       .with({ scheme: 'vscode-resource' }); | ||||
|     const customStyleUri = vscode.Uri | ||||
|       .file(path.join(this._workspacePath, this._kanbn.getFolderName(), 'board.css')) | ||||
|       .with({ scheme: 'vscode-resource' }); | ||||
|     const codiconsUri = vscode.Uri | ||||
|       .file(path.join(this._extensionPath, 'node_modules', 'vscode-codicons', 'dist', 'codicon.css')) | ||||
|       .with({ scheme: 'vscode-resource' }); | ||||
|     const manifest = require(path.join(this._extensionPath, "build", "asset-manifest.json")); | ||||
|     const mainScript = manifest["main.js"]; | ||||
|     const mainStyle = manifest["main.css"]; | ||||
|     const scriptUri = vscode.Uri.file(path.join(this._extensionPath, "build", mainScript)).with({ | ||||
|       scheme: "vscode-resource", | ||||
|     }); | ||||
|     const styleUri = vscode.Uri.file(path.join(this._extensionPath, "build", mainStyle)).with({ | ||||
|       scheme: "vscode-resource", | ||||
|     }); | ||||
|     const customStyleUri = vscode.Uri.file( | ||||
|       path.join(this._workspacePath, this._kanbn.getFolderName(), "board.css") | ||||
|     ).with({ scheme: "vscode-resource" }); | ||||
|     const codiconsUri = vscode.Uri.file( | ||||
|       path.join(this._extensionPath, "node_modules", "vscode-codicons", "dist", "codicon.css") | ||||
|     ).with({ scheme: "vscode-resource" }); | ||||
|  | ||||
|     // Use a nonce to whitelist which scripts can be run | ||||
|     const nonce = getNonce(); | ||||
| @ -147,7 +160,7 @@ export default class KanbnBurndownPanel { | ||||
| <link rel="stylesheet" type="text/css" href="${customStyleUri}"> | ||||
| <link rel="stylesheet" type="text/css" href="${codiconsUri}"> | ||||
| <meta http-equiv="Content-Security-Policy" content="default-src 'none'; img-src vscode-resource: https:; script-src 'nonce-${nonce}'; font-src vscode-resource:; style-src vscode-resource: 'unsafe-inline' http: https: data:;"> | ||||
| <base href="${vscode.Uri.file(path.join(this._extensionPath, 'build')).with({ scheme: 'vscode-resource' })}/"> | ||||
| <base href="${vscode.Uri.file(path.join(this._extensionPath, "build")).with({ scheme: "vscode-resource" })}/"> | ||||
| </head> | ||||
| <body> | ||||
| <noscript>You need to enable JavaScript to run this app.</noscript> | ||||
|  | ||||
		Reference in New Issue
	
	Block a user