Skip to Content
Odoo Menu
  • Prijavi
  • Try it free
  • Aplikacije
    Finance
    • Knjigovodstvo
    • Obračun
    • Stroški
    • Spreadsheet (BI)
    • Dokumenti
    • Podpisovanje
    Prodaja
    • CRM
    • Prodaja
    • POS Shop
    • POS Restaurant
    • Naročnine
    • Najem
    Spletne strani
    • Website Builder
    • Spletna trgovina
    • Blog
    • Forum
    • Pogovor v živo
    • eUčenje
    Dobavna veriga
    • Zaloga
    • Proizvodnja
    • PLM
    • Nabava
    • Vzdrževanje
    • Kakovost
    Kadri
    • Kadri
    • Kadrovanje
    • Odsotnost
    • Ocenjevanja
    • Priporočila
    • Vozni park
    Marketing
    • Družbeno Trženje
    • Email Marketing
    • SMS Marketing
    • Dogodki
    • Avtomatizacija trženja
    • Ankete
    Storitve
    • Projekt
    • Časovnice
    • Storitve na terenu
    • Služba za pomoč
    • Načrtovanje
    • Termini
    Produktivnost
    • Razprave
    • Odobritve
    • IoT
    • Voip
    • Znanje
    • WhatsApp
    Third party apps Odoo Studio Odoo Cloud Platform
  • Industrije
    Trgovina na drobno
    • Book Store
    • Trgovina z oblačili
    • Trgovina s pohištvom
    • Grocery Store
    • Trgovina s strojno opremo računalnikov
    • Trgovina z igračami
    Food & Hospitality
    • Bar and Pub
    • Restavracija
    • Hitra hrana
    • Guest House
    • Beverage Distributor
    • Hotel
    Nepremičnine
    • Real Estate Agency
    • Arhitekturno podjetje
    • Gradbeništvo
    • Estate Management
    • Vrtnarjenje
    • Združenje lastnikov nepremičnin
    Svetovanje
    • Računovodsko podjetje
    • Odoo Partner
    • Marketinška agencija
    • Law firm
    • Pridobivanje talentov
    • Audit & Certification
    Proizvodnja
    • Tekstil
    • Metal
    • Pohištvo
    • Hrana
    • Brewery
    • Poslovna darila
    Health & Fitness
    • Športni klub
    • Trgovina z očali
    • Fitnes center
    • Wellness Practitioners
    • Lekarna
    • Frizerski salon
    Trades
    • Handyman
    • IT Hardware & Support
    • Sistemi sončne energije
    • Izdelovalec čevljev
    • Čistilne storitve
    • HVAC Services
    Ostali
    • Neprofitna organizacija
    • Agencija za okolje
    • Najem oglasnih panojev
    • Fotografija
    • Najem koles
    • Prodajalec programske opreme
    Browse all Industries
  • Skupnost
    Learn
    • Tutorials
    • Dokumentacija
    • Certifikati
    • Šolanje
    • Blog
    • Podcast
    Empower Education
    • Education Program
    • Scale Up! Business Game
    • Visit Odoo
    Get the Software
    • Prenesi
    • Compare Editions
    • Releases
    Collaborate
    • Github
    • Forum
    • Dogodki
    • Prevodi
    • Become a Partner
    • Services for Partners
    • Register your Accounting Firm
    Get Services
    • Find a Partner
    • Find an Accountant
    • Meet an advisor
    • Implementation Services
    • Sklici kupca
    • Podpora
    • Upgrades
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Get a demo
  • Določanje cen
  • Pomoč

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

  • CRM
  • e-Commerce
  • Knjigovodstvo
  • Zaloga
  • PoS
  • Projekt
  • MRP
All apps
You need to be registered to interact with the community.
All Posts People Badges
Ključne besede (View all)
odoo accounting v14 pos v15
About this forum
You need to be registered to interact with the community.
All Posts People Badges
Ključne besede (View all)
odoo accounting v14 pos v15
About this forum
Pomoč

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

Naroči se

Get notified when there's activity on this post

This question has been flagged
many2oneone2manyodoo10
3 Odgovori
4808 Prikazi
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
Opusti
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
Opusti
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
Opusti
Avatar
Cayprol
Avtor 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
Opusti
Anil Kesariya

If the answer was helpful than accept it. :)

Cayprol
Avtor

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
Avtor

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
Avtor

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!

Prijavi
Related Posts Odgovori Prikazi Aktivnost
How do I put One2many after Many2one defined? - transient module states reset
many2one one2many
Avatar
1
mar. 23
3258
Odoo Studio how to set a chain of multiple and related Many2one within a One2many lines
many2one one2many
Avatar
0
dec. 22
3855
One2many field odoo version 10
one2many odoo10
Avatar
Avatar
1
sep. 22
2879
filter according to comodel's fields
many2one one2many
Avatar
0
jun. 21
3540
How to display other fields of a onetomany relation ?
many2one one2many
Avatar
0
jun. 20
6391
Community
  • Tutorials
  • Dokumentacija
  • Forum
Open Source
  • Prenesi
  • Github
  • Runbot
  • Prevodi
Services
  • Odoo.sh Hosting
  • Podpora
  • Nadgradnja
  • Custom Developments
  • Izobraževanje
  • Find an Accountant
  • Find a Partner
  • Become a Partner
About us
  • Our company
  • Sredstva blagovne znamke
  • Kontakt
  • Zaposlitve
  • Dogodki
  • Podcast
  • Blog
  • Stranke
  • Pravno • Zasebnost
  • Varnost
الْعَرَبيّة 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 is a suite of open source business apps that cover all your company needs: CRM, eCommerce, accounting, inventory, point of sale, project management, etc.

Odoo's unique value proposition is to be at the same time very easy to use and fully integrated.

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