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