From 51fba116260a329cb4d01d0da63a6650a987bf2d Mon Sep 17 00:00:00 2001 From: Lois Rilo Date: Fri, 13 May 2022 15:15:36 +0200 Subject: [PATCH 1/2] [IMP] rma: add RMA reference to delivery slip report --- rma/__manifest__.py | 1 + rma/report/report_deliveryslip.xml | 57 ++++++++++++++++++++++++++++++ 2 files changed, 58 insertions(+) create mode 100644 rma/report/report_deliveryslip.xml diff --git a/rma/__manifest__.py b/rma/__manifest__.py index 7ac0c7e0..386e3c64 100644 --- a/rma/__manifest__.py +++ b/rma/__manifest__.py @@ -32,6 +32,7 @@ "wizards/rma_make_picking_view.xml", "wizards/rma_add_stock_move_view.xml", "wizards/rma_order_line_make_supplier_rma_view.xml", + "report/report_deliveryslip.xml", ], "installable": True, "application": True, diff --git a/rma/report/report_deliveryslip.xml b/rma/report/report_deliveryslip.xml new file mode 100644 index 00000000..7bf86cf2 --- /dev/null +++ b/rma/report/report_deliveryslip.xml @@ -0,0 +1,57 @@ + + + + + + + + + From 58e43ae0e39940b266ede0122303cf7b88c4373f Mon Sep 17 00:00:00 2001 From: Lois Rilo Date: Mon, 23 May 2022 18:39:20 +0200 Subject: [PATCH 2/2] [IMP] rma: add rma lines to group selecting serial numbers --- rma/__manifest__.py | 1 + rma/report/report_deliveryslip.xml | 24 ----- rma/security/ir.model.access.csv | 14 +++ rma/wizards/__init__.py | 4 +- rma/wizards/rma_add_serial.py | 137 +++++++++++++++++++++++++++ rma/wizards/rma_add_serial_views.xml | 100 +++++++++++++++++++ 6 files changed, 253 insertions(+), 27 deletions(-) create mode 100644 rma/wizards/rma_add_serial.py create mode 100644 rma/wizards/rma_add_serial_views.xml diff --git a/rma/__manifest__.py b/rma/__manifest__.py index 386e3c64..d10724bf 100644 --- a/rma/__manifest__.py +++ b/rma/__manifest__.py @@ -33,6 +33,7 @@ "wizards/rma_add_stock_move_view.xml", "wizards/rma_order_line_make_supplier_rma_view.xml", "report/report_deliveryslip.xml", + "wizards/rma_add_serial_views.xml", ], "installable": True, "application": True, diff --git a/rma/report/report_deliveryslip.xml b/rma/report/report_deliveryslip.xml index 7bf86cf2..13154ff2 100644 --- a/rma/report/report_deliveryslip.xml +++ b/rma/report/report_deliveryslip.xml @@ -30,28 +30,4 @@ - - - - diff --git a/rma/security/ir.model.access.csv b/rma/security/ir.model.access.csv index e899b9c9..3643627b 100644 --- a/rma/security/ir.model.access.csv +++ b/rma/security/ir.model.access.csv @@ -9,3 +9,17 @@ access_rma_operation_manager,access_rma_operation,model_rma_operation,group_rma_ access_rma_operation_customer_user,access_rma_operation,model_rma_operation,group_rma_customer_user,1,0,0,0 access_rma_operation_supplier_user,access_rma_operation,model_rma_operation,group_rma_supplier_user,1,0,0,0 access_rma_order_line_user,access_rma_order_line,model_rma_order_line,base.group_user,1,0,0,0 +access_rma_picking_wizard,rma.order.manager,model_rma_make_picking_wizard,group_rma_manager,1,1,1,1 +access_rma_picking_wizard_customer,rma.order.manager,model_rma_make_picking_wizard,group_rma_customer_user,1,1,1,1 +access_rma_picking_wizard_supplier,rma.order.manager,model_rma_make_picking_wizard,group_rma_supplier_user,1,1,1,1 +access_rma_picking_wizard_item,rma.order.manager,model_rma_make_picking_wizard_item,group_rma_manager,1,1,1,1 +access_rma_picking_wizard_item_customer,rma.order.manager,model_rma_make_picking_wizard_item,group_rma_customer_user,1,1,1,1 +access_rma_picking_wizard_item_supplier,rma.order.manager,model_rma_make_picking_wizard_item,group_rma_supplier_user,1,1,1,1 +access_rma_order_line_make_supplier_rma_customer_user,rma.order.line.make.supplier.rma.customer.user,model_rma_order_line_make_supplier_rma,rma.group_rma_customer_user,1,1,1,1 +access_rma_order_line_make_supplier_rmasupplier_user,rma.order.line.make.supplier.rma.supplier.user,model_rma_order_line_make_supplier_rma,rma.group_rma_supplier_user,1,1,1,1 +access_rma_order_line_make_supplier_rma_customer_user_item,rma.order.line.make.supplier.rma.item.customer.user,model_rma_order_line_make_supplier_rma_item,rma.group_rma_customer_user,1,1,1,1 +access_rma_order_line_make_supplier_rmasupplier_user_item,rma.order.line.make.supplier.rma.item.supplier.user,model_rma_order_line_make_supplier_rma_item,rma.group_rma_supplier_user,1,1,1,1 +access_rma_add_stock_move_customer_user_item,rma.add.stock.move.customer.user,model_rma_add_stock_move,rma.group_rma_customer_user,1,1,1,1 +access_rma_add_stock_move_supplier_user_item,rma.add.stock.move.supplier.user,model_rma_add_stock_move,rma.group_rma_supplier_user,1,1,1,1 +access_rma_add_serial_wiz_customer,access_rma_add_serial_wiz_customer,model_rma_add_serial_wiz,rma.group_rma_customer_user,1,1,1,1 +access_rma_add_serial_wiz_supplier,access_rma_add_serial_wiz_supplier,model_rma_add_serial_wiz,rma.group_rma_supplier_user,1,1,1,1 diff --git a/rma/wizards/__init__.py b/rma/wizards/__init__.py index 6d5e9355..7989b077 100644 --- a/rma/wizards/__init__.py +++ b/rma/wizards/__init__.py @@ -1,6 +1,4 @@ -# Copyright (C) 2017-20 ForgeFlow S.L. -# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html) - from . import rma_add_stock_move from . import rma_make_picking from . import rma_order_line_make_supplier_rma +from . import rma_add_serial diff --git a/rma/wizards/rma_add_serial.py b/rma/wizards/rma_add_serial.py new file mode 100644 index 00000000..7f142cdb --- /dev/null +++ b/rma/wizards/rma_add_serial.py @@ -0,0 +1,137 @@ +# Copyright 2022 ForgeFlow S.L. +# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html) + +from odoo import _, api, fields, models +from odoo.exceptions import ValidationError + + +class RmaAddSerialWiz(models.TransientModel): + _name = "rma.add.serial.wiz" + _description = "Wizard to add rma lines from Serial/Lot numbers" + + rma_id = fields.Many2one( + comodel_name="rma.order", string="RMA Order", readonly=True, ondelete="cascade" + ) + partner_id = fields.Many2one( + comodel_name="res.partner", string="Partner", readonly=True + ) + partner_shipping_id = fields.Many2one( + string="Deliver To", + comodel_name="res.partner", + ) + lot_ids = fields.Many2many( + comodel_name="stock.production.lot", + string="Lots/Serials selected", + ) + + @api.model + def default_get(self, fields_list): + res = super().default_get(fields_list) + rma_obj = self.env["rma.order"] + rma_id = self.env.context["active_ids"] or [] + active_model = self.env.context["active_model"] + if not rma_id: + return res + assert active_model == "rma.order", "Bad context propagation" + + rma = rma_obj.browse(rma_id) + res["rma_id"] = rma.id + res["partner_id"] = rma.partner_id.id + return res + + @api.onchange("partner_id") + def onchange_partner_id(self): + if not self.partner_id: + self.update( + { + "partner_shipping_id": False, + } + ) + return + + self = self.with_company(self.rma_id.company_id) + addr = self.partner_id.address_get(["delivery"]) + self.update( + { + "partner_shipping_id": addr["delivery"], + } + ) + + def _prepare_rma_line_from_lot_vals(self, lot): + if self.env.context.get("customer"): + operation = ( + lot.product_id.rma_customer_operation_id + or lot.product_id.categ_id.rma_customer_operation_id + ) + else: + operation = ( + lot.product_id.rma_supplier_operation_id + or lot.product_id.categ_id.rma_supplier_operation_id + ) + if not operation: + operation = self.env["rma.operation"].search( + [("type", "=", self.rma_id.type)], limit=1 + ) + if not operation: + raise ValidationError(_("Please define an operation first")) + + if not operation.in_route_id or not operation.out_route_id: + route = self.env["stock.location.route"].search( + [("rma_selectable", "=", True)], limit=1 + ) + if not route: + raise ValidationError(_("Please define an RMA route")) + + if not operation.in_warehouse_id or not operation.out_warehouse_id: + warehouse = self.env["stock.warehouse"].search( + [ + ("company_id", "=", self.rma_id.company_id.id), + ("lot_rma_id", "!=", False), + ], + limit=1, + ) + if not warehouse: + raise ValidationError( + _("Please define a warehouse with a default RMA location") + ) + + product_qty = 1 # serial + if lot.product_id.tracking == "lot": + # TODO: improve logic, allow to specify qty? + product_qty = 1 + + vals = { + "partner_id": self.partner_id.id, + "product_id": lot.product_id.id, + "lot_id": lot.id, + "uom_id": lot.product_id.uom_id.id, + "operation_id": operation.id, + "product_qty": product_qty, + "delivery_address_id": self.partner_shipping_id.id or self.partner_id.id, + "rma_id": self.rma_id.id, + "receipt_policy": operation.receipt_policy, + "delivery_policy": operation.delivery_policy, + "in_warehouse_id": operation.in_warehouse_id.id or warehouse.id, + "out_warehouse_id": operation.out_warehouse_id.id or warehouse.id, + "in_route_id": operation.in_route_id.id or route.id, + "out_route_id": operation.out_route_id.id or route.id, + "location_id": ( + operation.location_id.id + or operation.in_warehouse_id.lot_rma_id.id + or warehouse.lot_rma_id.id + ), + } + return vals + + def action_confirm(self): + rma_line_obj = self.env["rma.order.line"] + existing_lots = self.rma_id.mapped("rma_line_ids.lot_id") + for lot in self.lot_ids: + if lot in existing_lots: + raise ValidationError( + _("Lot/Serial Number %s already added.") % lot.name + ) + + vals = self._prepare_rma_line_from_lot_vals(lot) + rma_line_obj.create(vals) + return {"type": "ir.actions.act_window_close"} diff --git a/rma/wizards/rma_add_serial_views.xml b/rma/wizards/rma_add_serial_views.xml new file mode 100644 index 00000000..bd03e5a3 --- /dev/null +++ b/rma/wizards/rma_add_serial_views.xml @@ -0,0 +1,100 @@ + + + + rma.add.serial.wiz.customer + rma.add.serial.wiz + +
+ + + + + + +
+
+ +
+
+ + + Add from Lot/Serial Numbers + ir.actions.act_window + rma.add.serial.wiz + form + new + + + + + + + rma.order.form - rma.add.serial.wiz + rma.order + + + +