[WIP] broken state

bzr revid: fme@openerp.com-20120313155852-1d9fb2ky4pvlja8u
This commit is contained in:
Fabien Meghazi 2012-03-13 16:58:52 +01:00
parent 42f813f7dc
commit 91cf25ae07
2 changed files with 104 additions and 95 deletions

View File

@ -98,10 +98,9 @@ openerp.web.FormView = openerp.web.View.extend( /** @lends openerp.web.FormView#
}
this.fields_order = [];
this.fields_view = data;
this.arch = this.preprocess_arch(data);
var html_view = openerp.web.xml_to_str(this.arch);
this.$element.find('.oe_form_content').append(html_view);
var $form = this.create_view(data);
this.$element.find('.oe_form_content').appendTo(this.$form);
//this.root_frame = instanciate_widget(this.registry.get_object('frame'), this, this.fields_view.arch);
//var to_append = $(".oe_form_header", this.$element);
@ -136,75 +135,64 @@ openerp.web.FormView = openerp.web.View.extend( /** @lends openerp.web.FormView#
}
this.has_been_loaded.resolve();
},
preprocess_arch: function(data) {
create_view: function(fvg) {
// TODO: extract embeded views before preprocessing
// Cut down this function into rendering API amongst form, page and kanban
//
// OpenERP views spec :
// - @width is obsolete ?
var self = this,
baseclass = 'oe_layout_',
fields = data.fields,
arch = $.parseXML(data.arch_string);
var view = this,
fields = fvg.fields,
$form = $(fvg.arch_string)
field_prefix = view.dataset ? view.dataset.model : '';
// Step #1:
// - If field has no @string, fetch it from fvg.fields.
// - If field has no label, create one.
// - Unless @nolabel, create unique @id and @for pair
$(arch).find('field').each(function() {
$form.find('field').each(function() {
var $field = $(this),
name = $field.attr('name'),
field_orm = fields[name],
field_id = _.uniqueId([self.dataset.model, name, '#'].join('.'));
field_id = _.uniqueId([field_prefix, name, '#'].join('.'));
if (!field_orm) {
throw new Error("Field '" + name + "' specified in view could not be found.");
}
var $label = $(arch).find('label[for="' + name + '"]'),
// TODO: manage @nolabel
var $label = $form.find('label[for="' + name + '"]'),
label_string = $field.attr('string') || field_orm.string || '';
if ($label.length) {
label_string = $label.attr('string') || $label.text();
} else {
// TODO: find a way to prevent @xmlns.
$label = $('<label/>').insertBefore($field);
}
$field.attr('id', field_id);
$label.attr('for', field_id).text(label_string);
// debug
$field.text('INPUT: ' + name)
$field.attr({
'id' : field_id,
'data-widget' : $field.attr('widget') || field_orm.widget
});
$label.attr({
'for' : field_id,
'string' : label_string,
'help' : $field.attr('help') || field_orm.help || '',
'data-widget' : 'label'
});
// TODO: Add custom attribute in orer to differenciate from a real label
});
// Step #2:
// - Convert groups to tables
var $group, $table, $tr, $td, $child, cols, row_cols, colspan;
while (true) {
$group = $(arch).find('group:first');
if (!$group.length) {
break;
// TODO: modifiers invisible. Add a special attribute, eg: data-invisible that should be used in order to create openerp.form.InvisibleWidgetG
// TODO: split registry ? tags and fields types ?
$form.find('*').each(function() {
var $elem = $(this),
key = $elem.attr('data-widget') || $elem[0].tagName.toLowerCase();
if (view.registry.contains(key)) {
var obj = view.registry.get_object(key);
var w = new (obj)(view, $elem[0]);
w.replace($elem);
}
});
$table = $('<table border="1"/>').addClass(baseclass + 'group');
$tr = null;
cols = parseInt($group.attr('col') || 4, 10);
row_cols = cols;
$group.children().each(function() {
$child = $(this);
colspan = parseInt($child.attr('colspan') || 1, 10);
if ($child[0].tagName === 'newline') {
$tr = null;
return;
}
if (!$tr || row_cols < colspan) {
$tr = $('<tr/>').addClass(baseclass + 'group_row').appendTo($table);
row_cols = cols;
}
row_cols -= colspan;
$td = $('<td/>').addClass(baseclass + 'group_cell');
$tr.append($td.append($child));
});
$group.replaceWith($table);
}
return $form
// Step #3:
// - Process <button>'s
@ -416,7 +404,7 @@ openerp.web.FormView = openerp.web.View.extend( /** @lends openerp.web.FormView#
var response = {}, can_process_onchange = $.Deferred();
processed = processed || [];
processed.push(widget.name);
var on_change = widget.node.attrs.on_change;
var on_change = widget.node_attrs.on_change;
if (on_change) {
var change_spec = self.parse_on_change(on_change, widget);
if (change_spec) {
@ -515,9 +503,9 @@ openerp.web.FormView = openerp.web.View.extend( /** @lends openerp.web.FormView#
}
if (result.domain) {
function edit_domain(node) {
var new_domain = result.domain[node.attrs.name];
var new_domain = result.domain[node_attrs.name];
if (new_domain) {
node.attrs.domain = new_domain;
node_attrs.domain = new_domain;
}
_(node.children).each(edit_domain);
}
@ -624,7 +612,7 @@ openerp.web.FormView = openerp.web.View.extend( /** @lends openerp.web.FormView#
var msg = "<ul>";
_.each(this.fields, function(f) {
if (!f.is_valid()) {
msg += "<li>" + f.string + "</li>";
msg += "<li>" + f.node_attrs.string + "</li>";
}
});
msg += "</ul>";
@ -762,7 +750,7 @@ openerp.web.FormView = openerp.web.View.extend( /** @lends openerp.web.FormView#
return {
name: name,
string: field.string,
string: field.node_atts.string,
value: value,
displayed: displayed,
// convert undefined to false
@ -770,7 +758,7 @@ openerp.web.FormView = openerp.web.View.extend( /** @lends openerp.web.FormView#
}
})
.compact()
.sortBy(function (field) { return field.string; })
.sortBy(function (field) { return field.node_atts.string; })
.value();
var conditions = _.chain(fields)
.filter(function (field) { return field.change_default; })
@ -966,11 +954,10 @@ openerp.web.form.compute_domain = function(expr, fields) {
return _.all(stack, _.identity);
};
openerp.web.form.Widget = openerp.web.OldWidget.extend(/** @lends openerp.web.form.Widget# */{
form_template: 'Widget',
openerp.web.form.Widget = openerp.web.Widget.extend(/** @lends openerp.web.form.Widget# */{
/**
* @constructs openerp.web.form.Widget
* @extends openerp.web.OldWidget
* @extends openerp.web.Widget
*
* @param view
* @param node
@ -978,32 +965,17 @@ openerp.web.form.Widget = openerp.web.OldWidget.extend(/** @lends openerp.web.fo
init: function(view, node) {
this.view = view;
this.node = node;
this.modifiers = JSON.parse(this.node.attrs.modifiers || '{}');
this.node_attrs = {};
for (var attr, i = 0, attrs = this.node.attributes, l = attrs.length; i < l; i++) {
attr = attrs.item(i)
this.node_attrs[attr.nodeName] = attr.nodeValue;
}
this.modifiers = JSON.parse(this.node_attrs.modifiers || '{}');
this.always_invisible = (this.modifiers.invisible && this.modifiers.invisible === true);
this.type = this.type || node.tag;
this.element_name = this.element_name || this.type;
this._super(view);
this.children = node.children;
this.colspan = parseInt(node.attrs.colspan || 1, 10);
this.decrease_max_width = 0;
this.string = this.string || node.attrs.string;
this.help = this.help || node.attrs.help;
this.invisible = this.modifiers['invisible'] === true;
this.classname = 'oe_form_' + this.type;
this.align = parseFloat(this.node.attrs.align);
if (isNaN(this.align) || this.align === 1) {
this.align = 'right';
} else if (this.align === 0) {
this.align = 'left';
} else {
this.align = 'center';
}
this.width = this.node.attrs.width;
},
destroy: function() {
this._super.apply(this, arguments);
@ -1018,9 +990,6 @@ openerp.web.form.Widget = openerp.web.OldWidget.extend(/** @lends openerp.web.fo
update_dom: function() {
this.$element.toggle(!this.invisible);
},
renderElement: function() {
this.$element.html(QWeb.render(this.form_template, { "widget": this }));
},
do_attach_tooltip: function(widget, trigger, options) {
widget = widget || this;
trigger = trigger || this.$element;
@ -1204,8 +1173,41 @@ openerp.web.form.WidgetFrame = openerp.web.form.Widget.extend({
}
});
openerp.web.form.WidgetGroup = openerp.web.form.WidgetFrame.extend({
form_template: 'WidgetGroup'
openerp.web.form.WidgetGroup = openerp.web.form.Widget.extend({
template: 'WidgetGroup',
init: function(view, node) {
this._super(view, node);
},
start: function() {
this._super();
var self = this,
$table;
if (this.$element.is('table')) {
$table = this.$element;
} else {
$table = this.$element.find('table:first');
}
var $tr, $td, $child, cols, row_cols, colspan;
$tr = null;
cols = parseInt(self.node_attrs('col') || 4, 10);
row_cols = cols;
$(node).children().each(function() {
$child = $(this);
colspan = parseInt($child.attr('colspan') || 1, 10);
if ($child[0].tagName.toLowerCase() === 'newline') {
$tr = null;
return;
}
if (!$tr || row_cols < colspan) {
$tr = $('<tr/>').addClass(baseclass + 'group_row').appendTo($table);
row_cols = cols;
}
row_cols -= colspan;
$td = $('<td/>').addClass(baseclass + 'group_cell');
$tr.append($td.append($child));
});
}
}),
openerp.web.form.WidgetNotebook = openerp.web.form.Widget.extend({
@ -1299,15 +1301,12 @@ openerp.web.form.WidgetSeparator = openerp.web.form.Widget.extend({
});
openerp.web.form.WidgetButton = openerp.web.form.Widget.extend({
form_template: 'WidgetButton',
template: 'WidgetButton',
init: function(view, node) {
this._super(view, node);
this.force_disabled = false;
if (this.string) {
// We don't have button key bindings in the webclient
this.string = this.string.replace(/_/g, '');
}
if (node.attrs.default_focus == '1') {
this.string = (this.node_attrs.string || '').replace(/_/g, '');
if (this.node_attrs.default_focus == '1') {
// TODO fme: provide enter key binding to widgets
this.view.default_focus_button = this;
}
@ -1318,6 +1317,7 @@ openerp.web.form.WidgetButton = openerp.web.form.Widget.extend({
if (this.help || openerp.connection.debug) {
this.do_attach_tooltip();
}
debugger
},
on_click: function() {
var self = this;
@ -1395,6 +1395,15 @@ openerp.web.form.WidgetLabel = openerp.web.form.Widget.extend({
this._super(view, node);
this.align = parseFloat(this.node.attrs.align);
if (isNaN(this.align) || this.align === 1) {
this.align = 'right';
} else if (this.align === 0) {
this.align = 'left';
} else {
this.align = 'center';
}
if (this.node.tag == 'label' && !this.string && this.node.children.length) {
this.string = this.node.children[0];
this.align = 'left';

View File

@ -857,14 +857,14 @@
</t>
</t>
<t t-name="WidgetGroup">
<t t-if="widget.string">
<fieldset class="oe_group_box">
<legend><t t-esc="widget.string"/></legend>
<t t-call="WidgetFrame"/>
</fieldset>
<t t-if="widget.node_attrs.string">
<fieldset class="oe_group_box">
<legend><t t-esc="widget.node_attrs.string"/></legend>
<table border="1"/>
</fieldset>
</t>
<t t-if="!widget.string">
<t t-call="WidgetFrame"/>
<t t-if="!widget.node_attrs.string">
<table border="1"/>
</t>
</t>
<t t-name="WidgetNotebook">
@ -1209,7 +1209,7 @@
</t>
<t t-name="WidgetButton">
<button type="button" class="oe_button">
<img t-if="widget.node.attrs.icon" t-att-src="_s + '/web/static/src/img/icons/' + widget.node.attrs.icon + '.png'" width="16" height="16"/>
<img t-if="widget.node_attrs.icon" t-att-src="_s + '/web/static/src/img/icons/' + widget.node_attrs.icon + '.png'" width="16" height="16"/>
<span t-if="widget.string"><t t-esc="widget.string"/></span>
</button>
</t>