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.
149 lines
6.5 KiB
149 lines
6.5 KiB
# -*- coding: utf-8 -*-
|
|
###############################################################################
|
|
#
|
|
# Cybrosys Technologies Pvt. Ltd.
|
|
#
|
|
# Copyright (C) 2025-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
|
|
# Author: Afra K (odoo@cybrosys.com)
|
|
#
|
|
# You can modify it under the terms of the GNU AFFERO
|
|
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
|
|
#
|
|
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
|
|
# (AGPL v3) along with this program.
|
|
# If not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
###############################################################################
|
|
from datetime import datetime
|
|
from odoo import fields, models
|
|
|
|
|
|
class CreditDetails(models.Model):
|
|
"""
|
|
Model for managing credit details associated with customers.
|
|
"""
|
|
_name = "credit.details"
|
|
_description = "Credit Details"
|
|
_rec_name = 'customer_id'
|
|
|
|
credit_id = fields.Many2one(
|
|
'credit.amount',
|
|
help='Reference to the associated credit amount record.')
|
|
customer_id = fields.Many2one(
|
|
'res.partner', string='Customer',
|
|
help='Reference to the associated customer/partner.')
|
|
credit_amount = fields.Float(
|
|
"Credit", compute='_compute_credit_amount',
|
|
help='Representing the total credit amount associated with this '
|
|
'record.')
|
|
debit_amount = fields.Float(
|
|
"Debit", compute='_compute_debit_amount',
|
|
help='Representing the total debit amount associated with this record.')
|
|
credit_details_amount = fields.Float(
|
|
"Credit Details", compute='_compute_credit_details_amount',
|
|
help='Representing the total credit details amount associated with '
|
|
'this record.')
|
|
updated_amount = fields.Float(
|
|
"Update", help='Field used for updating the credit amount.')
|
|
credit_details_ids = fields.One2many(
|
|
'credit.detail.lines', 'credit_id',
|
|
help='Credit detail lines associated with this record.')
|
|
debit_details_ids = fields.One2many(
|
|
'debit.detail.lines', 'debit_id',
|
|
help='Debit detail lines associated with this record.')
|
|
_is_amount_updated = fields.Boolean(
|
|
string='to check whether the credit is updated with accounts')
|
|
|
|
def _compute_credit_amount(self):
|
|
""" Function to compute the credit amount """
|
|
for rec in self:
|
|
rec.credit_amount = 0.0
|
|
if rec.credit_details_ids:
|
|
rec.credit_amount = sum(
|
|
rec.credit_details_ids.mapped('amount'))
|
|
|
|
def _compute_debit_amount(self):
|
|
""""" Function to compute the debit amount """
|
|
for rec in self:
|
|
rec.debit_amount = 0.0
|
|
if rec.debit_details_ids:
|
|
rec.debit_amount = sum(
|
|
rec.debit_details_ids.mapped('debit_amount'))
|
|
|
|
def _compute_credit_details_amount(self):
|
|
""" Function to compute the credit details amount """
|
|
for rec in self:
|
|
rec.credit_details_amount = 0.0
|
|
rec.credit_details_amount = rec.credit_amount + rec.debit_amount
|
|
|
|
def _compute_amount_updated(self):
|
|
for rec in self:
|
|
if rec.credit_details_ids.mapped(
|
|
'previous_credit_amount').pop() < rec.credit_details_amount:
|
|
rec._is_amount_updated = True
|
|
|
|
def action_update_account(self):
|
|
""" Function to update the amount in the account payment"""
|
|
self._is_amount_updated = True
|
|
return {
|
|
'name': 'Credit Payment',
|
|
'view_mode': 'form',
|
|
'res_model': 'credit.payment',
|
|
'type': 'ir.actions.act_window',
|
|
'context': {'default_partner_id': self.customer_id.id,
|
|
'default_credit_amount': self.credit_details_ids.mapped(
|
|
'amount').pop(),
|
|
'default_payment_journal': self.env[
|
|
'account.journal'].search([('type', '=', 'bank')],
|
|
limit=1).id,
|
|
'default_credit_detail_id': self.id,
|
|
},
|
|
'target': 'new'
|
|
}
|
|
|
|
|
|
class CreditDetailsLines(models.Model):
|
|
""" Model for managing credit detail lines associated with credit details"""
|
|
_name = "credit.detail.lines"
|
|
_description = "Credit Detail Lines"
|
|
|
|
credit_id = fields.Many2one('credit.details', string=" Credit Id",
|
|
help="Credit detail associate with this "
|
|
"record.")
|
|
customer_id = fields.Many2one('res.partner', string="Customer details",
|
|
help="Customer details")
|
|
amount = fields.Float(string='Amount',
|
|
help="Total credit amount associated with the "
|
|
"partner.")
|
|
previous_credit_amount = fields.Float(string='Previous Credit Amount',
|
|
help='The previous credit amount')
|
|
approve_date = fields.Datetime(string='Approve Date',
|
|
default=datetime.today(),
|
|
help='Approved date of the credit amount')
|
|
updated_amount = fields.Float(string='Updated Amount',
|
|
help='Updated amount')
|
|
|
|
|
|
class DebitDetailsLines(models.Model):
|
|
""" Model for managing debit detail lines associated with credit details """
|
|
_name = "debit.detail.lines"
|
|
_description = "Debit Detail lines"
|
|
|
|
debit_id = fields.Many2one('credit.details', string=" Credit Id",
|
|
help="Credit detail associate with this record.")
|
|
customer_id = fields.Many2one('res.partner', string="Customer details",
|
|
help="Customer details")
|
|
debit_amount = fields.Float(string='Amount',
|
|
help="Total credit amount associated with the "
|
|
"partner.")
|
|
previous_debit_amount = fields.Float(string='Previous Debit Amount',
|
|
help='The previous credit amount')
|
|
approve_date = fields.Datetime('Approve Date', default=datetime.today(),
|
|
help='Approved date of the credit amount')
|
|
updated_amount = fields.Float(string='Updated Amount',
|
|
help='Updated amount')
|
|
|