clara/app/DataTables/PermissionsDataTable.php

86 lines
2.8 KiB
PHP
Raw Normal View History

2023-09-26 09:51:59 +00:00
<?php
namespace App\DataTables;
use Illuminate\Database\Eloquent\Builder as QueryBuilder;
use Spatie\Permission\Models\Permission;
use Yajra\DataTables\EloquentDataTable;
use Yajra\DataTables\Html\Builder as HtmlBuilder;
use Yajra\DataTables\Html\Column;
use Yajra\DataTables\Services\DataTable;
class PermissionsDataTable extends DataTable
{
/**
* Build the DataTable class.
*
* @param QueryBuilder $query Results from query() method.
*/
public function dataTable(QueryBuilder $query): EloquentDataTable
{
return (new EloquentDataTable($query))
->editColumn('name', function (Permission $permission) {
return ucwords($permission->name);
})
->addColumn('assigned_to', function (Permission $permission) {
$roles = $permission->roles;
2023-11-03 09:12:15 +00:00
return view('pages/apps.user-management.permissions.columns._assign-to', compact('roles'));
2023-09-26 09:51:59 +00:00
})
->editColumn('created_at', function (Permission $permission) {
return $permission->created_at->format('d M Y, h:i a');
})
->addColumn('actions', function (Permission $permission) {
2023-11-03 09:12:15 +00:00
return view('pages/apps.user-management.permissions.columns._actions', compact('permission'));
2023-09-26 09:51:59 +00:00
})
->setRowId('id');
}
/**
* Get the query source of dataTable.
*/
public function query(Permission $model): QueryBuilder
{
return $model->newQuery();
}
/**
* Optional method if you want to use the html builder.
*/
public function html(): HtmlBuilder
{
return $this->builder()
->setTableId('permissions-table')
->columns($this->getColumns())
->minifiedAjax()
->dom('rt' . "<'row'<'col-sm-12 col-md-5'l><'col-sm-12 col-md-7'p>>",)
->addTableClass('table align-middle table-row-dashed fs-6 gy-5 dataTable no-footer text-gray-600 fw-semibold')
->setTableHeadClass('text-start text-muted fw-bold fs-7 text-uppercase gs-0')
->orderBy(0)
2023-11-03 09:12:15 +00:00
->drawCallback("function() {" . file_get_contents(resource_path('views/pages/apps/user-management/permissions/columns/_draw-scripts.js')) . "}");
2023-09-26 09:51:59 +00:00
}
/**
* Get the dataTable columns definition.
*/
public function getColumns(): array
{
return [
Column::make('name'),
Column::make('assigned_to'),
Column::make('created_at')->addClass('text-nowrap'),
Column::computed('actions')
->addClass('text-end text-nowrap')
->exportable(false)
->printable(false),
];
}
/**
* Get the filename for export.
*/
protected function filename(): string
{
return 'Permissions_' . date('YmdHis');
}
}