隐藏One2many字段有条件地Odoo / OpenERP

时间:2015-04-01 22:25:07

标签: python xml openerp odoo-8

我正在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的全新品牌。

1 个答案:

答案 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,[])])]}"/>