136 lines
6.1 KiB
Python
136 lines
6.1 KiB
Python
# -*- coding: utf-8 -*-
|
|
# Part of Odoo, Flectra. See LICENSE file for full copyright and licensing details.
|
|
|
|
from datetime import date
|
|
from dateutil.relativedelta import relativedelta
|
|
|
|
from flectra import api, fields, models, _
|
|
from flectra.exceptions import ValidationError
|
|
|
|
|
|
class Employee(models.Model):
|
|
|
|
_inherit = "hr.employee"
|
|
|
|
manager = fields.Boolean(string='Is a Manager')
|
|
medic_exam = fields.Date(string='Medical Examination Date', groups="hr.group_hr_user")
|
|
place_of_birth = fields.Char('Place of Birth', groups="hr.group_hr_user")
|
|
children = fields.Integer(string='Number of Children', groups="hr.group_hr_user")
|
|
vehicle = fields.Char(string='Company Vehicle', groups="hr.group_hr_user")
|
|
vehicle_distance = fields.Integer(
|
|
string='Home-Work Dist.', help="In kilometers", groups="hr.group_hr_user")
|
|
contract_ids = fields.One2many('hr.contract', 'employee_id', string='Contracts')
|
|
contract_id = fields.Many2one('hr.contract', compute='_compute_contract_id', string='Current Contract', help='Latest contract of the employee')
|
|
contracts_count = fields.Integer(compute='_compute_contracts_count', string='Contracts')
|
|
|
|
def _compute_contract_id(self):
|
|
""" get the lastest contract """
|
|
Contract = self.env['hr.contract']
|
|
for employee in self:
|
|
employee.contract_id = Contract.search([('employee_id', '=', employee.id)], order='date_start desc', limit=1)
|
|
|
|
def _compute_contracts_count(self):
|
|
# read_group as sudo, since contract count is displayed on form view
|
|
contract_data = self.env['hr.contract'].sudo().read_group([('employee_id', 'in', self.ids)], ['employee_id'], ['employee_id'])
|
|
result = dict((data['employee_id'][0], data['employee_id_count']) for data in contract_data)
|
|
for employee in self:
|
|
employee.contracts_count = result.get(employee.id, 0)
|
|
|
|
|
|
class ContractType(models.Model):
|
|
|
|
_name = 'hr.contract.type'
|
|
_description = 'Contract Type'
|
|
_order = 'sequence, id'
|
|
|
|
name = fields.Char(string='Contract Type', required=True)
|
|
sequence = fields.Integer(help="Gives the sequence when displaying a list of Contract.", default=10)
|
|
|
|
|
|
class Contract(models.Model):
|
|
|
|
_name = 'hr.contract'
|
|
_description = 'Contract'
|
|
_inherit = ['mail.thread']
|
|
|
|
name = fields.Char('Contract Reference', required=True)
|
|
employee_id = fields.Many2one('hr.employee', string='Employee')
|
|
department_id = fields.Many2one('hr.department', string="Department")
|
|
type_id = fields.Many2one('hr.contract.type', string="Contract Type", required=True, default=lambda self: self.env['hr.contract.type'].search([], limit=1))
|
|
job_id = fields.Many2one('hr.job', string='Job Position')
|
|
date_start = fields.Date('Start Date', required=True, default=fields.Date.today,
|
|
help="Start date of the contract.")
|
|
date_end = fields.Date('End Date',
|
|
help="End date of the contract (if it's a fixed-term contract).")
|
|
trial_date_end = fields.Date('End of Trial Period',
|
|
help="End date of the trial period (if there is one).")
|
|
resource_calendar_id = fields.Many2one(
|
|
'resource.calendar', 'Working Schedule',
|
|
default=lambda self: self.env['res.company']._company_default_get().resource_calendar_id.id)
|
|
wage = fields.Monetary('Wage', digits=(16, 2), required=True, track_visibility="onchange", help="Employee's monthly gross wage.")
|
|
advantages = fields.Text('Advantages')
|
|
notes = fields.Text('Notes')
|
|
state = fields.Selection([
|
|
('draft', 'New'),
|
|
('open', 'Running'),
|
|
('pending', 'To Renew'),
|
|
('close', 'Expired'),
|
|
('cancel', 'Cancelled')
|
|
], string='Status', group_expand='_expand_states',
|
|
track_visibility='onchange', help='Status of the contract', default='draft')
|
|
company_id = fields.Many2one('res.company', default=lambda self: self.env.user.company_id)
|
|
currency_id = fields.Many2one(string="Currency", related='company_id.currency_id', readonly=True)
|
|
permit_no = fields.Char('Work Permit No', related="employee_id.permit_no")
|
|
visa_no = fields.Char('Visa No', related="employee_id.visa_no")
|
|
visa_expire = fields.Date('Visa Expire Date', related="employee_id.visa_expire")
|
|
|
|
def _expand_states(self, states, domain, order):
|
|
return [key for key, val in type(self).state.selection]
|
|
|
|
@api.onchange('employee_id')
|
|
def _onchange_employee_id(self):
|
|
if self.employee_id:
|
|
self.job_id = self.employee_id.job_id
|
|
self.department_id = self.employee_id.department_id
|
|
self.resource_calendar_id = self.employee_id.resource_calendar_id
|
|
|
|
@api.constrains('date_start', 'date_end')
|
|
def _check_dates(self):
|
|
if self.filtered(lambda c: c.date_end and c.date_start > c.date_end):
|
|
raise ValidationError(_('Contract start date must be less than contract end date.'))
|
|
|
|
@api.model
|
|
def update_state(self):
|
|
self.search([
|
|
('state', '=', 'open'),
|
|
'|',
|
|
'&',
|
|
('date_end', '<=', fields.Date.to_string(date.today() + relativedelta(days=7))),
|
|
('date_end', '>=', fields.Date.to_string(date.today() + relativedelta(days=1))),
|
|
'&',
|
|
('visa_expire', '<=', fields.Date.to_string(date.today() + relativedelta(days=60))),
|
|
('visa_expire', '>=', fields.Date.to_string(date.today() + relativedelta(days=1))),
|
|
]).write({
|
|
'state': 'pending'
|
|
})
|
|
|
|
self.search([
|
|
('state', 'in', ('open', 'pending')),
|
|
'|',
|
|
('date_end', '<=', fields.Date.to_string(date.today() + relativedelta(days=1))),
|
|
('visa_expire', '<=', fields.Date.to_string(date.today() + relativedelta(days=1))),
|
|
]).write({
|
|
'state': 'close'
|
|
})
|
|
|
|
return True
|
|
|
|
@api.multi
|
|
def _track_subtype(self, init_values):
|
|
self.ensure_one()
|
|
if 'state' in init_values and self.state == 'pending':
|
|
return 'hr_contract.mt_contract_pending'
|
|
elif 'state' in init_values and self.state == 'close':
|
|
return 'hr_contract.mt_contract_close'
|
|
return super(Contract, self)._track_subtype(init_values)
|