diff --git a/l10n_es_aeat_sii_oca/models/account_move.py b/l10n_es_aeat_sii_oca/models/account_move.py index 2ad0ee73272..8de7df27cd4 100644 --- a/l10n_es_aeat_sii_oca/models/account_move.py +++ b/l10n_es_aeat_sii_oca/models/account_move.py @@ -17,6 +17,7 @@ from odoo import _, api, exceptions, fields, models from odoo.modules.registry import Registry +from odoo.osv.expression import AND, OR SII_VALID_INVOICE_STATES = ["posted"] _logger = logging.getLogger(__name__) @@ -810,6 +811,24 @@ def _compute_sii_enabled(self): else: invoice.sii_enabled = False + @api.model + def _search_sii_enabled(self, operator, value): + domain = super()._search_sii_enabled(operator, value) + invoice_types = self.get_sale_types() + self.get_purchase_types() + condition_1 = [("journal_id.sii_enabled", operator, value)] + condition_2 = [("fiscal_position_id.aeat_active", operator, value)] + search_ko = (operator == "=" and not value) or (operator == "!=" and value) + exp_condition = OR if search_ko else AND + if not search_ko: + condition_2 = OR([condition_2, [("fiscal_position_id", "=", False)]]) + move_type_exp = "not in" if search_ko else "in" + return exp_condition( + [ + [("move_type", move_type_exp, invoice_types)], + exp_condition([domain, exp_condition([condition_1, condition_2])]), + ] + ) + def _reverse_moves(self, default_values_list=None, cancel=False): # OVERRIDE if not default_values_list: diff --git a/l10n_es_aeat_sii_oca/models/sii_mixin.py b/l10n_es_aeat_sii_oca/models/sii_mixin.py index ed9dabbcd58..eeaa89831ea 100644 --- a/l10n_es_aeat_sii_oca/models/sii_mixin.py +++ b/l10n_es_aeat_sii_oca/models/sii_mixin.py @@ -88,6 +88,7 @@ class SiiMixin(models.AbstractModel): sii_enabled = fields.Boolean( string="Enable SII", compute="_compute_sii_enabled", + search="_search_sii_enabled", ) sii_macrodata = fields.Boolean( string="MacroData", @@ -151,6 +152,16 @@ def _compute_sii_registration_key_code(self): def _compute_sii_enabled(self): raise NotImplementedError + @api.model + def _is_unsupported_search_operator(self, operator): + return operator not in ("=", "!=") + + @api.model + def _search_sii_enabled(self, operator, value): + if self._is_unsupported_search_operator(operator): + raise ValueError(_("Unsupported search operator")) + return [("company_id.sii_enabled", operator, value)] + def _compute_macrodata(self): for document in self: document.sii_macrodata = ( diff --git a/l10n_es_aeat_sii_oca/tests/test_l10n_es_aeat_sii.py b/l10n_es_aeat_sii_oca/tests/test_l10n_es_aeat_sii.py index b982522c4d4..8503e89bd3a 100644 --- a/l10n_es_aeat_sii_oca/tests/test_l10n_es_aeat_sii.py +++ b/l10n_es_aeat_sii_oca/tests/test_l10n_es_aeat_sii.py @@ -186,6 +186,25 @@ def setUpClass(cls): [("sii_wsdl_out", "!=", False)] ) + def test_invoice_search_sii_enabled(self): + domain_base = [("id", "=", self.invoice.id)] + domain_ok = domain_base + [("sii_enabled", "=", True)] + items = self.env["account.move"].search(domain_ok) + self.assertIn(self.invoice, items) + domain_ko_1 = domain_base + [("sii_enabled", "=", False)] + items = self.env["account.move"].search(domain_ko_1) + self.assertNotIn(self.invoice, items) + domain_ko_2 = domain_base + [("sii_enabled", "!=", True)] + items = self.env["account.move"].search(domain_ko_2) + self.assertNotIn(self.invoice, items) + self.invoice.journal_id.sii_enabled = False + items = self.env["account.move"].search(domain_ok) + self.assertNotIn(self.invoice, items) + items = self.env["account.move"].search(domain_ko_1) + self.assertIn(self.invoice, items) + items = self.env["account.move"].search(domain_ko_2) + self.assertIn(self.invoice, items) + def test_intracomunitary_customer_extracomunitary_delivery(self): """Comprobar venta a un cliente intracomunitario enviada al extranjero. diff --git a/l10n_es_aeat_sii_oca/views/account_move_views.xml b/l10n_es_aeat_sii_oca/views/account_move_views.xml index c0f8819dda1..f3b4ca9fde5 100644 --- a/l10n_es_aeat_sii_oca/views/account_move_views.xml +++ b/l10n_es_aeat_sii_oca/views/account_move_views.xml @@ -202,7 +202,7 @@