Skip to Content
Odoo Меню
  • Увійти
  • Спробуйте це безкоштовно
  • Додатки
    Фінанси
    • Бухоблік
    • Виставлення рахунку
    • Витрати
    • Електронні таблиці (BI)
    • Документи
    • Підпис
    Продажі
    • CRM
    • Продажі
    • POS Магазин
    • POS Ресторан
    • Підписки
    • Оренда
    Веб-сайти
    • Конструктор веб-сайту
    • Електронна комерція
    • Блог
    • Форум
    • Живий чат
    • Електронне навчання
    Ланцюг поставок
    • Склад
    • Виробництво
    • PLM
    • Купівлі
    • Технічне обслуговування
    • Якість
    Кадри
    • Співробітники
    • Рекрутинг
    • Відпустки
    • Оцінювання
    • Рекомендації
    • Автотранспорт
    Маркетинг
    • Маркетинг соцмереж
    • Email-маркетинг
    • SMS-маркетинг
    • Події
    • Автом. маркетингу
    • Опитування
    Послуги
    • Проект
    • Табелі
    • Виїзне обслуговування
    • Служба підтримки
    • Планування
    • Призначення
    Продуктивність
    • Обговорення
    • Схвалення
    • IoT
    • IP-телефонія
    • База знань
    • WhatsApp
    Сторонні модулі Odoo Studio Платформа Odoo Cloud
  • Сфери
    Роздрібна торгівля
    • Книжковий магазин
    • Магазин одягу
    • Магазин меблів
    • Продуктовий магазин
    • Магазин будівельних матеріалів
    • Магазин іграшок
    Food & Hospitality
    • Бар та паб
    • Ресторан
    • Фастфуд
    • Guest House
    • Дистриб'ютор напоїв
    • Hotel
    Нерухомість
    • Real Estate Agency
    • Архітектурна фірма
    • Будівництво
    • Управління нерухомістю
    • Садівництво
    • Асоціація власників нерухомості
    Консалтинг
    • Бухгалтерська компанія
    • Партнер Odoo
    • Агенція маркетингу
    • Юридична фірма
    • Придбання Талантів
    • Аудит та сертифікація
    Виробництво
    • Textile
    • Metal
    • Меблі
    • Їжа
    • Brewery
    • Корпоративні подарунки
    Здоров'я & Фітнес
    • Спортивний клуб
    • Оптика
    • Фітнес-центр
    • Практики здоров'я
    • Аптека
    • Салон краси
    Trades
    • Ремонтник
    • IT-обладнання та Підтримка
    • Системи сонячної енергії
    • Shoe Maker
    • Cleaning Services
    • HVAC Services
    Інші
    • Nonprofit Organization
    • Екологічна агенція
    • Оренда білбордів
    • Фотографія
    • Лізинг велосипедів
    • Реселлер програмного забезпечення
    Browse all Industries
  • Спільнота
    Навчання
    • Навчальний посібник
    • Документація
    • Сертифікації
    • Тренування
    • Блог
    • Подкаст
    Сприяйте Освіті
    • Програма навчання
    • Бізнес гра Scale Up!
    • Відвідайте Odoo
    Отримайте програмне забезпечення
    • Завантаження
    • Порівняйте версії
    • Релізи
    Співпрацюйте
    • Github
    • Форум
    • Події
    • Переклади
    • Стати партнером
    • Services for Partners
    • Зареєструйте вашу бухгалтерську фірму
    Отримайте послуги
    • Знайдіть партнера
    • Знайдіть бухгалтера
    • Зустріньтеся з консультантом
    • Послуги з впровадження
    • Референси клієнтів
    • Підтримка
    • Оновлення
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Отримати демо
  • Ціни
  • Допомога

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

  • CRM
  • e-Commerce
  • Бухоблік
  • Склад
  • PoS
  • Проект
  • MRP
All apps
Вам необхідно зареєструватися, щоб взаємодіяти зі спільнотою.
All Posts Люди Значки
Мітки (View all)
odoo accounting v14 pos v15
Про цей форум
Вам необхідно зареєструватися, щоб взаємодіяти зі спільнотою.
All Posts Люди Значки
Мітки (View all)
odoo accounting v14 pos v15
Про цей форум
Допомога

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

Підписатися

Отримуйте сповіщення про активність щодо цієї публікації

Це запитання позначене
many2oneone2manyodoo10
3 Відповіді
4824 Переглядів
Аватар
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
Аватар
Відмінити
Аватар
Anil Kesariya
Найкраща відповідь

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
Аватар
Відмінити
Аватар
Hilar Andikkadavath
Найкраща відповідь

problem on your customer domain, field name.

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

1
Аватар
Відмінити
Аватар
Cayprol
Автор Найкраща відповідь

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
Аватар
Відмінити
Anil Kesariya

If the answer was helpful than accept it. :)

Cayprol
Автор

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
Автор

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
Автор

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!

Реєстрація
Related Posts Відповіді Переглядів Дія
How do I put One2many after Many2one defined? - transient module states reset
many2one one2many
Аватар
1
бер. 23
3267
Odoo Studio how to set a chain of multiple and related Many2one within a One2many lines
many2one one2many
Аватар
0
груд. 22
3872
One2many field odoo version 10
one2many odoo10
Аватар
Аватар
1
вер. 22
2892
filter according to comodel's fields
many2one one2many
Аватар
0
черв. 21
3544
How to display other fields of a onetomany relation ?
many2one one2many
Аватар
0
черв. 20
6404
Спільнота
  • Навчальний посібник
  • Документація
  • Форум
Open Source
  • Завантаження
  • Github
  • Runbot
  • Переклади
Послуги
  • Хостинг Odoo.sh
  • Підтримка
  • Оновлення
  • Кастомні доробки
  • Навчання
  • Знайдіть бухгалтера
  • Знайдіть партнера
  • Стати партнером
Про нас
  • Наша компанія
  • Торгові активи
  • Зв'яжіться з нами
  • Вакансії
  • Події
  • Подкаст
  • Блог
  • Клієнти
  • Юридичні документи • Конфіденційність
  • Безпека
الْعَرَبيّة 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 - це набір програм для роботи з відкритим кодом, які охоплюють всі ваші потреби компанії: CRM, електронна комерція, бухгалтерський облік, склад, точка продажу, управління проектами тощо.

Унікальна пропозиція Odoo - це одночасно дуже проста у використанні та повністю інтегрована.

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