mirror of
https://gitlab.com/hibou-io/hibou-odoo/suite.git
synced 2025-01-20 12:37:31 +02:00
hr_payroll_holidays hr_payroll_input_name_report hr_payroll_input_report hr_payroll_payment hr_payroll_timesheet hr_payslip_line_date l10n_us_fl_hr_payroll l10n_us_hr_payroll l10n_us_mo_hr_payroll l10n_us_oh_hr_payroll l10n_us_va_hr_payroll
51 lines
1.7 KiB
Python
Executable File
51 lines
1.7 KiB
Python
Executable File
# -*- coding: utf-8 -*-
|
|
from odoo import api, models
|
|
|
|
|
|
class HrPayslip(models.Model):
|
|
_inherit = 'hr.payslip'
|
|
|
|
@api.model
|
|
def get_worked_day_lines(self, contracts, date_from, date_to):
|
|
def create_empty_worked_lines(employee_id, contract_id, date_from, date_to):
|
|
attendance = {
|
|
'name': 'Timesheet Attendance',
|
|
'sequence': 10,
|
|
'code': 'ATTN',
|
|
'number_of_days': 0.0,
|
|
'number_of_hours': 0.0,
|
|
'contract_id': contract_id,
|
|
}
|
|
|
|
valid_days = [
|
|
('sheet_id.employee_id', '=', employee_id),
|
|
('sheet_id.state', '=', 'done'),
|
|
('sheet_id.date_from', '>=', date_from),
|
|
('sheet_id.date_to', '<=', date_to),
|
|
]
|
|
return attendance, valid_days
|
|
|
|
attendances = []
|
|
|
|
for contract in contracts:
|
|
attendance, valid_days = create_empty_worked_lines(
|
|
contract.employee_id.id,
|
|
contract.id,
|
|
date_from,
|
|
date_to
|
|
)
|
|
|
|
for day in self.env['hr_timesheet_sheet.sheet.day'].search(valid_days):
|
|
if day.total_attendance >= 0.0:
|
|
attendance['number_of_days'] += 1
|
|
attendance['number_of_hours'] += day.total_attendance
|
|
|
|
# needed so that the shown hours matches any calculations you use them for
|
|
attendance['number_of_hours'] = round(attendance['number_of_hours'], 2)
|
|
attendances.append(attendance)
|
|
|
|
res = super(HrPayslip, self).get_worked_day_lines(contracts, date_from, date_to)
|
|
res.extend(attendances)
|
|
return res
|
|
|