Skip to content

Commit

Permalink
Automatically request SObject type when data export from an SObject r…
Browse files Browse the repository at this point in the history
…ecord (#45)
  • Loading branch information
dufoli committed Dec 21, 2023
1 parent c06a67c commit c80085f
Show file tree
Hide file tree
Showing 4 changed files with 59 additions and 17 deletions.
3 changes: 3 additions & 0 deletions CHANGES.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@
- Fix 'Custom Object Name Links Don't Work' in popup [issue 218](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/218) (contribution by [Jeferson Chaves](https://github.com/JefersonChaves))
- Show field API Name on Record Page [PR202](https://github.com/tprouvot/Salesforce-Inspector-reloaded/pull/202) (contribution by [Mouloud Habchi](https://github.com/MD931))
- Add support for domains protected by Microsoft Defender for Cloud Apps [issue 234](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/234) (contribution by [Mehdi Cherfaoui](https://github.com/mehdisfdc))
- Add Salesforce SObject documentation links [feature 219](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/219) (idea by [Antoine Audollent])
- Automatically request SObject type when data export from an SObject record [feature 45](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/45) SObject record (#45))

## Version 1.20.1

Expand Down Expand Up @@ -51,6 +53,7 @@
- Detect SObject on list view page [feature 121](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/121) (idea by [Mehdi Cherfaoui](https://github.com/mehdisfdc))
- Automate test setup manual step of contact to multiple accounts [Aidan Majewski](https://github.com/aimaj)
- In Data export, set input focus in SOQL query text area. [feature 183](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/183) (contribution by [Sarath Addanki](https://github.com/asknet))
- In Data export, set input focus in SQOL query text area. [feature 183](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/183) (contribution by [Sarath Addanki](https://github.com/asknet))

## Version 1.19

Expand Down
3 changes: 3 additions & 0 deletions addon/data-import.js
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,9 @@ class Model {
Succeeded: true,
Failed: true
};
if (args.has("sobject")) {
this.importType = args.get("sobject");
}
if (localStorage.getItem(sfHost + "_isSandbox") != "true") {
//change background color for production
document.body.classList.add("prod");
Expand Down
4 changes: 2 additions & 2 deletions addon/inspect.js
Original file line number Diff line number Diff line change
Expand Up @@ -236,9 +236,9 @@ class Model {
if (!objectName) {
return undefined;
}
let query = "select Id from " + objectName;
let query = "SELECT Id FROM " + objectName;
if (this.recordData && this.recordData.Id) {
query += " where Id = '" + this.recordData.Id + "'";
query += " WHERE Id = '" + this.recordData.Id + "'";
}
return this.dataExportUrl(query);
}
Expand Down
66 changes: 51 additions & 15 deletions addon/popup.js
Original file line number Diff line number Diff line change
Expand Up @@ -53,15 +53,44 @@ function initLinks({sfHost}){
class App extends React.PureComponent {
constructor(props) {
super(props);
let {sfHost} = this.props;
let hostArg = new URLSearchParams();
hostArg.set("host", sfHost);
this.state = {
isInSetup: false,
contextUrl: null,
apiVersionInput: apiVersion,
isFieldsPresent: false
isFieldsPresent: false,
exportHref: "data-export.html?" + hostArg,
importHref: "data-import.html?" + hostArg,
limitsHref: "limits.html?" + hostArg
};
this.onContextUrlMessage = this.onContextUrlMessage.bind(this);
this.onShortcutKey = this.onShortcutKey.bind(this);
this.onChangeApi = this.onChangeApi.bind(this);
this.onContextRecordChange = this.onContextRecordChange.bind(this);
}
onContextRecordChange(e) {
let {sfHost} = this.props;
let limitsArg = new URLSearchParams();
let exportArg = new URLSearchParams();
let importArg = new URLSearchParams();
exportArg.set("host", sfHost);
importArg.set("host", sfHost);
limitsArg.set("host", sfHost);
if (e.contextSobject) {
let query = "SELECT Id FROM " + e.contextSobject;
if (e.contextRecordId && (e.contextRecordId.length == 15 || e.contextRecordId.length == 18)) {
query += " WHERE Id = '" + e.contextRecordId + "'";
}
exportArg.set("query", query);
importArg.set('sobject', e.contextSobject)
}
this.setState({
exportHref: "data-export.html?" + exportArg,
importHref: "data-import.html?" + importArg,
limitsHref: "limits.html?" + limitsArg
})
}
onContextUrlMessage(e) {
if (e.source == parent && e.data.insextUpdateRecordId) {
Expand Down Expand Up @@ -172,7 +201,7 @@ class App extends React.PureComponent {
inInspector,
addonVersion
} = this.props;
let {isInSetup, contextUrl, apiVersionInput, isFieldsPresent} = this.state;
let {isInSetup, contextUrl, apiVersionInput, exportHref, importHref, limitsHref, isFieldsPresent} = this.state;
let clientId = localStorage.getItem(sfHost + "_clientId");
let hostArg = new URLSearchParams();
hostArg.set("host", sfHost);
Expand All @@ -199,16 +228,16 @@ class App extends React.PureComponent {
)
),
h("div", {className: "main"},
h(AllDataBox, {ref: "showAllDataBox", sfHost, showDetailsSupported: !inLightning && !inInspector, linkTarget, contextUrl, isFieldsPresent}),
h(AllDataBox, {ref: "showAllDataBox", sfHost, showDetailsSupported: !inLightning && !inInspector, linkTarget, contextUrl, onContextRecordChange: this.onContextRecordChange, isFieldsPresent}),
h("div", {className: "slds-p-vertical_x-small slds-p-horizontal_x-small slds-border_bottom"},
h("div", {className: "slds-m-bottom_xx-small"},
h("a", {ref: "dataExportBtn", href: "data-export.html?" + hostArg, target: linkTarget, className: "page-button slds-button slds-button_neutral"}, h("span", {}, "Data ", h("u", {}, "E"), "xport"))
h("a", {ref: "dataExportBtn", href: exportHref, target: linkTarget, className: "page-button slds-button slds-button_neutral"}, h("span", {}, "Data ", h("u", {}, "E"), "xport"))
),
h("div", {className: "slds-m-bottom_xx-small"},
h("a", {ref: "dataImportBtn", href: "data-import.html?" + hostArg, target: linkTarget, className: "page-button slds-button slds-button_neutral"}, h("span", {}, "Data ", h("u", {}, "I"), "mport"))
h("a", {ref: "dataImportBtn", href: importHref, target: linkTarget, className: "page-button slds-button slds-button_neutral"}, h("span", {}, "Data ", h("u", {}, "I"), "mport"))
),
h("div", {},
h("a", {ref: "limitsBtn", href: "limits.html?" + hostArg, target: linkTarget, className: "page-button slds-button slds-button_neutral"}, h("span", {}, "Org ", h("u", {}, "L"), "imits"))
h("a", {ref: "limitsBtn", href: limitsHref, target: linkTarget, className: "page-button slds-button slds-button_neutral"}, h("span", {}, "Org ", h("u", {}, "L"), "imits"))
),
),
h("div", {className: "slds-p-vertical_x-small slds-p-horizontal_x-small"},
Expand Down Expand Up @@ -331,16 +360,18 @@ class AllDataBox extends React.PureComponent {
}

ensureKnownBrowserContext() {
let {contextUrl} = this.props;
let {contextUrl, onContextRecordChange} = this.props;
if (contextUrl) {
let recordId = getRecordId(contextUrl);
let path = getSfPathFromUrl(contextUrl);
let sobject = getSobject(contextUrl);
this.setState({
let context = {
contextRecordId: recordId,
contextPath: path,
contextSobject: sobject
});
};
this.setState(context);
onContextRecordChange(context);
}
}

Expand Down Expand Up @@ -489,7 +520,7 @@ class AllDataBox extends React.PureComponent {

render() {
let {activeSearchAspect, sobjectsLoading, contextRecordId, contextSobject, contextUserId, contextOrgId, contextPath, sobjectsList} = this.state;
let {sfHost, showDetailsSupported, linkTarget, isFieldsPresent} = this.props;
let {sfHost, showDetailsSupported, linkTarget, onContextRecordChange, isFieldsPresent} = this.props;

return (
h("div", {className: "slds-p-top_small slds-p-horizontal_x-small slds-p-bottom_x-small slds-border_bottom" + (this.isLoading() ? " loading " : "")},
Expand All @@ -500,7 +531,7 @@ class AllDataBox extends React.PureComponent {
h("li", {ref: "orgTab", onClick: this.onAspectClick, "data-aspect": this.SearchAspectTypes.org, className: (activeSearchAspect == this.SearchAspectTypes.org) ? "active" : ""}, h("span", {}, "O", h("u", {}, "r"), "g"))
),
(activeSearchAspect == this.SearchAspectTypes.sobject)
? h(AllDataBoxSObject, {ref: "showAllDataBoxSObject", sfHost, showDetailsSupported, sobjectsList, sobjectsLoading, contextRecordId, contextSobject, linkTarget, isFieldsPresent})
? h(AllDataBoxSObject, {ref: "showAllDataBoxSObject", sfHost, showDetailsSupported, sobjectsList, sobjectsLoading, contextRecordId, contextSobject, linkTarget, onContextRecordChange, isFieldsPresent})
: (activeSearchAspect == this.SearchAspectTypes.users)
? h(AllDataBoxUsers, {ref: "showAllDataBoxUsers", sfHost, linkTarget, contextUserId, contextOrgId, contextPath, setIsLoading: (value) => { this.setIsLoading("usersBox", value); }}, "Users")
: (activeSearchAspect == this.SearchAspectTypes.shortcuts)
Expand Down Expand Up @@ -815,8 +846,12 @@ class AllDataBoxSObject extends React.PureComponent {
}

onDataSelect(value) {
let {onContextRecordChange} = this.props;
this.setState({selectedValue: value}, () => {
this.loadRecordIdDetails();
if (value) {
onContextRecordChange({contextSobject : value.sobject.name, contextRecordId : value.recordId});
}
});
}

Expand Down Expand Up @@ -1814,10 +1849,11 @@ function getRecordId(href) {

function getSobject(href) {
let url = new URL(href);
if (url.pathname && url.pathname.endsWith("/list")){
let sobject = url.pathname.substring(0, url.pathname.lastIndexOf("/list"));
sobject = sobject.substring(sobject.lastIndexOf("/") + 1);
return sobject;
if (url.pathname) {
let match = url.pathname.match(/\/lightning\/[r|o]\/([a-zA-Z0-9_]+)\/[a-zA-Z0-9]+/);
if (match) {
return match[1];
}
}
return null;
}
Expand Down

0 comments on commit c80085f

Please sign in to comment.