odoo18/addons_extensions/helpdesk/models/res_partner.py

51 lines
2.3 KiB
Python

# Part of Odoo. See LICENSE file for full copyright and licensing details.
from odoo import fields, models, _
class ResPartner(models.Model):
_inherit = 'res.partner'
ticket_count = fields.Integer("Tickets", compute='_compute_ticket_count')
sla_ids = fields.Many2many(
'helpdesk.sla', 'helpdesk_sla_res_partner_rel',
'res_partner_id', 'helpdesk_sla_id', string='SLA Policies',
help="SLA Policies that will automatically apply to the tickets submitted by this customer.")
def _compute_ticket_count(self):
all_partners_subquery = self.with_context(active_test=False)._search([('id', 'child_of', self.ids)])
# group tickets by partner, and account for each partner in self
groups = self.env['helpdesk.ticket']._read_group(
[('partner_id', 'in', all_partners_subquery)],
groupby=['partner_id'], aggregates=['__count'],
)
self.ticket_count = 0
for partner, count in groups:
while partner:
if partner in self:
partner.ticket_count += count
partner = partner.with_context(prefetch_fields=False).parent_id
def action_open_helpdesk_ticket(self):
self.ensure_one()
action = {
**self.env["ir.actions.actions"]._for_xml_id("helpdesk.helpdesk_ticket_action_main_tree"),
'display_name': _("%(partner_name)s's Tickets", partner_name=self.name),
'context': {},
}
all_child = self.with_context(active_test=False).search([('id', 'child_of', self.ids)])
search_domain = [('partner_id', 'in', (self | all_child).ids)]
if self.ticket_count <= 1:
ticket_id = self.env['helpdesk.ticket'].search(search_domain, limit=1)
action['res_id'] = ticket_id.id
action['views'] = [(view_id, view_type) for view_id, view_type in action['views'] if view_type == "form"]
else:
action['domain'] = search_domain
action['views'] = [
(self.env['ir.model.data']._xmlid_to_res_id('helpdesk.helpdesk_tickets_view_tree_res_partner'), view_type) if view_type == 'list' else
(view_id, view_type)
for view_id, view_type in action['views']
]
return action