mirror of
https://github.com/OCA/reporting-engine.git
synced 2025-02-16 16:30:38 +02:00
[MIG] : Migration to 14.0
This commit is contained in:
@@ -7,13 +7,13 @@
|
|||||||
"author": "Creu Blanca," "Odoo Community Association (OCA)",
|
"author": "Creu Blanca," "Odoo Community Association (OCA)",
|
||||||
"website": "https://github.com/OCA/reporting-engine",
|
"website": "https://github.com/OCA/reporting-engine",
|
||||||
"category": "Reporting",
|
"category": "Reporting",
|
||||||
"version": "11.0.1.0.1",
|
"version": "14.0.1.0.1",
|
||||||
"license": "AGPL-3",
|
"license": "AGPL-3",
|
||||||
"external_dependencies": {
|
"external_dependencies": {
|
||||||
"python": [
|
"python": [
|
||||||
"fdfgen",
|
"fdfgen",
|
||||||
],
|
],
|
||||||
"bin": [
|
"deb": [
|
||||||
"pdftk",
|
"pdftk",
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -8,7 +8,9 @@ from odoo.exceptions import UserError
|
|||||||
class ReportAction(models.Model):
|
class ReportAction(models.Model):
|
||||||
_inherit = "ir.actions.report"
|
_inherit = "ir.actions.report"
|
||||||
|
|
||||||
report_type = fields.Selection(selection_add=[("fillpdf", "PDF Filler")])
|
report_type = fields.Selection(
|
||||||
|
selection_add=[("fillpdf", "PDF Filler")], ondelete={"fillpdf": "set default"}
|
||||||
|
)
|
||||||
|
|
||||||
@api.model
|
@api.model
|
||||||
def render_fillpdf(self, docids, data):
|
def render_fillpdf(self, docids, data):
|
||||||
|
|||||||
98
report_fillpdf/static/src/js/report/action_manager_report.js
Normal file
98
report_fillpdf/static/src/js/report/action_manager_report.js
Normal file
@@ -0,0 +1,98 @@
|
|||||||
|
// © 2017 Creu Blanca
|
||||||
|
// License AGPL-3.0 or later (https://www.gnuorg/licenses/agpl.html).
|
||||||
|
odoo.define("report_fillpdf.report", function (require) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
var core = require("web.core");
|
||||||
|
var ActionManager = require("web.ActionManager");
|
||||||
|
var framework = require("web.framework");
|
||||||
|
var session = require("web.session");
|
||||||
|
var _t = core._t;
|
||||||
|
|
||||||
|
ActionManager.include({
|
||||||
|
_downloadReportfillpdf: function (url, actions) {
|
||||||
|
var self = this;
|
||||||
|
framework.blockUI();
|
||||||
|
var type = "fillpdf";
|
||||||
|
var cloned_action = _.clone(actions);
|
||||||
|
var new_url = url;
|
||||||
|
|
||||||
|
if (
|
||||||
|
_.isUndefined(cloned_action.data) ||
|
||||||
|
_.isNull(cloned_action.data) ||
|
||||||
|
(_.isObject(cloned_action.data) && _.isEmpty(cloned_action.data))
|
||||||
|
) {
|
||||||
|
if (cloned_action.context.active_ids) {
|
||||||
|
new_url += "/" + cloned_action.context.active_ids.join(",");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
new_url +=
|
||||||
|
"?options=" +
|
||||||
|
encodeURIComponent(JSON.stringify(cloned_action.data));
|
||||||
|
new_url +=
|
||||||
|
"&context=" +
|
||||||
|
encodeURIComponent(JSON.stringify(cloned_action.context));
|
||||||
|
}
|
||||||
|
|
||||||
|
return new Promise(function (resolve, reject) {
|
||||||
|
var blocked = !session.get_file({
|
||||||
|
url: new_url,
|
||||||
|
data: {
|
||||||
|
data: JSON.stringify([new_url, type]),
|
||||||
|
},
|
||||||
|
success: resolve,
|
||||||
|
error: (error) => {
|
||||||
|
self.call("crash_manager", "rpc_error", error);
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
_triggerDownload: function (action, options, type) {
|
||||||
|
var self = this;
|
||||||
|
var reportUrls = this._makeReportUrls(action);
|
||||||
|
if (type === "fillpdf") {
|
||||||
|
return this._downloadReportfillpdf(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")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
return options.on_close();
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
return this._super.apply(this, arguments);
|
||||||
|
},
|
||||||
|
|
||||||
|
_makeReportUrls: function (action) {
|
||||||
|
var reportUrls = this._super.apply(this, arguments);
|
||||||
|
reportUrls.fillpdf = "/report/fillpdf/" + action.report_name;
|
||||||
|
return reportUrls;
|
||||||
|
},
|
||||||
|
|
||||||
|
_executeReportAction: function (action, options) {
|
||||||
|
var self = this;
|
||||||
|
if (action.report_type === "fillpdf") {
|
||||||
|
return self._triggerDownload(action, options, "fillpdf");
|
||||||
|
}
|
||||||
|
return this._super.apply(this, arguments);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
});
|
||||||
@@ -1,49 +0,0 @@
|
|||||||
// © 2017 Creu Blanca
|
|
||||||
// License AGPL-3.0 or later (https://www.gnuorg/licenses/agpl.html).
|
|
||||||
odoo.define("report_fillpdf.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 === "fillpdf") {
|
|
||||||
framework.blockUI();
|
|
||||||
var report_fillpdf_url = "report/fillpdf/" + cloned_action.report_name;
|
|
||||||
if (cloned_action.context.active_ids) {
|
|
||||||
report_fillpdf_url +=
|
|
||||||
"/" + cloned_action.context.active_ids.join(",");
|
|
||||||
} else {
|
|
||||||
report_fillpdf_url +=
|
|
||||||
"?options=" +
|
|
||||||
encodeURIComponent(JSON.stringify(cloned_action.data));
|
|
||||||
report_fillpdf_url +=
|
|
||||||
"&context=" +
|
|
||||||
encodeURIComponent(JSON.stringify(cloned_action.context));
|
|
||||||
}
|
|
||||||
self.getSession().get_file({
|
|
||||||
url: report_fillpdf_url,
|
|
||||||
data: {
|
|
||||||
data: JSON.stringify([
|
|
||||||
report_fillpdf_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);
|
|
||||||
},
|
|
||||||
});
|
|
||||||
});
|
|
||||||
@@ -11,4 +11,4 @@ class TestReport(common.TransactionCase):
|
|||||||
report = report_object._get_report_from_name(report_name)
|
report = report_object._get_report_from_name(report_name)
|
||||||
docs = self.env["res.company"].search([], limit=1).partner_id
|
docs = self.env["res.company"].search([], limit=1).partner_id
|
||||||
self.assertEqual(report.report_type, "fillpdf")
|
self.assertEqual(report.report_type, "fillpdf")
|
||||||
report.render(docs.ids, {})
|
report._render(docs.ids, {})
|
||||||
|
|||||||
@@ -8,9 +8,8 @@
|
|||||||
<xpath expr="." position="inside">
|
<xpath expr="." position="inside">
|
||||||
<script
|
<script
|
||||||
type="text/javascript"
|
type="text/javascript"
|
||||||
src="/report_fillpdf/static/src/js/report/qwebactionmanager.js"
|
src="/report_fillpdf/static/src/js/report/action_manager_report.js"
|
||||||
/>
|
/>
|
||||||
</xpath>
|
</xpath>
|
||||||
|
|
||||||
</template>
|
</template>
|
||||||
</odoo>
|
</odoo>
|
||||||
|
|||||||
@@ -1,2 +0,0 @@
|
|||||||
[bdist_wheel]
|
|
||||||
universal=1
|
|
||||||
Reference in New Issue
Block a user