mirror of
https://github.com/ForgeFlow/stock-rma.git
synced 2025-01-21 12:57:49 +02:00
[FIX] rma_purchase: name_search migration
This commit is contained in:
committed by
JasminSForgeFlow
parent
ef3c219a8f
commit
48260dac20
@@ -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):
|
||||||
|
|||||||
Reference in New Issue
Block a user