Skip to Content
Odoo Menú
  • Registra entrada
  • Prova-ho gratis
  • Aplicacions
    Finances
    • Comptabilitat
    • Facturació
    • Despeses
    • Full de càlcul (IA)
    • Documents
    • Signatura
    Vendes
    • CRM
    • Vendes
    • Punt de venda per a botigues
    • Punt de venda per a restaurants
    • Subscripcions
    • Lloguer
    Imatges de llocs web
    • Creació de llocs web
    • Comerç electrònic
    • Blog
    • Fòrum
    • Xat en directe
    • Aprenentatge en línia
    Cadena de subministrament
    • Inventari
    • Fabricació
    • PLM
    • Compres
    • Manteniment
    • Qualitat
    Recursos humans
    • Empleats
    • Reclutament
    • Absències
    • Avaluacions
    • Recomanacions
    • Flota
    Màrqueting
    • Màrqueting Social
    • Màrqueting per correu electrònic
    • Màrqueting per SMS
    • Esdeveniments
    • Automatització del màrqueting
    • Enquestes
    Serveis
    • Projectes
    • Fulls d'hores
    • Servei de camp
    • Suport
    • Planificació
    • Cites
    Productivitat
    • Converses
    • Validacions
    • IoT
    • VoIP
    • Coneixements
    • WhatsApp
    Aplicacions de tercers Odoo Studio Plataforma d'Odoo al núvol
  • Sectors
    Comerç al detall
    • Llibreria
    • Botiga de roba
    • Botiga de mobles
    • Botiga d'ultramarins
    • Ferreteria
    • Botiga de joguines
    Food & Hospitality
    • Bar i pub
    • Restaurant
    • Menjar ràpid
    • Guest House
    • Distribuïdor de begudes
    • Hotel
    Immobiliari
    • Agència immobiliària
    • Estudi d'arquitectura
    • Construcció
    • Gestió immobiliària
    • Jardineria
    • Associació de propietaris de béns immobles
    Consultoria
    • Empresa comptable
    • Partner d'Odoo
    • Agència de màrqueting
    • Bufet d'advocats
    • Captació de talent
    • Auditoria i certificació
    Fabricació
    • Textile
    • Metal
    • Mobles
    • Menjar
    • Brewery
    • Regals corporatius
    Salut i fitness
    • Club d'esport
    • Òptica
    • Centre de fitness
    • Especialistes en benestar
    • Farmàcia
    • Perruqueria
    Trades
    • Servei de manteniment
    • Hardware i suport informàtic
    • Sistemes d'energia solar
    • Shoe Maker
    • Serveis de neteja
    • Instal·lacions HVAC
    Altres
    • Nonprofit Organization
    • Agència del medi ambient
    • Lloguer de panells publicitaris
    • Fotografia
    • Lloguer de bicicletes
    • Distribuïdors de programari
    Browse all Industries
  • Comunitat
    Aprèn
    • Tutorials
    • Documentació
    • Certificacions
    • Formació
    • Blog
    • Pòdcast
    Potenciar l'educació
    • Programa educatiu
    • Scale-Up! El joc empresarial
    • Visita Odoo
    Obtindre el programari
    • Descarregar
    • Comparar edicions
    • Novetats de les versions
    Col·laborar
    • GitHub
    • Fòrum
    • Esdeveniments
    • Traduccions
    • Converteix-te en partner
    • Services for Partners
    • Registra la teva empresa comptable
    Obtindre els serveis
    • Troba un partner
    • Troba un comptable
    • Contacta amb un expert
    • Serveis d'implementació
    • Referències del client
    • Suport
    • Actualitzacions
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Programar una demo
  • Preus
  • Ajuda

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • CRM
  • e-Commerce
  • Comptabilitat
  • Inventari
  • PoS
  • Projectes
  • MRP
All apps
You need to be registered to interact with the community.
All Posts People Badges
Etiquetes (View all)
odoo accounting v14 pos v15
About this forum
You need to be registered to interact with the community.
All Posts People Badges
Etiquetes (View all)
odoo accounting v14 pos v15
About this forum
Ajuda

[V10]Adding Customer PID to 'product.template'

Subscriure's

Get notified when there's activity on this post

This question has been flagged
many2oneone2manyodoo10
3 Respostes
4877 Vistes
Avatar
Cayprol

Hi all, I just started developing Odoo.

My goals are

  1. Add multiple customer product ID to each product, because many clients of mine purchase the same item from me, but they all give it a different name.

  2. Display customer pid in table(column/row) as in each row be like, "Customer Name" | "Customer PID" | "Last update" .

From my understanding, this is done through adding a One2many field in the model 'product.template', so the form view 'product.product_template_only_form_view' can access this field.

I am able to add the desired format of view in my .xml file(mymodule_product_template.xml), and also add the One2many field named 'customer_pid' in my .py code(product.fields.py).

Image link: https://imgur.com/7ub92lb

But when I click on "Add an item", an error occurred.

Odoo Server Error
Traceback (most recent call last):
  File "/usr/lib/python2.7/dist-packages/odoo/http.py", line 640, in _handle_exception
    return super(JsonRequest, self)._handle_exception(exception)
  File "/usr/lib/python2.7/dist-packages/odoo/http.py", line 677, in dispatch
    result = self._call_function(**self.params)
  File "/usr/lib/python2.7/dist-packages/odoo/http.py", line 333, in _call_function
    return checked_call(self.db, *args, **kwargs)
  File "/usr/lib/python2.7/dist-packages/odoo/service/model.py", line 101, in wrapper
    return f(dbname, *args, **kwargs)
  File "/usr/lib/python2.7/dist-packages/odoo/http.py", line 326, in checked_call
    result = self.endpoint(*a, **kw)
  File "/usr/lib/python2.7/dist-packages/odoo/http.py", line 935, in __call__
    return self.method(*args, **kw)
  File "/usr/lib/python2.7/dist-packages/odoo/http.py", line 506, in response_wrap
    response = f(*args, **kw)
  File "/usr/lib/python2.7/dist-packages/odoo/addons/web/controllers/main.py", line 885, in call_kw
    return self._call_kw(model, method, args, kwargs)
  File "/usr/lib/python2.7/dist-packages/odoo/addons/web/controllers/main.py", line 877, in _call_kw
    return call_kw(request.env[model], method, args, kwargs)
  File "/usr/lib/python2.7/dist-packages/odoo/api.py", line 689, in call_kw
    return call_kw_multi(method, model, args, kwargs)
  File "/usr/lib/python2.7/dist-packages/odoo/api.py", line 680, in call_kw_multi
    result = method(recs, *args, **kwargs)
  File "/usr/lib/python2.7/dist-packages/odoo/models.py", line 5456, in onchange
    record = self.new(values)
  File "/usr/lib/python2.7/dist-packages/odoo/models.py", line 5030, in new
    record._cache.update(record._convert_to_cache(values, update=True))
  File "/usr/lib/python2.7/dist-packages/odoo/models.py", line 4909, in _convert_to_cache
    for name, value in values.iteritems()
  File "/usr/lib/python2.7/dist-packages/odoo/models.py", line 4910, in <dictcomp>
    if name in fields
  File "/usr/lib/python2.7/dist-packages/odoo/fields.py", line 1949, in convert_to_cache
    return process(record.env[self.comodel_name].new(value)._ids)
  File "/usr/lib/python2.7/dist-packages/odoo/models.py", line 5030, in new
    record._cache.update(record._convert_to_cache(values, update=True))
  File "/usr/lib/python2.7/dist-packages/odoo/models.py", line 4909, in _convert_to_cache
    for name, value in values.iteritems()
  File "/usr/lib/python2.7/dist-packages/odoo/models.py", line 4910, in <dictcomp>
    if name in fields
  File "/usr/lib/python2.7/dist-packages/odoo/fields.py", line 1780, in convert_to_cache
    raise ValueError("Wrong value for %s: %r" % (self, value))
ValueError: Wrong value for res.partner.type: u'consu'

I can hit "Ok" to by-pass the error but whatever I enter, it will become public user.  Seems like the default value will replace what I fill with this record regardlessly.


Here's my xml code

<?xml version="1.0" encoding="utf-8" ?>


<odoo>
 <data>
  <record model="ir.ui.view" id="product_description">
   <field name="model">product.template</field>
   <field name="name">product.template.product.form.mymodule</field>
         <field name="inherit_id" ref="product.product_template_only_form_view"></field>
   <field name="arch" type="xml">     <!-- Hide Field: Barcode -->
    <xpath expr="//field[@name='barcode']" position="replace">
     <field name="barcode" invisible="1" modifiers="{'invisible': true}"/>
    </xpath>

    <!-- Add Feild: Last Update -->
    <group name="group_general">
     <field name="__last_update" string="Last Update" modifiers="{'readonly': true}"/>
    </group>

    <!-- Add Customer Product ID table -->
    <xpath expr="//group[@name='sale_condition']" position="after">
     <separator string="Customer Info" colspan="4"/>
     <field name="customer_pid" nolabel="1" modifiers="{}">
      <tree>
       <field name="name"/>
       <field name="pid"/>
       <field name="__last_update"/>
      </tree>
     </field>
    </xpath>

    <!-- Add Product Description(Specs) & Re-layout -->
    <xpath expr="//group[@name='description']" position="replace">
     <group name="description">
      <separator string="Description for Product" colspan="4"/>
      <field name="description" colspan="4" nolabel="1" placeholder="Description of the Prodcut Specification" modifiers="{}"/>
      <separator string="Description for Quotations" colspan="4"/>
      <field name="description_sale" colspan="4" nolabel="1" placeholder="This note will be displayed on the quotations." modifiers="{}"/>
      <separator string="Description for Vendors" colspan="4"/>
      <field name="description_purchase" nolabel="1" placeholder="This note will be displayed on requests for quotation." colspan="4" modifiers="{}"/>
      <separator string="Description for Pickings" colspan="4"/>
      <field name="description_picking" placeholder="Description for Pickings (Rack, Row and Case Information)" nolabel="1" colspan="4" modifiers="{}"/>
     </group>
    </xpath>

   </field>
  </record>

 </data>
</odoo>

Here's my py code 

from odoo import models, fields, api

class ProductTemplateInherited(models.Model):
 _inherit = 'product.template'
 customer_pid = fields.One2many('product.customerinfo', 'name', string='Customer PID')

class ProductCustomerInfo(models.Model):
 _name = 'product.customerinfo'
 _description = 'Information about a product customer'
 name = fields.Many2one('res.partner', 'Customer', index=True, domain=[('customer', '=', True)], ondelete='restrict', required=True, help='Customer relates to this product')
 pid = fields.Char(string='Product ID', required=True)
 company_id = fields.Many2one('res.company', string='Company', default=lambda self: self.env.user.company_id.id, index=1)

Any help is much appreciated, thank you.

0
Avatar
Descartar
Avatar
Anil Kesariya
Best Answer

Hi Justin,

You need correction on your python code.

from odoo import models, fields, api

class ProductTemplateInherited(models.Model):
 _inherit = 'product.template'
 customer_pid = fields.One2many('product.customerinfo', 'product_template_id', string='Customer PID')

class ProductCustomerInfo(models.Model):
 _name = 'product.customerinfo'
 _description = 'Information about a product customer'
product_template_id = fields.Many2one("product.template", "Product")
 name = fields.Many2one('res.partner', 'Customer', index=True, domain=[('customer', '=', True)], ondelete='restrict', required=True, help='Customer relates to this product')
 pid = fields.Char(string='Product ID', required=True)
 company_id = fields.Many2one('res.company', string='Company', default=lambda self: self.env.user.company_id.id, index=1)

Note. : Whenever you take One2many field you need to take self model as Many2one field inside comodel.

Hope this will clear your idea about the One2many field.


Regards,

Anil.


2
Avatar
Descartar
Avatar
Hilar Andikkadavath
Best Answer

problem on your customer domain, field name.

instead of customer = true try customer 'is' true or exact partner type and value

1
Avatar
Descartar
Avatar
Cayprol
Autor Best Answer

I don't have enough karma to comment,

Thank you very much Anil.  Your solution works great and solve two problems at once.

In the end, I have, 1 One2many field in 'product.template', 2 Many2one fields in 'product.customerinfo'.
One of the two links back to the One2many in  'product.template' and the other remain the same linking to 'res.partner' with domain filtering for only customer.


Also, thx to Hilar, it turned out the domain filter was not the cause of problem.

1
Avatar
Descartar
Anil Kesariya

If the answer was helpful than accept it. :)

Cayprol
Autor

done, didn't know I could click on the check circle. Thanks.

Anil Kesariya

thanks.

Anil Kesariya

Do not display this field product_template_id on view. because this field value will be auto-updated when any new line will be added using add an item.

Cayprol
Autor

I understand. Should I do it in the xml or the py code?

I am thinking the best practice is to use context or attr to pass condition to hide product_template_id.

For now, I made it readonly=True, so when filling the record, the product field string is visible, but it's not editable. This is just a workaround.

By any change I can hide field "product_template_id" when filling the record, after saving it, I can still see this field by clicking on in each individual record?

Cayprol
Autor

Forgot to mention, by adding

context="{'default_product_tmpl_id': context.get('product_tmpl_id', active_id)}"

in the xml field context, will bring up the current active product as default, making product_template_id readonly would prevent it from being editable(it will be updated to the active item upon saving anyway)

Enjoying the discussion? Don't just read, join in!

Create an account today to enjoy exclusive features and engage with our awesome community!

Registrar-se
Related Posts Respostes Vistes Activitat
How do I put One2many after Many2one defined? - transient module states reset
many2one one2many
Avatar
1
de març 23
3302
Odoo Studio how to set a chain of multiple and related Many2one within a One2many lines
many2one one2many
Avatar
0
de des. 22
3910
One2many field odoo version 10
one2many odoo10
Avatar
Avatar
1
de set. 22
2931
filter according to comodel's fields
many2one one2many
Avatar
0
de juny 21
3563
How to display other fields of a onetomany relation ?
many2one one2many
Avatar
0
de juny 20
6449
Community
  • Tutorials
  • Documentació
  • Fòrum
Codi obert
  • Descarregar
  • GitHub
  • Runbot
  • Traduccions
Serveis
  • Allotjament a Odoo.sh
  • Suport
  • Actualització
  • Desenvolupaments personalitzats
  • Educació
  • Troba un comptable
  • Troba un partner
  • Converteix-te en partner
Sobre nosaltres
  • La nostra empresa
  • Actius de marca
  • Contacta amb nosaltres
  • Llocs de treball
  • Esdeveniments
  • Pòdcast
  • Blog
  • Clients
  • Informació legal • Privacitat
  • Seguretat
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

Odoo és un conjunt d'aplicacions empresarials de codi obert que cobreix totes les necessitats de la teva empresa: CRM, comerç electrònic, comptabilitat, inventari, punt de venda, gestió de projectes, etc.

La proposta única de valor d'Odoo és ser molt fàcil d'utilitzar i estar totalment integrat, ambdues alhora.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now