UserController.php 4.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\User\ChangePasswordRequest;
  5. use App\Http\Requests\User\StoreUserRequest;
  6. use App\Http\Requests\User\UpdateUserRequest;
  7. use App\Models\Role;
  8. use App\Models\User;
  9. use Illuminate\Support\Facades\Hash;
  10. class UserController extends Controller
  11. {
  12. public function __construct()
  13. {
  14. $this->authorizeResource(User::class);
  15. }
  16. /**
  17. * Display a listing of the resource.
  18. *
  19. * @return \Inertia\Response
  20. */
  21. public function index()
  22. {
  23. return inertia('Users/Index', [
  24. 'initialSearch' => request('search'),
  25. 'users' => User::filter(request()->only('search'))
  26. ->latest()
  27. ->paginate(10)
  28. ->withQueryString()
  29. ->through(fn($user) => [
  30. 'id' => $user->id,
  31. 'name' => $user->name,
  32. 'username' => $user->username,
  33. 'role' => $user->role->name,
  34. 'role_id' => $user->role_id,
  35. 'status' => $user->status
  36. ])
  37. ]);
  38. }
  39. /**
  40. * Show the form for creating a new resource.
  41. *
  42. * @return \Inertia\Response
  43. */
  44. public function create()
  45. {
  46. return inertia('Users/Create', [
  47. 'roles' => Role::whereNotIn('id', [1])
  48. ->get()
  49. ->transform(fn($role) => [
  50. 'label' => $role->name,
  51. 'value' => $role->id
  52. ])
  53. ]);
  54. }
  55. /**
  56. * Store a newly created resource in storage.
  57. *
  58. * @param \Illuminate\Http\Request $request
  59. * @return \Illuminate\Http\Response
  60. */
  61. public function store(StoreUserRequest $request)
  62. {
  63. User::create($request->validated());
  64. return back()->with('success', __('messages.success.store.user'));
  65. }
  66. /**
  67. * Display the specified resource.
  68. *
  69. * @param User $user
  70. * @return \Inertia\Response
  71. */
  72. public function show(User $user)
  73. {
  74. return inertia('Users/Show', [
  75. 'user' => $user,
  76. 'roles' => Role::whereNotIn('id', [1])
  77. ->get()
  78. ->transform(fn($role) => [
  79. 'label' => $role->name,
  80. 'value' => $role->id
  81. ])
  82. ]);
  83. }
  84. /**
  85. * Show the form for editing the specified resource.
  86. *
  87. * @param User $user
  88. * @return \Inertia\Response
  89. */
  90. public function edit(User $user)
  91. {
  92. return inertia('Users/Edit', [
  93. 'user' => $user,
  94. 'roles' => Role::whereNotIn('id', [1])
  95. ->get()
  96. ->transform(fn($role) => [
  97. 'label' => $role->name,
  98. 'value' => $role->id
  99. ])
  100. ]);
  101. }
  102. /**
  103. * Update the specified resource in storage.
  104. *
  105. * @param \Illuminate\Http\Request $request
  106. * @param User $user
  107. * @return \Illuminate\Http\Response
  108. */
  109. public function update(UpdateUserRequest $request, User $user)
  110. {
  111. $user->update($request->validated());
  112. return back()->with('success', __('messages.success.update.user'));
  113. }
  114. /**
  115. * Remove the specified resource from storage.
  116. *
  117. * @param User $user
  118. * @return \Illuminate\Http\Response
  119. */
  120. public function destroy(User $user)
  121. {
  122. $user->delete();
  123. return to_route('users.index')->with('success', __('messages.success.destroy.user'));
  124. }
  125. /**
  126. * Block user
  127. *
  128. * @param User $user
  129. * @return \Illuminate\Http\Response
  130. */
  131. public function block(User $user)
  132. {
  133. $user->status = !$user->getRawOriginal('status');
  134. $user->update();
  135. if ($user->getRawOriginal('status')) {
  136. $msg = __('messages.user.active_user');
  137. } else {
  138. $msg = __('messages.user.no_active_user');
  139. }
  140. return back()->with('success', $msg);
  141. }
  142. /**
  143. * Change Password
  144. *
  145. * @param \Illuminate\Http\Request $request
  146. * @return \Illuminate\Http\Response
  147. */
  148. public function changePassword(ChangePasswordRequest $request)
  149. {
  150. if (!Hash::check($request->old_password, $request->user()->password)) {
  151. return back()->with('error', __('messages.error.store.change_password'));
  152. }
  153. $request->user()->update(['password' => bcrypt($request->new_password)]);
  154. return back()->with('success', __('messages.success.update.change_password'));
  155. }
  156. public function resetPassword(User $user)
  157. {
  158. $user->update(['password' => bcrypt('12345678')]);
  159. return back()->with('success', __('messages.success.store.reset_password'));
  160. }
  161. }