İçereği Atla
Odoo Menü
  • Portal
  • Ücretsiz deneyin
  • Uygulamalar
    Finans
    • Muhasebe
    • Faturalama
    • Masraf Yönetimi
    • Elektronik Çizelge (BI)
    • Belgeler
    • İmza
    Satış
    • Müşteri İlişkileri Yönetimi (CRM)
    • Satış
    • Satış Noktası Mağaza
    • Satış Noktası Restoran
    • Abonelikler
    • Kiralama
    Web Sitesi
    • Web Sitesi Oluşturucu
    • eTicaret
    • Blog
    • Forum
    • Canlı Sohbet
    • eÖğrenme
    Tedarik Zinciri
    • Envanter
    • Üretim
    • Ürün Yaşam Döngüsü Yönetimi
    • Satın Alma
    • Bakım
    • Kalite
    İnsan Kaynakları
    • Çalışanlar
    • İşe Alım
    • İzin
    • Değerlendirme
    • Referans
    • Filo Yönetimi
    Pazarlama
    • Sosyal Medyada Pazarlama
    • E-posta ile Pazarlama
    • SMS ile Pazarlama
    • Etkinlikler
    • Pazarlama Otomasyonu
    • Anket
    Hizmetler
    • Proje Yönetimi
    • Çalışma Çizelgeleri
    • Saha Hizmeti
    • Yardım Masası
    • Planlama
    • Randevular
    Verimlilik
    • Sohbet
    • Onay
    • Nesnelerin İnterneti
    • VoIP
    • Bilgi Bankası
    • WhatsApp
    Üçüncü taraf uygulamalar Odoo Stüdyo Odoo Bulut Platformu
  • Sektörler
    Perakende satış
    • Kitapçı
    • Giyim Mağazası
    • Mobilya Mağazası
    • Gıda Marketi
    • Hırdavat Dükkanı
    • Oyuncak Dükkanı
    Gıda ve Konaklama
    • Bar ve Pub
    • Restoran
    • Fast Food Restoranı
    • Konuk Evi
    • İçecek Distribütörü
    • Otel
    Gayrimenkul
    • Emlak Acentesi
    • Mimarlık Firması
    • İnşaat
    • Emlak Yönetimi
    • Bahçe Tasarımı
    • Mülk Sahipleri Derneği
    Uzmanlık
    • Muhasebe Firması
    • Odoo Partner
    • Pazarlama Ajansı
    • Hukuk Firması
    • Yetenek Kazanımı
    • Denetim ve Belgelendirme
    Üretim
    • Tekstil
    • Metal
    • Mobilyalar
    • Gıda
    • Bira fabrikası
    • Kurumsal Hediye
    Sağlık ve Spor
    • Spor Kulübü
    • Optik Mağazası
    • Fitness Merkezi
    • Sağlıklı Yaşam Merkezi
    • Eczane
    • Kuaför Salonu
    Ticaret
    • Tamirci
    • BT Donanım & Destek
    • Güneş Enerjisi Sistemleri
    • Ayakkabı İmalatçısı
    • Temizlik Hizmetleri
    • HVAC Hizmetleri
    Diğerleri
    • Kar Amacı Gütmeyen Kuruluş
    • Çevre Ajansı
    • Reklam Panosu Kiralama
    • Fotoğrafçılık
    • Bisiklet Kiralama
    • Yazılım Bayisi
    Tüm Sektörlere Göz Atın
  • Topluluk
    Öğrenim
    • Eğitim Araçları
    • Dokümantasyon
    • Sertifikasyonlar
    • Eğitim Etkinlikleri
    • Blog
    • Podcast
    Eğitim ve Gelişim
    • Eğitim Programı
    • Scale Up! İşletme Oyunu
    • Odoo'yu Ziyaret Edin
    Yazılım
    • İndirin
    • Sürümleri Kıyaslayın
    • Sürümler
    İş Birliği
    • Github
    • Forum
    • Etkinlikler
    • Çeviriler
    • Partner Olun
    • Partnerler için Hizmetler
    • Muhasebe Firmanızı Kaydettirin
    Hizmetler
    • Partner Bulun
    • Muhasebeci Bulun
    • Bir danışmanla görüşün
    • Kurulum Hizmetleri
    • Müşteri Referansları
    • Destek
    • Sürüm Yükseltme
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Demo randevusu alın
  • Fiyatlandırma
  • Yardım

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

  • Müşteri İlişkileri Yönetimi
  • e-Commerce
  • Muhasebe
  • Envanter
  • PoS
  • Proje Yönetimi
  • MRP
All apps
You need to be registered to interact with the community.
All Posts People Badges
Etiketler (View all)
odoo accounting v14 pos v15
About this forum
You need to be registered to interact with the community.
All Posts People Badges
Etiketler (View all)
odoo accounting v14 pos v15
About this forum
Yardım

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

Abone Ol

Get notified when there's activity on this post

Bu soru işaretlendi
wizardcontextactive_idpopulateodoo10
4 Cevaplar
18970 Görünümler
Avatar
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
Avatar
Vazgeç
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
Üretici

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
Üretici

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.

Avatar
Bérengère Bouillon
Üretici En İyi Yanıt

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
Avatar
Vazgeç
Avatar
Shameem Babu
En İyi Yanıt

It is related question :

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


0
Avatar
Vazgeç
Enjoying the discussion? Don't just read, join in!

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

Üye Ol
İlgili Gönderiler Cevaplar Görünümler Aktivite
Call a wizard, in context pass an id. Not recognized Çözüldü
wizard context odoo10
Avatar
1
Ağu 19
5239
Update Wizard without closing it after button click
wizard odoo10
Avatar
0
Eki 23
2608
How to save the values of fields ?
wizard odoo10
Avatar
Avatar
Avatar
4
Eki 18
9466
Is it possible to create a new record with wizard? Çözüldü
wizard odoo10
Avatar
Avatar
Avatar
3
Haz 18
7783
active_domain not found in context when using wizard
wizard context
Avatar
0
Ağu 17
4231
Topluluk
  • Eğitim Araçları
  • Dokümantasyon
  • Forum
Açık Kaynak
  • İndirin
  • Github
  • Runbot
  • Çeviriler
Hizmetler
  • Odoo.sh Hosting
  • Destek
  • Sürüm Yükseltme
  • Özel Geliştirmeler
  • Eğitim
  • Muhasebeci Bulun
  • Partner Bulun
  • Partner Olun
Hakkında
  • Şirketimiz
  • Pazarlama Gereçleri
  • İletişim
  • Kariyer
  • Etkinlikler
  • Podcast
  • Blog
  • Müşteriler
  • Hukuki • Gizlilik
  • Güvenlik
الْعَرَبيّة 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, müşteri ilişkileri yönetimi, eTicaret, muhasebe, envanter, satış noktası, proje yönetimi gibi şirketinizin tüm ihtiyaçlarını karşılayan bir açık kaynak işletme uygulamaları paketidir.

Odoo’nun eşsiz değer önermesi, aynı anda hem kullanımının çok kolay olup hem de tamamen entegre olmasıdır.

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