Skip to content

Commit

Permalink
[IMP] l10n_fr_account_vat_return: reconciliation of 445670 now possible
Browse files Browse the repository at this point in the history
  • Loading branch information
alexis-via committed Nov 22, 2024
1 parent 5dad1c9 commit 8207b50
Showing 1 changed file with 19 additions and 1 deletion.
20 changes: 19 additions & 1 deletion l10n_fr_account_vat_return/models/l10n_fr_account_vat_return.py
Original file line number Diff line number Diff line change
Expand Up @@ -963,7 +963,7 @@ def _generate_credit_deferment(self, speedy):
raise UserError(
_(
"The balance of account '%(account)s' is %(balance)s. "
"It should always be positive.",
"It should always be positive or null.",
account=account.display_name,
balance=format_amount(self.env, balance, speedy["currency"]),
)
Expand Down Expand Up @@ -2041,20 +2041,38 @@ def _reconcile_account_move(self, move, speedy):
["origin_move_id"],
)
excluded_line_ids = [x["origin_move_id"][0] for x in excluded_lines]
# to allow reconciliation of 445670, we need to exclude the debit line
# from the reconciliation to have a balance at 0
credit_vat_account = self._get_box_account(
speedy["meaning_id2box"]["credit_deferment"]
)
credit_vat_debit_mline = speedy["aml_obj"].search(
[
("move_id", "=", move.id),
("account_id", "=", credit_vat_account.id),
("debit", ">", 0.9),
],
limit=1,
)
for line in move.line_ids.filtered(lambda x: x.account_id.reconcile):
account = line.account_id
domain = speedy["base_domain_end"] + [
("account_id", "=", account.id),
("full_reconcile_id", "=", False),
("move_id", "not in", excluded_line_ids),
]
if account == credit_vat_account and credit_vat_debit_mline:
domain.append(("id", "!=", credit_vat_debit_mline.id))
rg_res = speedy["aml_obj"].read_group(domain, ["balance"], [])
# or 0 is need to avoid a crash: rg_res[0]["balance"] = None
# when the moves are already reconciled
if rg_res and speedy["currency"].is_zero(rg_res[0]["balance"] or 0):
moves_to_reconcile = speedy["aml_obj"].search(domain)
moves_to_reconcile.remove_move_reconcile()
moves_to_reconcile.reconcile()
logger.info(
"Successful reconciliation in account %s", account.display_name
)

def _create_draft_account_move(self, speedy):
self.ensure_one()
Expand Down

0 comments on commit 8207b50

Please sign in to comment.