mirror of
https://github.com/OCA/pms.git
synced 2025-01-29 00:17:45 +02:00
[IMP] pms_api_rest: add filters in partner service
This commit is contained in:
committed by
Darío Lodeiros
parent
4a6430dd25
commit
08bc00d7df
@@ -8,9 +8,11 @@ class PmsPartnerSearchParam(Datamodel):
|
|||||||
_name = "pms.partner.search.param"
|
_name = "pms.partner.search.param"
|
||||||
_inherit = "pms.rest.metadata"
|
_inherit = "pms.rest.metadata"
|
||||||
id = fields.Integer(required=False, allow_none=True)
|
id = fields.Integer(required=False, allow_none=True)
|
||||||
vatNumber = fields.String(required=False, allow_none=True)
|
|
||||||
documentType = fields.Integer(required=False, allow_none=True)
|
documentType = fields.Integer(required=False, allow_none=True)
|
||||||
documentNumber = fields.String(required=False, allow_none=True)
|
documentNumber = fields.String(required=False, allow_none=True)
|
||||||
|
name = fields.String(required=False, allow_none=True)
|
||||||
|
housed = fields.Boolean(required=False, allow_none=True)
|
||||||
|
filter = fields.String(required=False, allow_none=True)
|
||||||
|
|
||||||
|
|
||||||
class PmsPartnerInfo(Datamodel):
|
class PmsPartnerInfo(Datamodel):
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ from datetime import datetime
|
|||||||
from odoo.addons.base_rest import restapi
|
from odoo.addons.base_rest import restapi
|
||||||
from odoo.addons.base_rest_datamodel.restapi import Datamodel
|
from odoo.addons.base_rest_datamodel.restapi import Datamodel
|
||||||
from odoo.addons.component.core import Component
|
from odoo.addons.component.core import Component
|
||||||
|
from odoo.odoo.osv import expression
|
||||||
|
|
||||||
|
|
||||||
class PmsPartnerService(Component):
|
class PmsPartnerService(Component):
|
||||||
@@ -26,7 +27,28 @@ class PmsPartnerService(Component):
|
|||||||
)
|
)
|
||||||
def get_partners(self, pms_partner_search_params):
|
def get_partners(self, pms_partner_search_params):
|
||||||
result_partners = []
|
result_partners = []
|
||||||
|
domain_fields = []
|
||||||
|
|
||||||
|
if pms_partner_search_params.name:
|
||||||
|
domain_fields.append(("name", "ilike", pms_partner_search_params.name))
|
||||||
|
if pms_partner_search_params.housed:
|
||||||
|
partners_housed = self.env["pms.checkin.partner"].search([("state", "=", "onboard")]).mapped(
|
||||||
|
"partner_id")
|
||||||
|
domain_fields.append(("id", "in", partners_housed.ids))
|
||||||
|
domain_filter = list()
|
||||||
|
if pms_partner_search_params.filter:
|
||||||
|
for search in pms_partner_search_params.filter.split(" "):
|
||||||
|
subdomains = [
|
||||||
|
[("name", "ilike", search)],
|
||||||
|
[("firstname", "ilike", search)],
|
||||||
|
[("lastname", "ilike", search)],
|
||||||
|
]
|
||||||
|
domain_filter.append(expression.OR(subdomains))
|
||||||
domain = []
|
domain = []
|
||||||
|
if domain_filter:
|
||||||
|
domain = expression.AND([domain_fields, domain_filter[0]])
|
||||||
|
else:
|
||||||
|
domain = domain_fields
|
||||||
PmsPartnerResults = self.env.datamodels["pms.partner.results"]
|
PmsPartnerResults = self.env.datamodels["pms.partner.results"]
|
||||||
PmsPartnerInfo = self.env.datamodels["pms.partner.info"]
|
PmsPartnerInfo = self.env.datamodels["pms.partner.info"]
|
||||||
total_partners = self.env["res.partner"].search_count(domain)
|
total_partners = self.env["res.partner"].search_count(domain)
|
||||||
|
|||||||
Reference in New Issue
Block a user