2010-12-14 7 views
2

このsum_taxesメソッドのlotパラメータがどのように設定されていますか?これはopenerpのオークションアドオンのコードサンプルです。ここでは、ファイルのオークション/レポート/ buyer_form_report.sxw
[[ repeatIn(o['lots'],'oo') ]] [[ oo.obj_num ]]を以下関数がopenerpレポートを呼び出す

import pooler 
    import time 
    from report import report_sxw 
    from osv import osv 

    class seller_form_report(report_sxw.rml_parse): 
     def __init__(self, cr, uid, name, context): 
      super(seller_form_report, self).__init__(cr, uid, name, context=context) 
      lot=self.pool.get('auction.lots').browse(cr,uid,uid) 
      #address=lot.bord_vnd_id.address_get(self.cr,self.uid,[partner.id]) 
     # partner=lot.bord_vnd_id.partner_id 
     # address=partner.address and partner.address[0] or "" 
     # street = address and address.street or "" 



      self.localcontext.update({ 
       'time': time, 
       'sum_taxes': self.sum_taxes, 
       'sellerinfo' : self.seller_info, 
       'grand_total' : self.grand_seller_total, 
     #  'street':street, 
     #  'address':address, 
    }) 


    def sum_taxes(self, lot): 
     taxes=[] 
     amount=0.0 
     if lot.bord_vnd_id.tax_id: 
      taxes.append(lot.bord_vnd_id.tax_id) 
     elif lot.auction_id and lot.auction_id.seller_costs: 
      taxes += lot.auction_id.seller_costs 
     tax=self.pool.get('account.tax').compute(self.cr,self.uid,taxes,lot.obj_price,1) 
     for t in tax: 
      amount+=t['amount'] 
     return amount 
    def seller_info(self): 
     objects = [object for object in self.localcontext.get('objects')] 
     ret_dict = {} 
     ret_list = [] 
     for object in objects: 

      partner = ret_dict.get(object.bord_vnd_id.partner_id.id,False) 
      if not partner: 
       ret_dict[object.bord_vnd_id.partner_id.id] = {'partner' : object.bord_vnd_id.partner_id or False,'lots':[object]} 
      else: 
       lots = partner.get('lots') 
       lots.append(object) 
#  buyer_ids=self.pool.get(auction.lots).read(cr,uid,lot) 
     return ret_dict.values() 
    def grand_seller_total(self,o): 
     grand_total = 0 
     for oo in o: 
      grand_total =grand_total + oo['obj_price']+ self.sum_taxes(oo) 
     return grand_total 


report_sxw.report_sxw('report.seller_form_report', 'auction.lots', 'addons/auction/report/seller_form_report.rml', parser=seller_form_report) 
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: 

答えて

1

チェックが「OO」が定義されており、このレポートは、モデルに登録されているように、その[[ oo.obj_price + sum_taxes(oo) ]]

のように呼ばれ:auction.lotsそれが返されますユーザーがレポートをクリックしたときのactive_idBrowseRecord

1

実際にはそのコードで関数を呼び出すわけではないので、関数はおそらくレポート内から呼び出され、そこにロットパラメータを渡します。投稿したコード例では、コンテキストに関数ポインタを置くだけです。

OpenERPレポートの詳細については、開発者向け書籍のreports sectionをご覧ください。 EclipseでOpenERPサーバーを実行し、デバッグモードでコードをステップ実行することが本当に役に立ちます。次に、sum_taxes()メソッドの呼び出し元を確認できます。

関連する問題