mirror of
https://github.com/OCA/pms.git
synced 2025-01-29 00:17:45 +02:00
[IMP]pms_api_rest: add PATCH service and serviceLines field in pms service
This commit is contained in:
@@ -8,7 +8,7 @@ class PmsServiceInfo(Datamodel):
|
||||
_name = "pms.service.info"
|
||||
id = fields.Integer(required=False, allow_none=True)
|
||||
name = fields.String(required=False, allow_none=True)
|
||||
productId = fields.Integer(required=True, allow_none=False)
|
||||
productId = fields.Integer(required=False, allow_none=True)
|
||||
quantity = fields.Integer(required=False, allow_none=True)
|
||||
priceTotal = fields.Float(required=False, allow_none=True)
|
||||
priceSubtotal = fields.Float(required=False, allow_none=True)
|
||||
|
||||
@@ -1,3 +1,4 @@
|
||||
import logging
|
||||
from datetime import datetime
|
||||
|
||||
from odoo import _
|
||||
@@ -7,6 +8,8 @@ from odoo.addons.base_rest import restapi
|
||||
from odoo.addons.base_rest_datamodel.restapi import Datamodel
|
||||
from odoo.addons.component.core import Component
|
||||
|
||||
_logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class PmsServiceService(Component):
|
||||
_inherit = "base.rest.service"
|
||||
@@ -34,13 +37,12 @@ class PmsServiceService(Component):
|
||||
lines = [
|
||||
self.env.datamodels["pms.service.line.info"](
|
||||
id=line.id,
|
||||
date=datetime.combine(
|
||||
line.date, datetime.min.time()
|
||||
).isoformat(),
|
||||
date=datetime.combine(line.date, datetime.min.time()).isoformat(),
|
||||
priceUnit=line.price_unit,
|
||||
discount=line.discount,
|
||||
quantity=line.day_qty,
|
||||
) for line in service.service_line_ids
|
||||
)
|
||||
for line in service.service_line_ids
|
||||
]
|
||||
return PmsServiceInfo(
|
||||
id=service.id,
|
||||
@@ -55,6 +57,70 @@ class PmsServiceService(Component):
|
||||
serviceLines=lines,
|
||||
)
|
||||
|
||||
@restapi.method(
|
||||
[
|
||||
(
|
||||
[
|
||||
"/<int:service_id>",
|
||||
],
|
||||
"PATCH",
|
||||
)
|
||||
],
|
||||
input_param=Datamodel("pms.service.info", is_list=False),
|
||||
auth="jwt_api_pms",
|
||||
)
|
||||
def update_service(self, service_id, service_data):
|
||||
service = self.env["pms.service"].search([("id", "=", service_id)])
|
||||
if not service:
|
||||
raise MissingError(_("Service not found"))
|
||||
vals = {}
|
||||
if service_data.serviceLines:
|
||||
cmds_lines = []
|
||||
date_list = []
|
||||
for line_data in service_data.serviceLines:
|
||||
date_line = datetime.strptime(line_data.date, "%Y-%m-%d").date()
|
||||
date_list.append(date_line)
|
||||
service_line = service.service_line_ids.filtered(
|
||||
lambda l: l.date == date_line
|
||||
)
|
||||
# 1- update values in existing lines
|
||||
if service_line:
|
||||
line_vals = self._get_service_lines_mapped(line_data, service_line)
|
||||
cmds_lines.append((1, service_line.id, line_vals))
|
||||
# 2- create new lines
|
||||
else:
|
||||
line_vals = self._get_service_lines_mapped(line_data)
|
||||
line_vals["date"] = line_data.date
|
||||
cmds_lines.append((0, False, line_vals))
|
||||
# 3- delete old lines:
|
||||
for line in service.service_line_ids.filtered(
|
||||
lambda l: l.date not in date_list
|
||||
):
|
||||
cmds_lines.append((2, line.id))
|
||||
if cmds_lines:
|
||||
vals["service_line_ids"] = cmds_lines
|
||||
_logger.info(vals)
|
||||
if vals:
|
||||
service.write(vals)
|
||||
|
||||
def _get_service_lines_mapped(self, origin_data, service_line=False):
|
||||
# Return dict witch reservation.lines values (only modified if line exist,
|
||||
# or all pass values if line not exist)
|
||||
line_vals = {}
|
||||
if origin_data.priceUnit and (
|
||||
not service_line or origin_data.priceUnit != service_line.price_unit
|
||||
):
|
||||
line_vals["price_unit"] = origin_data.priceUnit
|
||||
if origin_data.discount and (
|
||||
not service_line or origin_data.discount != service_line.discount
|
||||
):
|
||||
line_vals["discount"] = origin_data.discount
|
||||
if origin_data.quantity and (
|
||||
not service_line or origin_data.quantity != service_line.day_qty
|
||||
):
|
||||
line_vals["day_qty"] = origin_data.quantity
|
||||
return line_vals
|
||||
|
||||
@restapi.method(
|
||||
[
|
||||
(
|
||||
|
||||
Reference in New Issue
Block a user