Openerp:onChange事件,用于在帐户移动时创建行

时间:2012-09-14 15:40:47

标签: python onchange openerp

我在日记帐分录(帐户移动表单)上有一个字段amount,我需要定义一个onChange事件,在我填写金额后自动插入行。但我不确定如何。

3 个答案:

答案 0 :(得分:1)

昨天我必须做一些类似于你的要求的事情。我在购买时有一个salo订单(m2o)字段... on_change of sale_order我必须填写采购订单行...希望它可以帮助你。

class purchase_order(osv.osv):
    _inherit = 'purchase.order'

    _columns = {
        'sale_order':fields.many2one('sale.order','Sale Order'),
        'purchase_type':
            fields.selection([
                ('order','Purchase Order'),
                ('job','Job Order')
                ],
            'Purchase Type',
            required=True,
            states={
                'confirmed':[('readonly',True)],
                'approved':[('readonly',True)],
                },
            select=True,
            help="Define type of purchase order.",
         ),
     }

def onchange_saleorder(self,cr,uid,ids,order,context=None):
    res={}
    lis=[]
    sorder_id=self.pool.get('sale.order').browse(cr,uid,order)
    for line in sorder_id.order_line:
        print "uom",line.product_id.uom_id.id
        res={'product_id':line.product_id.id,
             'name':line.product_id.name,
             'product_qty':1,
             'product_uom':line.product_id.uom_id.id,
             'price_unit':line.price_unit,
             'date_planned':time.strftime('%Y-%m-%d'),}
        lis.append(res)
    print "list is .........",lis
    res={'value':{'order_line':lis}} // here order_line is o2m field of purchase.
    return res

答案 1 :(得分:0)

您的 on_change 方法必须返回由行值组成的词典列表。

例如:

res['value']['line_ids'] = [
    {
        'account_id': 1,
        'debit': 100,
    },
    {
        'account_id': 2,
        'credit': 100,
    }]

另外,请参阅 account.voucher recompute_voucher_lines 方法作为示例。

答案 2 :(得分:0)

有时会生成错误'0',所以我们必须编写这样的代码。 在上述例子的情况下 lis.append((0,0,res))