123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193 |
- <?php
- namespace Dcat\Admin\Http\Controllers;
- use Dcat\Admin\Form;
- use Dcat\Admin\Grid;
- use Dcat\Admin\Http\Auth\Permission;
- use Dcat\Admin\Http\Repositories\Administrator;
- use Dcat\Admin\Models\Administrator as AdministratorModel;
- use Dcat\Admin\Show;
- use Dcat\Admin\Support\Helper;
- use Dcat\Admin\Widgets\Tree;
- class UserController extends AdminController
- {
- public function title()
- {
- return trans('admin.administrator');
- }
- protected function grid()
- {
- return Grid::make(Administrator::with(['roles']), function (Grid $grid) {
- $grid->column('id', 'ID')->sortable();
- $grid->column('username');
- $grid->column('name');
- if (config('admin.permission.enable')) {
- $grid->column('roles')->pluck('name')->label('primary', 3);
- $permissionModel = config('admin.database.permissions_model');
- $roleModel = config('admin.database.roles_model');
- $nodes = (new $permissionModel())->allNodes();
- $grid->column('permissions')
- ->if(function () {
- return ! empty($this->roles);
- })
- ->showTreeInDialog(function (Grid\Displayers\DialogTree $tree) use (&$nodes, $roleModel) {
- $tree->nodes($nodes);
- foreach (array_column($this->roles, 'slug') as $slug) {
- if ($roleModel::isAdministrator($slug)) {
- $tree->checkAll();
- }
- }
- })
- ->else()
- ->display('');
- }
- $grid->column('created_at');
- $grid->column('updated_at')->sortable();
- $grid->quickSearch(['id', 'name', 'username']);
- $grid->showQuickEditButton();
- $grid->enableDialogCreate();
- $grid->showColumnSelector();
- $grid->actions(function (Grid\Displayers\Actions $actions) {
- if ($actions->getKey() == AdministratorModel::DEFAULT_ID) {
- $actions->disableDelete();
- }
- });
- });
- }
- protected function detail($id)
- {
- return Show::make($id, Administrator::with(['roles']), function (Show $show) {
- $show->field('id');
- $show->field('username');
- $show->field('name');
- $show->field('avatar', __('admin.avatar'))->image();
- if (config('admin.permission.enable')) {
- $show->field('roles')->as(function ($roles) {
- if (! $roles) {
- return;
- }
- return collect($roles)->pluck('name');
- })->label();
- $show->field('permissions')->unescape()->as(function () {
- $roles = $this->roles->toArray();
- $permissionModel = config('admin.database.permissions_model');
- $roleModel = config('admin.database.roles_model');
- $permissionModel = new $permissionModel();
- $nodes = $permissionModel->allNodes();
- $tree = Tree::make($nodes);
- $isAdministrator = false;
- foreach (array_column($roles, 'slug') as $slug) {
- if ($roleModel::isAdministrator($slug)) {
- $tree->checkAll();
- $isAdministrator = true;
- }
- }
- if (! $isAdministrator) {
- $keyName = $permissionModel->getKeyName();
- $tree->check(
- $roleModel::getPermissionId(array_column($roles, $keyName))->flatten()
- );
- }
- return $tree->render();
- });
- }
- $show->field('created_at');
- $show->field('updated_at');
- });
- }
- public function form()
- {
- return Form::make(Administrator::with(['roles']), function (Form $form) {
- $userTable = config('admin.database.users_table');
- $connection = config('admin.database.connection');
- $id = $form->getKey();
- $form->display('id', 'ID');
- $form->text('username', trans('admin.username'))
- ->required()
- ->creationRules(['required', "unique:{$connection}.{$userTable}"])
- ->updateRules(['required', "unique:{$connection}.{$userTable},username,$id"]);
- $form->text('name', trans('admin.name'))->required();
- $form->image('avatar', trans('admin.avatar'))->autoUpload();
- if ($id) {
- $form->password('password', trans('admin.password'))
- ->minLength(5)
- ->maxLength(20)
- ->customFormat(function () {
- return '';
- });
- } else {
- $form->password('password', trans('admin.password'))
- ->required()
- ->minLength(5)
- ->maxLength(20);
- }
- $form->password('password_confirmation', trans('admin.password_confirmation'))->same('password');
- $form->ignore(['password_confirmation']);
- if (config('admin.permission.enable')) {
- $form->multipleSelect('roles', trans('admin.roles'))
- ->options(function () {
- $roleModel = config('admin.database.roles_model');
- return $roleModel::all()->pluck('name', 'id');
- })
- ->customFormat(function ($v) {
- return array_column($v, 'id');
- });
- }
- $form->display('created_at', trans('admin.created_at'));
- $form->display('updated_at', trans('admin.updated_at'));
- if ($id == AdministratorModel::DEFAULT_ID) {
- $form->disableDeleteButton();
- }
- })->saving(function (Form $form) {
- if ($form->password && $form->model()->get('password') != $form->password) {
- $form->password = bcrypt($form->password);
- }
- if (! $form->password) {
- $form->deleteInput('password');
- }
- });
- }
- public function destroy($id)
- {
- if (in_array(AdministratorModel::DEFAULT_ID, Helper::array($id))) {
- Permission::error();
- }
- return parent::destroy($id);
- }
- }
|