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.
80 lines
3.3 KiB
80 lines
3.3 KiB
# -*- coding: utf-8 -*-
|
|
#############################################################################
|
|
#
|
|
# Cybrosys Technologies Pvt. Ltd.
|
|
#
|
|
# Copyright (C) 2019-TODAY Cybrosys Technologies(<https://www.cybrosys.com>).
|
|
# Author: Cybrosys Techno Solutions(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 odoo import models, fields, api, _
|
|
from odoo.exceptions import UserError
|
|
|
|
|
|
class EmployeeDetails(models.Model):
|
|
_name = 'employee.details'
|
|
|
|
name = fields.Char(string='Name', required=True)
|
|
related_partner = fields.Many2one('res.users', string='Related User', copy=False)
|
|
sex = fields.Selection([('male', 'Male'), ('female', 'Female')])
|
|
phone = fields.Float(string='Phone Number', size=15, digits=(15, 0))
|
|
salary_type = fields.Selection([('fixed', 'Fixed'), ('commission', 'Commission'), ('both', 'Both')],
|
|
default='commission', required=True)
|
|
base_salary = fields.Integer(string='Base Salary')
|
|
last_salary = fields.Date(string='Last Payment On', copy=False)
|
|
insurance_ids = fields.One2many('insurance.details', 'employee_id', string='Last Payment On', readonly=True)
|
|
note_field = fields.Html(string='Comment')
|
|
invoice_id = fields.Many2one('account.move', string='Last payment', copy=False, readonly=True)
|
|
|
|
|
|
def salary_payment(self):
|
|
if self.invoice_id:
|
|
if self.invoice_id.state == 'draft':
|
|
raise UserError(_("You Must validate last payment made in order to create a new payment"))
|
|
amount = 0
|
|
if self.base_salary == 0:
|
|
raise UserError(_("Amount should be greater than zero"))
|
|
if self.salary_type == 'fixed':
|
|
amount = self.base_salary
|
|
elif self.salary_type == 'commission':
|
|
for ins in self.insurance_ids:
|
|
if self.last_salary:
|
|
if ins.date_start > self.last_salary:
|
|
amount += (ins.commission_rate * ins.amount)/100
|
|
else:
|
|
amount = self.base_salary
|
|
for ins in self.insurance_ids:
|
|
if ins.date_start > self.last_salary:
|
|
amount += (ins.commission_rate * ins.amount) / 100
|
|
|
|
|
|
invoice_date = self.env['account.move'].create({
|
|
'move_type': 'in_invoice',
|
|
'partner_id': self.related_partner.partner_id.id,
|
|
'invoice_user_id': self.env.user.id,
|
|
'claim_id': self.id,
|
|
'invoice_origin': self.name,
|
|
'invoice_line_ids': [(0, 0, {
|
|
'name': 'Invoice For Insurance Claim',
|
|
'quantity': 1,
|
|
'price_unit': amount,
|
|
'account_id': 41,
|
|
})],
|
|
})
|
|
self.write({
|
|
'invoice_id': invoice_date.id,
|
|
'last_salary': fields.Date.today()
|
|
})
|
|
|