我正在Odoo 8.0设置的客户部分中创建一个名为Master Account的选项。如果选中,则会将另一个帐户设置为祖父母。这对于拥有多个位置但只有一个结算中心的公司/客户非常有用。我能够应用此功能,但现在我不想显示将主帐户设置为已设置为某人主人的公司的选项。
我尝试过以下操作但不起作用:
PYTHON
from openerp import models, fields, api, _
class res_partner(models.Model):
_inherit = 'res.partner'
related_partner_id = fields.Many2one('res.partner', 'Master Account')
related_partner_ids = fields.One2many('res.partner', 'Master Account')
XML
<?xml version="1.0" ?>
<openerp>
<data>
<record model="ir.ui.view" id="base_view_partner_demo_inherit">
<field name="name">res.partner.form.demo</field>
<field name="model">res.partner</field>
<field name="inherit_id" ref="base.view_partner_form" />
<field name="arch" type="xml">
<field name="website" position="after">
<field name="related_partner_id" attrs="{'invisible': [('related_partner_ids','>', '0')]}"/>
<field name="related_partner_ids" invisible="1"/>
<label string="Master Account" attrs="{'invisible': [['related_partner_id', '!=', False]]}"/>
</field>
</field>
</record>
</data>
</openerp>
非常感谢任何帮助。我是Odoo的全新品牌。
答案 0 :(得分:5)
尝试以下,
from openerp import models, fields, api, _
class res_partner(models.Model):
_inherit = 'res.partner'
related_partner_id = fields.Many2one('res.partner', 'Master Account')
related_partner_ids = fields.One2many('res.partner', 'related_partner_id', 'Master Account')
One2many 也需要反向字段ID。 并设置这样的attrs,
<field name="related_partner_id" attrs="{'invisible': [('related_partner_ids','!=', False)]}"/>
或者你应该这样写
<field name="related_partner_id" attrs="{'invisible': [('related_partner_ids','!=', [])]}"/>
对于 Many2many 字段,应按以下方式应用attrs。
<field name="m2m_field" attrs="{'invisible': [('m2m_field','=', [(6,0,[])])]}"/>