From 5c2457b47057cd20fe2ef2c193192af7f8893970 Mon Sep 17 00:00:00 2001 From: Pablo Montenegro Date: Tue, 17 May 2022 16:07:17 -0300 Subject: [PATCH] [IMP]account_ux:prevent currency change when the invoice is not draft Ticket: 51808 --- account_ux/__manifest__.py | 2 +- account_ux/wizards/account_change_currency.py | 9 ++++++++- 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/account_ux/__manifest__.py b/account_ux/__manifest__.py index b15a45c43..c7550440f 100644 --- a/account_ux/__manifest__.py +++ b/account_ux/__manifest__.py @@ -19,7 +19,7 @@ ############################################################################## { 'name': 'Account UX', - 'version': "13.0.1.24.0", + 'version': "13.0.1.25.0", 'category': 'Accounting', 'sequence': 14, 'summary': '', diff --git a/account_ux/wizards/account_change_currency.py b/account_ux/wizards/account_change_currency.py index 110a24384..d3cb0589a 100644 --- a/account_ux/wizards/account_change_currency.py +++ b/account_ux/wizards/account_change_currency.py @@ -3,7 +3,7 @@ # directory ############################################################################## from odoo import fields, models, api, _ - +from odoo.exceptions import ValidationError class AccountChangeCurrency(models.TransientModel): _name = 'account.change.currency' @@ -55,6 +55,13 @@ def onchange_currency(self): date=self.move_id.date or fields.Date.context_today(self)) + @api.constrains('currency_to_id', 'currency_rate') + def _prevent_change_currency(self): + """prevent currency or currency rate change when the invoice is not draft + """ + if self.move_id.state != 'draft': + raise ValidationError(_('This invoice is not draft, reset it to draft to change currency or currency rate')) + def change_currency(self): self.ensure_one() if self.change_type == 'currency':