| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230 |
- <?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\Outlet;
- use App\Models\Role;
- use App\Models\User;
- use Illuminate\Support\Facades\Auth;
- use Illuminate\Support\Facades\Hash;
-
- class UserController extends Controller
- {
- /**
- * Display a listing of the resource.
- *
- * @return \Inertia\Response
- */
- public function index()
- {
- if (!Auth::user()->hasRole('Admin')) {
- return inertia('Access');
- }
-
- return inertia('user/Index', [
- 'filters' => request()->all('search'),
- 'users' => User::filter(request()->only('search'))
- ->latest()
- ->paginate(10)
- ->withQueryString()
- ->through(fn($user) => [
- 'id' => $user->id,
- 'name' => $user->name,
- 'phone' => $user->phone,
- 'email' => $user->email,
- 'gender' => $user->gender_id,
- 'role' => $user->role->name,
- 'outlet' => $user->outlet->name,
- 'status' => $user->status,
- ]),
- ]);
- }
-
- /**
- * Show the form for creating a new resource.
- *
- * @return \Inertia\Response
- */
- public function create()
- {
- if (!Auth::user()->hasRole('Admin')) {
- return inertia('Access');
- }
-
- return inertia('user/Create', [
- 'roles' => Role::whereNotIn('id', [1])
- ->get()
- ->transform(fn($role) => [
- 'label' => $role->name,
- 'value' => $role->id,
- ]),
- 'outlets' => Outlet::get()
- ->transform(fn($outlet) => [
- 'label' => $outlet->name,
- 'value' => $outlet->id,
- ]),
- 'genders' => [
- ['label' => 'Perempuan', 'value' => 1],
- ['label' => 'Laki-laki', 'value' => 2],
- ],
- ]);
- }
-
- /**
- * 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,
- 'gender_id' => (int) $user->getRawOriginal('gender_id'),
- 'outlet_id' => $user->outlet_id,
- 'role_id' => $user->role_id,
- ],
- 'roles' => Role::whereNotIn('id', [1])
- ->get()
- ->transform(fn($role) => [
- 'label' => $role->name,
- 'value' => $role->id,
- ]),
- 'outlets' => Outlet::get()
- ->transform(fn($outlet) => [
- 'label' => $outlet->name,
- 'value' => $outlet->id,
- ]),
- 'genders' => [
- ['label' => 'Perempuan', 'value' => 1],
- ['label' => 'Laki-laki', 'value' => 2],
- ],
- ]);
- }
-
- /**
- * Show the form for editing the specified resource.
- *
- * @param User $user
- * @return \Inertia\Response
- */
- public function edit(User $user)
- {
- if (!Auth::user()->hasRole('Admin')) {
- return inertia('Access');
- }
-
- return inertia('user/Edit', [
- 'user' => [
- 'id' => $user->id,
- 'name' => $user->name,
- 'phone' => $user->phone,
- 'email' => $user->email,
- 'gender_id' => (int) $user->getRawOriginal('gender_id'),
- 'outlet_id' => $user->outlet_id,
- 'role_id' => $user->role_id,
- ],
- 'roles' => Role::whereNotIn('id', [1])
- ->get()
- ->transform(fn($role) => [
- 'label' => $role->name,
- 'value' => $role->id,
- ]),
- 'outlets' => Outlet::get()
- ->transform(fn($outlet) => [
- 'label' => $outlet->name,
- 'value' => $outlet->id,
- ]),
- 'genders' => [
- ['label' => 'Perempuan', 'value' => 1],
- ['label' => 'Laki-laki', 'value' => 2],
- ],
- ]);
- }
-
- /**
- * 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($request->validated());
-
- 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, auth()->user()->password)) {
- return back()->with('error', __('messages.error.store.change-password'));
- }
-
- auth()->user()->update(['password' => bcrypt($request->new_password)]);
-
- return back()->with('success', __('messages.success.update.change-password'));
- }
- }
|