Browse Source
[MIG] report_xlsx: Migration to 12.0
[MIG] report_xlsx: Migration to 12.0
* refactor: On new ActionManager override _makeReportUrls and triggerDownload to support XLSX format * pass action to custom _downloadReportXLSX: Need action to get report data * dict constructor to remove context lang14.0
Cristian Salamea
6 years ago
committed by
Alex Cuellar
8 changed files with 110 additions and 65 deletions
-
7report_xlsx/README.rst
-
2report_xlsx/__manifest__.py
-
26report_xlsx/models/ir_report.py
-
1report_xlsx/report/report_xlsx.py
-
88report_xlsx/static/src/js/report/action_manager_report.js
-
47report_xlsx/static/src/js/report/qwebactionmanager.js
-
2report_xlsx/tests/test_report.py
-
2report_xlsx/views/webclient_templates.xml
@ -0,0 +1,88 @@ |
|||||
|
// © 2017 Creu Blanca
|
||||
|
// License AGPL-3.0 or later (https://www.gnuorg/licenses/agpl.html).
|
||||
|
odoo.define("report_xlsx.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({ |
||||
|
|
||||
|
_downloadReportXLSX: function (url, actions) { |
||||
|
framework.blockUI(); |
||||
|
var def = $.Deferred(); |
||||
|
var type = "xlsx"; |
||||
|
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) { |
||||
|
url += "/" + cloned_action.context.active_ids.join(','); |
||||
|
} |
||||
|
} else { |
||||
|
url += "?options=" + encodeURIComponent(JSON.stringify(cloned_action.data)); |
||||
|
url += "&context=" + encodeURIComponent(JSON.stringify(cloned_action.context)); |
||||
|
} |
||||
|
|
||||
|
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, |
||||
|
}); |
||||
|
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 === "xlsx") { |
||||
|
return this._downloadReportXLSX(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.xlsx = '/report/xlsx/' + action.report_name; |
||||
|
return reportUrls; |
||||
|
}, |
||||
|
|
||||
|
_executeReportAction: function (action, options) { |
||||
|
var self = this; |
||||
|
if (action.report_type === 'xlsx') { |
||||
|
return self._triggerDownload(action, options, 'xlsx'); |
||||
|
} |
||||
|
return this._super.apply(this, arguments); |
||||
|
} |
||||
|
}); |
||||
|
|
||||
|
}); |
@ -1,47 +0,0 @@ |
|||||
// © 2017 Creu Blanca
|
|
||||
// License AGPL-3.0 or later (https://www.gnuorg/licenses/agpl.html).
|
|
||||
odoo.define('report_xlsx.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 === 'xlsx') { |
|
||||
framework.blockUI(); |
|
||||
var report_xlsx_url = 'report/xlsx/' + cloned_action.report_name; |
|
||||
if (_.isUndefined(cloned_action.data) || |
|
||||
_.isNull(cloned_action.data) || |
|
||||
(_.isObject(cloned_action.data) && _.isEmpty(cloned_action.data))) |
|
||||
{ |
|
||||
if(cloned_action.context.active_ids) { |
|
||||
report_xlsx_url += '/' + cloned_action.context.active_ids.join(','); |
|
||||
} |
|
||||
} else { |
|
||||
report_xlsx_url += '?options=' + encodeURIComponent(JSON.stringify(cloned_action.data)); |
|
||||
report_xlsx_url += '&context=' + encodeURIComponent(JSON.stringify(cloned_action.context)); |
|
||||
} |
|
||||
self.getSession().get_file({ |
|
||||
url: report_xlsx_url, |
|
||||
data: {data: JSON.stringify([ |
|
||||
report_xlsx_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(); |
|
||||
} |
|
||||
} |
|
||||
}); |
|
||||
framework.unblockUI(); |
|
||||
return; |
|
||||
} |
|
||||
return self._super(action, options); |
|
||||
} |
|
||||
}); |
|
||||
}); |
|
Write
Preview
Loading…
Cancel
Save
Reference in new issue