在OpenERP v8中向BOM行添加列

时间:2015-02-04 16:13:24

标签: python xml odoo openerp-8

我正在尝试根据https://www.odoo.com/apps/modules/7.0/mrp_bom_product_details/

在物料清单行中使用自定义列自定义物料清单表单视图

我的企图滞留在以下状态:

custom_bom_form.py:

from openerp.osv import fields, osv
from openerp.tools.translate import _

class mrp_bom(osv.osv):
    _inherit = 'mrp.bom'

    _columns ={
        'product_qty_available': fields.related('product_id', 'qty_available', type='float', string='Quantity On Hand', readonly=True),
    }
    _defaults = {
    } 

mrp_bom()

custom_bom_form.xml:

<?xml version="1.0"?>
<openerp>
    <data>

        <record id="mrp_bom_form_view_product_details" model="ir.ui.view">
            <field name="name">mrp.bom.form.product_details</field>
            <field name="model">mrp.bom</field>
            <field name="inherit_id" ref="mrp.mrp_bom_form_view"/>    
            <field name="arch" type="xml">
                <xpath expr="//notebook/page[@string='Components']/field/tree[@string='Components']/field[@name='product_qty']" position="after" >
                    <field name="product_qty_available" />
                </xpath> 
            </field>
        </record>

    </data>
</openerp>

安装模块时,这会导致Odoo出错:

ParseError: "ValidateError
Field(s) `arch` failed against a constraint: Invalid view definition

Error details:
Field `product_qty_available` does not exist

Error context:
View `mrp.bom.form.product_details`
[view_id: 1094, xml_id: n/a, model: mrp.bom, parent_id: 675]" while parsing /usr/lib/python2.7/dist-packages/openerp/addons/mrp_bom_product_details/mrp_bom_product_details.xml:5, near
    <record id="mrp_bom_form_view_product_details" model="ir.ui.view">
        <field name="name">mrp.bom.form.product_details</field>
        <field name="model">mrp.bom</field>
        <field name="inherit_id" ref="mrp.mrp_bom_form_view"/>    
        <field name="arch" type="xml">
            <xpath expr="//notebook/page[@string='Components']/field/tree[@string='Components']/field[@name='product_qty']" position="after">
                <field name="product_qty_available"/>
            </xpath> 
        </field>
    </record>

我无法弄清楚为什么我不能在那里引用product_qty_available,它可以在BOM表格的其他地方使用。 E.g:

        <field name="arch" type="xml">
            <field name="product_id" position="after">
                <field name="product_qty_available" />
            </field> 
        </field>

作品。

而是将引用的字段更改为系统知道的工作,例如。添加另一个product_qty列:

        <field name="arch" type="xml">
            <xpath expr="//notebook/page[@string='Components']/field/tree[@string='Components']/field[@name='product_qty']" position="after" >
                <field name="product_qty" />
            </xpath> 
        </field>

有人能告诉我我做错了什么。我如何在那里引用product_qty_available?笔记本页面有什么特别之处吗?

更新

工作py文件:

from openerp.osv import fields, osv
from openerp.tools.translate import _

class mrp_bom_line(osv.osv):
    _inherit = 'mrp.bom.line'

    _columns ={
        'product_qty_available': fields.related('product_id', 'qty_available', type='float', string='Quantity On Hand', readonly=True),
    }
    _defaults = {
    }

mrp_bom_line()

和xml文件:

<?xml version="1.0"?>
<openerp>
    <data>

        <record id="mrp_bom_form_view_product_details" model="ir.ui.view">
            <field name="name">mrp.bom.form.product_details</field>
            <field name="model">mrp.bom</field>
            <field name="inherit_id" ref="mrp.mrp_bom_form_view"/>    
            <field name="arch" type="xml">
                <xpath expr="//field[@name='bom_line_ids']/tree/field[@name='product_qty']" position="after">
                    <field name="product_qty_available" />
                </xpath>
            </field>
        </record>

    </data>
</openerp>

1 个答案:

答案 0 :(得分:1)

您已在模型product_qty_available中添加了字段mrp.bom,并且您尝试在字段bom_line_ids内添加字段 - 在bom_line_ids的树视图中这是mbrp.bom.line的one2many,因此系统会尝试在product_qty_available模型中找到那个实际上不存在的字段mrp.bom.line

我不确定,您的确切目标是什么,但请尝试以下

1.该字段已添加到模型mrp.bom中,因此您应该尝试使用     以下

<xpath expr="/form/group/group[1]/field[@name='product_id']" position="after">
    <field name="product_qty_available"/>
</xpath>

所以这会在屏幕顶部的product_id字段后添加字段,显示主信息。

2.在mrp.bom.line模型中添加字段,然后尝试以下操作:

<xpath expr="//field[@name='bom_line_ids']/tree/field[@name='product_qty']"  position="after">
    <field name="product_qty_available"/>
</xpath>