Skip to Content
Menu
You need to be registered to interact with the community.
This question has been flagged
1 Odgovori
3023 Prikazi

How can I limit number of invoice created for customers. For the example 1 customers only can have 2 invoices at the same times, it will raise warn if they create the 3rd invoice, any suggestion? thank you so much if anybody can help


Best Regards, Faalih

Avatar
Opusti
Best Answer

Hi,

You can inherit the account.move model if you are using odoo 13 and account.invoice model if you are using odoo12 and below and add the following constrains.

from odoo.exceptions import ValidationError


class AccountMove(models.Model):
_inherit = "account.move"

@api.constrains('partner_id')
def check_partner_id(self):
for rec in self:
invoices = self.search([('partner_id', '=', rec.partner_id.id),
('id', '!=', rec.id), ('state', '=', 'draft')])
if invoices and len(invoices) > 2:
raise ValidationError(_("You cannot have more than two draft invoice at a time."))

Then it will show validation error like this. Adjust the search domain if you need to consider only the customer invoice.



Thanks

Avatar
Opusti
Related Posts Odgovori Prikazi Aktivnost
1
nov. 21
5868
2
feb. 25
1438
2
jun. 24
2004
1
jun. 24
2913
0
jul. 23
1401