0

openerp的后续问题覆盖 onchange 行为而不影响基础 15244031

以下代码确实会被触发,但当任何相关字段具有值时,我会收到服务器错误 500。

当我查看日志时,它显示 JSON 序列化问题。

TypeError: browse_record(product.mycount, 1) is not JSON serializable

请提出解决方案。

class purchase_order_line_custom(osv.osv):
_name = 'purchase.order.line'
_inherit = 'purchase.order.line'

def onchange_product_id(self, cr, uid, ids, pricelist_id, product_id, qty, uom_id, partner_id, date_order=False, fiscal_position_id=False, date_planned=False, name=False, price_unit=False, context=None):
values = super(purchase_order_line_custom, self).onchange_product_id(cr, uid, ids, pricelist_id, product_id, qty, uom_id, partner_id, date_order, fiscal_position_id, date_planned,name, price_unit, context=context)
  if product_id:
    product = self.pool.get('product.product').browse(cr, uid, product_id, context=context)
    values['value'].update({
                            'qualified_name':product.qualified_name,
                            'product_type' : product.product_type or None,
                            'product_subtype' : product.product_subtype,
                            'count_id':product.count_id or None 
    })
  return values   

  _columns={
      'product_type': fields.related('product_id','product_type',type='selection', string='Product Type', selection=[('X','X'),('Y','Y'),('Z','Z')]),
      'product_subtype': fields.related('product_id','product_subtype',type='char', size=64, string='Sub-Type'),
      'qualified_name': fields.related('product_id','qualified_name',type='char', size=64, string='Qualified Name'),
      'count_id': fields.related('product_id','count_id',type='many2one',relation='product.mycount',string='Count')
      }

purchase_order_line_custom() 
4

1 回答 1

2

在该行'count_id':product.count_id or None中,我认为 count_id 是 product.you 中的 many2one 字段。您试图将 object 传递给 product.order.line 中的 count_id 字段,您需要通过 product.count_id.id 来获取 id。

于 2013-03-07T13:20:28.113 回答