![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/dceprojects.corals.io/Corals/modules/Timesheet/DataTables/ |
<?php namespace Corals\Modules\Timesheet\DataTables; use Corals\Foundation\DataTables\BaseDataTable; use Corals\Modules\ProjectPlan\DataTables\Scopes\OwnerScope; use Corals\Modules\ProjectPlan\Facades\ProjectPlan; use Corals\Modules\Timesheet\DataTables\Scopes\EmployeeJobsScope; use Corals\Modules\Timesheet\DataTables\Scopes\EmployeeUsersScope; use Corals\Modules\Timesheet\DataTables\Scopes\EntriesEntireableFilter; use Corals\Modules\Timesheet\Models\Entry; use Corals\Modules\Timesheet\Models\Job; use Corals\Modules\Timesheet\Transformers\EntryTransformer; use Corals\Modules\Utility\Facades\ListOfValue\ListOfValues; use Corals\User\Models\User; use Yajra\DataTables\EloquentDataTable; class EntriesDataTable extends BaseDataTable { /** * Build DataTable class. * * @param mixed $query Results from query() method. * @return \Yajra\DataTables\DataTableAbstract */ public function __construct() { $this->addScope(new OwnerScope()); parent::__construct(); } public function dataTable($query) { $this->setResourceUrl(config('timesheet.models.entry.resource_url')); $dataTable = new EloquentDataTable($query); return $dataTable->setTransformer(new EntryTransformer()); } /** * Get query source of dataTable. * @param Entry $model * @return \Illuminate\Database\Eloquent\Builder|static */ public function query(Entry $model) { return $model->newQuery(); } /** * Get columns. * * @return array */ protected function getColumns() { $columns = [ 'id' => ['visible' => false], ]; if (ProjectPlan::isPPAdmin() && !request()->route()->hasParameter('user')) { $columns['user'] = ['title' => trans('Timesheet::attributes.entry.employee'), 'orderable' => false, 'searchable' => false]; } $columns = array_merge($columns, [ 'spent_at' => ['title' => trans('Timesheet::attributes.entry.date'), 'orderable' => true], 'logged_time' => ['title' => trans('Timesheet::attributes.entry.logged_time'), 'orderable' => false, 'searchable' => false], 'description' => ['title' => trans('Timesheet::attributes.entry.description'), 'orderable' => true, 'searchable' => true], 'entrieable' => ['title' => trans('Timesheet::attributes.entry.job'), 'orderable' => false, 'searchable' => false], 'department' => ['title' => trans('Timesheet::attributes.job.department'), 'orderable' => false, 'searchable' => false], 'updated_at' => ['title' => trans('Corals::attributes.updated_at')], ]); return $columns; } public function getFilters() { $filters = [ 'spent_at' => [ 'title' => trans('Timesheet::attributes.entry.date'), 'class' => 'col-md-4', 'type' => 'date_range', 'active' => true ], 'entrieable' => [ 'title' => trans('Timesheet::attributes.entry.job'), 'class' => 'col-md-2', 'type' => 'select2-ajax', 'model' => Job::class, 'columns' => ['title'], 'attributes' => [ 'data' => [ 'scopes' => json_encode([EmployeeJobsScope::class]), ], ], 'builder' => EntriesEntireableFilter::class, 'active' => true ], 'department_code' => [ 'title' => trans('Timesheet::attributes.job.department'), 'class' => 'col-md-2', 'type' => 'select2', 'options' => ListOfValues::get('job-departments'), 'active' => true ] ]; if (ProjectPlan::isPPAdmin() && !request()->route()->hasParameter('user')) { $filters['user_id'] = [ 'title' => trans('Timesheet::attributes.entry.employee'), 'class' => 'col-md-2', 'type' => 'select2-ajax', 'model' => User::class, 'columns' => ['name', 'last_name', 'email'], 'attributes' => [ 'data' => [ 'scopes' => json_encode([EmployeeUsersScope::class]), ], ], 'active' => true ]; } if (request()->route()->hasParameter('user')) { $filters['spent_at']['class'] = 'col-md-6'; $filters['entrieable']['class'] = 'col-md-4'; } return $filters; } protected function getBuilderParameters() { return ['order' => [[2, 'desc']]]; } }