Hoppa till innehåll
Odoo Meny
  • Logga in
  • Prova gratis
  • Appar
    Ekonomi
    • Bokföring
    • Fakturering
    • Utgifter
    • Kalkylark (Affärsanalyser)
    • Dokument
    • Underskrifter
    Försäljning
    • CRM
    • Försäljning
    • Kassasystem Butik
    • Kassasystem Restaurang
    • Prenumerationer
    • Uthyrning
    Hemsida
    • Hemsidesverktyg
    • E-handel
    • Blogg
    • Forum
    • Livechatt
    • Utbildning
    Försörjningskedja
    • Lager
    • Produktion
    • Produktens livscykel (PLM)
    • Inköp
    • Underhåll
    • Kvalitet
    HR
    • Anställda
    • Rekrytering
    • Ledighet
    • Utvärderingar
    • Rekommendationer
    • Fordon
    Marknadsföring
    • Sociala medier
    • E-postmarknadsföring
    • Sms-marknadsföring
    • Evenemang
    • Automatiserad marknadsföring
    • Enkäter
    Tjänster
    • Projekt
    • Tidrapporter
    • Fältservice
    • Kundtjänst
    • Planering
    • Tidsbokningar
    Produktivitet
    • Diskutera
    • AI
    • IoT
    • VoIP
    • Kunskap
    • WhatsApp
    Community-appar Odoo Studio Odoo Cloud
  • Branscher
    Butiker
    • Bokaffärer
    • Klädbutiker
    • Möbelaffärer
    • Mataffärer
    • Byggvaruhus
    • Leksaksaffärer
    Restaurang & Hotell
    • Barer och pubar
    • Restauranger
    • Snabbmatsrestauranger
    • Gästhus
    • Dryckesdistributörer
    • Hotell
    Fastigheter
    • Fastighetsbyråer
    • Arkitektfirmor
    • Byggföretag
    • Fastighetsägare
    • Trädgårdsmästare
    • Bostadsrättsföreningar
    Hitta en konsult
    • Redovisningsbyrå
    • Odoo Partner
    • Reklambyråer
    • Advokatbyråer
    • Rekrytering
    • Revisioner och certifieringar
    Produktion
    • Textilproduktion
    • Metallproduktion
    • Möbelproduktion
    • Livsmedelsproduktion
    • Bryggerier
    • Företagsgåvor
    Hälsa och fitness
    • Sportklubbar
    • Optiker
    • Träningscenter
    • Friskvård
    • Apotek
    • Frisörsalonger
    Hantverk
    • Hantverkare
    • IT-utrustning och kundtjänst
    • Solceller, solpaneler och solenergi
    • Skomakare
    • Städföretag
    • VVS-tjänster
    Övrigt
    • Ideella föreningar
    • Miljöförvaltningar
    • Uthyrning av reklamtavlor
    • Fotografer
    • Cykeluthyrning
    • Återförsäljare av mjukvara
    Upptäck alla Branscher
  • Community
    Utbildning
    • Instruktionsvideor
    • Dokumentation
    • Certifiering
    • Utbildningar
    • Blogg
    • Podcast
    Lär dig med oss
    • Workshops
    • Företagsspelet Scale Up!
    • Studiebesök hos Odoo
    Mjukvaran
    • Ladda ner
    • Jämför utgåvor
    • Versionsinformation
    Samverkan
    • GitHub
    • Forum
    • Evenemang
    • Översättningar
    • Bli en partner
    • Partnertjänster
    • Registrera din redovisningsbyrå
    Våra tjänster
    • Partners
    • Revisorer
    • Träffa en rådgivare
    • Implementering
    • Kundrecensioner
    • Kundtjänst
    • Uppgraderingar
    GitHub Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Boka en demo
  • Priser
  • Hjälp
Du måste vara registrerad för att kunna interagera med communityn.
Alla inlägg Personer Utmärkelser
Etiketter (Visa alla)
odoo accounting v14 pos v15
Om detta forum
Du måste vara registrerad för att kunna interagera med communityn.
Alla inlägg Personer Utmärkelser
Etiketter (Visa alla)
odoo accounting v14 pos v15
Om detta forum
Hjälp

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

Prenumerera

Få ett meddelande när det finns aktivitet på detta inlägg

Denna fråga har flaggats
many2oneone2manyodoo10
3 Svar
6010 Vyer
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
Avbryt
Avatar
Anil Kesariya
Bästa svar

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
Avbryt
Avatar
Hilar Andikkadavath
Bästa svar

problem on your customer domain, field name.

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

1
Avatar
Avbryt
Avatar
Cayprol
Författare Bästa svar

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
Avbryt
Anil Kesariya

If the answer was helpful than accept it. :)

Cayprol
Författare

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
Författare

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
Författare

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)

Njuter du av diskussionen? Läs inte bara, delta också!

Skapa ett konto idag för att ta del av exklusiva funktioner och engagera dig i vår fantastiska community!

Registrera dig
Relaterade inlägg Svar Vyer Verksamhet
How do I put One2many after Many2one defined? - transient module states reset
many2one one2many
Avatar
1
mars 23
4787
Odoo Studio how to set a chain of multiple and related Many2one within a One2many lines
many2one one2many
Avatar
0
dec. 22
5438
One2many field odoo version 10
one2many odoo10
Avatar
Avatar
1
sep. 22
3878
filter according to comodel's fields
many2one one2many
Avatar
0
juni 21
4692
How to display other fields of a onetomany relation ?
many2one one2many
Avatar
0
juni 20
8084
Community
  • Instruktionsvideor
  • Dokumentation
  • Forum
Öppen källkod
  • Ladda ner
  • GitHub
  • Runbot
  • Översättningar
Tjänster
  • Odoo.sh Hosting
  • Kundtjänst
  • Uppgradera
  • Anpassningsbara modifikationer
  • Utbildning
  • Revisorer
  • Partners
  • Bli en partner
Om oss
  • Vårt företag
  • Varumärkestillgångar
  • Kontakta oss
  • Jobb
  • Evenemang
  • Podcast
  • Blogg
  • Kunder
  • Juridiskt • Integritet
  • Säkerhet
الْعَرَبيّة 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 Svenska ภาษาไทย Türkçe українська Tiếng Việt

Odoo är ett affärssystem med öppen källkod som täcker alla dina företagsbehov: CRM, e-handel, bokföring, lager, kassasystem, projektledning, och så vidare.

Odoos unika värdeförslag är att samtidigt vara väldigt enkel att använda men också helt integrerad.

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