UserController.php 5.2KB

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