2
0
account-financial-tools/account_invoice_constraint_chronology/model/account_invoice.py

60 lines
2.7 KiB
Python
Raw Normal View History

# Copyright 2015-2019 ACSONE SA/NV (<http://acsone.eu>)
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html).
import datetime
from odoo import models, api, fields, _
from odoo.exceptions import UserError
2017-03-14 19:09:03 +01:00
class AccountInvoice(models.Model):
_inherit = "account.invoice"
@api.multi
def action_move_create(self):
previously_validated = self.filtered(lambda inv: inv.move_name)
2017-03-14 19:09:03 +01:00
res = super(AccountInvoice, self).action_move_create()
for inv in self:
if inv.journal_id.check_chronology:
invoices = \
self.search([('state', 'not in',
['open', 'paid', 'cancel', 'proforma',
'proforma2']),
('date_invoice', '!=', False),
('date_invoice', '<', inv.date_invoice),
('journal_id', '=', inv.journal_id.id)],
limit=1)
if invoices:
date_invoice_format = datetime.datetime(
year=inv.date_invoice.year,
month=inv.date_invoice.month,
day=inv.date_invoice.day,
)
date_invoice_tz = fields.Date.context_today(
self, date_invoice_format)
raise UserError(_("Chronology Error. "
"Please confirm older draft "
"invoices before %s and try again.")
% date_invoice_tz)
if inv not in previously_validated:
invoices = self.search([('state', 'in', ['open', 'paid']),
('date_invoice', '>',
inv.date_invoice),
('journal_id', '=',
inv.journal_id.id)],
limit=1)
if invoices:
date_invoice_format = datetime.datetime(
year=inv.date_invoice.year,
month=inv.date_invoice.month,
day=inv.date_invoice.day,
)
date_invoice_tz = fields.Date.context_today(
self, date_invoice_format)
raise UserError(_("Chronology Error. "
"There exist at least one invoice "
2018-01-12 10:46:29 +01:00
"with a later date to %s.") %
date_invoice_tz)
return res