编程语言
首页 > 编程语言> > python – 隐藏One2many字段有条件的Odoo / OpenERP

python – 隐藏One2many字段有条件的Odoo / OpenERP

作者:互联网

我正在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的新手.

解决方法:

试试以下,

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

标签:odoo-8,python,openerp,xml
来源: https://codeday.me/bug/20190830/1764833.html