Files
pms/pms_api_rest/services/pms_folio_service.py

257 lines
11 KiB
Python

from datetime import datetime
from odoo.osv import expression
from odoo.addons.base_rest import restapi
from odoo.addons.base_rest_datamodel.restapi import Datamodel
from odoo.addons.component.core import Component
class PmsFolioService(Component):
_inherit = "base.rest.service"
_name = "pms.folio.service"
_usage = "folios"
_collection = "pms.services"
@restapi.method(
[
(
[
"/",
],
"GET",
)
],
input_param=Datamodel("pms.folio.search.param"),
output_param=Datamodel("pms.folio.info", is_list=True),
auth="jwt_api_pms",
)
def get_folios(self, folio_search_param):
domain_fields = list()
domain_fields.append(("pms_property_id", "=", folio_search_param.pmsPropertyId))
if folio_search_param.dateTo and folio_search_param.dateFrom:
reservation_lines = (
self.env["pms.reservation.line"]
.search(
[
("date", ">=", folio_search_param.dateFrom),
("date", "<", folio_search_param.dateTo),
]
)
.mapped("reservation_id")
.mapped("folio_id")
.ids
)
domain_fields.append(("folio_id", "in", reservation_lines))
domain_filter = list()
if folio_search_param.filter:
for search in folio_search_param.filter.split(" "):
subdomains = [
[("name", "ilike", search)],
[("folio_id.name", "ilike", search)],
[("partner_name", "ilike", search)],
[("partner_id.firstname", "ilike", search)],
[("partner_id.lastname", "ilike", search)],
[("partner_id.id_numbers.name", "ilike", search)],
]
domain_filter.append(expression.OR(subdomains))
domain = []
if domain_filter:
domain = expression.AND([domain_fields, domain_filter[0]])
else:
domain = domain_fields
result_folios = []
reservations_result = (
self.env["pms.reservation"].search(domain).mapped("folio_id").ids
)
PmsFolioInfo = self.env.datamodels["pms.folio.info"]
for folio in self.env["pms.folio"].search(
[("id", "in", reservations_result)],
):
result_folios.append(
PmsFolioInfo(
id=folio.id,
name=folio.name,
partnerName=folio.partner_name if folio.partner_name else "",
partnerPhone=folio.mobile if folio.mobile else "",
partnerEmail=folio.email if folio.email else "",
saleChannel=folio.channel_type_id.name
if folio.channel_type_id
else "",
agency=folio.agency_id.name if folio.agency_id else "",
state=dict(folio.fields_get(["state"])["state"]["selection"])[
folio.state
],
pendingAmount=folio.pending_amount,
salesPerson=folio.user_id.name if folio.user_id else "",
paymentState=dict(
folio.fields_get(["payment_state"])["payment_state"][
"selection"
]
)[folio.payment_state]
if folio.payment_state
else "",
propertyId=folio.pms_property_id,
agencyImage=folio.agency_id.image_1024 if folio.agency_id else "",
)
)
return result_folios
@restapi.method(
[
(
[
"/<int:id>/payments",
],
"GET",
)
],
input_param=Datamodel("pms.search.param"),
output_param=Datamodel("pms.payment.info", is_list=True),
auth="jwt_api_pms",
)
def get_folio_payments(self, folio_id, pms_search_param):
domain = list()
domain.append(("id", "=", folio_id))
domain.append(("pms_property_id", "=", pms_search_param.pmsPropertyId))
folio = self.env["pms.folio"].search(domain)
payments = []
PmsPaymentInfo = self.env.datamodels["pms.payment.info"]
if not folio:
pass
else:
if folio.payment_state == "not_paid":
pass
# si el folio está sin pagar no tendrá ningún pago o envíar []?
else:
if folio.statement_line_ids:
for payment in folio.statement_line_ids:
payments.append(
PmsPaymentInfo(
id=payment.id,
amount=payment.amount,
journalId=payment.journal_id,
journalName=payment.journal_id.name,
date=str(payment.date),
)
)
if folio.payment_ids:
if folio.payment_ids:
for payment in folio.payment_ids:
payments.append(
PmsPaymentInfo(
id=payment.id,
amount=payment.amount,
journalId=payment.journal_id,
journalName=payment.journal_id.name,
date=str(payment.date),
)
)
return payments
@restapi.method(
[
(
[
"/<int:id>/reservations",
],
"GET",
)
],
output_param=Datamodel("pms.reservation.info", is_list=True),
auth="jwt_api_pms",
)
def get_folio_reservations(self, folio_id):
folio = self.env["pms.folio"].browse(folio_id)
reservations = []
PmsReservationInfo = self.env.datamodels["pms.reservation.info"]
if not folio:
pass
else:
if folio.reservation_ids:
for reservation in folio.reservation_ids:
reservations.append(
PmsReservationInfo(
id=reservation.id,
name=reservation.name,
folioId=reservation.folio_id.id,
folioSequence=reservation.folio_sequence,
partnerName=reservation.partner_name,
pmsPropertyId=reservation.pms_property_id.id,
boardServiceId=reservation.board_service_room_id.id or None,
saleChannelId=reservation.channel_type_id.id or None,
agencyId=reservation.agency_id.id or None,
checkin=datetime.combine(
reservation.checkin, datetime.min.time()
).isoformat(),
checkout=datetime.combine(
reservation.checkout, datetime.min.time()
).isoformat(),
arrivalHour=reservation.arrival_hour,
departureHour=reservation.departure_hour,
roomTypeId=reservation.room_type_id.id or None,
preferredRoomId=reservation.preferred_room_id.id or None,
pricelistId=reservation.pricelist_id.id,
adults=reservation.adults,
overbooking=reservation.overbooking,
externalReference=reservation.external_reference or None,
state=reservation.state,
children=reservation.children or None,
readyForCheckin=reservation.ready_for_checkin,
allowedCheckout=reservation.allowed_checkout,
isSplitted=reservation.splitted,
pendingCheckinData=reservation.pending_checkin_data,
createDate=datetime.combine(
reservation.create_date, datetime.min.time()
).isoformat(),
segmentationId=reservation.segmentation_ids[0].id
if reservation.segmentation_ids
else None,
cancellationPolicyId=reservation.pricelist_id.cancelation_rule_id.id
or None,
toAssign=reservation.to_assign,
reservationType=reservation.reservation_type,
priceTotal=reservation.price_room_services_set,
discount=reservation.discount,
commissionAmount=reservation.commission_amount or None,
commissionPercent=reservation.commission_percent or None,
priceOnlyServices=reservation.price_services,
priceOnlyRoom=reservation.price_total,
pendingAmount=reservation.folio_pending_amount,
)
)
return reservations
# @restapi.method(
# [
# (
# [
# "/",
# ],
# "POST",
# )
# ],
# input_param=Datamodel("pms.reservation.info", is_list=False),
# auth="jwt_api_pms",
# )
# def create_reservation(self, pms_reservation_info):
# reservation = self.env["pms.reservation"].create(
# {
# "partner_name": pms_reservation_info.partner,
# "pms_property_id": pms_reservation_info.pmsPropertyId,
# "room_type_id": pms_reservation_info.roomTypeId,
# "pricelist_id": pms_reservation_info.pricelistId,
# "checkin": pms_reservation_info.checkin,
# "checkout": pms_reservation_info.checkout,
# "board_service_room_id": pms_reservation_info.boardServiceId,
# "channel_type_id": pms_reservation_info.channelTypeId,
# }
# )
# return reservation.id