UserController.php 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. <?php
  2. namespace Dcat\Admin\Http\Controllers;
  3. use Dcat\Admin\Form;
  4. use Dcat\Admin\Grid;
  5. use Dcat\Admin\Http\Auth\Permission;
  6. use Dcat\Admin\Http\Repositories\Administrator;
  7. use Dcat\Admin\Models\Administrator as AdministratorModel;
  8. use Dcat\Admin\Show;
  9. use Dcat\Admin\Support\Helper;
  10. use Dcat\Admin\Widgets\Tree;
  11. class UserController extends AdminController
  12. {
  13. public function title()
  14. {
  15. return trans('admin.administrator');
  16. }
  17. protected function grid()
  18. {
  19. return Grid::make(Administrator::with(['roles']), function (Grid $grid) {
  20. $grid->column('id', 'ID')->sortable();
  21. $grid->column('username');
  22. $grid->column('name');
  23. if (config('admin.permission.enable')) {
  24. $grid->column('roles')->pluck('name')->label('primary', 3);
  25. $permissionModel = config('admin.database.permissions_model');
  26. $roleModel = config('admin.database.roles_model');
  27. $nodes = (new $permissionModel())->allNodes();
  28. $grid->column('permissions')
  29. ->if(function () {
  30. return ! empty($this->roles);
  31. })
  32. ->showTreeInDialog(function (Grid\Displayers\DialogTree $tree) use (&$nodes, $roleModel) {
  33. $tree->nodes($nodes);
  34. foreach (array_column($this->roles, 'slug') as $slug) {
  35. if ($roleModel::isAdministrator($slug)) {
  36. $tree->checkAll();
  37. }
  38. }
  39. })
  40. ->else()
  41. ->display('');
  42. }
  43. $grid->column('created_at');
  44. $grid->column('updated_at')->sortable();
  45. $grid->quickSearch(['id', 'name', 'username']);
  46. $grid->showQuickEditButton();
  47. $grid->enableDialogCreate();
  48. $grid->showColumnSelector();
  49. $grid->actions(function (Grid\Displayers\Actions $actions) {
  50. if ($actions->getKey() == AdministratorModel::DEFAULT_ID) {
  51. $actions->disableDelete();
  52. }
  53. });
  54. });
  55. }
  56. protected function detail($id)
  57. {
  58. return Show::make($id, Administrator::with(['roles']), function (Show $show) {
  59. $show->field('id');
  60. $show->field('username');
  61. $show->field('name');
  62. $show->field('avatar', __('admin.avatar'))->image();
  63. if (config('admin.permission.enable')) {
  64. $show->field('roles')->as(function ($roles) {
  65. if (! $roles) {
  66. return;
  67. }
  68. return collect($roles)->pluck('name');
  69. })->label();
  70. $show->field('permissions')->unescape()->as(function () {
  71. $roles = $this->roles->toArray();
  72. $permissionModel = config('admin.database.permissions_model');
  73. $roleModel = config('admin.database.roles_model');
  74. $permissionModel = new $permissionModel();
  75. $nodes = $permissionModel->allNodes();
  76. $tree = Tree::make($nodes);
  77. $isAdministrator = false;
  78. foreach (array_column($roles, 'slug') as $slug) {
  79. if ($roleModel::isAdministrator($slug)) {
  80. $tree->checkAll();
  81. $isAdministrator = true;
  82. }
  83. }
  84. if (! $isAdministrator) {
  85. $keyName = $permissionModel->getKeyName();
  86. $tree->check(
  87. $roleModel::getPermissionId(array_column($roles, $keyName))->flatten()
  88. );
  89. }
  90. return $tree->render();
  91. });
  92. }
  93. $show->field('created_at');
  94. $show->field('updated_at');
  95. });
  96. }
  97. public function form()
  98. {
  99. return Form::make(Administrator::with(['roles']), function (Form $form) {
  100. $userTable = config('admin.database.users_table');
  101. $connection = config('admin.database.connection');
  102. $id = $form->getKey();
  103. $form->display('id', 'ID');
  104. $form->text('username', trans('admin.username'))
  105. ->required()
  106. ->creationRules(['required', "unique:{$connection}.{$userTable}"])
  107. ->updateRules(['required', "unique:{$connection}.{$userTable},username,$id"]);
  108. $form->text('name', trans('admin.name'))->required();
  109. $form->image('avatar', trans('admin.avatar'))->autoUpload();
  110. if ($id) {
  111. $form->password('password', trans('admin.password'))
  112. ->minLength(5)
  113. ->maxLength(20)
  114. ->customFormat(function () {
  115. return '';
  116. });
  117. } else {
  118. $form->password('password', trans('admin.password'))
  119. ->required()
  120. ->minLength(5)
  121. ->maxLength(20);
  122. }
  123. $form->password('password_confirmation', trans('admin.password_confirmation'))->same('password');
  124. $form->ignore(['password_confirmation']);
  125. if (config('admin.permission.enable')) {
  126. $form->multipleSelect('roles', trans('admin.roles'))
  127. ->options(function () {
  128. $roleModel = config('admin.database.roles_model');
  129. return $roleModel::all()->pluck('name', 'id');
  130. })
  131. ->customFormat(function ($v) {
  132. return array_column($v, 'id');
  133. });
  134. }
  135. $form->display('created_at', trans('admin.created_at'));
  136. $form->display('updated_at', trans('admin.updated_at'));
  137. if ($id == AdministratorModel::DEFAULT_ID) {
  138. $form->disableDeleteButton();
  139. }
  140. })->saving(function (Form $form) {
  141. if ($form->password && $form->model()->get('password') != $form->password) {
  142. $form->password = bcrypt($form->password);
  143. }
  144. if (! $form->password) {
  145. $form->deleteInput('password');
  146. }
  147. });
  148. }
  149. public function destroy($id)
  150. {
  151. if (in_array(AdministratorModel::DEFAULT_ID, Helper::array($id))) {
  152. Permission::error();
  153. }
  154. return parent::destroy($id);
  155. }
  156. }