mirror of
https://github.com/OCA/contract.git
synced 2025-02-13 17:57:24 +02:00
[FIX] looping contract in recurring_create_invoice to support multi recordset
This commit is contained in:
@@ -16,16 +16,19 @@ class ContractContract(models.Model):
|
|||||||
@api.multi
|
@api.multi
|
||||||
def _recurring_create_invoice(self, date_ref=False):
|
def _recurring_create_invoice(self, date_ref=False):
|
||||||
invoices = super()._recurring_create_invoice(date_ref)
|
invoices = super()._recurring_create_invoice(date_ref)
|
||||||
if not self.invoicing_sales:
|
for contract in self:
|
||||||
return invoices
|
if not contract.invoicing_sales or not contract.recurring_next_date:
|
||||||
|
continue
|
||||||
sales = self.env['sale.order'].search([
|
sales = self.env['sale.order'].search([
|
||||||
('analytic_account_id', '=', self.group_id.id),
|
('analytic_account_id', '=', contract.group_id.id),
|
||||||
('partner_invoice_id', 'child_of',
|
('partner_invoice_id', 'child_of',
|
||||||
self.partner_id.commercial_partner_id.ids),
|
contract.partner_id.commercial_partner_id.ids),
|
||||||
('invoice_status', '=', 'to invoice'),
|
('invoice_status', '=', 'to invoice'),
|
||||||
('date_order', '<=',
|
('date_order', '<=',
|
||||||
'{} 23:59:59'.format(self.recurring_next_date)),
|
'{} 23:59:59'.format(contract.recurring_next_date)),
|
||||||
])
|
])
|
||||||
if sales:
|
if sales:
|
||||||
invoice_ids = sales.action_invoice_create()
|
invoice_ids = sales.action_invoice_create()
|
||||||
invoices |= self.env['account.invoice'].browse(invoice_ids)[:1]
|
invoices |= self.env['account.invoice'].browse(invoice_ids)[:1]
|
||||||
|
|
||||||
|
return invoices
|
||||||
|
|||||||
Reference in New Issue
Block a user