19.0 vanilla

This commit is contained in:
Ernad Husremovic 2026-03-09 09:32:12 +01:00
parent 79f83631d5
commit 73afc09215
6267 changed files with 1534193 additions and 1130106 deletions

View file

@ -1,4 +1,3 @@
# -*- coding: utf-8 -*-
# Part of Odoo. See LICENSE file for full copyright and licensing details.
from odoo import fields, models
@ -7,8 +6,15 @@ from odoo import fields, models
class LoyaltyCard(models.Model):
_inherit = 'loyalty.card'
order_id = fields.Many2one('sale.order', 'Order Reference', readonly=True,
help="The sales order from which coupon is generated")
order_id = fields.Many2one(
string="Order Reference",
help="The sales order from which coupon is generated",
comodel_name='sale.order',
readonly=True,
)
order_id_partner_id = fields.Many2one(
string="Sale Order Customer", comodel_name='res.partner', related='order_id.partner_id'
)
def _get_default_template(self):
default_template = super()._get_default_template()
@ -16,11 +22,11 @@ class LoyaltyCard(models.Model):
default_template = self.env.ref('loyalty.mail_template_loyalty_card', raise_if_not_found=False)
return default_template
def _get_mail_partner(self):
return super()._get_mail_partner() or self.order_id.partner_id
def _mail_get_partner_fields(self, introspect_fields=False):
return super()._mail_get_partner_fields(introspect_fields=introspect_fields) + ['order_id_partner_id']
def _get_mail_author(self):
"""Default author is the order's salesperson if available, else the order's company."""
# Default author is the order's salesperson if available, else the order's company.
if not self.order_id or self.order_id.sudo().company_id not in self.env.companies:
return super()._get_mail_author()
self.ensure_one()
@ -32,10 +38,17 @@ class LoyaltyCard(models.Model):
def _compute_use_count(self):
super()._compute_use_count()
read_group_res = self.env['sale.order.line']._read_group(
[('coupon_id', 'in', self.ids)], ['id'], ['coupon_id'])
count_per_coupon = {r['coupon_id'][0]: r['coupon_id_count'] for r in read_group_res}
[('coupon_id', 'in', self.ids)], ['coupon_id'], ['__count'])
count_per_coupon = {coupon.id: count for coupon, count in read_group_res}
for card in self:
card.use_count += count_per_coupon.get(card.id, 0)
def _has_source_order(self):
return super()._has_source_order() or bool(self.order_id)
def action_archive(self):
self.env['sale.order.coupon.points'].search([
('coupon_id', 'in', self.ids),
('order_id.state', '=', 'draft'),
]).unlink()
return super().action_archive()