ispt4.0_laravel/app/DataTables/UsersDataTable.php
2025-03-12 12:02:15 +00:00

111 lines
2.8 KiB
PHP
Executable File

<?php
namespace App\DataTables;
use App\Models\Equipment;
use App\Models\User;
use Illuminate\Database\Eloquent\Builder as QueryBuilder;
use Yajra\DataTables\EloquentDataTable;
use Yajra\DataTables\Html\Builder as HtmlBuilder;
use Yajra\DataTables\Html\Button;
use Yajra\DataTables\Html\Column;
use Yajra\DataTables\Html\Editor\Editor;
use Yajra\DataTables\Html\Editor\Fields;
use Yajra\DataTables\Services\DataTable;
class UsersDataTable extends DataTable
{
/**
* Build the DataTable class.
*
* @param QueryBuilder $query Results from query() method.
*/
public function dataTable(QueryBuilder $query): EloquentDataTable
{
return (new EloquentDataTable($query))
->addColumn('action', 'users.action')
->setRowId('id');
}
/**
* Get the query source of dataTable.
*/
// public function query(User $model): QueryBuilder
// {
// return $model->newQuery();
// }
public function query()
{
$query = Equipment::select(['ispt_number', 'unit_id', 'equipment_tag']);
return $this->applyScopes($query);
}
/**
* Optional method if you want to use the html builder.
*/
// public function html(): HtmlBuilder
// {
// return $this->builder()
// ->setTableId('users-table')
// ->columns($this->getColumns())
// ->minifiedAjax()
// //->dom('Bfrtip')
// ->orderBy(1)
// ->selectStyleSingle()
// ->buttons([
// // Button::make('excel'),
// // Button::make('csv'),
// Button::make('pdf'),
// // Button::make('print'),
// // Button::make('reset'),
// // Button::make('reload')
// ]);
// }
public function html()
{
return $this->builder()
->setTableId('Equipments')
->columns($this->getColumns())
// Outras configurações necessárias ...
->minifiedAjax()
->dom('Bfrtip')
->orderBy(1);
}
/**
* Get the dataTable columns definition.
*/
// public function getColumns(): array
// {
// return [
// Column::computed('action')
// ->exportable(false)
// ->printable(false)
// ->width(60)
// ->addClass('text-center'),
// Column::make('id'),
// Column::make('add your columns'),
// Column::make('created_at'),
// Column::make('updated_at'),
// ];
// }
protected function getColumns()
{
return [
'ispt_number',
'unit_id',
'equipment_tag',
];
}
/**
* Get the filename for export.
*/
protected function filename(): string
{
return 'Users_' . date('YmdHis');
}
}