-
Notifications
You must be signed in to change notification settings - Fork 0
/
hr_policy_absence.py
120 lines (98 loc) · 3.83 KB
/
hr_policy_absence.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
# -*- coding:utf-8 -*-
#
#
# Copyright (C) 2013 Michael Telahun Makonnen <[email protected]>.
# All Rights Reserved.
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published
# by the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# 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 for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
#
from openerp.osv import fields, orm
class policy_absence(orm.Model):
_name = 'hr.policy.absence'
_columns = {
'name': fields.char('Name', size=128, required=True),
'date': fields.date('Effective Date', required=True),
'line_ids': fields.one2many(
'hr.policy.line.absence', 'policy_id', 'Policy Lines'),
}
# Return records with latest date first
_order = 'date desc'
def get_codes(self, cr, uid, idx, context=None):
res = []
[res.append(
(line.code, line.name, line.type, line.rate, line.use_awol))
for line in self.browse(cr, uid, idx, context=context).line_ids]
return res
def paid_codes(self, cr, uid, idx, context=None):
res = []
[res.append((line.code, line.name))
for line in self.browse(
cr, uid, idx, context=context).line_ids if line.type == 'paid']
return res
def unpaid_codes(self, cr, uid, idx, context=None):
res = []
[res.append((line.code, line.name))
for line in self.browse(
cr, uid, idx, context=context
).line_ids if line.type == 'unpaid']
return res
class policy_line_absence(orm.Model):
_name = 'hr.policy.line.absence'
_columns = {
'name': fields.char('Name', size=64, required=True),
'code': fields.char(
'Code', required=True, help="Use this code in the salary rules."),
'holiday_status_id': fields.many2one(
'hr.holidays.status', 'Leave', required=True),
'policy_id': fields.many2one('hr.policy.absence', 'Policy'),
'type': fields.selection(
[
('paid', 'Paid'),
('unpaid', 'Unpaid'),
('dock', 'Dock')
],
'Type',
required=True,
help="Determines how the absence will be treated in payroll. "
"The 'Dock Salary' type will deduct money (useful for "
"salaried employees).",
),
'rate': fields.float(
'Rate', required=True, help='Multiplier of employee wage.'),
'use_awol': fields.boolean(
'Absent Without Leave',
help='Use this policy to record employee time absence not covered '
'by other leaves.'
)
}
def onchange_holiday(self, cr, uid, ids, holiday_status_id, context=None):
res = {'value': {'name': False, 'code': False}}
if not holiday_status_id:
return res
data = self.pool.get(
'hr.holidays.status').read(
cr, uid, holiday_status_id, ['name', 'code'],
context=context)
res['value']['name'] = data['name']
res['value']['code'] = data['code']
return res
class policy_group(orm.Model):
_name = 'hr.policy.group'
_inherit = 'hr.policy.group'
_columns = {
'absence_policy_ids': fields.many2many(
'hr.policy.absence', 'hr_policy_group_absence_rel',
'group_id', 'absence_id', 'Absence Policy'),
}