[IMP] incongruence partner fields on reservation/folio/checkin

This commit is contained in:
Dario Lodeiros
2021-06-19 10:55:27 +02:00
parent b82a1a7cc4
commit fbe8d2bef3
8 changed files with 159 additions and 19 deletions

View File

@@ -3788,8 +3788,8 @@ msgid "Income Account"
msgstr "Cuenta de Ingresos"
#. module: pms
#: model:ir.model.fields,field_description:pms.field_pms_checkin_partner__incongruences
msgid "Incongruences"
#: model:ir.model.fields,field_description:pms.field_pms_checkin_partner__partner_incongruences
msgid "partner_incongruences"
msgstr ""
#. module: pms
@@ -7963,7 +7963,7 @@ msgstr "Computación técnica"
#. module: pms
#: model:ir.model.fields,help:pms.field_pms_checkin_partner__document_id
#: model:ir.model.fields,help:pms.field_pms_checkin_partner__incongruences
#: model:ir.model.fields,help:pms.field_pms_checkin_partner__partner_incongruences
#, fuzzy
msgid "Technical field"
msgstr "Computación técnica"

View File

@@ -3582,8 +3582,8 @@ msgid "Income Account"
msgstr ""
#. module: pms
#: model:ir.model.fields,field_description:pms.field_pms_checkin_partner__incongruences
msgid "Incongruences"
#: model:ir.model.fields,field_description:pms.field_pms_checkin_partner__partner_incongruences
msgid "partner_incongruences"
msgstr ""
#. module: pms
@@ -7586,7 +7586,7 @@ msgstr ""
#. module: pms
#: model:ir.model.fields,help:pms.field_pms_checkin_partner__document_id
#: model:ir.model.fields,help:pms.field_pms_checkin_partner__incongruences
#: model:ir.model.fields,help:pms.field_pms_checkin_partner__partner_incongruences
msgid "Technical field"
msgstr ""

View File

@@ -192,10 +192,12 @@ class PmsCheckinPartner(models.Model):
ondelete="restrict",
)
incongruences = fields.Char(
string="Incongruences",
help="Technical field",
compute="_compute_incongruences",
partner_incongruences = fields.Char(
string="partner_incongruences",
help="indicates that some partner fields \
on the checkin do not correspond to that of \
the associated partner",
compute="_compute_partner_incongruences",
)
@api.depends("partner_id")
@@ -405,25 +407,29 @@ class PmsCheckinPartner(models.Model):
"nationality_id",
"email",
"mobile",
"partner_id",
)
def _compute_incongruences(self):
def _compute_partner_incongruences(self):
for record in self:
incongruous_fields = ""
incongruous_fields = False
if record.partner_id:
for field in record._checkin_partner_fields():
if (
record.partner_id[field]
and record.partner_id[field] != record[field]
):
incongruous_fields += record._fields[field].string + ", "
if not incongruous_fields:
incongruous_fields = record._fields[field].string
else:
incongruous_fields += ", " + record._fields[field].string
if incongruous_fields:
record.incongruences = (
incongruous_fields + "field/s don't correspond to saved host"
record.partner_incongruences = (
incongruous_fields + " field/s don't correspond to saved host"
)
else:
record.incongruences = False
record.partner_incongruences = False
else:
record.incongruences = False
record.partner_incongruences = False
@api.constrains("departure", "arrival")
def _check_departure(self):

View File

@@ -338,6 +338,13 @@ class PmsFolio(models.Model):
readonly=False,
compute="_compute_mobile",
)
partner_incongruences = fields.Char(
string="partner_incongruences",
help="indicates that some partner fields \
on the folio do not correspond to that of \
the associated partner",
compute="_compute_partner_incongruences",
)
partner_internal_comment = fields.Text(
string="Internal Partner Notes",
help="Internal notes of the partner",
@@ -770,6 +777,36 @@ class PmsFolio(models.Model):
elif not record.mobile:
record.mobile = False
@api.depends(
"partner_name",
"email",
"mobile",
"partner_id",
)
def _compute_partner_incongruences(self):
fields_mapping = {
"partner_name": "name",
"email": "email",
"mobile": "mobile",
}
for record in self:
incongruous_fields = False
if record.partner_id:
for k, v in fields_mapping.items():
if record.partner_id[v] and record.partner_id[v] != record[k]:
if not incongruous_fields:
incongruous_fields = v
else:
incongruous_fields += ", " + v
if incongruous_fields:
record.partner_incongruences = (
incongruous_fields + " field/s don't correspond to saved host"
)
else:
record.partner_incongruences = False
else:
record.partner_incongruences = False
@api.depends("sale_line_ids.price_total")
def _compute_amount_all(self):
"""
@@ -978,6 +1015,20 @@ class PmsFolio(models.Model):
"target": "new",
}
def open_partner(self):
""" Utility method used to add an "View Customer" button in folio views """
self.ensure_one()
partner_form_id = self.env.ref("base.view_partner_address_form").id
return {
"type": "ir.actions.act_window",
"res_model": "res.partner",
"view_mode": "form",
"views": [(partner_form_id, "form")],
"res_id": self.partner_id.id,
"target": "new",
"flags": {"form": {"action_buttons": True}},
}
def open_moves_folio(self):
invoices = self.mapped("move_ids")
action = self.env.ref("account.action_move_out_invoice_type").sudo().read()[0]

View File

@@ -480,6 +480,13 @@ class PmsReservation(models.Model):
readonly=False,
compute="_compute_mobile",
)
partner_incongruences = fields.Char(
string="partner_incongruences",
help="indicates that some partner fields \
on the reservation do not correspond to that of \
the associated partner",
compute="_compute_partner_incongruences",
)
partner_internal_comment = fields.Text(
string="Internal Partner Notes",
help="Internal reservation comment",
@@ -1176,6 +1183,36 @@ class PmsReservation(models.Model):
elif not record.partner_mobile:
record.partner_mobile = False
@api.depends(
"partner_name",
"partner_email",
"partner_mobile",
"partner_id",
)
def _compute_partner_incongruences(self):
fields_mapping = {
"partner_name": "name",
"partner_email": "email",
"partner_mobile": "mobile",
}
for record in self:
incongruous_fields = False
if record.partner_id:
for k, v in fields_mapping.items():
if record.partner_id[v] and record.partner_id[v] != record[k]:
if not incongruous_fields:
incongruous_fields = v
else:
incongruous_fields += ", " + v
if incongruous_fields:
record.partner_incongruences = (
incongruous_fields + " field/s don't correspond to saved host"
)
else:
record.partner_incongruences = False
else:
record.partner_incongruences = False
def _compute_checkin_partner_count(self):
for record in self:
if record.reservation_type != "out":
@@ -1369,6 +1406,20 @@ class PmsReservation(models.Model):
raise ValidationError(_("booking agency with wrong configuration: "))
# Action methods
def open_partner(self):
""" Utility method used to add an "View Customer" button in folio views """
self.ensure_one()
partner_form_id = self.env.ref("base.view_partner_address_form").id
return {
"type": "ir.actions.act_window",
"res_model": "res.partner",
"view_mode": "form",
"views": [(partner_form_id, "form")],
"res_id": self.partner_id.id,
"target": "new",
"flags": {"form": {"action_buttons": True}},
}
def print_all_checkins(self):
checkins = self.env["pms.checkin.partner"]
for record in self:

View File

@@ -29,9 +29,9 @@
class="alert alert-danger"
role="danger"
style="margin-bottom:0px;"
attrs="{'invisible': [('incongruences','=',False)]}"
attrs="{'invisible': [('partner_incongruences','=',False)]}"
>
<field name="incongruences" />
<field name="partner_incongruences" />
</div>
<group name="group_top">
<group name="group_left">

View File

@@ -39,6 +39,22 @@
statusbar_visible="draft,sent,sale,done"
/>
</header>
<div
class="alert alert-info"
role="alert"
style="margin-bottom:0px;"
attrs="{'invisible': [('partner_incongruences','=',False)]}"
>
<field name="partner_incongruences" />
<bold>
<button
class="alert-link"
type="object"
name="open_partner"
string="View Customer"
/>
</bold>
</div>
<sheet>
<div class="oe_button_box" name="button_box">
<button

View File

@@ -61,6 +61,22 @@
/>
</bold>
</div>
<div
class="alert alert-info"
role="alert"
style="margin-bottom:0px;"
attrs="{'invisible': [('partner_incongruences','=',False)]}"
>
<field name="partner_incongruences" />
<bold>
<button
class="alert-link"
type="object"
name="open_partner"
string="View Customer"
/>
</bold>
</div>
<div
class="alert alert-warning"
role="alert"