[IMP]developed code for @ sign inherit view with xpath.

bzr revid: vme@tinyerp.com-20110930124932-78pdg9o6o450rnur
This commit is contained in:
Vidhin Mehta (OpenERP) 2011-09-30 18:19:32 +05:30
parent 889cff8a19
commit 654478b811
1 changed files with 230 additions and 161 deletions

View File

@ -1,6 +1,7 @@
openerp.web.view_editor = function(openerp) {
var QWeb = openerp.web.qweb;
openerp.web.ViewEditor = openerp.web.Widget.extend({
init: function(parent, element_id, dataset, view, options) {
this._super(parent);
this.element_id = element_id
@ -9,9 +10,11 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
this.model = dataset.model;
this.xml_id = 0;
},
start: function() {
this.View_editor();
},
View_editor : function(){
var self = this;
var action = {
@ -41,18 +44,16 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
height: 500,
buttons: {
"Create": function(){
//to do
},
"Edit": function(){
self.xml_id = 0 ;
self.get_data();
},
"Close": function(){
$(this).dialog('destroy');
}
},
});
this.dialog.start();
this.dialog.open();
@ -66,7 +67,7 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
obj.id = this.xml_id++;
obj.level = level;
var att_list = [];
var name1 = "<" + tag;
var render_name = "<" + tag;
var xml_tag = "<" + tag;
$(xml).each(function() {
att_list = this.attributes;
@ -74,17 +75,17 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
xml_tag += ' ' +attrs.nodeName+'='+'"'+attrs.nodeValue+'"';
if (tag != 'button'){
if(attrs.nodeName == "string" || attrs.nodeName == "name" || attrs.nodeName == "index"){
name1 += ' ' +attrs.nodeName+'='+'"'+attrs.nodeValue+'"';}
render_name += ' ' +attrs.nodeName+'='+'"'+attrs.nodeValue+'"';}
}else{
if(attrs.nodeName == "name"){
name1 += ' ' +attrs.nodeName+'='+'"'+attrs.nodeValue+'"';}
render_name += ' ' +attrs.nodeName+'='+'"'+attrs.nodeValue+'"';}
}
});
name1+= ">";
render_name+= ">";
xml_tag+= ">";
});
obj.main_xml = xml_tag;
obj.name = name1;
obj.name = render_name;
return obj;
},
@ -120,45 +121,117 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
var string = self.check_attr(child_node,child_node.tagName.toLowerCase(),parents.length);
child_obj_list.push(string);
});
if(children_list.length != 0){
var child_ids = _.map(child_obj_list ,function(num){return num.id;});
parent_child_id.push({'key': parent_id, 'value': child_ids});
var parents = $(children_list[0]).parents().get();
if(parents.length <= parent_list.length){
parent_list.splice(parents.length-1);}
parent_list.splice(parents.length-1);
}
parent_list.push(parent_id);
$.each(main_object, function(key,val) {
self.save_object(val,parent_list.slice(1),child_obj_list);
});
}
for(var i=0;i<children_list.length;i++){
self.children_function
(children_list[i],children_list[i].tagName.toLowerCase(),parent_list,child_obj_list[i].id,main_object,parent_child_id);
(children_list[i],children_list[i].tagName.toLowerCase(),
parent_list,child_obj_list[i].id,main_object,parent_child_id);
}
return {"main_object":main_object,"parent_child_id":parent_child_id};
},
parse_xml :function(arch){
var self = this;
var root = $(arch).filter(":first")[0];
var tag = root.tagName.toLowerCase();
var root_object = self.check_attr(root,tag,0);
return self.children_function(arch,tag,[],0,[root_object],[]);
var root_object = self.check_attr(root,tag,this.xml_id);
return self.children_function(arch,tag,[],this.xml_id-1,[root_object],[]);
},
get_data : function(){
var self = this;
var inherited_view =[];
var result;
var view_id =(($("input[name='radiogroup']:checked").parent()).parent()).attr('data-id');
var ve_dataset = new openerp.web.DataSet(this,'ir.ui.view');
ve_dataset.read_ids([parseInt(view_id)],['arch'],function (arch){
one_object = self.parse_xml(arch[0].arch);
one_object.arch = arch[0].arch;
dataset = new openerp.web.DataSetSearch(self,'ir.ui.view', null, null);
dataset.read_slice([],{domain : [['inherit_id','=',parseInt(view_id)]]},function (result) {
return result;
_.each(result,function(res){
self.inherit_view(one_object,res);
});
ve_dataset.read_ids([parseInt(view_id)],['arch'],function (arch){
var one_object = self.parse_xml(arch[0].arch);
return self.edit_view(one_object);
});
});
},
inherit_view : function(one_object,result){
var self = this;
var root = $(result.arch).filter('*');
var xpath_list = [];
var part_expr = [];
var position ;
if(root[0].tagName.toLowerCase() == "data"){
_.each($(root).find('xpath'),function(xpath){
xpath_list.push(xpath);
});
} else if(root[0].tagName.toLowerCase() == "xpath"){
xpath_list.push(root[0]);
}
_.each(xpath_list,function(element){
var xpath_object = self.parse_xml(element);
var expr = $(element).attr('expr');
var position = $(element).attr('position');
part_expr = expr.split("/");
if(part_expr[0]=="" && part_expr[1]==""){
part_expr = part_expr.splice(2);
}else if(part_expr[0]==""){
part_expr = part_expr.splice(1);
}
if(part_expr[part_expr.length-1].search("@")!=-1){
var part = part_expr[part_expr.length-1];
var pp = $.trim(part.replace(/[^a-zA-Z 0-9 _]+/g,' ')).split(" ");
$.each(one_object['main_object'], function(key,val) {
self.search_object(val,pp,[],position,xpath_object['main_object']);
});
}
});
},
search_object:function(val,list,p_list,position,xpath_object){
var self = this;
var pp = $.trim(val.name.replace(/[^a-zA-Z 0-9 _]+/g,' ')).split(" ");
var insert = _.intersection(pp,list);
if(insert.length == list.length){
var level = val.level;
$.each(xpath_object, function(key,val) {
self.increase_level(val,level)
});
var index = _.indexOf(p_list.child_id,val);
if(position == "before"){
if(index!=0){index--;}
}else if(position == "after"){
index++;
}
var check = _.indexOf(p_list.child_id,xpath_object[0]);
if(check == -1){
p_list.child_id.splice(index,0,xpath_object[0]);
return val.id;
}
}else{
if(val.child_id.length!=0){p_list = val;}
$.each(val.child_id, function(key,val) {
self.search_object(val,list,p_list,position,xpath_object);
});
}
},
increase_level :function(val,level){
var self = this;
val.level = level;
$.each(val.child_id, function(key,val) {
self.increase_level(val,level+1);
});
},
edit_view : function(one_object){
var self = this;
@ -169,10 +242,10 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
height: 500,
buttons: {
"Inherited View": function(){
//todo
},
"Preview": function(){
//todo
},
"Close": function(){
$(this).dialog('destroy');
@ -201,6 +274,13 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
$("img[id^='side-']").click(function() {
var side = $(this).closest("tr[id^='viewedit-']")
var id_tr = (side.attr('id')).split('-')[1];
var img = side.find("img[id='parentimg-"+id_tr+"']").attr('src'); ;
var level = side.attr('level');
var list_shift =[];
var last_tr;
var cur_tr = side;
list_shift.push(side);
var next_tr;
switch (this.id)
{
case "side-add":
@ -210,13 +290,6 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
case "side-edit":
break;
case "side-up":
var img = side.find("img[id='parentimg-"+id_tr+"']").attr('src');
var level = side.attr('level');
var list_shift =[];
var last_tr;
var next_tr;
list_shift.push(side);
var cur_tr = side;
while(1){
var prev_tr = cur_tr.prev();
if(level >= prev_tr.attr('level') || prev_tr.length==0){
@ -227,7 +300,7 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
}
if(img){
while(1){
var next_tr = side.next();
next_tr = side.next();
if(next_tr.attr('level') <= level || next_tr.length==0){
break;
}else{
@ -243,16 +316,9 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
}
break;
case "side-down":
var img = side.find("img[id='parentimg-"+id_tr+"']").attr('src');
var level = side.attr('level');
var list_shift =[];
var last_tr;
var next_tr;
var cur_tr = side;
list_shift.push(side);
if(img){
while(1){
var next_tr = cur_tr.next();
next_tr = cur_tr.next();
if(next_tr.attr('level') <= level || next_tr.length==0){
last_tr = next_tr;
break;
@ -261,7 +327,10 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
cur_tr = next_tr;
}
}
}else{last_tr = cur_tr.next();}
}
else{
last_tr = cur_tr.next();
}
if(last_tr.length != 0 && last_tr.attr('level')==level){
var last_tr_id = (last_tr.attr('id')).split('-')[1];
img = last_tr.find("img[id='parentimg-"+last_tr_id+"']").attr('src');