This patch fixes egCore.pcrud.apply() method so that it
behaves as intended (i.e., process an array of fieldmapper
objects and either creates, updates, or deletes them based
on the value of the isnew(), ischanged(), and isdeleted()
flags).
To test
-------
Currently no code uses this method (but some will soon), but
it can be tested by writing some code like this:
var notes = [];
var n1 = new egCore.idl.aun();
n1.usr(userid); // etc.
n1.isnew(true);
notes.push(n1);
var n2 = new egCore.idl.aun();
n2.usr(userid); // etc.
n2.isnew(true);
notes.push(n1);
egCore.pcrud.apply(notes).then(...
Signed-off-by: Galen Charlton <gmc@equinoxinitiative.org>
Signed-off-by: Bill Erickson <berickxx@gmail.com>
var action = this.cud_action;
var fm_obj = this.cud_list[this.cud_idx++];
- if (action == 'auto') {
+ if (action == 'apply') {
if (fm_obj.ischanged()) action = 'update';
if (fm_obj.isnew()) action = 'create';
if (fm_obj.isdeleted()) action = 'delete';
- if (action == 'auto') {
+ if (action == 'apply') {
// object does not need updating; move along
this._CUD_next_request();
}