Jaime Arroyo
6 years ago
7 changed files with 167 additions and 54 deletions
-
66report_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
|
// © 2019 Creu Blanca
|
||||
// License AGPL-3.0 or later (https://www.gnuorg/licenses/agpl.html).
|
// 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(); |
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) || |
if (_.isUndefined(cloned_action.data) || |
||||
_.isNull(cloned_action.data) || |
_.isNull(cloned_action.data) || |
||||
(_.isObject(cloned_action.data) && _.isEmpty(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 { |
} 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