19.0 vanilla

This commit is contained in:
Ernad Husremovic 2026-03-09 09:30:07 +01:00
parent ba20ce7443
commit 768b70e05e
2357 changed files with 1057103 additions and 712486 deletions

View file

@ -1,6 +1,6 @@
# -*- coding: utf-8 -*-
import re
from odoo import fields, models
from odoo import _, fields, models, api
class AccountAnalyticApplicability(models.Model):
@ -18,22 +18,53 @@ class AccountAnalyticApplicability(models.Model):
},
)
account_prefix = fields.Char(
string='Financial Accounts Prefix',
string='Financial Accounts Prefixes',
help="Prefix that defines which accounts from the financial accounting this applicability should apply on.",
)
product_categ_id = fields.Many2one(
'product.category',
string='Product Category'
)
display_account_prefix = fields.Boolean(
compute='_compute_display_account_prefix',
help='Defines if the field account prefix should be displayed'
)
account_prefix_placeholder = fields.Char(compute='_compute_prefix_placeholder')
@api.depends('account_prefix', 'business_domain')
def _compute_prefix_placeholder(self):
account_expense = self.env['account.account'].search([('account_type', '=', 'expense')], limit=1)
account_income = self.env['account.account'].search([('account_type', '=', 'income')], limit=1)
for applicability in self:
if applicability.business_domain == 'bill':
account = account_expense
account_prefixes = "60, 61, 62"
else:
account = account_income
account_prefixes = "40, 41, 42"
if account and account.code:
prefix_base = account.code[:2]
try:
# Convert prefix_base to an integer for numerical manipulation
prefix_num = int(prefix_base)
account_prefixes = f"{prefix_num}, {prefix_num + 1}, {prefix_num + 2}"
except ValueError:
pass
applicability.account_prefix_placeholder = _("e.g. %(prefix)s", prefix=account_prefixes)
def _get_score(self, **kwargs):
score = super(AccountAnalyticApplicability, self)._get_score(**kwargs)
if score == -1:
return -1
product = self.env['product.product'].browse(kwargs.get('product', None))
account = self.env['account.account'].browse(kwargs.get('account', None))
product = self.env['product.product'].browse(kwargs.get('product'))
account = self.env['account.account'].browse(kwargs.get('account'))
if self.account_prefix:
if account and account.code.startswith(self.account_prefix):
account_prefixes = tuple(prefix for prefix in re.split("[,;]", self.account_prefix.replace(" ", "")) if prefix)
if account.code and account.code.startswith(account_prefixes):
score += 1
else:
return -1
@ -43,3 +74,8 @@ class AccountAnalyticApplicability(models.Model):
else:
return -1
return score
@api.depends('business_domain')
def _compute_display_account_prefix(self):
for applicability in self:
applicability.display_account_prefix = applicability.business_domain in ('general', 'invoice', 'bill')