Forum Discussion
_anomDiebolt_
10 years agoQrew Elite
The documentation can be found here:
https://quickbase.intuitcdn.net/res/72799-10/js/gridEdit.js
Use this documentation viewer:
http://jsbeautifier.org/
Then look for the GeditSubmit function and redefine it to suit your needs along with a lot of console.logs():
function GeditSubmit(dbid) {
if (!gGED.HasDataChanged() && !gAndDone) {
QBalert("<div class=redhead>Nothing to save.</div>You haven't made any changes.");
return
}
if (!GE_validate(gGED)) {
return
}
ClearErrors();
HidePopupDiv();
QBbusy("Saving . . .");
var jax = new jaxreq(dbid + "?a=QBI_GridEditSubmit");
console.log(JSON.stringify(gGED));
GE_AddGeInfoToJax(gGED, jax);
jax.DoAsyncCmd(GESubmitCallback)
console.log(JSON.stringify(jax.params));
}
You can redefine any QuickBase authored function by injecting a modified function of the same name using IOL.
QuickBase makes heavy use of encoded strings that are delimited by multi character separator strings (in this case "~~!~^" is a five character separator string):
1~~!~^3~~!~^4~~!~^5~~!~^6~~!~^2~~!~^-10~~!~^-11~~!~^-12~~!~^-13
If you decode these strings in the XML you can grab the rids, fids and field values of the modified/deleted records/fields and log what you need. It isn't fun but it isn't too difficult.
https://quickbase.intuitcdn.net/res/72799-10/js/gridEdit.js
Use this documentation viewer:
http://jsbeautifier.org/
Then look for the GeditSubmit function and redefine it to suit your needs along with a lot of console.logs():
function GeditSubmit(dbid) {
if (!gGED.HasDataChanged() && !gAndDone) {
QBalert("<div class=redhead>Nothing to save.</div>You haven't made any changes.");
return
}
if (!GE_validate(gGED)) {
return
}
ClearErrors();
HidePopupDiv();
QBbusy("Saving . . .");
var jax = new jaxreq(dbid + "?a=QBI_GridEditSubmit");
console.log(JSON.stringify(gGED));
GE_AddGeInfoToJax(gGED, jax);
jax.DoAsyncCmd(GESubmitCallback)
console.log(JSON.stringify(jax.params));
}
You can redefine any QuickBase authored function by injecting a modified function of the same name using IOL.
QuickBase makes heavy use of encoded strings that are delimited by multi character separator strings (in this case "~~!~^" is a five character separator string):
1~~!~^3~~!~^4~~!~^5~~!~^6~~!~^2~~!~^-10~~!~^-11~~!~^-12~~!~^-13
If you decode these strings in the XML you can grab the rids, fids and field values of the modified/deleted records/fields and log what you need. It isn't fun but it isn't too difficult.
MacLanphier
8 years agoQrew Trainee
I see what you mean. I used the suggestion above to track what edits occurred during the grid edit, and I want the GeditSubmit() function to add a record of those changes to a particular field. The only blocker I have is finding out how to programmatically edit the desired field from GeditSubmit()