Skip to Content
Menu
This question has been flagged
3 Replies
4557 Zobrazenia

i created many2many field in (mrp.bom model) that select multiply product from product.template based on boolean filed must be True,

i need to created many2one field in (mrp.production model) that select one record form selected product in many2many field in mrp.bom model

any idea how to do that ?

Avatar
Zrušiť
Best Answer

Hi  loay elhaj,


You can use domain to filter the Many2one field,

product_ids = fields.Many2many('product.template')


product_id = fields.Many2one('product.template' , domain=[('id', 'in', product_ids.ids)])

where product_ids is the many2many field and product_id is the Many2one field. 


Hope it Helps,

Kiran K


Avatar
Zrušiť
Autor

but the product_ids and product_id in different models

Autor

in mrp.bom is many2many and my other field that should be many2one in mrp.production

Then Try,

product_id = fields.Many2one('product.template' , domain=[('id', 'in', bom_id.product_ids.ids)])

Autor

i've update the question see it again plz

Add Many2one field in mrp.production with domain

product_id = fields.Many2one('product.template' , domain=[('id', 'in', bom_id.product_ids.ids)])

Autor

error raised
packing = fields.Many2one('product.template', domain=[('id', 'in', bom_id.product_ids.id)])
AttributeError: 'Many2one' object has no attribute 'product_ids' - - -

Best Answer

I solved this issue by returning many2one field domain depending on many2many field results on changing the desired field. Like following:

@api.onchange('product_id')
def _onchange_product_alternative_domain(self):
for line in self:
if line.product_id:
return {'domain': {'alternative_product_id': [('id', 'in', line.product_id.alternative_product_ids.ids)]}}

Here alternative_product_ids is many2many field.

Avatar
Zrušiť
Autor Best Answer

Error raised
ValueError: Invalid domain term ('id', 'in', 'bom_id.product_ids.ids')

Avatar
Zrušiť
Related Posts Replies Zobrazenia Aktivita
4
jún 24
14858
2
feb 25
5829
1
dec 24
1403
1
nov 22
15921
3
aug 22
12907