Browse Source

[FIX] web_export_view: Several things:

* Compatibility with Werkzeug 0.9.3
* Export of first one2many field works again
* Parsing of float values
pull/798/head
Stefan Rijnhart 12 years ago
committed by Pedro M. Baeza
parent
commit
d7276a4739
  1. 2
      web_export_view/controllers.py
  2. 12
      web_export_view/static/js/web_advanced_export.js

2
web_export_view/controllers.py

@ -45,5 +45,5 @@ class ExcelExportView(ExcelExport):
% self.filename(model)), % self.filename(model)),
('Content-Type', self.content_type) ('Content-Type', self.content_type)
], ],
cookies={'fileToken': int(token)}
cookies={'fileToken': token}
) )

12
web_export_view/static/js/web_advanced_export.js

@ -37,9 +37,9 @@ openerp.web_export_view = function(instance, m) {
// or assume the main view is a list view and use that // or assume the main view is a list view and use that
var self = this, var self = this,
view = this.getParent(), view = this.getParent(),
columns = view.visible_columns;
if (view.widget_children) {
view.widget_children.every(function(child) {
children = view.getChildren();
if (children) {
children.every(function(child) {
if (child.field && child.field.type == 'one2many') { if (child.field && child.field.type == 'one2many') {
view = child.viewmanager.views.list.controller; view = child.viewmanager.views.list.controller;
return false; // break out of the loop return false; // break out of the loop
@ -53,7 +53,7 @@ openerp.web_export_view = function(instance, m) {
} }
export_columns_keys = []; export_columns_keys = [];
export_columns_names = []; export_columns_names = [];
$.each(columns,function(){
$.each(view.visible_columns, function(){
if(this.tag=='field'){ if(this.tag=='field'){
// non-fields like `_group` or buttons // non-fields like `_group` or buttons
export_columns_keys.push(this.id); export_columns_keys.push(this.id);
@ -68,12 +68,12 @@ openerp.web_export_view = function(instance, m) {
if($row.attr('data-id')){ if($row.attr('data-id')){
export_row = []; export_row = [];
checked = $row.find('th input[type=checkbox]').attr("checked"); checked = $row.find('th input[type=checkbox]').attr("checked");
if (checked === "checked"){
if (children || checked === "checked"){
$.each(export_columns_keys,function(){ $.each(export_columns_keys,function(){
cell = $row.find('td[data-field="'+this+'"]').get(0); cell = $row.find('td[data-field="'+this+'"]').get(0);
text = cell.text || cell.textContent || cell.innerHTML || ""; text = cell.text || cell.textContent || cell.innerHTML || "";
if (cell.classList.contains("oe_list_field_float")){ if (cell.classList.contains("oe_list_field_float")){
export_row.push(parseFloat(text));
export_row.push(instance.web.parse_value(text, {'type': "float"}));
} }
else if (cell.classList.contains("oe_list_field_integer")){ else if (cell.classList.contains("oe_list_field_integer")){
export_row.push(parseInt(text)); export_row.push(parseInt(text));

Loading…
Cancel
Save