diff options
| author | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
|---|---|---|
| committer | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
| commit | 3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch) | |
| tree | a44932296ef4a9b71d5f010906253d8c53727726 /addons/event_crm_sale/models | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/event_crm_sale/models')
| -rw-r--r-- | addons/event_crm_sale/models/__init__.py | 4 | ||||
| -rw-r--r-- | addons/event_crm_sale/models/event_registration.py | 49 |
2 files changed, 53 insertions, 0 deletions
diff --git a/addons/event_crm_sale/models/__init__.py b/addons/event_crm_sale/models/__init__.py new file mode 100644 index 00000000..20ce9ac3 --- /dev/null +++ b/addons/event_crm_sale/models/__init__.py @@ -0,0 +1,4 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from . import event_registration diff --git a/addons/event_crm_sale/models/event_registration.py b/addons/event_crm_sale/models/event_registration.py new file mode 100644 index 00000000..480d4a0e --- /dev/null +++ b/addons/event_crm_sale/models/event_registration.py @@ -0,0 +1,49 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from collections import defaultdict + +from odoo import models + + +class EventRegistration(models.Model): + _inherit = 'event.registration' + + def _get_lead_grouping(self, rules, rule_to_new_regs): + """ Override to support sale-order based grouping and update. + + When checking for groups for rules, we search for existing leads linked + to same group (based on sale_order_id) and rule. Each rule can therefore + update an existing lead or create a new one, for each sale order that + makes the group. """ + so_registrations = self.filtered(lambda reg: reg.sale_order_id) + grouping_res = super(EventRegistration, self - so_registrations)._get_lead_grouping(rules, rule_to_new_regs) + + if so_registrations: + # find existing leads in batch to put them in cache and avoid multiple search / queries + related_registrations = self.env['event.registration'].search([ + ('sale_order_id', 'in', so_registrations.sale_order_id.ids) + ]) + related_leads = self.env['crm.lead'].search([ + ('event_lead_rule_id', 'in', rules.ids), + ('registration_ids', 'in', related_registrations.ids) + ]) + + for rule in rules: + rule_new_regs = rule_to_new_regs[rule] + + # for each group (sale_order), find its linked registrations + so_to_regs = defaultdict(lambda: self.env['event.registration']) + for registration in rule_new_regs & so_registrations: + so_to_regs[registration.sale_order_id] |= registration + + # for each grouped registrations, prepare result with group and existing lead + so_res = [] + for sale_order, registrations in so_to_regs.items(): + registrations = registrations.sorted('id') # as an OR was used, re-ensure order + leads = related_leads.filtered(lambda lead: lead.event_lead_rule_id == rule and lead.registration_ids.sale_order_id == sale_order) + so_res.append((leads, sale_order, registrations)) + if so_res: + grouping_res[rule] = grouping_res.get(rule, list()) + so_res + + return grouping_res |
