You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

111 lines
5.3 KiB

# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# 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 (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
###############################################################################
import pandas
from datetime import timedelta
from odoo import api, fields, models
from odoo.tools import date_utils
class HrLeaveReport(models.AbstractModel):
"""Model for the dashboard for viewing the employees leave"""
_name = 'report.hr_leave_dashboard.hr_leave_report'
_description = 'HR Leave Report'
@api.model
def _get_report_values(self, docids, data=None):
"""Function for getting the report values"""
if data.get('duration') == 'this_month':
option = pandas.date_range(
date_utils.start_of(fields.Date.today(), 'month'),
date_utils.end_of(fields.Date.today(), 'month') - timedelta(
days=0),
freq='d').strftime(
"%Y-%m-%d").tolist()
elif data.get('duration') == 'this_year':
option = pandas.date_range(
date_utils.start_of(fields.Date.today(), 'year'),
date_utils.end_of(fields.Date.today(), 'year') - timedelta(
days=0),
freq='d').strftime(
"%Y-%m-%d").tolist()
elif data.get('duration') == 'this_week':
option = pandas.date_range(
date_utils.start_of(fields.Date.today(), 'week'),
date_utils.end_of(fields.Date.today(), 'week') - timedelta(
days=0),
freq='d').strftime(
"%Y-%m-%d").tolist()
else:
option = [str(fields.Date.today())]
if not self.env.user.employee_ids.child_ids:
query = """SELECT l.id, lt.id as hr_leave_type_id, e.id as
emp_id, e.name as emp_name, e.department_id as emp_department,
e.parent_id as emp_parent_id, request_date_from, request_date_to,
l.number_of_days, lt.name as leave_type,
SUM(al.number_of_days) AS allocated_days, SUM(CASE WHEN l.state =
'validate' THEN l.number_of_days ELSE 0 END) AS taken_days,
SUM(al.number_of_days) - SUM(CASE WHEN l.state = 'validate' THEN
l.number_of_days ELSE 0 END) AS balance_days FROM hr_employee e
inner join hr_leave_allocation al ON al.employee_id = e.id inner
join hr_leave l on l.employee_id = e.id inner join hr_leave_type
lt on l.holiday_status_id = lt.id WHERE l.state = 'validate' AND
e.department_id = '%s' GROUP BY e.id,lt.id,l.id""" % \
self.env.user.employee_ids.department_id.id
else:
query = """SELECT l.id, lt.id as hr_leave_type_id, e.id as
emp_id, e.name as emp_name, e.department_id as emp_department,
e.parent_id as emp_parent_id, request_date_from, request_date_to,
l.number_of_days, lt.name as leave_type,
SUM(al.number_of_days) AS allocated_days, SUM(CASE WHEN l.state =
'validate' THEN l.number_of_days ELSE 0 END) AS taken_days,
SUM(al.number_of_days) - SUM(CASE WHEN l.state = 'validate' THEN
l.number_of_days ELSE 0 END) AS balance_days FROM hr_employee e
inner join hr_leave_allocation al ON al.employee_id = e.id inner
join hr_leave l on l.employee_id = e.id inner join hr_leave_type
lt on l.holiday_status_id = lt.id WHERE l.state = 'validate'
GROUP BY e.id,lt.id,l.id"""
self.env.cr.execute(query)
leave_data = self.env.cr.dictfetchall()
filtered_list = []
filtered_tuple = []
for leave in leave_data:
leave_list = pandas.date_range(leave.get('request_date_from'),
leave.get(
'request_date_to') - timedelta(
days=1), freq='d').strftime(
"%Y-%m-%d").tolist()
for date in leave_list:
if date in option:
filtered_list.append(leave)
break
for leave in filtered_list:
if (leave.get('hr_leave_type_id'), leave.get('emp_id')) in \
filtered_tuple:
filtered_list.remove(leave)
else:
filtered_tuple.append(
(leave.get('hr_leave_type_id'), leave.get('emp_id')))
return {
'duration': data.get('duration'),
'filtered_list': filtered_list,
}