| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198 |
- <?php
-
- namespace App\Http\Controllers;
-
- use App\Http\Controllers\Controller;
- use App\Http\Requests\User\ChangePasswordRequest;
- use App\Http\Requests\User\StoreUserRequest;
- use App\Http\Requests\User\UpdateUserRequest;
- use App\Models\Role;
- use App\Models\User;
- use Illuminate\Support\Facades\Hash;
-
- class UserController extends Controller
- {
- /**
- * Create the controller instance.
- *
- * @return void
- */
- public function __construct()
- {
- $this->authorizeResource(User::class);
- }
-
- /**
- * Display a listing of the resource.
- *
- * @return \Inertia\Response
- */
- public function index()
- {
- return inertia('user/Index', [
- 'initialSearch' => request('search'),
- 'users' => User::filter(request()->only('search'))
- ->latest()
- ->paginate(10)
- ->withQueryString()
- ->through(fn($user) => [
- 'id' => $user->id,
- 'name' => $user->name,
- 'email' => $user->email,
- 'role' => $user->role->name,
- 'role_id' => $user->role_id,
- 'status' => $user->status
- ])
- ]);
- }
-
- /**
- * Show the form for creating a new resource.
- *
- * @return \Inertia\Response
- */
- public function create()
- {
- return inertia('user/Create', [
- 'roles' => Role::whereNotIn('id', [1])
- ->get()
- ->transform(fn($role) => [
- 'label' => $role->name,
- 'value' => $role->id
- ])
- ]);
- }
-
- /**
- * Store a newly created resource in storage.
- *
- * @param \Illuminate\Http\Request $request
- * @return \Illuminate\Http\Response
- */
- public function store(StoreUserRequest $request)
- {
- User::create($request->validated());
-
- return back()->with('success', __('messages.success.store.user'));
- }
-
- /**
- * Display the specified resource.
- *
- * @param User $user
- * @return \Inertia\Response
- */
- public function show(User $user)
- {
- return inertia('user/Show', [
- 'user' => [
- 'id' => $user->id,
- 'name' => $user->name,
- 'phone' => $user->phone,
- 'email' => $user->email,
- 'role_id' => $user->role_id
- ],
- 'roles' => Role::whereNotIn('id', [1])
- ->get()
- ->transform(fn($role) => [
- 'label' => $role->name,
- 'value' => $role->id
- ])
- ]);
- }
-
- /**
- * Show the form for editing the specified resource.
- *
- * @param User $user
- * @return \Inertia\Response
- */
- public function edit(User $user)
- {
- return inertia('user/Edit', [
- 'user' => [
- 'id' => $user->id,
- 'name' => $user->name,
- 'phone' => $user->phone,
- 'email' => $user->email,
- 'role_id' => $user->role_id
- ],
- 'roles' => Role::whereNotIn('id', [1])
- ->get()
- ->transform(fn($role) => [
- 'label' => $role->name,
- 'value' => $role->id
- ])
- ]);
- }
-
- /**
- * Update the specified resource in storage.
- *
- * @param \Illuminate\Http\Request $request
- * @param User $user
- * @return \Illuminate\Http\Response
- */
- public function update(UpdateUserRequest $request, User $user)
- {
- $user->update([
- 'name' => $request->name,
- 'phone' => $request->phone ?? $user->phone,
- 'email' => $request->email,
- 'role_id' => $request->role_id
- ]);
-
- return back()->with('success', __('messages.success.update.user'));
- }
-
- /**
- * Remove the specified resource from storage.
- *
- * @param User $user
- * @return \Illuminate\Http\Response
- */
- public function destroy(User $user)
- {
- $user->delete();
-
- return to_route('users.index')->with('success', __('messages.success.destroy.user'));
- }
-
- /**
- * Block user
- *
- * @param User $user
- * @return \Illuminate\Http\Response
- */
- public function block(User $user)
- {
- $user->status = !$user->getRawOriginal('status');
- $user->update();
-
- if ($user->getRawOriginal('status')) {
- $msg = __('messages.user.active_user');
- } else {
- $msg = __('messages.user.no_active_user');
- }
-
- return back()->with('success', $msg);
- }
-
- /**
- * Change Password
- *
- * @param \Illuminate\Http\Request $request
- * @return \Illuminate\Http\Response
- */
- public function changePassword(ChangePasswordRequest $request)
- {
- if (!Hash::check($request->old_password, $request->user()->password)) {
- return back()->with('error', __('messages.error.store.change_password'));
- }
-
- $request->user()->update(['password' => bcrypt($request->new_password)]);
-
- return back()->with('success', __('messages.success.update.change_password'));
- }
- }
|