From 109a52d98b0c9581ef6422568cfabd8ff5090ad4 Mon Sep 17 00:00:00 2001 From: Jacques-Etienne Baudoux Date: Fri, 17 Jan 2025 14:38:32 +0100 Subject: [PATCH] despatch_advice_import: fix processing - Fix cancellation of backorder moves with stock_picking_restrict_cancel_printed module - Always skip backorder wizard when validating the picking - Don't call validate when all moves are canceled --- despatch_advice_import/__manifest__.py | 3 ++- .../wizard/despatch_advice_import.py | 18 +++++++++++------- 2 files changed, 13 insertions(+), 8 deletions(-) diff --git a/despatch_advice_import/__manifest__.py b/despatch_advice_import/__manifest__.py index cb879e543c..8cd8545288 100644 --- a/despatch_advice_import/__manifest__.py +++ b/despatch_advice_import/__manifest__.py @@ -8,7 +8,8 @@ "version": "16.0.1.2.0", "website": "https://github.com/OCA/edi", "license": "AGPL-3", - "author": "ACSONE SA/NV,Odoo Community Association (OCA)", + "author": "ACSONE SA/NV,BCIM,Odoo Community Association (OCA)", + "maintainers": ["jbaudoux"], "depends": ["purchase", "purchase_stock", "base_business_document_import"], "data": ["security/ir.model.access.csv", "wizard/despatch_advice_import.xml"], "demo": [], diff --git a/despatch_advice_import/wizard/despatch_advice_import.py b/despatch_advice_import/wizard/despatch_advice_import.py index 17a64b672e..17255a846c 100644 --- a/despatch_advice_import/wizard/despatch_advice_import.py +++ b/despatch_advice_import/wizard/despatch_advice_import.py @@ -202,11 +202,11 @@ def process_data(self, parsed_order_document): self._process_picking_done(lines[0].move_ids[0]) def _process_picking_done(self, move): - if all([line.quantity_done != 0 for line in move.picking_id.move_ids]): - move.picking_id.button_validate() - else: - picking = move.picking_id - picking.with_context(skip_backorder=True).button_validate() + picking = move.picking_id + if all(line.state == "cancel" for line in picking.move_ids): + return True + # skip backorder wizard + picking.with_context(skip_backorder=True).button_validate() def _process_rejected(self, stock_moves, parsed_order_document): parsed_order_document["chatter_msg"] = parsed_order_document.get( @@ -216,7 +216,9 @@ def _process_rejected(self, stock_moves, parsed_order_document): _("Delivery cancelled by the supplier.") ) - stock_moves._action_cancel() + # stock_picking_restrict_cancel_printed module checks we are + # canceling the backorder to allow move cancellation + stock_moves.with_context(cancel_backorder=True)._action_cancel() def _process_accepted(self, stock_moves, parsed_order_document, forced_qty=False): parsed_order_document["chatter_msg"] = ( @@ -296,7 +298,9 @@ def _process_conditional(self, moves, parsed_order_document, line): # cancel moves to cancel if move_ids_to_cancel: moves_to_cancel = self.env["stock.move"].browse(move_ids_to_cancel) - moves_to_cancel._action_cancel() + # stock_picking_restrict_cancel_printed module checks we are + # canceling the backorder to allow move cancellation + moves_to_cancel.with_context(cancel_backorder=True)._action_cancel() # move backorder moves to a backorder if move_ids_to_backorder: moves_to_backorder = self.env["stock.move"].browse(move_ids_to_backorder)