UserController.php 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. <?php
  2. namespace Dcat\Admin\Http\Controllers;
  3. use Dcat\Admin\Auth\Permission;
  4. use Dcat\Admin\Form;
  5. use Dcat\Admin\Grid;
  6. use Dcat\Admin\Models\Administrator as AdministratorModel;
  7. use Dcat\Admin\Http\Repositories\Administrator;
  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->disableFilterButton();
  48. $grid->enableDialogCreate();
  49. $grid->showColumnSelector();
  50. $grid->actions(function (Grid\Displayers\Actions $actions) {
  51. if ($actions->getKey() == AdministratorModel::DEFAULT_ID) {
  52. $actions->disableDelete();
  53. }
  54. });
  55. });
  56. }
  57. protected function detail($id)
  58. {
  59. return Show::make($id, Administrator::with(['roles']), function (Show $show) {
  60. $show->field('id');
  61. $show->field('username');
  62. $show->field('name');
  63. $show->field('avatar', __('admin.avatar'))->image();
  64. if (config('admin.permission.enable')) {
  65. $show->field('roles')->as(function ($roles) {
  66. if (! $roles) {
  67. return;
  68. }
  69. return collect($roles)->pluck('name');
  70. })->label();
  71. $show->field('permissions')->unescape()->as(function () {
  72. $roles = (array) $this->roles;
  73. $permissionModel = config('admin.database.permissions_model');
  74. $roleModel = config('admin.database.roles_model');
  75. $permissionModel = new $permissionModel();
  76. $nodes = $permissionModel->allNodes();
  77. $tree = Tree::make($nodes);
  78. $isAdministrator = false;
  79. foreach (array_column($roles, 'slug') as $slug) {
  80. if ($roleModel::isAdministrator($slug)) {
  81. $tree->checkAll();
  82. $isAdministrator = true;
  83. }
  84. }
  85. if (! $isAdministrator) {
  86. $keyName = $permissionModel->getKeyName();
  87. $tree->check(
  88. $roleModel::getPermissionId(array_column($roles, $keyName))->flatten()
  89. );
  90. }
  91. return $tree->render();
  92. });
  93. }
  94. $show->field('created_at');
  95. $show->field('updated_at');
  96. });
  97. }
  98. public function form()
  99. {
  100. return Form::make(Administrator::with(['roles']), function (Form $form) {
  101. $userTable = config('admin.database.users_table');
  102. $connection = config('admin.database.connection');
  103. $id = $form->getKey();
  104. $form->display('id', 'ID');
  105. $form->text('username', trans('admin.username'))
  106. ->required()
  107. ->creationRules(['required', "unique:{$connection}.{$userTable}"])
  108. ->updateRules(['required', "unique:{$connection}.{$userTable},username,$id"]);
  109. $form->text('name', trans('admin.name'))->required();
  110. $form->image('avatar', trans('admin.avatar'))->autoUpload();
  111. if ($id) {
  112. $form->password('password', trans('admin.password'))
  113. ->minLength(5)
  114. ->maxLength(20)
  115. ->customFormat(function () {
  116. return '';
  117. });
  118. } else {
  119. $form->password('password', trans('admin.password'))
  120. ->required()
  121. ->minLength(5)
  122. ->maxLength(20);
  123. }
  124. $form->password('password_confirmation', trans('admin.password_confirmation'))->same('password');
  125. $form->ignore(['password_confirmation']);
  126. if (config('admin.permission.enable')) {
  127. $form->multipleSelect('roles', trans('admin.roles'))
  128. ->options(function () {
  129. $roleModel = config('admin.database.roles_model');
  130. return $roleModel::all()->pluck('name', 'id');
  131. })
  132. ->customFormat(function ($v) {
  133. return array_column($v, 'id');
  134. });
  135. }
  136. $form->display('created_at', trans('admin.created_at'));
  137. $form->display('updated_at', trans('admin.updated_at'));
  138. if ($id == AdministratorModel::DEFAULT_ID) {
  139. $form->disableDeleteButton();
  140. }
  141. })->saving(function (Form $form) {
  142. if ($form->password && $form->model()->get('password') != $form->password) {
  143. $form->password = bcrypt($form->password);
  144. }
  145. if (! $form->password) {
  146. $form->deleteInput('password');
  147. }
  148. });
  149. }
  150. public function destroy($id)
  151. {
  152. if (in_array(AdministratorModel::DEFAULT_ID, Helper::array($id))) {
  153. Permission::error();
  154. }
  155. return parent::destroy($id);
  156. }
  157. }