1
0
forked from Mapan/odoo17e
odoo17e-kedaikipas58/addons/l10n_de_reports/models/res_partner.py
2024-12-10 09:04:09 +07:00

53 lines
2.2 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 ResPartner(models.Model):
_inherit = 'res.partner'
l10n_de_datev_identifier = fields.Integer(
string='DateV Vendor',
copy=False,
tracking=True,
index='btree_not_null',
help="In the DateV export of the General Ledger, each vendor will be identified by this identifier. "
"If this identifier is not set, the database id of the partner will be added to a multiple of ten starting by the number 7."
"The account code's length can be specified in the company settings."
)
l10n_de_datev_identifier_customer = fields.Integer(
string='DateV Customer',
copy=False,
tracking=True,
index='btree_not_null',
help="In the DateV export of the General Ledger, each customer will be identified by this identifier. "
"If this identifier is not set, the database id of the partner will be added to a multiple of ten starting by the number 1."
"The account code's length can be specified in the company settings."
)
@api.constrains('l10n_de_datev_identifier')
def _check_datev_identifier(self):
self.flush_model(['l10n_de_datev_identifier'])
self.env.cr.execute("""
SELECT 1 FROM res_partner
WHERE l10n_de_datev_identifier != 0
GROUP BY l10n_de_datev_identifier
HAVING COUNT(*) > 1
""")
if self.env.cr.dictfetchone():
raise ValidationError(_('You have already defined a partner with the same Datev identifier. '))
@api.constrains('l10n_de_datev_identifier_customer')
def _check_datev_identifier_customer(self):
self.flush_model(['l10n_de_datev_identifier_customer'])
self.env.cr.execute("""
SELECT 1 FROM res_partner
WHERE l10n_de_datev_identifier_customer != 0
GROUP BY l10n_de_datev_identifier_customer
HAVING COUNT(*) > 1
""")
if self.env.cr.dictfetchone():
raise ValidationError(_('You have already defined a partner with the same Datev Customer identifier'))