mirror of
https://github.com/OCA/pms.git
synced 2025-01-29 00:17:45 +02:00
[IMP] pms_api_rest: add free-rooms service
This commit is contained in:
committed by
Darío Lodeiros
parent
064e74ab91
commit
f5eccc2add
@@ -25,6 +25,7 @@ class PmsCalendarSearchParam(Datamodel):
|
|||||||
date_from = fields.String(required=False, allow_none=True)
|
date_from = fields.String(required=False, allow_none=True)
|
||||||
date_to = fields.String(required=False, allow_none=True)
|
date_to = fields.String(required=False, allow_none=True)
|
||||||
pms_property_id = fields.Integer(required=True, allow_none=False)
|
pms_property_id = fields.Integer(required=True, allow_none=False)
|
||||||
|
pricelist_id = fields.Integer(required=False, allow_none=True)
|
||||||
|
|
||||||
|
|
||||||
class PmsCalendarInfo(Datamodel):
|
class PmsCalendarInfo(Datamodel):
|
||||||
|
|||||||
@@ -177,3 +177,61 @@ class PmsCalendarService(Component):
|
|||||||
result.append(daily_invoicing)
|
result.append(daily_invoicing)
|
||||||
|
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
@restapi.method(
|
||||||
|
[
|
||||||
|
(
|
||||||
|
[
|
||||||
|
"/free-rooms",
|
||||||
|
],
|
||||||
|
"GET",
|
||||||
|
)
|
||||||
|
],
|
||||||
|
input_param=Datamodel("pms.calendar.search.param", is_list=False),
|
||||||
|
auth="jwt_api_pms",
|
||||||
|
)
|
||||||
|
def get_free_rooms(self, pms_calendar_search_param):
|
||||||
|
|
||||||
|
date_from = datetime.strptime(
|
||||||
|
pms_calendar_search_param.date_from, "%Y-%m-%d"
|
||||||
|
).date()
|
||||||
|
date_to = datetime.strptime(
|
||||||
|
pms_calendar_search_param.date_to, "%Y-%m-%d"
|
||||||
|
).date()
|
||||||
|
|
||||||
|
self.env.cr.execute(
|
||||||
|
"""
|
||||||
|
SELECT date,
|
||||||
|
(SELECT COUNT(1) FROM pms_room WHERE pms_property_id = %s) - COUNT(1) free_rooms
|
||||||
|
FROM pms_reservation_line
|
||||||
|
WHERE occupies_availability = true
|
||||||
|
AND pms_property_id = %s
|
||||||
|
AND date >= %s
|
||||||
|
AND date <= %s
|
||||||
|
GROUP BY date
|
||||||
|
ORDER BY date;
|
||||||
|
""",
|
||||||
|
(
|
||||||
|
pms_calendar_search_param.pms_property_id,
|
||||||
|
pms_calendar_search_param.pms_property_id,
|
||||||
|
date_from,
|
||||||
|
date_to,
|
||||||
|
),
|
||||||
|
)
|
||||||
|
reservation_lines = self.env.cr.fetchall()
|
||||||
|
|
||||||
|
all_property_rooms = self.env["pms.room"].search(
|
||||||
|
[
|
||||||
|
("pms_property_id", "=", pms_calendar_search_param.pms_property_id),
|
||||||
|
]
|
||||||
|
)
|
||||||
|
result = []
|
||||||
|
for date, free_rooms in reservation_lines:
|
||||||
|
daily_free_rooms = {
|
||||||
|
"date": datetime.combine(date, datetime.min.time()).isoformat(),
|
||||||
|
"freeRooms": free_rooms,
|
||||||
|
"totalRooms": len(all_property_rooms),
|
||||||
|
}
|
||||||
|
result.append(daily_free_rooms)
|
||||||
|
|
||||||
|
return result
|
||||||
|
|||||||
Reference in New Issue
Block a user