Passa al contenuto
Odoo Menu
  • Accedi
  • Provalo gratis
  • App
    Finanze
    • Contabilità
    • Fatturazione
    • Note spese
    • Fogli di calcolo (BI)
    • Documenti
    • Firma
    Vendite
    • CRM
    • Vendite
    • Punto vendita Negozio
    • Punto vendita Ristorante
    • Abbonamenti
    • Noleggi
    Siti web
    • Configuratore sito web
    • E-commerce
    • Blog
    • Forum
    • Live chat
    • E-learning
    Supply chain
    • Magazzino
    • Produzione
    • PLM
    • Acquisti
    • Manutenzione
    • Qualità
    Risorse umane
    • Dipendenti
    • Assunzioni
    • Ferie
    • Valutazioni
    • Referral dipendenti
    • Parco veicoli
    Marketing
    • Social marketing
    • E-mail marketing
    • SMS marketing
    • Eventi
    • Marketing automation
    • Sondaggi
    Servizi
    • Progetti
    • Fogli ore
    • Assistenza sul campo
    • Helpdesk
    • Pianificazione
    • Appuntamenti
    Produttività
    • Comunicazioni
    • Approvazioni
    • IoT
    • VoIP
    • Knowledge
    • WhatsApp
    App di terze parti Odoo Studio Piattaforma cloud Odoo
  • Settori
    Retail
    • Libreria
    • Negozio di abbigliamento
    • Negozio di arredamento
    • Alimentari
    • Ferramenta
    • Negozio di giocattoli
    Cibo e ospitalità
    • Bar e pub
    • Ristorante
    • Fast food
    • Pensione
    • Grossista di bevande
    • Hotel
    Agenzia immobiliare
    • Agenzia immobiliare
    • Studio di architettura
    • Edilizia
    • Gestione immobiliare
    • Impresa di giardinaggio
    • Associazione di proprietari immobiliari
    Consulenza
    • Società di contabilità
    • Partner Odoo
    • Agenzia di marketing
    • Studio legale
    • Selezione del personale
    • Audit e certificazione
    Produzione
    • Tessile
    • Metallo
    • Arredamenti
    • Alimentare
    • Birrificio
    • Ditta di regalistica aziendale
    Benessere e sport
    • Club sportivo
    • Negozio di ottica
    • Centro fitness
    • Centro benessere
    • Farmacia
    • Parrucchiere
    Commercio
    • Tuttofare
    • Hardware e assistenza IT
    • Ditta di installazione di pannelli solari
    • Calzolaio
    • Servizi di pulizia
    • Servizi di climatizzazione
    Altro
    • Organizzazione non profit
    • Ente per la tutela ambientale
    • Agenzia di cartellonistica pubblicitaria
    • Studio fotografico
    • Punto noleggio di biciclette
    • Rivenditore di software
    Carica tutti i settori
  • Community
    Apprendimento
    • Tutorial
    • Documentazione
    • Certificazioni 
    • Formazione
    • Blog
    • Podcast
    Potenzia la tua formazione
    • Programma educativo
    • Scale Up! Business Game
    • Visita Odoo
    Ottieni il software
    • Scarica
    • Versioni a confronto
    • Note di versione
    Collabora
    • Github
    • Forum
    • Eventi
    • Traduzioni
    • Diventa nostro partner
    • Servizi per partner
    • Registra la tua società di contabilità
    Ottieni servizi
    • Trova un partner
    • Trova un contabile
    • Incontra un esperto
    • Servizi di implementazione
    • Testimonianze dei clienti
    • Supporto
    • Aggiornamenti
    GitHub Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Richiedi una demo
  • Prezzi
  • Aiuto

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

  • CRM
  • e-Commerce
  • Contabilità
  • Magazzino
  • PoS
  • Progetti
  • MRP
All apps
È necessario essere registrati per interagire con la community.
Tutti gli articoli Persone Badge
Etichette (Mostra tutto)
odoo accounting v14 pos v15
Sul forum
È necessario essere registrati per interagire con la community.
Tutti gli articoli Persone Badge
Etichette (Mostra tutto)
odoo accounting v14 pos v15
Sul forum
Assistenza

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

Iscriviti

Ricevi una notifica quando c'è un'attività per questo post

La domanda è stata contrassegnata
wizardcontextactive_idpopulateodoo10
4 Risposte
18935 Visualizzazioni
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
Abbandona
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
Autore

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
Autore

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
Autore Risposta migliore

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
Abbandona
Avatar
Shameem Babu
Risposta migliore

It is related question :

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


0
Avatar
Abbandona
Ti stai godendo la conversazione? Non leggere soltanto, partecipa anche tu!

Crea un account oggi per scoprire funzionalità esclusive ed entrare a far parte della nostra fantastica community!

Registrati
Post correlati Risposte Visualizzazioni Attività
Call a wizard, in context pass an id. Not recognized Risolto
wizard context odoo10
Avatar
1
ago 19
5227
Update Wizard without closing it after button click
wizard odoo10
Avatar
0
ott 23
2584
How to save the values of fields ?
wizard odoo10
Avatar
Avatar
Avatar
4
ott 18
9442
Is it possible to create a new record with wizard? Risolto
wizard odoo10
Avatar
Avatar
Avatar
3
giu 18
7774
active_domain not found in context when using wizard
wizard context
Avatar
0
ago 17
4189
Community
  • Tutorial
  • Documentazione
  • Forum
Open source
  • Scarica
  • Github
  • Runbot
  • Traduzioni
Servizi
  • Hosting Odoo.sh
  • Supporto
  • Aggiornamenti
  • Sviluppi personalizzati
  • Formazione
  • Trova un contabile
  • Trova un partner
  • Diventa nostro partner
Chi siamo
  • La nostra azienda
  • Branding
  • Contattaci
  • Lavora con noi
  • Eventi
  • Podcast
  • Blog
  • Clienti
  • Note legali • Privacy
  • Sicurezza
الْعَرَبيّة 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 è un gestionale di applicazioni aziendali open source pensato per coprire tutte le esigenze della tua azienda: CRM, Vendite, E-commerce, Magazzino, Produzione, Fatturazione elettronica, Project Management e molto altro.

Il punto di forza di Odoo è quello di offrire un ecosistema unico di app facili da usare, intuitive e completamente integrate tra loro.

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