You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

104 lines
3.2 KiB

# -*- coding: utf-8 -*-
# Copyright (C) 2017 Creu Blanca
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl.html).
from odoo import api, fields, models
class CashInvoiceOut(models.TransientModel):
_name = 'cash.invoice.out'
_inherit = 'cash.box.in'
def _default_value(self, default_function):
active_model = self.env.context.get('active_model', False)
if active_model:
active_ids = self.env.context.get('active_ids', False)
return default_function(active_model, active_ids)
return None
def _default_company(self):
return self._default_value(self.default_company)
def _default_currency(self):
return self._default_value(self.default_currency)
def _default_journals(self):
return self._default_value(self.default_journals)
def _default_journal(self):
journals = self._default_journals()
if journals and len(journals.ids) > 0:
return self.env['account.journal'].browse(
journals.ids[0]
).ensure_one()
def _default_journal_count(self):
return len(self._default_journals())
invoice_id = fields.Many2one(
'account.invoice',
string='Invoice',
required=True
)
name = fields.Char(
related='invoice_id.number'
)
company_id = fields.Many2one(
'res.company',
default=_default_company,
required=True,
readonly=True
)
currency_id = fields.Many2one(
'res.currency',
default=_default_currency,
required=True,
readonly=True)
journal_ids = fields.Many2many(
'account.journal',
default=_default_journals,
required=True,
readonly=True
)
journal_id = fields.Many2one(
'account.journal',
required=True,
default=_default_journal
)
journal_count = fields.Integer(
default=_default_journal_count,
readonly=True
)
def default_company(self, active_model, active_ids):
return self.env[active_model].browse(active_ids)[0].company_id
def default_currency(self, active_model, active_ids):
return self.default_company(active_model, active_ids).currency_id
def default_journals(self, active_model, active_ids):
return self.env[active_model].browse(active_ids)[0].journal_id
@api.onchange('journal_ids')
def compute_journal_count(self):
self.journal_count = len(self.journal_ids.ids)
@api.onchange('journal_id')
def _onchange_journal(self):
self.currency_id = (self.journal_id.currency_id or
self.journal_id.company_id.currency_id)
@api.onchange('invoice_id')
def _onchange_invoice(self):
self.amount = self.invoice_id.residual
@api.multi
def _calculate_values_for_statement_line(self, record):
res = super(CashInvoiceOut, self)._calculate_values_for_statement_line(
record
)
res['invoice_id'] = self.invoice_id.id
res['account_id'] = self.invoice_id.account_id.id
res['ref'] = self.invoice_id.number
res['partner_id'] = self.invoice_id.partner_id.id
return res