![]() 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/ts.corals.io/corals-api/Corals/modules/Timesheet/DataTables/ |
<?php namespace Corals\Modules\Timesheet\DataTables; use Corals\Foundation\DataTables\BaseDataTable; use Corals\Modules\Timesheet\Facades\Timesheet; use Corals\Modules\Timesheet\Models\Invoice; use Corals\Modules\Timesheet\Transformers\API\InvoiceTransformer; use Illuminate\Database\Eloquent\Builder; use Yajra\DataTables\EloquentDataTable; class InvoicesDataTable extends BaseDataTable { /** * Build DataTable class. * * @param mixed $query Results from query() method. * @return \Yajra\DataTables\DataTableAbstract */ public function dataTable($query) { $this->setResourceUrl(config('Timesheet.models.invoice.resource_url')); $dataTable = new EloquentDataTable($query); return $dataTable->setTransformer(new InvoiceTransformer()); } /** * @param Invoice $model * @return \Illuminate\Database\Eloquent\Builder */ public function query(Invoice $model) { $query = $model->newQuery()->with(['items']); if (Timesheet::isTimesheetAdministration()) { return $query; } $userClients = Timesheet::getUserClients(user(), false) ->pluck('id') ->toArray(); return $query->whereHas('client', function (Builder $builder) use ($userClients) { $builder->whereIn('timesheet_clients.id', $userClients); }); } /** * Get columns. * * @return array */ protected function getColumns() { return [ 'id' => ['visible' => false], 'created_at' => ['title' => trans('Corals::attributes.created_at')], 'updated_at' => ['title' => trans('Corals::attributes.updated_at')], ]; } public function getFilters() { return [ 'code' => ['title' => trans('Timesheet::attributes.entry.description'), 'class' => 'col-md-2', 'type' => 'text', 'condition' => 'like', 'active' => true], 'notes' => ['title' => trans('Timesheet::attributes.entry.description'), 'class' => 'col-md-2', 'type' => 'text', 'condition' => 'like', 'active' => true], 'status' => [ 'type' => 'text', 'active' => true ], 'invoice_date' => ['title' => trans('Timesheet::attributes.entry.spent_at'), 'class' => 'col-md-2', 'type' => 'date', 'active' => true], ]; } }