Se rendre au contenu
Menu
Cette question a été signalée
1 Répondre
6327 Vues

I would like to add new column to the table account_invoice

I tried using:

from openerp import fields  as fieldss

    product_id= fieldss.related('order_line', 'product_id', type='many2one', relation='product.product', string='Product'),

the purpose:  add product in the view account invoice view search  <record id="view_account_invoice_filter" model="ir.ui.view">

 

Avatar
Ignorer

There could be more than one product in the invoice line which product you want to store in the account.invoice. If you just want to search the product in accout.invoice then look in to sale.order model for reference, which includes product_id as a related field.

Auteur

Yes I want to search product on account.invoice but the the account module is writen in differnet APÏ

May I know, what you exactly want to get as value in that column "name_product"

Auteur

I updated my question

Meilleure réponse

Try this

from openerp import models,fields,api

class account_invoice_ext(models.Model):
        _inherit = 'account.invoice'

product_id=fields.Many2one("product.product",related="invoice_line.product_id",string="Product")
    
 

Your xml file

 

        <record id="view_account_invoice_filter_inherit" model="ir.ui.view">
            <field name="name">account.invoice.inherit.select</field>
            <field name="model">account.invoice</field>
            <field name="inherit_id" ref="account.view_account_invoice_filter"/>
            <field name="arch" type="xml">
                <field name="period_id" position="after">
                    <field name="product_id"/>
                </field>
             </field>
         </record>

Hope this helps !!.

Avatar
Ignorer
Auteur

I got : File "/opt/odoo/odoo/openerp/models.py", line 1276, in _validate_fields raise ValidationError('\n'.join(errors)) ParseError: "ValidateError Field(s) `arch` failed against a constraint: Invalid view definition Error details: Field `product_id` does not exist

Auteur

I tried it in different DB same result

Did you updated the module? I have tried this, it working perfectly. Did you restarted the server and updated the module?

Auteur

your code apair perfect, I update & unistalled & installed the module I get that error. The field doesn't create a column in the DataBase !!!!!

Publications associées Réponses Vues Activité
4
nov. 23
3371
1
oct. 22
4035
2
mars 21
2571
1
mars 15
6102
1
mars 15
7015