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.

182 lines
7.7 KiB

  1. # Copyright 2019 Coop IT Easy SCRL fs
  2. # Houssine BAKKALI <houssine@coopiteasy.be>
  3. # License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html).
  4. import logging
  5. from odoo import api, fields, models, _
  6. _logger = logging.getLogger(__name__)
  7. class LoanIssue(models.Model):
  8. _name = 'loan.issue'
  9. _description = 'Loan Issue'
  10. @api.multi
  11. def _compute_subscribed_amount(self):
  12. for issue in self:
  13. susbscribed_amount = 0.0
  14. for line in issue.loan_issue_lines.filtered(
  15. lambda record: record.state != 'cancelled'):
  16. susbscribed_amount += line.amount
  17. issue.subscribed_amount = susbscribed_amount
  18. name = fields.Char(string="Name",
  19. translate=True)
  20. default_issue = fields.Boolean(string="Default issue")
  21. subscription_start_date = fields.Date(string="Start date subscription period")
  22. subscription_end_date = fields.Date(string="End date subscription period")
  23. user_id = fields.Many2one('res.users',
  24. string="Responsible")
  25. term_date = fields.Date(string="Term date")
  26. loan_term = fields.Float(string="Duration of the loan in month")
  27. rate = fields.Float(string="Interest rate")
  28. face_value = fields.Monetary(string="Facial value",
  29. currency_field='company_currency_id',
  30. required=True)
  31. minimum_amount = fields.Monetary(string="Minimum amount of issue",
  32. currency_field='company_currency_id')
  33. maximum_amount = fields.Monetary(string="Maximum amount of issue",
  34. currency_field='company_currency_id')
  35. min_amount_company = fields.Monetary(string="Minimum amount for a company",
  36. currency_field='company_currency_id')
  37. max_amount_company = fields.Monetary(string="Maximum amount for a company",
  38. currency_field='company_currency_id')
  39. min_amount_person = fields.Monetary(string="Minimum amount for a person",
  40. currency_field='company_currency_id')
  41. max_amount_person = fields.Monetary(string="Maximum amount for a person",
  42. currency_field='company_currency_id')
  43. subscribed_amount = fields.Monetary(string="Subscribed amount",
  44. compute="_compute_subscribed_amount",
  45. currency_field='company_currency_id')
  46. interest_payment = fields.Selection([('end', 'End'),
  47. ('yearly', 'Yearly')],
  48. string="Interest payment")
  49. interest_payment_info = fields.Char(string="Yearly payment on")
  50. loan_issue_lines = fields.One2many('loan.issue.line',
  51. 'loan_issue_id',
  52. string="Loan issue lines")
  53. state = fields.Selection([('draft', 'Draft'),
  54. ('confirmed', 'Confirmed'),
  55. ('cancelled', 'Cancelled'),
  56. ('ongoing', 'Ongoing'),
  57. ('closed', 'Closed')],
  58. string="State",
  59. default='draft')
  60. company_currency_id = fields.Many2one('res.currency',
  61. related='company_id.currency_id',
  62. string="Company Currency",
  63. readonly=True)
  64. company_id = fields.Many2one('res.company',
  65. string='Company',
  66. required=True,
  67. readonly=True,
  68. default=lambda self: self.env['res.company']._company_default_get()) # noqa
  69. by_company = fields.Boolean(string="By company")
  70. by_individual = fields.Boolean(string='By individuals')
  71. display_on_website = fields.Boolean(sting='Display on website')
  72. taxes_rate = fields.Float(string="Taxes on interest",
  73. required=True)
  74. @api.multi
  75. def get_max_amount(self, partner):
  76. lines = self.loan_issue_lines.filtered(
  77. lambda r: r.partner_id == partner and r.state != 'cancelled')
  78. already_subscribed = sum(line.amount for line in lines)
  79. if partner.is_company:
  80. max_amount = self.max_amount_company - already_subscribed
  81. else:
  82. max_amount = self.max_amount_person - already_subscribed
  83. return max_amount
  84. # @api.multi
  85. # def toggle_display(self):
  86. # for loan_issue in self:
  87. # loan_issue.display_on_website = not loan_issue.display_on_website
  88. @api.multi
  89. def get_web_issues(self, is_company):
  90. bond_issues = self.search([
  91. ('display_on_website', '=', True),
  92. ('state', '=', 'ongoing')
  93. ])
  94. if is_company is True:
  95. return bond_issues.filtered('by_company')
  96. else:
  97. return bond_issues.filtered('by_company')
  98. @api.multi
  99. def action_confirm(self):
  100. self.ensure_one()
  101. self.write({'state': 'confirmed'})
  102. @api.multi
  103. def action_open(self):
  104. self.ensure_one()
  105. self.write({'state': 'ongoing'})
  106. @api.multi
  107. def action_draft(self):
  108. self.ensure_one()
  109. self.write({'state': 'draft'})
  110. @api.multi
  111. def action_cancel(self):
  112. self.ensure_one()
  113. self.write({'state': 'cancelled'})
  114. @api.multi
  115. def action_close(self):
  116. self.ensure_one()
  117. self.write({'state': 'closed'})
  118. def get_interest_vals(self, line, vals):
  119. interest_obj = self.env['loan.interest.line']
  120. accrued_amount = line.amount
  121. accrued_interest = 0
  122. accrued_net_interest = 0
  123. accrued_taxes = 0
  124. for year in range(1, int(self.loan_term) + 1):
  125. interest = accrued_amount * (line.loan_issue_id.rate / 100)
  126. accrued_amount += interest
  127. taxes_amount = interest * (self.taxes_rate / 100)
  128. net_interest = interest - taxes_amount
  129. accrued_interest += interest
  130. accrued_net_interest += net_interest
  131. accrued_taxes += taxes_amount
  132. vals['interest'] = interest
  133. vals['net_interest'] = net_interest
  134. vals['taxes_amount'] = taxes_amount
  135. vals['accrued_amount'] = accrued_amount
  136. vals['accrued_interest'] = accrued_interest
  137. vals['accrued_net_interest'] = accrued_net_interest
  138. vals['accrued_taxes'] = accrued_taxes
  139. vals['name'] = year
  140. interest_obj.create(vals)
  141. @api.multi
  142. def compute_loan_interest(self):
  143. self.ensure_one()
  144. if self.interest_payment == 'end':
  145. due_date = self.term_date
  146. else:
  147. raise NotImplementedError(_("Interest payment by year hasn't been "
  148. "implemented yet"))
  149. for line in self.loan_issue_lines:
  150. # TODO remove this line
  151. line.interest_lines.unlink()
  152. # Please Do not Forget
  153. vals = {
  154. 'issue_line': line.id,
  155. 'due_date': due_date,
  156. 'taxes_rate': self.taxes_rate
  157. }
  158. self.get_interest_vals(line, vals)
  159. rounded_term = int(self.loan_term)
  160. if self.loan_term - rounded_term > 0:
  161. # TODO Handle this case
  162. raise NotImplementedError(_("Calculation on non entire year "
  163. "hasn't been implemented yet"))