[IMP] Improve code of reload kanban view and resequence record.

bzr revid: ysa@tinyerp.com-20110808083748-0rjkrx93a9bgpqje
This commit is contained in:
Yogesh (OpenERP) 2011-08-08 14:07:48 +05:30
parent c117b60b0b
commit dc9f1f4d2d
2 changed files with 96 additions and 62 deletions

View File

@ -9,12 +9,9 @@ openerp.base_kanban.KanbanView = openerp.base.View.extend({
this.dataset = dataset;
this.model = this.dataset.model;
this.view_id = view_id;
this.element_id = element_id;
this.group_by_field = false;
this.domains = this.dataset.domain;
this.contexts = this.dataset.context;
this.group_by = false;
this.destination_index = false;
this.source_index = {};
this.all_display_data = false;
},
start: function() {
@ -32,7 +29,9 @@ openerp.base_kanban.KanbanView = openerp.base.View.extend({
});
if(this.template_xml){
self.dataset.read_slice([], 0, false, function (records) {
self.on_reload_kanban([{'records': records, 'value':false, 'header': false}]);
self.all_display_data = [];
self.all_display_data.push({'records': records, 'value':false, 'header': false});
self.on_show_data(self.all_display_data);
});
}
},
@ -41,19 +40,14 @@ openerp.base_kanban.KanbanView = openerp.base.View.extend({
var self = this;
this.all_records = [];
var new_qweb = new QWeb2.Engine();
new_qweb.add_template('<templates><t t-name="custom_template">' + this.template_xml + '</t></templates>')
self.$element.html(QWeb.render("KanbanBiew", {"datas" :datas}));
_.each(datas, function(data) {
_.each(data.records, function(record) {
self.$element.find("#data_" + record.id).append(new_qweb.render('custom_template', record));
self.all_records.push(record);
});
});
this.$element.find( ".oe_table_column " ).css("width", 99 / datas.length +"%");
this.on_reload_kanban();
this.$element.find(".oe_column").sortable({
connectWith: ".oe_column",
start: function(event, ui) {
self.destination_index = ui.item.index();
self.source_index['index'] = ui.item.index();
self.source_index['column'] = ui.item.parent().attr('id');
console.log("self.source_index::",self.source_index);
},
stop: self.on_recieve_record,
});
@ -78,18 +72,23 @@ openerp.base_kanban.KanbanView = openerp.base.View.extend({
on_recieve_record: function(event, ui) {
var self = this;
var from = ui.item.index(), to = ui.item.prev().index() || 0;
var from = ui.item.index();
this.flag = false;
if(this.columns.sequence && self.destination_index != from){
var to = ui.item.prev().index() || 0;
if(!ui.item.attr("id")){
return false;
}
if(self.columns.sequence && self.source_index.index && self.source_index.index != from) {
var child_record = ui.item.parent().children();
var data, sequence=1, index = to;
var data, sequence = 1, index = to;
child_record.splice(0, to);
if(to >= 0 && child_record) {
var record_id = child_record.attr('id').split("_");
if(record_id.length >= 2) {
_.each(this.all_records, function(record){
_.each(self.all_records, function(record){
if(parseInt(record_id[1]) == record.id && record.sequence) {
sequence = record.sequence;
return false;
}
});
}
@ -97,34 +96,74 @@ openerp.base_kanban.KanbanView = openerp.base.View.extend({
_.each(child_record, function (child) {
var child_id = parseInt($(child).attr("id").split("_")[1]);
if(child_id) {
_.each(self.all_display_data, function(data, index) {
_.each(data.records, function(record, index_row) {
if(parseInt(record.id) == child_id) {
self.all_display_data[index]['records'][index_row]['sequence'] = sequence;
return false;
}
});
});
self.dataset.write(child_id, {sequence: sequence});
sequence++;
self.flag = true;
}
});
}
if(ui.item.attr("id") && this.group_by_field) {
if(self.group_by_field && self.source_index.column && self.source_index.column != ui.item.parent().attr('id')) {
var value = ui.item.closest("td").attr("id")
if(value) {
var data_val = {};
var wirte_id = parseInt(ui.item.attr("id").split("_")[1]);
value = value.split("_")[1];
if(value == 'false') {
value = false;
}
data_val[this.group_by_field] = value;
this.dataset.write(parseInt(ui.item.attr("id").split("_")[1]), data_val);
this.flag = true;
var update_record = false;
_.each(self.all_display_data, function(data, index) {
_.each(data.records, function(record, index_row) {
if(parseInt(record.id) == wirte_id) {
self.all_display_data[index]['records'][index_row][self.group_by_field] = value;
update_record = self.all_display_data[index]['records'].splice(index_row,1)
return false;
}
});
});
_.each(self.all_display_data, function(data, index) {
if (data.value == value || (data.value == 'false' && value == false)) {
self.all_display_data[index]['records'].push(update_record[0]);
}
});
data_val[self.group_by_field] = value;
self.dataset.write(wirte_id, data_val);
self.flag = true;
}
}
if(this.flag) {
this.do_actual_search(this.domains, this.contexts, this.group_by);
if(self.flag) {
self.on_reload_kanban(this.all_display_data);
}
this.destination_index = false;
this.source_index = {};
},
on_reload_kanban: function(datas){
this.$element.find("#kanbanview").remove();
this.on_show_data(datas);
on_reload_kanban: function(){
var self = this;
var new_qweb = new QWeb2.Engine();
this.all_records = []
new_qweb.add_template('<templates><t t-name="custom_template">' + this.template_xml + '</t></templates>')
_.each(self.all_display_data, function(data, index) {
if(data.records.length > 0){
_.each(data.records, function(record) {
self.$element.find("#data_" + record.id).children().remove()
self.$element.find("#data_" + record.id).append(new_qweb.render('custom_template', record));
self.all_records.push(record);
});
}
else{
self.$element.find("#column_" + data.value).remove();
self.all_display_data.splice(index, 1);
}
});
this.$element.find( ".oe_table_column " ).css("width", 99 / self.all_display_data.length +"%");
},
do_search: function (domains, contexts, group_by) {
@ -134,38 +173,32 @@ openerp.base_kanban.KanbanView = openerp.base.View.extend({
contexts: contexts,
group_by_seq: group_by
}, function (results) {
self.contexts = results.context;
self.domains = results.domain;
self.group_by = results.group_by;
self.do_actual_search(results.domain, results.context, results.group_by);
self.group_by_field = false;
self.dataset.context = results.context;
self.dataset.domain = results.domain;
self.groups = new openerp.base.DataGroup(self, self.model, results.domain, results.context, results.group_by || []);
self.groups.list([],
function (groups) {
if (group_by.length >= 1) {
self.group_by_field = group_by[0].group_by;
self.do_render_group(groups);
}
},
function (dataset) {
self.dataset.read_slice(false, false, false, function(records) {
self.all_display_data = [];
self.all_display_data.push({'records': records, 'value':false, 'header' : false});
self.$element.find("#kanbanview").remove();
self.on_show_data(self.all_display_data);
});
}
);
});
},
do_actual_search: function (domain, context, group_by) {
var self = this;
this.group_by_field = false;
self.dataset.context = context;
self.dataset.domain = domain;
this.groups = new openerp.base.DataGroup(this, this.model, domain, context, group_by || []);
this.groups.list([],
function (groups) {
if (group_by.length >= 1) {
self.group_by_field = group_by[0];
self.do_render_group(groups);
}
},
function (dataset) {
self.dataset.read_slice(false, false, false, function(records) {
self.on_reload_kanban([{'records': records, 'value':false, 'header' : false}]);
});
}
);
},
do_render_group : function(datagroups){
this.columns = [];
this.all_display_data = [];
var self = this;
_.each(datagroups, function (group) {
self.dataset.context = group.context;
@ -181,9 +214,10 @@ openerp.base_kanban.KanbanView = openerp.base.View.extend({
group_value = group.value[0]
}
self.dataset.read_slice(false, false, false, function(records) {
self.columns.push({"value" : group_value, "records": records, 'header':group_name});
if (datagroups.length == self.columns.length) {
self.on_reload_kanban(self.columns);
self.all_display_data.push({"value" : group_value, "records": records, 'header':group_name});
if (datagroups.length == self.all_display_data.length) {
self.$element.find("#kanbanview").remove();
self.on_show_data(self.all_display_data);
}
});
});

View File

@ -3,9 +3,9 @@
<table style="width:100%;" id="kanbanview">
<tr>
<t t-foreach="datas" t-as="columns">
<td class="oe_table_column oe_column_heading">
<td class="oe_table_column oe_column_heading" t-att-id="'column_' + columns.value">
<t t-if="columns.value">
<t t-esc="columns.header"/> (<t t-esc="columns.records.length"/>)
<t t-esc="columns.header"/>
</t>
</td>
</t>