Для этого вам необходимо обработать код js.
В вашем представлении формы добавьте следующий код:
<button string="Reports_print" name="print_reports" type="object"/>
Тогда мы должны генерировать требуемые отчеты из js
с помощью кода питона Whithout с помощью:
return {
'type': 'ir.actions.report.xml',
'report_name': 'my_report',
'datas': datas,
'nodestroy': True
}
Для этого ваш метод `print_reports' должно быть:
def print_reports(self, cr, uid, ids, context):
"""DO NOT EDIT !"""
Это необходимо, чтобы поймать кнопку cli ck событие от js
код.
В вашем JS скрипт /modulename/static/js/script.js сделать это:
openerp.MODULENAME=function(instance)
{
var QWEB=instance.web.qweb,_t=instance.web._t;
instance.web.DataSet.include({
call_button:function(method, args){
var id = args[0];
if(String(method)=='print_reports'){
//get_reports should be created in modele_name class
new instance.web.Model('modele_name',this.get_context()).ca ll('get_reports',[id],{context:this.get_context()}).done(function(reports){
for(var b=0; b<reports.length; b+=2)
download('data:application/pdf;base64,'+reports[b],reports[b+1]+'.pdf','application/pdf');
});
}
return this._super(method, args);
}
});
};
мы называем метод питон get_reports
из js
и результат отчеты как 64 base string
get_reports
метод генерации и отформатировать отчеты перед отправкой их в js
.
ли это как ниже:
def get_reports(self, cr, uid, ids, context):
#Get datas used in the reports from modele
datas = {
'ids': ids,
'model': 'modele_name',
'form': {
'key': value,
...
}
}
pdf1 = self.pool.get('ir.actions.report.xml').render_report(cr,
uid,
ids,
"report_name1",
datas,
context=None)
pdf2 = self.pool.get('ir.actions.report.xml').render_report(cr,
uid,
ids,
"report_name2",
datas,
context=None)
...
#We send 'report naem ' to name downloaded report ('reports[b+1]+'.pdf')
return pdf1[0].encode('base64'), 'report_name1', pdf2[0].encode(
'base64'), 'report_name2',...
значение может быть использовано в Р коде: DATAS [ 'форма'] [ключ].
Чтобы загрузить их, я использовал download.js
script, Существует много способов сделать это, но я обнаружил, что download.js - самый простой способ.
Содержание download.js
:
//download.js v3.0, by dandavis; 2008-2014. [CCBY2] see http://danml.com/download.html for tests/usage
// v1 landed a FF+Chrome compat way of downloading strings to local un-named files, upgraded to use a hidden frame and optional mime
// v2 added named files via a[download], msSaveBlob, IE (10+) support, and window.URL support for larger+faster saves than dataURLs
// v3 added dataURL and Blob Input, bind-toggle arity, and legacy dataURL fallback was improved with force-download mime and base64 support
// data can be a string, Blob, File, or dataURL
function download(data, strFileName, strMimeType) {
var self = window, // this script is only for browsers anyway...
u = "application/octet-stream", // this default mime also triggers iframe downloads
m = strMimeType || u,
x = data,
D = document,
a = D.createElement("a"),
z = function(a){return String(a);},
B = self.Blob || self.MozBlob || self.WebKitBlob || z,
BB = self.MSBlobBuilder || self.WebKitBlobBuilder || self.BlobBuilder,
fn = strFileName || "download",
blob,
b,
ua,
fr;
//if(typeof B.bind === 'function'){ B=B.bind(self); }
if(String(this)==="true"){ //reverse arguments, allowing download.bind(true, "text/xml", "export.xml") to act as a callback
x=[x, m];
m=x[0];
x=x[1];
}
//go ahead and download dataURLs right away
if(String(x).match(/^data\:[\w+\-]+\/[\w+\-]+[,;]/)){
return navigator.msSaveBlob ? // IE10 can't do a[download], only Blobs:
navigator.msSaveBlob(d2b(x), fn) :
saver(x) ; // everyone else can save dataURLs un-processed
}//end if dataURL passed?
try{
blob = x instanceof B ?
x :
new B([x], {type: m}) ;
}catch(y){
if(BB){
b = new BB();
b.append([x]);
blob = b.getBlob(m); // the blob
}
}
function d2b(u) {
var p= u.split(/[:;,]/),
t= p[1],
dec= p[2] == "base64" ? atob : decodeURIComponent,
bin= dec(p.pop()),
mx= bin.length,
i= 0,
uia= new Uint8Array(mx);
for(i;i<mx;++i) uia[i]= bin.charCodeAt(i);
return new B([uia], {type: t});
}
function saver(url, winMode){
if ('download' in a) { //html5 A[download]
a.href = url;
a.setAttribute("download", fn);
a.innerHTML = "downloading...";
D.body.appendChild(a);
setTimeout(function() {
a.click();
D.body.removeChild(a);
if(winMode===true){setTimeout(function(){ self.URL.revokeObjectURL(a.href);}, 250);}
}, 66);
return true;
}
//do iframe dataURL download (old ch+FF):
var f = D.createElement("iframe");
D.body.appendChild(f);
if(!winMode){ // force a mime that will download:
url="data:"+url.replace(/^data:([\w\/\-\+]+)/, u);
}
f.src = url;
setTimeout(function(){ D.body.removeChild(f); }, 333);
}//end saver
if (navigator.msSaveBlob) { // IE10+ : (has Blob, but not a[download] or URL)
return navigator.msSaveBlob(blob, fn);
}
if(self.URL){ // simple fast and modern way using Blob and URL:
saver(self.URL.createObjectURL(blob), true);
}else{
// handle non-Blob()+non-URL browsers:
if(typeof blob === "string" || blob.constructor===z){
try{
return saver("data:" + m + ";base64," + self.btoa(blob) );
}catch(y){
return saver("data:" + m + "," + encodeURIComponent(blob) );
}
}
// Blob but not URL:
fr=new FileReader();
fr.onload=function(e){
saver(this.result);
};
fr.readAsDataURL(blob);
}
return true;
} /* end download() */
Чтобы иметь возможность вызвать download
метод в сценарии вы должны загрузить download.js
файл, чтобы сделать это изменить MODULENAME_view.xml, чтобы добавить новую строку
<?xml version="1.0" encoding="utf-8"?>
<openerp>
<data>
<template id="assets_backend_MODULENAME" name="MODULENAME assets" inherit_id="web.assets_backend">
<xpath expr="." position="inside">
...
<!-- The new line-->
<script type="text/javascript" src="/MODULENAME/static/src/js/download.js"></script>
...
</xpath>
</template>
</data>
</openerp>
Почему дону Вы хотите распечатать все, что хотите, в одном отчете? – ChesuCR
ОК, но вы хотите создать два разных файла правильно? – ChesuCR
@zetysz и поставить два варианта (каждый, чтобы загрузить каждый отчет), не является хорошим способом? – forvas