X7ROOT File Manager
Current Path:
/home/gfecatvj/sites/realesbar/platform/core/acl/src/Tables
home
/
gfecatvj
/
sites
/
realesbar
/
platform
/
core
/
acl
/
src
/
Tables
/
📁
..
📄
RoleTable.php
(4.65 KB)
📄
UserTable.php
(9.09 KB)
Editing: RoleTable.php
<?php namespace Botble\ACL\Tables; use Botble\ACL\Models\Role; use Html; use Illuminate\Support\Facades\Auth; use Botble\ACL\Repositories\Interfaces\RoleInterface; use Botble\ACL\Repositories\Interfaces\UserInterface; use Botble\Table\Abstracts\TableAbstract; use Illuminate\Contracts\Routing\UrlGenerator; use Yajra\DataTables\DataTables; class RoleTable extends TableAbstract { /** * @var bool */ protected $hasActions = true; /** * @var bool */ protected $hasFilter = true; /** * @var UserInterface */ protected $userRepository; /** * RoleTable constructor. * @param DataTables $table * @param UrlGenerator $urlGenerator * @param RoleInterface $roleRepository * @param UserInterface $userRepository */ public function __construct( DataTables $table, UrlGenerator $urlGenerator, RoleInterface $roleRepository, UserInterface $userRepository ) { $this->repository = $roleRepository; $this->userRepository = $userRepository; $this->setOption('id', 'table-roles'); parent::__construct($table, $urlGenerator); if (!Auth::user()->hasAnyPermission(['roles.edit', 'roles.destroy'])) { $this->hasOperations = false; $this->hasActions = false; } } /** * {@inheritDoc} */ public function ajax() { $data = $this->table ->eloquent($this->query()) ->editColumn('name', function ($item) { if (!Auth::user()->hasPermission('roles.edit')) { return $item->name; } return Html::link(route('roles.edit', $item->id), $item->name); }) ->editColumn('checkbox', function ($item) { return table_checkbox($item->id); }) ->editColumn('created_at', function ($item) { return date_from_database($item->created_at, config('core.base.general.date_format.date')); }) ->editColumn('created_by', function ($item) { return $item->author->getFullName(); }); return apply_filters(BASE_FILTER_GET_LIST_DATA, $data, $this->repository->getModel()) ->addColumn('operations', function ($item) { return table_actions('roles.edit', 'roles.destroy', $item); }) ->escapeColumns([]) ->make(true); } /** * {@inheritDoc} */ public function query() { $model = $this->repository->getModel(); $query = $model ->with('author') ->select([ 'roles.id', 'roles.name', 'roles.description', 'roles.created_at', 'roles.created_by', ]); return $this->applyScopes(apply_filters(BASE_FILTER_TABLE_QUERY, $query, $model)); } /** * {@inheritDoc} */ public function columns() { return [ 'id' => [ 'name' => 'roles.id', 'title' => trans('core/base::tables.id'), 'width' => '20px', ], 'name' => [ 'name' => 'roles.name', 'title' => trans('core/base::tables.name'), ], 'description' => [ 'name' => 'roles.description', 'title' => trans('core/base::tables.description'), 'class' => 'text-left', ], 'created_at' => [ 'name' => 'roles.created_at', 'title' => trans('core/base::tables.created_at'), 'width' => '100px', ], 'created_by' => [ 'name' => 'roles.created_by', 'title' => trans('core/acl::permissions.created_by'), 'width' => '100px', ], ]; } /** * {@inheritDoc} */ public function buttons() { $buttons = $this->addCreateButton(route('roles.create'), 'roles.create'); return apply_filters(BASE_FILTER_TABLE_BUTTONS, $buttons, Role::class); } /** * {@inheritDoc} */ public function bulkActions(): array { return $this->addDeleteAction(route('roles.deletes'), 'roles.destroy', parent::bulkActions()); } /** * {@inheritDoc} */ public function getBulkChanges(): array { return [ 'roles.name' => [ 'title' => trans('core/base::tables.name'), 'type' => 'text', 'validate' => 'required|max:120', ], ]; } }
Upload File
Create Folder