diff --git a/package.json b/package.json index f3fa0626..afc05b17 100644 --- a/package.json +++ b/package.json @@ -304,6 +304,11 @@ "command": "microsoft-powerapps-portals.pagetemplate", "category": "Powerpages", "title": "New Page Template" + }, + { + "command": "microsoft-powerapps-portals.bootstrap-diff", + "category": "Powerpages", + "title": "Bootstrap Diff" } ], "configuration": { diff --git a/src/client/extension.ts b/src/client/extension.ts index d30bbd07..a8850d0d 100644 --- a/src/client/extension.ts +++ b/src/client/extension.ts @@ -31,6 +31,7 @@ import { handleFileSystemCallbacks } from "./power-pages/fileSystemCallbacks"; import { readUserSettings } from "./telemetry/localfileusersettings"; import { initializeGenerator } from "./power-pages/create/CreateCommandWrapper"; import { disposeDiagnostics } from "./power-pages/validationDiagnostics"; +import { bootstrapDiff } from "./power-pages/bootstrapdiff/BootstrapDiff"; let client: LanguageClient; let _context: vscode.ExtensionContext; @@ -96,6 +97,18 @@ export async function activate( ) ); + // registering bootstrapdiff command + _context.subscriptions.push( + vscode.commands.registerCommand('microsoft-powerapps-portals.bootstrap-diff', async() => { + _telemetry.sendTelemetryEvent("StartCommand", { + commandId: "microsoft-powerapps-portals.bootstrap-diff", + }); + bootstrapDiff(); + } + ) + ); + + _context.subscriptions.push( vscode.workspace.onDidOpenTextDocument(() => { if (vscode.window.activeTextEditor === undefined) { diff --git a/src/client/power-pages/bootstrapdiff/BootstrapDiff.ts b/src/client/power-pages/bootstrapdiff/BootstrapDiff.ts new file mode 100644 index 00000000..a5a3433b --- /dev/null +++ b/src/client/power-pages/bootstrapdiff/BootstrapDiff.ts @@ -0,0 +1,111 @@ +/* + * Copyright (c) Microsoft Corporation. All rights reserved. + * Licensed under the MIT License. See License.txt in the project root for license information. + */ + +import * as vscode from 'vscode'; + +// Green highlight for modifications in the output file +const outputDecorationType = vscode.window.createTextEditorDecorationType({ + backgroundColor: '#90ee90' +}); + +// Red highlight for the classes output in the input file +const inputDecorationType = vscode.window.createTextEditorDecorationType({ + backgroundColor: '#E1AEAD' +}); + +// object for storing class range +type ClassRange = { + start: number; + end : number; + offset : number; + matchedClass : string; + replacedClass: string; + message: string; +}; + +let matchedClasses : ClassRange[][]; + +export async function bootstrapDiff() +{ + const editor = vscode.window.activeTextEditor; + if(!editor) + { + // Handle this to prompt the user to open a file and the run the command + vscode.window.showErrorMessage("Open a file before executing the command") + return; + } + + const inputPath = editor.document.uri.path; + + const diffFileName = inputPath + "-diff.json"; + let diffData = ""; + await vscode.workspace.openTextDocument(vscode.Uri.file(diffFileName)).then((document) => { + diffData = document.getText(); + }); + + matchedClasses = JSON.parse(diffData); + hihglightReplacedClasses(editor); + + const websiteFolder = vscode.workspace.getWorkspaceFolder(editor.document.uri)?.name; + if(!websiteFolder) + { + vscode.window.showErrorMessage("Open Website folder in the wrokspace") + return;`` + } + + const v3websiteFolder = websiteFolder.substring(0,websiteFolder.length - 2); + const v3FilePath = inputPath.replace(websiteFolder,v3websiteFolder); + + const options : vscode.TextDocumentShowOptions = { + viewColumn : 2, + preserveFocus : false + }; + + await vscode.window.showTextDocument(vscode.Uri.file(v3FilePath),options); + const v3editor = vscode.window.activeTextEditor; + if(!v3editor) + { + // Handle this case + return; + } + hihglightMatchedClasses(v3editor); +} + +// Hihglights the replaced classes in V5 file +function hihglightReplacedClasses(editor: vscode.TextEditor) +{ + const hoverMessages : vscode.DecorationOptions[] = []; + let offset = 0; + + for(let l=0;l