From d016a2a2ff522a6ae6de6be717fafc5232178376 Mon Sep 17 00:00:00 2001 From: Oscar Gomez Date: Sat, 30 Dec 2023 00:42:28 +0100 Subject: [PATCH] fix: Fix for issue #254 Fixing the Delete button for the cases where the "Tooling API" option has been selected when querying --- CHANGES.md | 1 + addon/data-export.js | 1 + addon/data-import-test.js | 28 +++++++++++++++++++++++----- addon/data-import.js | 7 +++++-- 4 files changed, 30 insertions(+), 7 deletions(-) diff --git a/CHANGES.md b/CHANGES.md index 227a03ca..6ee0b8a6 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -2,6 +2,7 @@ ## Version 1.22 +- Bugfix Delete button does not check for 'toolingApi' parameter [issue 254](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/254) (contribution by [Oscar Gomez Balaguer](https://github.com/ogomezba)) - Add Apex classes documentation in shortcut [feature 247](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/247) - Disable "Delete records" button when a query returns more than 20k records [feature 251](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/251) - Automatically request SObject type for data import and SObject record id for data export [feature 45](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/45) SObject record (#45)) (contribution by [Olivier Dufour](https://github.com/dufoli)) diff --git a/addon/data-export.js b/addon/data-export.js index c04d8bdf..6efd3650 100644 --- a/addon/data-export.js +++ b/addon/data-export.js @@ -245,6 +245,7 @@ class Model { let args = new URLSearchParams(); args.set("host", this.sfHost); args.set("data", encodedData); + if (this.queryTooling) args.set("apitype", 'Tooling'); window.open("data-import.html?" + args, getLinkTarget(e)); } diff --git a/addon/data-import-test.js b/addon/data-import-test.js index 3a203e70..b3076486 100644 --- a/addon/data-import-test.js +++ b/addon/data-import-test.js @@ -367,23 +367,41 @@ export async function dataImportTest(test) { separator = localStorage.getItem("csvSeparator"); } - let data = [ + let generateDataParam = data => { + let encodedData = btoa(data.map(r => r.join(separator)).join("\r\n")); + let args = new URLSearchParams(); + args.set("data", encodedData); + return args; + }; + + let args = generateDataParam([ ["_", "Id", "Name"], ["[Account]", "0010Y00000kCUn3QAG", "GenePoint1111"], ["[Account]", "0010Y00000kCUn1QAG", "United Oil & Gas UK2222"] - ]; - let encodedData = btoa(data.map(r => r.join(separator)).join("\r\n")); - let args = new URLSearchParams(); - args.set("data", encodedData); + ]); let result = await loadPage("data-import.html", args); let importModel = result.model; + assertEquals([ ["[Account]", "0010Y00000kCUn3QAG", "GenePoint1111"], ["[Account]", "0010Y00000kCUn1QAG", "United Oil & Gas UK2222"] ], importModel.importData.importTable.data); + assertEquals("Enterprise", importModel.apiType); assertEquals("delete", importModel.importAction); + args = generateDataParam([ + ["_", "Id", "ApexCode"], + ["[TraceFlag]", "7tf1n000006zoecAAA", "FINEST"], + ["[TraceFlag]", "7tf1n000007GUCAAA4", "DEBUG"] + ]); + args.set("apitype", "Tooling"); + + result = await loadPage("data-import.html", args) + importModel = result.model; + assertEquals("Tooling", importModel.apiType); + + // Big result // TODO Write test for clipboard copy // TODO Write test for showStatus diff --git a/addon/data-import.js b/addon/data-import.js index 081085c8..2f9b714a 100644 --- a/addon/data-import.js +++ b/addon/data-import.js @@ -49,11 +49,13 @@ class Model { this.userInfo = res.userFullName + " / " + res.userName + " / " + res.organizationName; })); + let apiTypeParam = args.get("apitype"); + this.apiType = this.importType.endsWith("__mdt") ? "Metadata" : apiTypeParam ? apiTypeParam : 'Enterprise'; + if (args.has("data")) { let data = atob(args.get("data")); this.dataFormat = "csv"; this.setData(data); - this.apiType = this.importType.endsWith("__mdt") ? "Metadata" : "Enterprise"; this.updateAvailableActions(); this.importAction = this.importType.endsWith("__mdt") ? "deleteMetadata" : "delete"; this.importActionName = this.importType.endsWith("__mdt") ? "Delete Metadata" : "Delete"; @@ -175,7 +177,8 @@ class Model { //automatically select the SObject if possible let sobj = this.getSObject(data); if (sobj) { - this.apiType = sobj.endsWith("__mdt") ? "Metadata" : "Enterprise"; + //We avoid overwriting the Tooling option in case it was already set + this.apiType = sobj.endsWith("__mdt") ? "Metadata" : this.apiType === 'Tooling' ? 'Tooling' : 'Enterprise'; this.updateAvailableActions(); this.importType = sobj; }