Jaime Arroyo
6 years ago
7 changed files with 167 additions and 54 deletions
-
68report_csv/README.rst
-
2report_csv/__manifest__.py
-
2report_csv/readme/CONTRIBUTORS.rst
-
1report_csv/readme/DESCRIPTION.rst
-
38report_csv/readme/USAGE.rst
-
1report_csv/report/report_csv.py
-
109report_csv/static/src/js/report/qwebactionmanager.js
@ -0,0 +1,2 @@ |
|||
* Enric Tobella <etobella@creublanca.es> |
|||
* Jaime Arroyo <jaime.arroyo@creublanca.es> |
@ -0,0 +1 @@ |
|||
This module provides a basic report class to generate csv report. |
@ -0,0 +1,38 @@ |
|||
An example of CSV report for partners on a module called `module_name`: |
|||
|
|||
A python class :: |
|||
|
|||
from odoo import models |
|||
|
|||
class PartnerCSV(models.AbstractModel): |
|||
_name = 'report.report_csv.partner_csv' |
|||
_inherit = 'report.report_csv.abstract' |
|||
|
|||
def generate_csv_report(self, writer, data, partners): |
|||
writer.writeheader() |
|||
for obj in partners: |
|||
writer.writerow({ |
|||
'name': obj.name, |
|||
'email': obj.email, |
|||
}) |
|||
|
|||
def csv_report_options(self): |
|||
res = super().csv_report_options() |
|||
res['fieldnames'].append('name') |
|||
res['fieldnames'].append('email') |
|||
res['delimiter'] = ';' |
|||
res['quoting'] = csv.QUOTE_ALL |
|||
return res |
|||
|
|||
|
|||
A report XML record :: |
|||
|
|||
<report |
|||
id="partner_csv" |
|||
model="res.partner" |
|||
string="Print to CSV" |
|||
report_type="csv" |
|||
name="module_name.report_name" |
|||
file="res_partner" |
|||
attachment_use="False" |
|||
/> |
@ -1,47 +1,88 @@ |
|||
// © 2019 Creu Blanca
|
|||
// License AGPL-3.0 or later (https://www.gnuorg/licenses/agpl.html).
|
|||
odoo.define('report_csv.report', function(require){ |
|||
'use strict'; |
|||
|
|||
var ActionManager= require('web.ActionManager'); |
|||
var crash_manager = require('web.crash_manager'); |
|||
var framework = require('web.framework'); |
|||
|
|||
ActionManager.include({ |
|||
ir_actions_report: function (action, options){ |
|||
var self = this; |
|||
var cloned_action = _.clone(action); |
|||
if (cloned_action.report_type === 'csv') { |
|||
odoo.define("report_csv.report", function (require) { |
|||
"use strict"; |
|||
|
|||
var core = require("web.core"); |
|||
var ActionManager = require("web.ActionManager"); |
|||
var crash_manager = require("web.crash_manager"); |
|||
var framework = require("web.framework"); |
|||
var session = require("web.session"); |
|||
var _t = core._t; |
|||
|
|||
ActionManager.include({ |
|||
|
|||
_downloadReportCSV: function (url, actions) { |
|||
framework.blockUI(); |
|||
var report_csv_url = 'report/csv/' + cloned_action.report_name; |
|||
var def = $.Deferred(); |
|||
var type = "csv"; |
|||
var cloned_action = _.clone(actions); |
|||
|
|||
if (_.isUndefined(cloned_action.data) || |
|||
_.isNull(cloned_action.data) || |
|||
(_.isObject(cloned_action.data) && _.isEmpty(cloned_action.data))) |
|||
{ |
|||
if(cloned_action.context.active_ids) { |
|||
report_csv_url += '/' + cloned_action.context.active_ids.join(','); |
|||
if (cloned_action.context.active_ids) { |
|||
url += "/" + cloned_action.context.active_ids.join(','); |
|||
} |
|||
} else { |
|||
report_csv_url += '?options=' + encodeURIComponent(JSON.stringify(cloned_action.data)); |
|||
report_csv_url += '&context=' + encodeURIComponent(JSON.stringify(cloned_action.context)); |
|||
url += "?options=" + encodeURIComponent(JSON.stringify(cloned_action.data)); |
|||
url += "&context=" + encodeURIComponent(JSON.stringify(cloned_action.context)); |
|||
} |
|||
self.getSession().get_file({ |
|||
url: report_csv_url, |
|||
data: {data: JSON.stringify([ |
|||
report_csv_url, |
|||
cloned_action.report_type |
|||
])}, |
|||
error: crash_manager.rpc_error.bind(crash_manager), |
|||
success: function (){ |
|||
if(cloned_action && options && !cloned_action.dialog){ |
|||
options.on_close(); |
|||
} |
|||
} |
|||
|
|||
var blocked = !session.get_file({ |
|||
url: url, |
|||
data: { |
|||
data: JSON.stringify([url, type]), |
|||
}, |
|||
success: def.resolve.bind(def), |
|||
error: function () { |
|||
crash_manager.rpc_error.apply(crash_manager, arguments); |
|||
def.reject(); |
|||
}, |
|||
complete: framework.unblockUI, |
|||
}); |
|||
framework.unblockUI(); |
|||
return; |
|||
if (blocked) { |
|||
// AAB: this check should be done in get_file service directly,
|
|||
// should not be the concern of the caller (and that way, get_file
|
|||
// could return a deferred)
|
|||
var message = _t('A popup window with your report was blocked. You ' + |
|||
'may need to change your browser settings to allow ' + |
|||
'popup windows for this page.'); |
|||
this.do_warn(_t('Warning'), message, true); |
|||
} |
|||
return def; |
|||
}, |
|||
|
|||
_triggerDownload: function (action, options, type) { |
|||
var self = this; |
|||
var reportUrls = this._makeReportUrls(action); |
|||
if (type === "csv") { |
|||
return this._downloadReportCSV(reportUrls[type], action).then(function () { |
|||
if (action.close_on_report_download) { |
|||
var closeAction = {type: 'ir.actions.act_window_close'}; |
|||
return self.doAction(closeAction, _.pick(options, 'on_close')); |
|||
} else { |
|||
return options.on_close(); |
|||
} |
|||
}); |
|||
} |
|||
return this._super.apply(this, arguments); |
|||
}, |
|||
|
|||
_makeReportUrls: function (action) { |
|||
var reportUrls = this._super.apply(this, arguments); |
|||
reportUrls.csv = '/report/csv/' + action.report_name; |
|||
return reportUrls; |
|||
}, |
|||
|
|||
_executeReportAction: function (action, options) { |
|||
var self = this; |
|||
if (action.report_type === 'csv') { |
|||
return self._triggerDownload(action, options, 'csv'); |
|||
} |
|||
return this._super.apply(this, arguments); |
|||
} |
|||
return self._super(action, options); |
|||
} |
|||
}); |
|||
}); |
|||
|
|||
}); |
Write
Preview
Loading…
Cancel
Save
Reference in new issue