[FIX] rma_purchase: name_search migration

This commit is contained in:
AaronHForgeFlow
2024-05-07 18:03:27 +02:00
committed by JasminSForgeFlow
parent ef3c219a8f
commit 48260dac20

View File

@@ -2,70 +2,57 @@
# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html) # License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html)
from odoo import api, fields, models from odoo import api, fields, models
from odoo.osv import expression
class PurchaseOrderLine(models.Model): class PurchaseOrderLine(models.Model):
_inherit = "purchase.order.line" _inherit = "purchase.order.line"
_rec_names_search = ["name", "order_id"]
rma_line_id = fields.Many2one( rma_line_id = fields.Many2one(
comodel_name="rma.order.line", comodel_name="rma.order.line",
string="RMA", string="RMA",
) )
@api.model def _name_search(self, name, domain=None, operator="ilike", limit=None, order=None):
def name_search(self, name="", args=None, operator="ilike", limit=100): domain = domain or []
"""Allows to search by PO reference.""" if self.env.context.get("rma"):
if not args: domain = expression.AND([domain, [("display_type", "=", False)]])
args = [] lines = self.search([("order_id.name", operator, name)] + domain, limit=limit)
args += [ if limit:
"|", limit_rest = limit - len(lines)
(self._rec_name, operator, name), else:
("order_id.name", operator, name), # limit can be 0 or None representing infinite
] limit_rest = limit
return super().name_search(name=name, args=args, operator=operator, limit=limit) if limit_rest or not limit:
domain += [("id", "in", lines.ids)]
return super()._name_search(
name, domain=domain, operator=operator, limit=limit_rest, order=order
)
return self._search(domain, limit=limit, order=order)
@api.model def _get_purchase_line_rma_name_get_label(self):
def _name_search( self.ensure_one()
self, name="", args=None, operator="ilike", limit=100, name_get_uid=None return "PO:{} | INV: {}, | PART:{} | QTY:{}".format(
): self.order_id.name,
"""Typed text is cleared here for better extensibility.""" " ".join(str(x) for x in [inv.name for inv in self.order_id.invoice_ids]),
return super()._name_search( self.product_id.name,
name="", self.product_uom_qty,
args=args,
operator=operator,
limit=limit,
name_get_uid=name_get_uid,
) )
def name_get(self): def _compute_display_name(self):
res = [] if not self.env.context.get("rma"):
if self.env.context.get("rma"): return super()._compute_display_name()
for purchase in self: for purchase_line in self:
invoices = self.env["account.move.line"].search( for purchase_line in self:
[("purchase_line_id", "=", purchase.id)] if purchase_line.order_id.name:
) purchase_line.display_name = (
if purchase.order_id.name: purchase_line._get_purchase_line_rma_name_get_label()
res.append(
(
purchase.id,
"{} {} {} qty:{}".format(
purchase.order_id.name,
" ".join(
str(x)
for x in [
inv.name for inv in invoices.mapped("move_id")
]
),
purchase.product_id.name,
purchase.product_qty,
),
)
) )
else: else:
res.append(super(PurchaseOrderLine, purchase).name_get()[0]) return super(
return res PurchaseOrderLine, purchase_line
else: )._compute_display_name()
return super().name_get()
@api.model_create_multi @api.model_create_multi
def create(self, vals_list): def create(self, vals_list):