2018-01-16 11:28:15 +05:30
|
|
|
# -*- coding:utf-8 -*-
|
2018-01-16 02:34:37 -08:00
|
|
|
# Part of Odoo, Flectra. See LICENSE file for full copyright and licensing details.
|
2018-01-16 11:28:15 +05:30
|
|
|
|
2018-01-16 02:34:37 -08:00
|
|
|
from flectra import api, fields, models
|
2018-01-16 11:28:15 +05:30
|
|
|
|
|
|
|
|
|
|
|
class HrContract(models.Model):
|
|
|
|
_inherit = 'hr.contract'
|
|
|
|
|
|
|
|
car_id = fields.Many2one('fleet.vehicle', string='Company Car',
|
|
|
|
domain=lambda self: self._get_available_cars_domain(),
|
|
|
|
default=lambda self: self.env['fleet.vehicle'].search([('driver_id', '=', self.employee_id.address_home_id.id)], limit=1),
|
2018-04-05 13:55:40 +05:30
|
|
|
track_visibility="onchange",
|
2018-01-16 11:28:15 +05:30
|
|
|
help="Employee's company car.")
|
|
|
|
car_atn = fields.Float(compute='_compute_car_atn_and_costs', string='ATN Company Car', store=True)
|
|
|
|
company_car_total_depreciated_cost = fields.Float(compute='_compute_car_atn_and_costs', store=True)
|
|
|
|
available_cars_amount = fields.Integer(compute='_compute_available_cars_amount', string='Number of available cars')
|
|
|
|
new_car = fields.Boolean('Request a new car')
|
|
|
|
new_car_model_id = fields.Many2one('fleet.vehicle.model', string="Model", domain=lambda self: self._get_possible_model_domain())
|
|
|
|
max_unused_cars = fields.Integer(compute='_compute_max_unused_cars')
|
|
|
|
|
2018-04-05 13:55:40 +05:30
|
|
|
@api.depends('car_id', 'new_car', 'new_car_model_id', 'car_id.total_depreciated_cost',
|
|
|
|
'car_id.atn', 'new_car_model_id.default_atn', 'new_car_model_id.default_total_depreciated_cost',
|
|
|
|
'car_id.co2_fee', 'car_id.log_contracts', 'car_id.log_contracts.state', # YTI TODO: Store total_depreciated_costs on
|
|
|
|
'car_id.log_contracts.recurring_cost_amount_depreciated') # the fleet vehicle to avoid these dependencies
|
2018-01-16 11:28:15 +05:30
|
|
|
def _compute_car_atn_and_costs(self):
|
|
|
|
for contract in self:
|
2018-07-13 09:21:44 +00:00
|
|
|
if not contract.new_car and contract.car_id:
|
2018-01-16 11:28:15 +05:30
|
|
|
contract.car_atn = contract.car_id.atn
|
|
|
|
contract.company_car_total_depreciated_cost = contract.car_id.total_depreciated_cost
|
|
|
|
elif contract.new_car and contract.new_car_model_id:
|
|
|
|
contract.car_atn = contract.new_car_model_id.default_atn
|
|
|
|
contract.company_car_total_depreciated_cost = contract.new_car_model_id.default_total_depreciated_cost
|
|
|
|
|
|
|
|
@api.depends('name')
|
|
|
|
def _compute_available_cars_amount(self):
|
|
|
|
for contract in self:
|
|
|
|
contract.available_cars_amount = self.env['fleet.vehicle'].search_count([('driver_id', '=', False)])
|
|
|
|
|
|
|
|
@api.depends('name')
|
|
|
|
def _compute_max_unused_cars(self):
|
|
|
|
params = self.env['ir.config_parameter'].sudo()
|
|
|
|
max_unused_cars = params.get_param('l10n_be_hr_payroll_fleet.max_unused_cars', default=1000)
|
|
|
|
for contract in self:
|
|
|
|
contract.max_unused_cars = int(max_unused_cars)
|
|
|
|
|
|
|
|
@api.onchange('employee_id')
|
|
|
|
def _onchange_employee_id(self):
|
|
|
|
super(HrContract, self)._onchange_employee_id()
|
|
|
|
self.car_id = self.env['fleet.vehicle'].search([('driver_id', '=', self.employee_id.address_home_id.id)], limit=1)
|
|
|
|
return {'domain': {'car_id': self._get_available_cars_domain()}}
|
|
|
|
|
|
|
|
@api.onchange('transport_mode')
|
|
|
|
def _onchange_transport_mode(self):
|
|
|
|
super(HrContract, self)._onchange_transport_mode()
|
|
|
|
if self.transport_mode != 'company_car':
|
|
|
|
self.car_id = False
|
|
|
|
self.new_car_model_id = False
|
|
|
|
|
|
|
|
def _get_available_cars_domain(self):
|
|
|
|
return ['|', ('driver_id', '=', False), ('driver_id', '=', self.employee_id.address_home_id.id)]
|
|
|
|
|
|
|
|
def _get_possible_model_domain(self):
|
|
|
|
return [('can_be_requested', '=', True)]
|