[MERGE] Implement xpath expression for rendering tree view. Merge Branch :- lp:~openerp-dev/openerp-web/trunk-vieweditor-all_xpath-vme

bzr revid: ysa@tinyerp.com-20111012124052-1b35lcoivl2oe1xc
This commit is contained in:
Yogesh (OpenERP) 2011-10-12 18:10:52 +05:30
commit 62c0f04b47
2 changed files with 122 additions and 111 deletions

View File

@ -1,7 +1,6 @@
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
@ -10,12 +9,10 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
this.model = dataset.model;
this.xml_id = 0;
},
start: function() {
this.View_editor();
},
View_editor : function(){
View_editor : function() {
var self = this;
var action = {
name:'ViewEditor',
@ -60,36 +57,33 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
action_manager.appendTo(this.dialog);
action_manager.do_action(action);
},
check_attr: function(xml, tag, level) {
var obj = new Object();
obj.child_id = [];
obj.id = this.xml_id++;
obj.level = level;
var att_list = [];
obj.level = level+1;
var render_name = "<" + tag;
var xml_tag = "<" + tag;
obj.att_list = [];
obj.att_list.push(tag);
$(xml).each(function() {
att_list = this.attributes;
att_list = _.select(att_list, function(attrs) {
xml_tag += ' ' + attrs.nodeName + '=' + '"' + attrs.nodeValue + '"';
_.each(this.attributes, function(attrs){
if (tag != 'button') {
if (attrs.nodeName == "string" || attrs.nodeName == "name" || attrs.nodeName == "index") {
render_name += ' ' + attrs.nodeName + '=' + '"' + attrs.nodeValue + '"';
render_name += ' ' + attrs.nodeName + '=' + '"' + attrs.nodeValue + '"' ;
}
} else {
if (attrs.nodeName == "name") render_name += ' ' + attrs.nodeName + '=' + '"' + attrs.nodeValue + '"';
} else if (attrs.nodeName == "name") {
render_name += ' ' + attrs.nodeName + '=' + '"' + attrs.nodeValue + '"';
}
if (attrs.nodeName != "position") {
obj.att_list.push( [attrs.nodeName,attrs.nodeValue] );
}
});
render_name += ">";
xml_tag += ">";
render_name+= ">";
});
obj.main_xml = xml_tag;
obj.name = render_name;
return obj;
},
save_object : function(val, parent_list, child_obj_list) {
save_object: function(val, parent_list, child_obj_list) {
var self = this;
var check_id = parent_list[0];
var p_list = parent_list.slice(1);
@ -108,47 +102,37 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
val.child_id = child_obj_list;
}
},
children_function : function(xml, root, parent_list, parent_id, main_object, parent_child_id) {
xml_node_create: function(xml, root, parent_list, parent_id, main_object){
var self = this;
var child_obj_list = [];
var parent_child_id = parent_child_id;
var parent_list = parent_list;
var main_object = main_object;
var children_list = $(xml).filter(root).children();
var parents = $(children_list[0]).parents().get();
_.each(children_list, function (child_node) {
var string = self.check_attr(child_node,child_node.tagName.toLowerCase(),parents.length);
child_obj_list.push(string);
child_obj_list.push(self.check_attr(child_node,child_node.tagName.toLowerCase(),parents.length));
});
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.push(parent_id);
_.each(main_object, function (val, key) {
self.save_object(val, parent_list.slice(1), child_obj_list);
});
self.save_object(main_object[0], 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);
for (var i=0; i<children_list.length; i++) {
self.xml_node_create
(children_list[i], children_list[i].tagName.toLowerCase(),
parent_list, child_obj_list[i].id, main_object);
}
return {"main_object": main_object, "parent_child_id": parent_child_id};
return main_object;
},
parse_xml :function(arch, view_id){
parse_xml: function(arch, view_id) {
var root = $(arch).filter(":first")[0];
var tag = root.tagName.toLowerCase();
var root_object = this.check_attr(root, tag, this.xml_id);
return this.children_function(arch, tag, [], this.xml_id - 1, [root_object], []);
var obj ={'child_id':[],'id':this.xml_id++,'level':0,'att_list':[],'name':"<view view_id='"+view_id+"'>"};
var root_object = this.check_attr(root,tag,0);
obj.child_id = this.xml_node_create(arch, tag, [], this.xml_id-1, [root_object], [])
return [obj];
},
get_data : function(){
get_data: function() {
var self = this;
var view_id =(($("input[name='radiogroup']:checked").parent()).parent()).attr('data-id');
var ve_dataset = new openerp.web.DataSet(this, 'ir.ui.view');
@ -160,76 +144,101 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
_.each(result, function(res) {
self.inherit_view(one_object, res);
});
return self.edit_view(one_object);
return self.edit_view({"main_object": one_object,
"parent_child_id": self.parent_child_list(one_object, [])});
});
});
},
inherit_view : function(one_object, result){
parent_child_list : function(one_object, p_list) {
var self = this;
_.each(one_object , function(element){
if(element.child_id.length != 0){
p_list.push({"key":element.id,"value":_.pluck(element.child_id, 'id')});
self.parent_child_list(element.child_id, p_list);
}
});
return p_list;
},
inherit_view : function(one_object, result) {
var self = this;
var root = $(result.arch).filter('*');
var xpath_list = [];
var part_expr = [];
var position ;
var xml_list = [];
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]);
xml_list = $(root[0]).children();
} else {
xml_list.push(root[0]);
}
_.each(xpath_list, function(element) {
var xpath_object = self.parse_xml(element, result.id);
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 xpath_list = $.trim(part.replace(/[^a-zA-Z 0-9 _]+/g,' ')).split(" ");
one_object['parent_child_id'].push(xpath_object['parent_child_id'][0]);
_.each(one_object['main_object'], function(val, key) {
var id = self.search_object(val, xpath_list, [], position, xpath_object['main_object'], []);
_.detect(one_object['parent_child_id'], function(res) {
if (res.key==id) {
res.value.push(xpath_object['main_object'][0].id);
}
});
_.each(xml_list , function(xml){
var parent_id;
var check_list = [];
var xpath_object = self.parse_xml(xml,result.id);
if (xml.tagName.toLowerCase() == "xpath" ) {
var part_expr = _.without($(xml).attr('expr').split("/"),"");
_.each(part_expr,function(part){
check_list.push(_.without($.trim(part.replace(/[^a-zA-Z 0-9 _]+/g,'!')).split("!"),""));
});
} else {
check_list = [_.flatten(xpath_object[0].child_id[0].att_list)];
}
self.full_path_search(check_list ,one_object ,xpath_object);
});
},
search_object:function(val, list, p_list, position, xpath_object, r_list) {
full_path_search: function(check_list ,val ,xpath_object) {
var self = this;
var return_list = r_list;
var main_list = $.trim(val.name.replace(/[^a-zA-Z 0-9 _]+/g,' ')).split(" ");
var insert = _.intersection(main_list,list);
var check = _.indexOf(p_list.child_id,xpath_object[0]);
if (check == -1) {
if (insert.length == list.length) {
var level = val.level;
_.each(xpath_object, function(val, key) {
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++;
if(xpath_object.length!=0){
var check = check_list[0];
var obj;
if(check.length == 2){
if(parseInt(check[1])){
var list_1 = _.select(val,function(element){
var main_list = _.flatten(element.att_list);
return _.include(main_list, check[0]);
});
obj = val[_.indexOf(val,list_1[parseInt(check[1])-1])];
} else {
obj = _.detect(val, function(element){
var main_list = _.flatten(element.att_list);
return _.include(main_list, check[0]);
});
}
p_list.child_id.splice(index, 0, xpath_object[0]);
return_list.push(p_list.id);
} else if(check.length == 3) {
obj = _.detect(val,function(element){
var main_list = _.flatten(element.att_list);
check = _.uniq(check);
var insert = _.intersection(main_list,check);
if(insert.length == check.length ){return element;}
});
} else {
if (val.child_id.length != 0) { p_list = val; }
_.each(val.child_id, function(val, key) {
self.search_object(val, list, p_list, position, xpath_object, return_list);
var list_1 = _.select(val,function(element){
var main_list = _.flatten(element.att_list);
return _.include(main_list, check[0]);
});
if(list_1 != 0){
if(check_list.length == 1){
obj = list_1[0];
} else {
check_list.shift();
}
}
}
if(obj) {
check_list.shift();
if (check_list.length !=0){
self.full_path_search(check_list ,obj.child_id ,xpath_object);
} else {
var level = obj.level+1;
self.increase_level(xpath_object[0], level)
obj.child_id.push(xpath_object[0]);
xpath_object.pop();
return;
}
}
else {
_.each(val,function(element){
self.full_path_search(check_list ,element.child_id ,xpath_object);
});
}
}
return return_list;
},
increase_level: function(val, level) {
var self = this;
@ -238,7 +247,7 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
self.increase_level(val, level + 1);
});
},
edit_view : function(one_object){
edit_view: function(one_object) {
var self = this;
this.dialog = new openerp.web.Dialog(this,{
modal: true,
@ -261,12 +270,10 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
this.dialog.$element.html(QWeb.render('view_editor', {
'data': one_object['main_object'],
}));
$("tr[id^='viewedit-']").click(function() {
$("tr[id^='viewedit-']").removeClass('ui-selected');
$(this).addClass('ui-selected');
});
$("img[id^='parentimg-']").click(function() {
if ($(this).attr('src') == '/web/static/src/img/collapse.gif') {
$(this).attr('src', '/web/static/src/img/expand.gif');
@ -358,11 +365,11 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
});
},
on_expand: function(self){
var level = $(self).closest("tr[id^='viewedit-']").attr('level');
var level = parseInt($(self).closest("tr[id^='viewedit-']").attr('level'));
var cur_tr = $(self).closest("tr[id^='viewedit-']");
while (1) {
var nxt_tr = cur_tr.next();
if (nxt_tr.attr('level') > level) {
if (parseInt(nxt_tr.attr('level')) > level){
cur_tr = nxt_tr;
nxt_tr.hide();
} else return nxt_tr;
@ -380,4 +387,4 @@ openerp.web.ViewEditor = openerp.web.Widget.extend({
});
}
});
};
};

View File

@ -1302,20 +1302,24 @@
<td align="left" class="view_editor" width="15%">
<table cellspacing="0" cellpadding ="0" width="100%">
<tr>
<td>
<img id="side-add" src="/web/static/src/img/icons/gtk-add.png" style="cursor: pointer;"/>
<td width="20%">
<img t-if="rec.att_list.length"
id="side-add" src="/web/static/src/img/icons/gtk-add.png" style="cursor: pointer;"/>
</td>
<td>
<td width="20%">
<img id="side-remove" src="/web/static/src/img/icons/gtk-remove.png" style="cursor: pointer;"/>
</td>
<td>
<img id="side-edit" src="/web/static/src/img/icons/gtk-edit.png" style="cursor: pointer;"/>
<td width="20%">
<img t-if="rec.att_list.length"
id="side-edit" src="/web/static/src/img/icons/gtk-edit.png" style="cursor: pointer;"/>
</td>
<td>
<img id="side-up" src="/web/static/src/img/icons/gtk-go-up.png" style="cursor: pointer;"/>
<td width="20%">
<img t-if="rec.att_list.length"
id="side-up" src="/web/static/src/img/icons/gtk-go-up.png" style="cursor: pointer;"/>
</td>
<td>
<img id="side-down" src="/web/static/src/img/icons/gtk-go-down.png" style="cursor: pointer;"/>
<td width="20%">
<img t-if="rec.att_list.length"
id="side-down" src="/web/static/src/img/icons/gtk-go-down.png" style="cursor: pointer;"/>
</td>
</tr>
</table>