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
Про цей форум
Допомога

Odoo 10 Wizard: How to populate with active fields from parent view

Підписатися

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

Це запитання позначене
wizardcontextactive_idpopulateodoo10
4 Відповіді
18926 Переглядів
Аватар
Bérengère Bouillon

Hello,


I'm stuck to populate a wizard and I'm completely lost on the way to do that.

Until know, I've created a custom button on the stock module, view_picking_form record with an inherited model (see views.xml). I also know how to create a custom wizard (wizard.py wizard.xml).

But what I do not know is how to populate it with the list of products fields (product_id, product_qty, qty_done) that are linked to the active view. I'm working with the new API on Odoo 10 and couln't find the method to do that. Odoo always tells me it doesn't know the fields I want to pass and they don't display on the wizard.

Can anyone help me on that please ?


views.xml

<?xml version="1.0" encoding="utf-8"?>
    <odoo>
        <data>
            <record id="view_picking_form_inherit" model="ir.ui.view">
                <field name="name">stock.picking.form.inherit</field>
                <field name="model">stock.picking</field>
                <field name="inherit_id" ref="stock.view_picking_form"/>
                <field name="arch" type="xml">

                    <xpath expr="//form/sheet/h1[@class='hidden-xs']" position="inside">
                        <div class="oe_right oe_button_box">

                            <button string="Open Wizard" name="%(action_wizard)d"
                                    type="action" class="oe_button oe_form_button oe_highlight"
                                    context="{'default_active_id': active_id}"/> </div> </xpath> </field> </record> </data> </odoo>


wizard.py

# -*- coding: utf-8 -*-
from odoo import _, api, fields, models

class MyClass(models.TransientModel):
    _name = 'stock.picking.wizard'
    _inherit = ['stock.picking', 'stock.pack.operation'] 

    @api.multi
def _default_products(self):
self.ensure_one()
active_id = self.env.context.get('active_ids', []) or []
record = self.env['stock.picking'].browse(active_id)
return record.product_id product_id
= fields.Many2one('product.product', string='Product', default=_default_products)


wizard.xml

<?xml version="1.0" encoding="utf-8"?>
<odoo>
    <data>
        <record id="view_wizard" model="ir.ui.view">
            <field name="name">stock_picking_wizard</field>
            <field name="model">stock.picking.wizard</field>
            <field name="arch" type="xml">
                <form string="Stock Products">
                    <tree string="Product list">
                        <field name="product_id"/>
                    </tree>
                </form>
            </field>
        </record>

        <record id="action_wizard" model="ir.actions.act_window">
            <field name="name">Wizard</field>
            <field name="type">ir.actions.act_window</field>
            <field name="res_model">stock.picking.wizard</field>
            <field name="view_type">form</field>
            <field name="view_mode">form</field>
            <field name="view_id" ref="view_wizard"/>
            <field name="target">new</field>
        </record>
    </data>
</odoo>


0
Аватар
Відмінити
Niyas Raphy (Walnut Software Solutions)

Hi Bérengère Bouillon,

I didn't understand what exactly you are looking for, as far as i undestood do you want to add all the product into the new field you have created in the wizard from the active stock picking lines ?

Bérengère Bouillon
Автор

Hi Niyas Raphy,

Yes it's that. When I'm on an available transfert, I need to retrieve all the products of the active record in my wizard.

Niyas Raphy (Walnut Software Solutions)

Hi , you can make it a many to many field, ie the product field in the wizard. Then you can write the products from the stock picking lines into it.

link : https://stackoverflow.com/questions/31853402/filling-many2many-field-odoo-8

Bérengère Bouillon
Автор

Thanks Niyas, but I don't understand how a many2many relation could be useful in this situation. Maybe I didn't explained well. The goal is to get the active view informations (included the product_id, product_qty,...) and pass them into the wizard to get the same products I had in the previous view (but only these ones). The lead I found to do that was to get the context through the active_id, but I didn't manage to do it for know.

Аватар
Bérengère Bouillon
Автор Найкраща відповідь

I managed to do something by creating the wizard in the models.py :

models.py

@api.multi
    def open_wizard2(self):
        view = self.env.ref('my_module.view_custom_wizard')
        wiz = self.env['stock.picking.wizard'].create({'picky_id': self.id})
        return {
            'name': _('Create wizard'),
            'type': 'ir.actions.act_window',
            'view_type': 'form',
            'view_mode': 'form',
            'res_model': 'stock.picking.wizard',
            'views': [(view.id, 'form')],
            'view_id': view.id,
            'target': 'new',
            'res_id': wiz.id,
            'context': self.env.context,
        }

wizard.py

class MyWizard(models.TransientModel):
    _name = 'stock.picking.wizard'
    _inherit = ['stock.picking', 'stock.pack.operation']

    picky_id = fields.Many2one('stock.picking')

    @api.model
    def default_get(self, fields):
        res = super(MyWizard, self).default_get(fields)
        if 'picky_id' in fields and self._context.get('active_id') and not res.get('picky_id'):
            res = {'picky_id': self._context['active_id']}
        return res


With this method I saw that I get most of the context, but there is still some fields missing like the location_id which gives me a validation Error. Can you tell me if I'm using the wright solution and why I'm getting this error ?

The operation cannot be completed, probably due to the following:
- deletion: you may be trying to delete a record while other records still reference it
- creation/update: a mandatory field is not correctly set
[object with reference: location_id - location.id]
db_1    | ERROR:  null value in column "location_id" violates not-null constraint
db_1    | DETAIL:  Failing row contains (5, null, null, null, null, f, f, 0.000, null, null, null, null, direct, null, 1, null, null, 0.000, , null, 1, 1, 0.000, t, null, null, null, f, 2017-06-08 08:26:59.126366, 2017-06-08 08:26:59, /, null, null, 2017-06-08 08:26:59.126366, null, null, null, null, 25).
db_1    | STATEMENT:  INSERT INTO "stock_picking_wizard" ("id", "body", "product_qty", "name", "move_type", "fresh_record", "company_id", "picky_id", "location_dest_id", "ordered_qty", "launch_pack_operations", "qty_done", "date", "printed", "location_id", "recompute_pack_op", "create_uid", "write_uid", "create_date", "write_date") VALUES(nextval('stock_picking_wizard_id_seq'), '', '0.000', '/', 'direct', true, 1, 25, NULL, '0.000', false, '0.000', '2017-06-08 08:26:59', false, NULL, false, 1, 1, (now() at time zone 'UTC'), (now() at time zone 'UTC')) RETURNING id
web_1   | 2017-06-08 08:26:59,133 1 INFO odoo10db odoo.sql_db: bad query: INSERT INTO "stock_picking_wizard" ("id", "body", "product_qty", "name", "move_type", "fresh_record", "company_id", "picky_id", "location_dest_id", "ordered_qty", "launch_pack_operations", "qty_done", "date", "printed", "location_id", "recompute_pack_op", "create_uid", "write_uid", "create_date", "write_date") VALUES(nextval('stock_picking_wizard_id_seq'), '', '0.000', '/', 'direct', true, 1, 25, NULL, '0.000', false, '0.000', '2017-06-08 08:26:59', false, NULL, false, 1, 1, (now() at time zone 'UTC'), (now() at time zone 'UTC')) RETURNING id



0
Аватар
Відмінити
Аватар
Shameem Babu
Найкраща відповідь

It is related question :

https://www.odoo.com/forum/help-1/question/110946 


0
Аватар
Відмінити
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 Відповіді Переглядів Дія
Call a wizard, in context pass an id. Not recognized Вирішено
wizard context odoo10
Аватар
1
серп. 19
5226
Update Wizard without closing it after button click
wizard odoo10
Аватар
0
жовт. 23
2581
How to save the values of fields ?
wizard odoo10
Аватар
Аватар
Аватар
4
жовт. 18
9441
Is it possible to create a new record with wizard? Вирішено
wizard odoo10
Аватар
Аватар
Аватар
3
черв. 18
7771
active_domain not found in context when using wizard
wizard context
Аватар
0
серп. 17
4181
Спільнота
  • Навчальний посібник
  • Документація
  • Форум
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