account_interest.py 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  1. # -*- coding: utf-8 -*-
  2. from openerp import models, fields, tools, api
  3. import openerp.addons.decimal_precision as dp
  4. from datetime import datetime
  5. from openerp.exceptions import ValidationError
  6. import logging
  7. _logger = logging.getLogger(__name__)
  8. class AccountInterest(models.Model):
  9. _name = 'account.interest'
  10. name = fields.Char()
  11. date = fields.Date('Date', help="Fecha de operación")
  12. comment = fields.Text('Comment', help="Información adicional")
  13. state = fields.Selection([('lines_paid', 'Sin interés'),('lines_open', 'Interés a cobrar.'),('paid', 'Factura pagada')],'Estado del pago', default="lines_open", help="Estado")
  14. ## Cliente
  15. customer_id = fields.Many2one('res.partner', string="customer")
  16. ## factura
  17. invoice_id = fields.Many2one('account.invoice', string='Invoice Reference', ondelete='restrict', index=True)
  18. reference = fields.Char(string='Invoice Reference', help="Invoice Reference")
  19. ## Currency
  20. currency_id = fields.Many2one('res.currency', string="Currency", help="Moneda de la operación")
  21. ## Line
  22. lines_ids = fields.One2many('account.interest.line', 'interest_id', string='interest line')
  23. '''
  24. Create
  25. '''
  26. @api.model
  27. def create(self, vals):
  28. interest = super(AccountInterest, self).create(vals)
  29. interest.write({'name':("INTEREST/%06d" % (interest.id))})
  30. return interest
  31. '''
  32. Unlink
  33. '''
  34. @api.multi
  35. def unlink(self):
  36. interestLine = self.env['account.interest.line'].search([('interest_id.id', '=', self.id)])
  37. invoice_ids = map(lambda x: x.invoice.id, interestLine)
  38. moves_ids = map(lambda x: x.move_line_id.id, interestLine)
  39. invoiceNumber = ""
  40. invoice = self.env['account.invoice'].search([('id', 'in', invoice_ids)])
  41. if (invoice):
  42. for invoiceN in invoice:
  43. invoiceNumber += "%s, " % (invoiceN.number)
  44. raise ValidationError('Existe relacion de la lineas de interes con las facturas (%s)' % (invoiceNumber))
  45. return False
  46. moveLine = self.env['account.move.line'].search([('id', 'in', moves_ids)])
  47. for lineMove in moveLine:
  48. lineMove.write({'date_interest': lineMove.date_maturity})
  49. return super(AccountInterest, self).unlink()
  50. ''' Invoice '''
  51. class accountInvoiceInterest(models.Model):
  52. _inherit = 'account.invoice'
  53. interest_ids = fields.One2many('account.interest', 'invoice_id', string=' Account Interest')
  54. is_interest = fields.Boolean('Factura de interés', default=False, help="Indica si esta factura fue generado por un interés.")
  55. interest_line_ids = fields.One2many('account.interest.line', 'invoice', string=' Account Interest Line')
  56. ''' Unlink Invoice '''
  57. @api.multi
  58. def unlink(self):
  59. interestLine = self.env['account.interest.line'].search([('invoice.id', '=', self.id)])
  60. for line in interestLine:
  61. moveLine = self.env['account.move.line'].browse(line.move_line_id.id)
  62. if (moveLine):
  63. moveLine.write({'date_interest': moveLine.date_maturity})
  64. line.write({
  65. 'state': 'open',
  66. 'reference': ''
  67. })
  68. return super(accountInvoiceInterest, self).unlink()
  69. @api.multi
  70. def write(self, vals):
  71. invoice = super(accountInvoiceInterest, self).write(vals)
  72. ''' Cambiar estado de lineas de interés'''
  73. interestLinesIDS = self._change_state_account_interest_line(self)
  74. ''' Cambiar estado del interés '''
  75. interest= self._change_state_account_interest(self)
  76. return invoice
  77. ''' Cambiar estado de lineas de interés '''
  78. def _change_state_account_interest_line(self, invoice):
  79. _logger.info('Change state account.interest.line.')
  80. linesIds = []
  81. if (invoice.interest_line_ids):
  82. linesIds = map(lambda x: x.id, invoice.interest_line_ids)
  83. if (invoice.interest_ids):
  84. linesIds = map(lambda x: x.id, invoice.interest_ids.lines_ids)
  85. if (linesIds):
  86. interestLine = self.env['account.interest.line'].search([('id', 'in', linesIds)])
  87. state = []
  88. for line in interestLine:
  89. lineInvoice = self.env['account.invoice'].browse(line.invoice.id)
  90. if (not lineInvoice):
  91. state = {'state': 'open'}
  92. if (lineInvoice.state == 'open'):
  93. state = {'state': 'invoiced'}
  94. if (lineInvoice.state == 'cancel'):
  95. state = {'state': 'invoice_cancel'}
  96. if (lineInvoice.state == 'draft'):
  97. state = {'state': 'invoice_draft'}
  98. if (lineInvoice.state == 'paid'):
  99. state = {'state': 'paid'}
  100. if (state):
  101. line.write(state)
  102. return True
  103. ''' Cambiar el Estado del account.interest '''
  104. def _change_state_account_interest(self, invoice):
  105. _logger.info('Change state account.interest')
  106. interestIds = []
  107. state = []
  108. if (invoice.interest_line_ids):
  109. interestIds = map(lambda x: x.interest_id.id, invoice.interest_line_ids)
  110. if (invoice.interest_ids):
  111. interestIds = map(lambda x: x.id, invoice.interest_ids)
  112. if (interestIds):
  113. accountInterest = self.env['account.interest'].search([('id', 'in', interestIds)])
  114. if (accountInterest.lines_ids):
  115. linesState = map(lambda x: x.state, accountInterest.lines_ids)
  116. if (('discount'in linesState) or ('paid' in linesState)):
  117. state ={ 'state': 'lines_paid'}
  118. if ((accountInterest.invoice_id.id == invoice.id) and (invoice.state == 'paid')):
  119. state ={ 'state': 'paid'}
  120. if (('invoiced' in linesState) or ('invoice_cancel' in linesState) or ('invoice_draft' in linesState) or ('open' in linesState)):
  121. state ={'state': 'lines_open'}
  122. if (state):
  123. accountInterest.write(state)
  124. return True
  125. ''' Verify Status Invoice and interest '''
  126. @api.model
  127. def eiru_invoice_verify_status(self):
  128. invoices = self.env['account.invoice'].search([('type', '=', 'out_invoice')])
  129. for invoice in invoices:
  130. interestLine = self._change_state_account_interest_line(invoice)
  131. interest = self._change_state_account_interest(invoice)
  132. return True
  133. ''' Partner '''
  134. class ResPartnerInterest(models.Model):
  135. _inherit = 'res.partner'
  136. interest_ids = fields.One2many('account.interest', 'customer_id', string=' Account Interest')
  137. class AccountInterestLine(models.Model):
  138. _name = 'account.interest.line'
  139. ## Interest
  140. interest_id = fields.Many2one('account.interest', string='Account Interest', ondelete='cascade', index=True, required=True)
  141. move_line_id = fields.Many2one('account.move.line', string="Registros del diario", help="Registros del diario")
  142. amount = fields.Float('amount', digits_compute=dp.get_precision('Account'), required=True, help="Monto del pago")
  143. amount_residual = fields.Float('amount', digits_compute=dp.get_precision('Account'), required=True, help="Monto del pago")
  144. amount_interest = fields.Float('amount', digits_compute=dp.get_precision('Account'), required=True, help="Monto del pago")
  145. date_maturity = fields.Date()
  146. expired_days = fields.Integer('Expired Days ')
  147. invoice = fields.Many2one('account.invoice', string='Invoice Reference', index=True)
  148. reference = fields.Char(string='Invoice Reference', help="Invoice Reference")
  149. state = fields.Selection([ ('discount','Descuento total'),
  150. ('open','Abierto'),
  151. ('invoiced','Facturado'),
  152. ('invoice_cancel', 'Factura Cancelada'),
  153. ('invoice_draft', 'Factura Borrador'),
  154. ('paid', 'Pagado')],'Estado del pago de la linea ', default="open")
  155. amount_dicount = fields.Float('amount disconut', digits_compute=dp.get_precision('Account'), help="Monto del descuento")
  156. '''
  157. Move Line
  158. '''
  159. class accountMoveLineInterest(models.Model):
  160. _inherit = 'account.move.line'
  161. interest_line_ids = fields.One2many('account.interest.line', 'move_line_id', string=' Account Interest Line')
  162. date_interest = fields.Date("Date interés", help="Fecha de la facturación de os interés")