summaryrefslogtreecommitdiff
path: root/addons/l10n_cl/models/account_move.py
diff options
context:
space:
mode:
Diffstat (limited to 'addons/l10n_cl/models/account_move.py')
-rw-r--r--addons/l10n_cl/models/account_move.py126
1 files changed, 126 insertions, 0 deletions
diff --git a/addons/l10n_cl/models/account_move.py b/addons/l10n_cl/models/account_move.py
new file mode 100644
index 00000000..06588533
--- /dev/null
+++ b/addons/l10n_cl/models/account_move.py
@@ -0,0 +1,126 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+from odoo.exceptions import ValidationError
+from odoo import models, fields, api, _
+from odoo.osv import expression
+
+SII_VAT = '60805000-0'
+
+
+class AccountMove(models.Model):
+ _inherit = "account.move"
+
+ l10n_latam_document_type_id_code = fields.Char(related='l10n_latam_document_type_id.code', string='Doc Type')
+ partner_id_vat = fields.Char(related='partner_id.vat', string='VAT No')
+ l10n_latam_internal_type = fields.Selection(
+ related='l10n_latam_document_type_id.internal_type', string='L10n Latam Internal Type')
+
+ def _get_l10n_latam_documents_domain(self):
+ self.ensure_one()
+ if self.journal_id.company_id.country_id != self.env.ref('base.cl') or not \
+ self.journal_id.l10n_latam_use_documents:
+ return super()._get_l10n_latam_documents_domain()
+ if self.journal_id.type == 'sale':
+ domain = [('country_id.code', '=', "CL"), ('internal_type', '!=', 'invoice_in')]
+ if self.company_id.partner_id.l10n_cl_sii_taxpayer_type == '1':
+ domain += [('code', '!=', '71')] # Companies with VAT Affected doesn't have "Boleta de honorarios Electrónica"
+ return domain
+ domain = [
+ ('country_id.code', '=', 'CL'),
+ ('internal_type', 'in', ['invoice', 'debit_note', 'credit_note', 'invoice_in'])]
+ if self.partner_id.l10n_cl_sii_taxpayer_type == '1' and self.partner_id_vat != '60805000-0':
+ domain += [('code', 'not in', ['39', '70', '71', '914', '911'])]
+ elif self.partner_id.l10n_cl_sii_taxpayer_type == '1' and self.partner_id_vat == '60805000-0':
+ domain += [('code', 'not in', ['39', '70', '71'])]
+ if self.move_type == 'in_invoice':
+ domain += [('internal_type', '!=', 'credit_note')]
+ elif self.partner_id.l10n_cl_sii_taxpayer_type == '2':
+ domain += [('code', 'in', ['70', '71', '56', '61'])]
+ elif self.partner_id.l10n_cl_sii_taxpayer_type == '3':
+ domain += [('code', 'in', ['35', '38', '39', '41', '56', '61'])]
+ elif not self.partner_id.l10n_cl_sii_taxpayer_type or self.partner_id.country_id != self.env.ref(
+ 'base.cl') or self.partner_id.l10n_cl_sii_taxpayer_type == '4':
+ domain += [('code', 'in', [])]
+ return domain
+
+
+ def _check_document_types_post(self):
+ for rec in self.filtered(
+ lambda r: r.company_id.country_id.code == "CL" and
+ r.journal_id.type in ['sale', 'purchase']):
+ tax_payer_type = rec.partner_id.l10n_cl_sii_taxpayer_type
+ vat = rec.partner_id.vat
+ country_id = rec.partner_id.country_id
+ latam_document_type_code = rec.l10n_latam_document_type_id.code
+ if (not tax_payer_type or not vat) and (country_id.code == "CL" and latam_document_type_code
+ and latam_document_type_code not in ['35', '38', '39', '41']):
+ raise ValidationError(_('Tax payer type and vat number are mandatory for this type of '
+ 'document. Please set the current tax payer type of this customer'))
+ if rec.journal_id.type == 'sale' and rec.journal_id.l10n_latam_use_documents:
+ if country_id.code != "CL":
+ if not ((tax_payer_type == '4' and latam_document_type_code in ['110', '111', '112']) or (
+ tax_payer_type == '3' and latam_document_type_code in ['39', '41', '61', '56'])):
+ raise ValidationError(_(
+ 'Document types for foreign customers must be export type (codes 110, 111 or 112) or you \
+ should define the customer as an end consumer and use receipts (codes 39 or 41)'))
+ if rec.journal_id.type == 'purchase' and rec.journal_id.l10n_latam_use_documents:
+ if vat != SII_VAT and latam_document_type_code == '914':
+ raise ValidationError(_('The DIN document is intended to be used only with RUT 60805000-0'
+ ' (Tesorería General de La República)'))
+ if not tax_payer_type or not vat:
+ if country_id.code == "CL" and latam_document_type_code not in [
+ '35', '38', '39', '41']:
+ raise ValidationError(_('Tax payer type and vat number are mandatory for this type of '
+ 'document. Please set the current tax payer type of this supplier'))
+ if tax_payer_type == '2' and latam_document_type_code not in ['70', '71', '56', '61']:
+ raise ValidationError(_('The tax payer type of this supplier is incorrect for the selected type'
+ ' of document.'))
+ if tax_payer_type in ['1', '3']:
+ if latam_document_type_code in ['70', '71']:
+ raise ValidationError(_('The tax payer type of this supplier is not entitled to deliver '
+ 'fees documents'))
+ if latam_document_type_code in ['110', '111', '112']:
+ raise ValidationError(_('The tax payer type of this supplier is not entitled to deliver '
+ 'imports documents'))
+ if tax_payer_type == '4' or country_id.code != "CL":
+ raise ValidationError(_('You need a journal without the use of documents for foreign '
+ 'suppliers'))
+ if rec.journal_id.type == 'purchase' and not rec.journal_id.l10n_latam_use_documents:
+ if tax_payer_type != '4':
+ raise ValidationError(_('This supplier should be defined as foreigner tax payer type and '
+ 'the country should be different from Chile to register purchases.'))
+
+ @api.onchange('journal_id')
+ def _l10n_cl_onchange_journal(self):
+ self.l10n_latam_document_type_id = False
+
+ def _post(self, soft=True):
+ self._check_document_types_post()
+ return super()._post(soft)
+
+ def _l10n_cl_get_formatted_sequence(self, number=0):
+ return '%s %06d' % (self.l10n_latam_document_type_id.doc_code_prefix, number)
+
+ def _get_starting_sequence(self):
+ """ If use documents then will create a new starting sequence using the document type code prefix and the
+ journal document number with a 6 padding number """
+ if self.journal_id.l10n_latam_use_documents and self.env.company.country_id.code == "CL":
+ if self.l10n_latam_document_type_id:
+ return self._l10n_cl_get_formatted_sequence()
+ return super()._get_starting_sequence()
+
+ def _get_last_sequence_domain(self, relaxed=False):
+ where_string, param = super(AccountMove, self)._get_last_sequence_domain(relaxed)
+ if self.company_id.country_id.code == "CL" and self.l10n_latam_use_documents:
+ where_string = where_string.replace('journal_id = %(journal_id)s AND', '')
+ where_string += ' AND l10n_latam_document_type_id = %(l10n_latam_document_type_id)s AND ' \
+ 'company_id = %(company_id)s AND move_type IN (\'out_invoice\', \'out_refund\')'
+ param['company_id'] = self.company_id.id or False
+ param['l10n_latam_document_type_id'] = self.l10n_latam_document_type_id.id or 0
+ return where_string, param
+
+ def _get_name_invoice_report(self):
+ self.ensure_one()
+ if self.l10n_latam_use_documents and self.company_id.country_id.code == 'CL':
+ return 'l10n_cl.report_invoice_document'
+ return super()._get_name_invoice_report()