Skip to Content
Menu
This question has been flagged
2 Replies
5336 Views

When I try to add same product multiple time in sale order line, how can I merge all of them in a same sale order line by increasing the quantity only?

Avatar
Discard
Author

Thank you.

Best Answer

Try with this code.

---------------------------------------------------------

def merge_duplicate_product_lines(self, res):
for line in res.order_line:
if line.id in res.order_line.ids:
line_ids = res.order_line.filtered(lambda m: m.product_id.id == line.product_id.id)
quantity = 0
for qty in line_ids:
quantity += qty.product_uom_qty
line_ids[0].write({'product_uom_qty': quantity,
'order_id': line_ids[0].order_id.id})
line_ids[1:].unlink()

@api.model
def create(self, vals):
res = super(SaleOrder, self).create(vals)
res.merge_duplicate_product_lines(res)

return res

def write(self, vals):
res = super(SaleOrder, self).write(vals)
self.merge_duplicate_product_lines(self)
return res

Avatar
Discard
Author

Thank you brother . it's working .

Related Posts Replies Views Activity
0
Jun 23
1942
1
Dec 22
3232
0
Apr 22
2457
1
Apr 19
6141
2
Jul 25
3723