[FIX] looping contract in recurring_create_invoice to support multi recordset

This commit is contained in:
Harshad
2020-08-04 17:08:18 +05:30
parent 6c809f759a
commit 145692af31

View File

@@ -16,16 +16,19 @@ class ContractContract(models.Model):
@api.multi
def _recurring_create_invoice(self, date_ref=False):
invoices = super()._recurring_create_invoice(date_ref)
if not self.invoicing_sales:
return invoices
sales = self.env['sale.order'].search([
('analytic_account_id', '=', self.group_id.id),
('partner_invoice_id', 'child_of',
self.partner_id.commercial_partner_id.ids),
('invoice_status', '=', 'to invoice'),
('date_order', '<=',
'{} 23:59:59'.format(self.recurring_next_date)),
])
if sales:
invoice_ids = sales.action_invoice_create()
invoices |= self.env['account.invoice'].browse(invoice_ids)[:1]
for contract in self:
if not contract.invoicing_sales or not contract.recurring_next_date:
continue
sales = self.env['sale.order'].search([
('analytic_account_id', '=', contract.group_id.id),
('partner_invoice_id', 'child_of',
contract.partner_id.commercial_partner_id.ids),
('invoice_status', '=', 'to invoice'),
('date_order', '<=',
'{} 23:59:59'.format(contract.recurring_next_date)),
])
if sales:
invoice_ids = sales.action_invoice_create()
invoices |= self.env['account.invoice'].browse(invoice_ids)[:1]
return invoices