What it does
This module connects the Attendance and Payroll modules, allowing users to automatically load all employees' attendance data into payslips, as a base for payroll.
Key Features
After installing this module, in addition to the Working Calendar Info, Leave Summary, a Summary of Attendance will be added on the employee's
pay slip with the following information:
- Late Coming Hours: total hours of late coming during the payslip period.
- Early Leave Hours: total hours of early leaves during the payslip period.
- Late Comings: number of times the employee came late during the payslip period.
- Early Leaves: number of times the employee leave earlier that the expected contracted check-out time during the payslip period.
- Missing Check-outs: the number of times the employee forgot to check-out during the payslip period.
- Total Attendance (in hours): The total time that the employee had been attending during the payslip period.
- Total Valid Attendance (in hours): The total valid time (that matches the employee's contracted working schedule) that the employee had been attending during the payslip period.
All these data is automatically loaded from the Attendance module.
How to access attendance data from salary rules
attendance_entries = payslip.attendance_ids
total_attendance_hours = payslip.total_attendance_hours
valid_attendance_hours = payslip.valid_attendance_hours
late_attendance_hours = payslip.late_attendance_hours
early_leave_hours = payslip.early_leave_hours
late_attendance_count = payslip.late_attendance_count
early_leave_count = payslip.early_leave_count
missing_checkout_count = payslip.missing_checkout_count
An example of basic wage computation based on total valid attendance
result = 0.0
for line in working_month_calendar_lines.filtered(lambda l: l.contract_id):
result += line.contract_id.wage * line.valid_attendance_hours / line.calendar_working_hours
An example of missing checkout penalty
Assume each missing checkout would cost $5
result = 5 * payslip.missing_checkout_count
Editions Supported
- Community Edition
Installation
- Navigate to Apps
- Find with keyword 'to_hr_payroll_attendance'
- Install it as usual then you are done
How to access attendance data from salary rules
attendance_entries = payslip.attendance_ids
total_attendance_hours = payslip.total_attendance_hours
valid_attendance_hours = payslip.valid_attendance_hours
late_attendance_hours = payslip.late_attendance_hours
early_leave_hours = payslip.early_leave_hours
late_attendance_count = payslip.late_attendance_count
early_leave_count = payslip.early_leave_count
missing_checkout_count = payslip.missing_checkout_count
An example of basic wage computation based on total valid attendance
result = 0.0
for line in working_month_calendar_lines.filtered(lambda l: l.contract_id):
result += line.contract_id.wage * line.valid_attendance_hours / line.calendar_working_hours
An example of missing checkout penalty
Assume each missing checkout would cost $5
result = 5 * payslip.missing_checkout_count
This software and associated files (the "Software") may only be
used
(executed, modified, executed after modifications) if you have
purchased a
valid license from the authors, typically via Odoo Apps,
or if you
have
received a written agreement from the authors of the
Software (see the
COPYRIGHT file).
You may develop Odoo modules that use the Software as a library
(typically
by depending on it, importing it and using its
resources), but
without
copying any source code or material from the
Software. You may distribute
those modules under the license of your
choice, provided that this
license
is compatible with the terms of
the Odoo Proprietary License (For
example:
LGPL, MIT, or proprietary
licenses similar to this one).
It is forbidden to publish, distribute, sublicense, or sell
copies of the
Software or modified copies of the Software.
Thông báo bản quyền và chấp thuận nêu trên buộc phải được bao gồm trong tất cả các bản sao hoặc các phần quan trọng của Phần mềm.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND
NONINFRINGEMENT. IN NO EVENT
SHALL THE
AUTHORS OR COPYRIGHT HOLDERS
BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN
ACTION OF CONTRACT, TORT OR OTHERWISE,
ARISING
FROM, OUT OF OR IN
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
DEALINGS IN THE
SOFTWARE.