diff --git a/rma/models/rma_order.py b/rma/models/rma_order.py index 75eac9cb..9330a783 100644 --- a/rma/models/rma_order.py +++ b/rma/models/rma_order.py @@ -89,7 +89,11 @@ class RmaOrder(models.Model): description = fields.Text() comment = fields.Text("Additional Information") date_rma = fields.Datetime( - string="Order Date", index=True, default=lambda self: self._default_date_rma() + compute="_compute_date_rma", + inverse="_inverse_date_rma", + string="Order Date", + index=True, + default=lambda self: self._default_date_rma(), ) partner_id = fields.Many2one( comodel_name="res.partner", string="Partner", required=True @@ -192,6 +196,26 @@ class RmaOrder(models.Model): self.in_route_id = self.operation_default_id.in_route_id self.out_route_id = self.operation_default_id.out_route_id + @api.depends("rma_line_ids.date_rma") + def _compute_date_rma(self): + """If all order line have same date set date_rma. + If no lines, respect value given by the user. + """ + for rma in self: + if rma.rma_line_ids: + date_rma = rma.rma_line_ids[0].date_rma or False + for rma_line in rma.rma_line_ids: + if rma_line.date_rma != date_rma: + date_rma = False + break + rma.date_rma = date_rma + + def _inverse_date_rma(self): + """When set date_rma set date_rma on all order lines""" + for po in self: + if po.date_rma: + po.rma_line_ids.write({"date_rma": po.date_rma}) + @api.constrains("partner_id", "rma_line_ids") def _check_partner_id(self): if self.rma_line_ids and self.partner_id != self.mapped( diff --git a/rma/models/rma_order_line.py b/rma/models/rma_order_line.py index be10aeb4..f631ace2 100644 --- a/rma/models/rma_order_line.py +++ b/rma/models/rma_order_line.py @@ -217,6 +217,10 @@ class RmaOrderLine(models.Model): for rec in self.filtered(lambda r: r.type == "supplier"): rec.rma_line_count = len(rec.customer_rma_id) + @api.model + def _default_date_rma(self): + return fields.Datetime.now() + delivery_address_id = fields.Many2one( comodel_name="res.partner", string="Partner delivery address", @@ -248,6 +252,9 @@ class RmaOrderLine(models.Model): states={"draft": [("readonly", False)]}, help="Reference of the document that produced this rma.", ) + date_rma = fields.Datetime( + string="Order Date", index=True, default=lambda self: self._default_date_rma() + ) state = fields.Selection( selection=[ ("draft", "Draft"), diff --git a/rma/views/rma_order_line_view.xml b/rma/views/rma_order_line_view.xml index 19898c41..f96de63c 100644 --- a/rma/views/rma_order_line_view.xml +++ b/rma/views/rma_order_line_view.xml @@ -19,6 +19,7 @@ /> + @@ -47,6 +48,7 @@ /> + @@ -191,6 +193,7 @@ + @@ -392,6 +395,7 @@ +