[fix] added setTimeout to all methods of o2m dataset to avoid lot of potential bugs in the views

bzr revid: nicolas.vanhoren@openerp.com-20110623122110-4cst4fm1dzup5z69
This commit is contained in:
niv-openerp 2011-06-23 14:21:10 +02:00
parent 63d23036a3
commit 9eede2e3a4
2 changed files with 21 additions and 4 deletions

View File

@ -357,6 +357,8 @@ openerp.base.DataSetStatic = openerp.base.DataSet.extend({
this.count = this.ids.length;
},
read_slice: function (fields, offset, limit, callback) {
var self = this;
offset = offset || 0;
var end_pos = limit && limit !== -1 ? offset + limit : undefined;
this.read_ids(this.ids.slice(offset, end_pos), fields, callback);
},

View File

@ -1402,7 +1402,9 @@ openerp.base.form.One2ManyDataset = openerp.base.DataSetStatic.extend({
this.to_create.push(cached);
this.cache.push(cached);
this.on_change();
return $.Deferred().then(callback).resolve({result: cached.id}).promise();
var to_return = $.Deferred().then(callback);
setTimeout(function() {to_return.resolve({result: cached.id});}, 0);
return to_return.promise();
},
write: function (id, data, callback) {
var record = _.select(this.to_create, function(x) {return x.id === id;});
@ -1416,9 +1418,11 @@ openerp.base.form.One2ManyDataset = openerp.base.DataSetStatic.extend({
var cached = _.select(this.cache, function(x) {return x.id === id;});
$.extend(cached.value, record.values);
this.on_change();
return $.Deferred().then(callback).resolve({result: true}).promise();
var to_return = $.Deferred().then(callback);
setTimeout(function () {to_return.resolve({result: true});}, 0);
return to_return.promise();
},
unlink: function(ids) {
unlink: function(ids, callback, error_callback) {
var self = this;
var to_create_size = this.to_create.length;
var remove = function(list, to_remove) {
@ -1432,6 +1436,9 @@ openerp.base.form.One2ManyDataset = openerp.base.DataSetStatic.extend({
_.each(ids, function(x) {self.to_delete.push({id:x})});
}
this.on_change();
var to_return = $.Deferred().then(callback);
setTimeout(function () {to_return.resolve({result: true});}, 0);
return to_return.promise();
},
reset_ids: function(ids) {
this.set_ids(ids);
@ -1457,12 +1464,20 @@ openerp.base.form.One2ManyDataset = openerp.base.DataSetStatic.extend({
var completion = $.Deferred().then(callback);
var return_records = function() {
var records = _.map(ids, function(id) {return _.detect(self.cache, function(c) {return c.id === id;}).values;});
// avoid giving fields that were not asked for (+ create a copy of the cache)
records = _.map(records, function(record) {
var tmp = {};
_.each(fields, function(field) {
tmp[field] = record[field];
});
return tmp;
});
if (self.debug_mode) {
if (_.include(records, undefined)) {
throw "Record not correctly loaded";
}
}
completion.resolve(records);
setTimeout(function () {completion.resolve(records);}, 0);
}
if(to_get.length > 0) {
var rpc_promise = this._super(to_get, fields, function(records) {