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/l10n_ch_qriban/models | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/l10n_ch_qriban/models')
| -rw-r--r-- | addons/l10n_ch_qriban/models/__init__.py | 4 | ||||
| -rw-r--r-- | addons/l10n_ch_qriban/models/res_bank.py | 47 |
2 files changed, 51 insertions, 0 deletions
diff --git a/addons/l10n_ch_qriban/models/__init__.py b/addons/l10n_ch_qriban/models/__init__.py new file mode 100644 index 00000000..e7a0951c --- /dev/null +++ b/addons/l10n_ch_qriban/models/__init__.py @@ -0,0 +1,4 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from . import res_bank diff --git a/addons/l10n_ch_qriban/models/res_bank.py b/addons/l10n_ch_qriban/models/res_bank.py new file mode 100644 index 00000000..45c2ddee --- /dev/null +++ b/addons/l10n_ch_qriban/models/res_bank.py @@ -0,0 +1,47 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from odoo import api, fields, models, _ +from odoo.addons.base_iban.models.res_partner_bank import normalize_iban, pretty_iban, validate_iban +from odoo.addons.base.models.res_bank import sanitize_account_number +from odoo.exceptions import ValidationError + +class ResPartnerBank(models.Model): + _inherit = 'res.partner.bank' + + l10n_ch_qr_iban = fields.Char(string='QR-IBAN', help="Put the QR-IBAN here for your own bank accounts. That way, you can " + "still use the main IBAN in the Account Number while you will see the " + "QR-IBAN for the barcode. ") + + def _validate_qr_iban(self, qr_iban): + # Check first if it's a valid IBAN. + validate_iban(qr_iban) + # We sanitize first so that _check_qr_iban_range() can extract correct IID from IBAN to validate it. + sanitized_qr_iban = sanitize_account_number(qr_iban) + # Now, check if it's valid QR-IBAN (based on its IID). + if not self._check_qr_iban_range(sanitized_qr_iban): + raise ValidationError(_("QR-IBAN '%s' is invalid.") % qr_iban) + return True + + @api.model + def create(self, vals): + if vals.get('l10n_ch_qr_iban'): + self._validate_qr_iban(vals['l10n_ch_qr_iban']) + vals['l10n_ch_qr_iban'] = pretty_iban(normalize_iban(vals['l10n_ch_qr_iban'])) + return super().create(vals) + + def write(self, vals): + if vals.get('l10n_ch_qr_iban'): + self._validate_qr_iban(vals['l10n_ch_qr_iban']) + vals['l10n_ch_qr_iban'] = pretty_iban(normalize_iban(vals['l10n_ch_qr_iban'])) + return super().write(vals) + + def _is_qr_iban(self): + return super(ResPartnerBank, self)._is_qr_iban() or self.l10n_ch_qr_iban + + def _l10n_ch_get_qr_vals(self, amount, currency, debtor_partner, free_communication, structured_communication): + qr_vals = super()._l10n_ch_get_qr_vals(amount, currency, debtor_partner, free_communication, structured_communication) + # If there is a QR IBAN we use it for the barcode instead of the account number + if self.l10n_ch_qr_iban: + qr_vals[3] = sanitize_account_number(self.l10n_ch_qr_iban) + return qr_vals |
