2018-01-16 06:58:15 +01:00
|
|
|
# -*- coding: utf-8 -*-
|
2018-01-16 11:34:37 +01:00
|
|
|
# Part of Odoo, Flectra. See LICENSE file for full copyright and licensing details.
|
2018-01-16 06:58:15 +01:00
|
|
|
|
2018-01-16 11:34:37 +01:00
|
|
|
from flectra import fields, models, _
|
2018-01-16 06:58:15 +01:00
|
|
|
|
|
|
|
|
|
|
|
class AccountInvoice(models.Model):
|
|
|
|
_inherit = 'account.invoice'
|
|
|
|
|
|
|
|
payment_tx_ids = fields.One2many('payment.transaction', 'account_invoice_id', string='Transactions')
|
|
|
|
payment_tx_id = fields.Many2one('payment.transaction', string='Last Transaction', copy=False)
|
|
|
|
payment_acquirer_id = fields.Many2one(
|
|
|
|
'payment.acquirer', string='Payment Acquirer',
|
|
|
|
related='payment_tx_id.acquirer_id', store=True)
|
|
|
|
payment_tx_count = fields.Integer(string="Number of payment transactions", compute='_compute_payment_tx_count')
|
|
|
|
|
|
|
|
def _compute_payment_tx_count(self):
|
|
|
|
tx_data = self.env['payment.transaction'].read_group(
|
|
|
|
[('account_invoice_id', 'in', self.ids)],
|
|
|
|
['account_invoice_id'], ['account_invoice_id']
|
|
|
|
)
|
|
|
|
mapped_data = dict([(m['account_invoice_id'][0], m['account_invoice_id_count']) for m in tx_data])
|
|
|
|
for invoice in self:
|
|
|
|
invoice.payment_tx_count = mapped_data.get(invoice.id, 0)
|
|
|
|
|
|
|
|
def action_view_transactions(self):
|
|
|
|
action = {
|
|
|
|
'name': _('Payment Transactions'),
|
|
|
|
'type': 'ir.actions.act_window',
|
|
|
|
'res_model': 'payment.transaction',
|
|
|
|
'target': 'current',
|
|
|
|
}
|
|
|
|
tx = self.env['payment.transaction'].search([('account_invoice_id', 'in', self.ids)])
|
|
|
|
if len(tx) == 1:
|
|
|
|
action['res_id'] = tx.ids[0]
|
|
|
|
action['view_mode'] = 'form'
|
|
|
|
else:
|
|
|
|
action['view_mode'] = 'tree,form'
|
|
|
|
action['domain'] = [('account_invoice_id', 'in', self.ids)]
|
|
|
|
return action
|