-
Notifications
You must be signed in to change notification settings - Fork 0
/
hr_accrual.py
98 lines (82 loc) · 2.43 KB
/
hr_accrual.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
# -*- 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/>.
#
#
import time
from openerp.osv import fields, orm
from openerp.tools import DEFAULT_SERVER_DATE_FORMAT as OE_DATEFORMAT
class hr_accrual(orm.Model):
_name = 'hr.accrual'
_description = 'Accrual'
_columns = {
'name': fields.char(
'Name',
size=128,
required=True,
),
'holiday_status_id': fields.many2one(
'hr.holidays.status',
'Leave',
),
'line_ids': fields.one2many(
'hr.accrual.line',
'accrual_id',
'Accrual Lines',
readonly=True,
),
}
def get_balance(self, cr, uid, ids, employee_id, date=None, context=None):
if date is None:
date = time.strftime(OE_DATEFORMAT)
res = 0.0
cr.execute('''\
SELECT SUM(amount)
FROM hr_accrual_line
WHERE accrual_id in %s AND employee_id=%s AND date <= %s
''', (tuple(ids), employee_id, date))
for row in cr.fetchall():
res = row[0]
return res
class hr_accrual_line(orm.Model):
_name = 'hr.accrual.line'
_description = 'Accrual Line'
_columns = {
'date': fields.date(
'Date',
required=True,
),
'accrual_id': fields.many2one(
'hr.accrual',
'Accrual',
required=True,
),
'employee_id': fields.many2one(
'hr.employee',
'Employee',
required=True,
),
'amount': fields.float(
'Amount',
required=True,
),
}
_defaults = {
'date': time.strftime(OE_DATEFORMAT),
}
_rec_name = 'date'