Odoo Help


many2many in custom wizard

on 7/17/13, 12:02 PM 2,769 views


In my custom wizard with different steps, I want to populate a m2m field defined on second step by selecting records with choice of first step... How can I do that in python code of action_choose ?

class account_change_lotnbr_wizard(osv.osv_memory):

def act_cancel(self, cr, uid, ids, context=None):
    #self.unlink(cr, uid, ids, context)
    return {'type':'ir.actions.act_window_close' }

def act_destroy(self, *args):
    return {'type':'ir.actions.act_window_close' }

def action_choose(self,cr,uid,ids,context=None):
    if not context:

    this = self.browse(cr, uid, ids)[0]

    # Contrôle pour recherche
    if not wizard.date_invoice:
        raise osv.except_osv(_('Error !'), _('No date !'))
    if not wizard.product_id:
        raise osv.except_osv(_('Error !'), _('No product !'))
    if not wizard.new_lot_nbr:
        raise osv.except_osv(_('Error !'), _('No new lot number !'))

    # Définition des objets
    invoice_obj = self.pool.get('account.invoice')

    # Recherche des factures à réaffecter
    inv_select_ids = []
    inv_ids = invoice_obj.search(cr, uid, [('date_invoice', '=', wizard.date_invoice), ('type', '=', 'out_invoice')])
    invs = invoice_obj.browse(cr, uid, inv_ids, context)
    for inv in invs:
        inv_select = False
        for line in inv.invoice_line:
            if line.product_id.id == wizard.product_id.id:
                inv_select = True
        if inv_select:

    # Mise à jour du wizard pour passer à l'étape suivante
    self.write(cr, uid, ids, {'state':'get'}, {'invoice_ids':inv_select_ids})

    return {
        'type': 'ir.actions.act_window',
        'res_model': 'iota.change.lotnbr.wizard',
        'view_mode': 'form',
        'view_type': 'form',
        'res_id': this.id,
        'views': [(False, 'form')],
        'target': 'new',

def action_confirm(self,cr,uid,ids,context=None):
    if not context:

    #this = self.browse(cr, uid, ids)[0]

    # Contrôle pour recherche
    if not wizard.invoice_ids:
        raise osv.except_osv(_('Error !'), _('No invoice !'))

    return {'type':'ir.actions.act_window_close' }

_columns = {
           'date_invoice': fields.date('Invoice Date'),
           'product_id': fields.many2one('product.product', 'Product'),
           'new_lot_nbr': fields.char('Lot number', size=15),
           'state': fields.selection( ( ('choose','choose'),
                                   ) ),

_defaults = {
    'date_invoice': fields.date.context_today,
    'state': lambda *a: 'choose',


E.g : In the first step, I give a date and product_id when I go to step 2, i want to obtain a list of invoices with a date and which have one line of product in invoice_ids field

About This Community

This platform is for beginners and experts willing to share their Odoo knowledge. It's not a forum to discuss ideas, but a knowledge base of questions and their answers.


Odoo Training Center

Access to our E-learning platform and experience all Odoo Apps through learning videos, exercises and Quizz.

Test it now

Question tools

1 follower(s)


Asked: 7/17/13, 12:02 PM
Seen: 2769 times
Last updated: 3/16/15, 8:10 AM