如何在编辑表单中显示/刷新相关字段



我有一个对象shipment,它有一个类型相关的many2one字段product,它引用了many2one对象contract,后者有一个产品(many2one)。创建发货时,在保存发货之前不会显示产品。此外,在编辑时,产品不会随合同而更改。

我试图创建一个返回新产品价值的onchange事件,但没有成功。

它们是在关系发生变化时刷新相关字段的方法吗?

  • 穆罕默德

阿里井,

是。如果字段相关,则只有在保存记录时才会显示值。因为你保存了记录,ORM会链接相关的字段值,网页会读回并显示给你。

但若要在from上立即显示值,您可以在更改字段本身时使用具有任何字段值功能的on_change

谨致问候。

我觉得sales.orderstock.picking标准对象非常接近您的需求。您最好扩展标准对象,而不是从头开始创建新对象。

关于你的问题,你需要on_change行为,所以你应该尝试修复不起作用的方法。在6.1中,您有一个很好的例子。请参见crm/crm.py中的crm_base对象。

您可以在CRM Lead表单中看到它的实际操作):选择合作伙伴时,会自动填写地址和电子邮件。您还需要查看crmcrm_lead_view.xml中的视图id crm_case_form_view_oppor,以检查该方法的使用情况。

型号代码为:

def onchange_partner_address_id(self, cr, uid, ids, add, email=False):
    """This function returns value of partner email based on Partner Address
    :param ids: List of case IDs
    :param add: Id of Partner's address
    :param email: Partner's email ID
    """
    data = {'value': {'email_from': False, 'phone':False}}
    if add:
        address = self.pool.get('res.partner.address').browse(cr, uid, add)
        data['value'] = {'email_from': address and address.email or False ,
                         'phone':  address and address.phone or False}
    if 'phone' not in self._columns:
        del data['value']['phone']
    return data
def onchange_partner_id(self, cr, uid, ids, part, email=False):
    """This function returns value of partner address based on partner
    :param ids: List of case IDs
    :param part: Partner's id
    :param email: Partner's email ID
    """
    data={}
    if  part:
        addr = self.pool.get('res.partner').address_get(cr, uid, [part], ['contact'])
        data = {'partner_address_id': addr['contact']}
        data.update(self.onchange_partner_address_id(cr, uid, ids, addr['contact'])['value'])
    return {'value': data}

视图侧代码为:

<field name="partner_id" select="1" colspan="2" 
  on_change="onchange_partner_id(partner_id, email_from)" string="Customer" />
<field name="partner_address_id" string="Contact" colspan="1"
  on_change="onchange_partner_address_id(partner_address_id, email_from)" />

最新更新