From 1be721d5deddfda47c8dd6006c138c97b14df896 Mon Sep 17 00:00:00 2001 From: Thierry Ducrest Date: Wed, 29 May 2024 10:37:04 +0200 Subject: [PATCH] s_a_bill_auto_complete: add info in chatter When a vendor bill is auto completed from a shipment advice. Log the information with a ling to the shipment. --- .../models/account_move.py | 42 +++++++++++++++++++ 1 file changed, 42 insertions(+) diff --git a/shipment_advice_bill_auto_complete/models/account_move.py b/shipment_advice_bill_auto_complete/models/account_move.py index b4bd928c..d44122e9 100644 --- a/shipment_advice_bill_auto_complete/models/account_move.py +++ b/shipment_advice_bill_auto_complete/models/account_move.py @@ -100,3 +100,45 @@ def _get_purchase_quantity_from_stock_move_line(self, po_line, move_lines): if move_lines.product_id == po_line.product_id: quantity_done = sum(move_lines.mapped("qty_done")) return quantity_done + + @api.model_create_multi + def create(self, vals_list): + moves = super().create(vals_list) + for move in moves: + if move.move_type not in ("in_invoice", "out_refund"): + continue + shipment = move.line_ids.mapped("shipment_advice_id") + if not shipment: + continue + refs = [ + "%s" + % tuple(name_get) + for name_get in shipment.name_get() + ] + message = _("This vendor bill has been created from: %s") % ",".join(refs) + move.message_post(body=message) + return moves + + def write(self, vals): + old_shipment = { + move.id: move.mapped("line_ids.shipment_advice_id") for move in self + } + res = super().write(vals) + for move in self: + if move.move_type not in ("in_invoice", "out_refund"): + continue + new_shipment = move.mapped("line_ids.shipment_advice_id") + if not new_shipment: + continue + diff_shipments = new_shipment - old_shipment[move.id] + if diff_shipments: + refs = [ + "%s" + % tuple(name_get) + for name_get in diff_shipments.name_get() + ] + message = _("This vendor bill has been modified from: %s") % ",".join( + refs + ) + move.message_post(body=message) + return res