UserController.php 5.1KB

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