2015-11-09 2 views
1

Как я могу сгенерировать и загрузить два отчета одним действием из кода python.Печать двух отчетов в Odoo8

def print_reports(self, cr, uid, ids, context): 
    'I have to do it here' 
    ... 
    return { 
     'type': 'ir.actions.report.xml', 
     'report_name': 'certificate_of_origin', 
     'datas': datas, 
    } 

мне нужно напечатать две версии certificate_of_origin одним щелчком мыши, но я могу напечатать только один вариант каждый раз.

+0

Почему дону Вы хотите распечатать все, что хотите, в одном отчете? – ChesuCR

+0

ОК, но вы хотите создать два разных файла правильно? – ChesuCR

+0

@zetysz и поставить два варианта (каждый, чтобы загрузить каждый отчет), не является хорошим способом? – forvas

ответ

2

Для этого вам необходимо обработать код 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> 
-1

Я не думаю, что это возможно, используя текущую отчетность. 2 года назад я сделал то же самое, используя отчеты яшмы. и использование функциональных возможностей вспомогательных отчетов.

Смежные вопросы