# -*- coding: utf-8 -*- # Part of Odoo. See LICENSE file for full copyright and licensing details. from odoo import api, models, fields class PurchaseOrder(models.Model): _inherit = 'purchase.order' dropship_picking_count = fields.Integer("Dropship Count", compute='_compute_incoming_picking_count') @api.depends('picking_ids.is_dropship') def _compute_incoming_picking_count(self): super()._compute_incoming_picking_count() for order in self: dropship_count = len(order.picking_ids.filtered(lambda p: p.is_dropship)) order.incoming_picking_count -= dropship_count order.dropship_picking_count = dropship_count def action_view_picking(self): return self._get_action_view_picking(self.picking_ids.filtered(lambda p: not p.is_dropship)) def action_view_dropship(self): return self._get_action_view_picking(self.picking_ids.filtered(lambda p: p.is_dropship)) class PurchaseOrderLine(models.Model): _inherit = 'purchase.order.line' def _prepare_stock_moves(self, picking): res = super(PurchaseOrderLine, self)._prepare_stock_moves(picking) for re in res: re['sale_line_id'] = self.sale_line_id.id return res def _find_candidate(self, product_id, product_qty, product_uom, location_id, name, origin, company_id, values): # if this is defined, this is a dropshipping line, so no # this is to correctly map delivered quantities to the so lines lines = self.filtered(lambda po_line: po_line.sale_line_id.id == values['sale_line_id']) if values.get('sale_line_id') else self return super(PurchaseOrderLine, lines)._find_candidate(product_id, product_qty, product_uom, location_id, name, origin, company_id, values) @api.model def _prepare_purchase_order_line_from_procurement(self, product_id, product_qty, product_uom, company_id, values, po): res = super()._prepare_purchase_order_line_from_procurement(product_id, product_qty, product_uom, company_id, values, po) res['sale_line_id'] = values.get('sale_line_id', False) return res