oca-ocb-core/odoo-bringout-oca-ocb-utm/utm/models/utm_source.py
Ernad Husremovic 2d3ee4855a 19.0 vanilla
2026-03-09 09:30:27 +01:00

113 lines
4.4 KiB
Python

# Part of Odoo. See LICENSE file for full copyright and licensing details.
from odoo import _, api, fields, models
from odoo.exceptions import ValidationError
class UtmSource(models.Model):
_name = 'utm.source'
_description = 'UTM Source'
name = fields.Char(string='Source Name', required=True)
_unique_name = models.Constraint(
'UNIQUE(name)',
'The name must be unique',
)
@api.ondelete(at_uninstall=False)
def _unlink_except_referral(self):
utm_source_referral = self.env.ref('utm.utm_source_referral', raise_if_not_found=False)
for record in self:
if record == utm_source_referral:
raise ValidationError(_("You cannot delete the 'Referral' UTM source record."))
@api.model_create_multi
def create(self, vals_list):
new_names = self.env['utm.mixin']._get_unique_names(self._name, [vals.get('name') for vals in vals_list])
for vals, new_name in zip(vals_list, new_names):
vals['name'] = new_name
return super().create(vals_list)
def _generate_name(self, record, content):
"""Generate the UTM source name based on the content of the source."""
if not content:
return False
content = content.replace('\n', ' ')
if len(content) >= 24:
content = f'{content[:20]}...'
create_date = record.create_date or fields.Datetime.today()
model_description = self.env['ir.model']._get(record._name).name
return _(
'%(content)s (%(model_description)s created on %(create_date)s)',
content=content,
model_description=model_description,
create_date=fields.Date.to_string(create_date),
)
class UtmSourceMixin(models.AbstractModel):
"""Mixin responsible of generating the name of the source based on the content
(field defined by _rec_name) of the record (mailing, social post,...).
"""
_name = 'utm.source.mixin'
_description = 'UTM Source Mixin'
name = fields.Char('Name', related='source_id.name', readonly=False)
source_id = fields.Many2one('utm.source', string='Source', required=True, ondelete='restrict', copy=False)
@api.model
def default_get(self, fields):
# Exclude 'name' from fields to avoid retrieving it from context.
return super().default_get([field for field in fields if field != "name"])
@api.model_create_multi
def create(self, vals_list):
"""Create the UTM sources if necessary, generate the name based on the content in batch."""
# Create all required <utm.source>
utm_sources = self.env['utm.source'].create([
{
'name': values.get('name')
or self.env.context.get('default_name')
or self.env['utm.source']._generate_name(self, values.get(self._rec_name)),
}
for values in vals_list
if not values.get('source_id')
])
# Update "vals_list" to add the ID of the newly created source
vals_list_missing_source = [values for values in vals_list if not values.get('source_id')]
for values, source in zip(vals_list_missing_source, utm_sources):
values['source_id'] = source.id
for values in vals_list:
if 'name' in values:
del values['name']
return super().create(vals_list)
def write(self, vals):
if (vals.get(self._rec_name) or vals.get('name')) and len(self) > 1:
raise ValueError(
_('You cannot update multiple records with the same name. The name should be unique!')
)
if vals.get(self._rec_name) and not vals.get('name'):
vals['name'] = self.env['utm.source']._generate_name(self, vals[self._rec_name])
if vals.get('name'):
vals['name'] = self.env['utm.mixin'].with_context(
utm_check_skip_record_ids=self.source_id.ids
)._get_unique_names("utm.source", [vals['name']])[0]
return super().write(vals)
def copy_data(self, default=None):
"""Increment the counter when duplicating the source."""
default = default or {}
default_name = default.get('name')
vals_list = super().copy_data(default=default)
for source, vals in zip(self, vals_list):
vals['name'] = self.env['utm.mixin']._get_unique_names("utm.source", [default_name or source.name])[0]
return vals_list