UserController.php 3.28 KB
Newer Older
Aan Choesni Herlingga committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140
<?php

namespace App\Http\Controllers\Webprofile;

use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use App\Http\Requests\UserRequest;
use App\Repositories\UserRepository;
use Crypt;

class UserController extends Controller
{
    public function __construct(UserRepository $userRepo)
    {
        $this->userRepo = $userRepo;
    }

    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    {
        $users = $this->userRepo->get();

        $data = [
            'users' => $users,
        ];

        return view('webprofile.backend.users.index', $data)->withTitle(trans('feature.user'));
    }

    public function status($id, Request $request)
    {
        $data = $request->except('_token');

        $user = $this->userRepo->findId($id);
        $this->userRepo->update($data, $user);

        return redirect()->route('user.index');
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function create()
    {
        return view('webprofile.backend.users.create')->withTitle(trans('feature.create_user'));
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param \Illuminate\Http\Request $request
     *
     * @return \Illuminate\Http\Response
     */
    public function store(UserRequest $request)
    {
        $user = auth()->user();
        $data = $request->except('_token');

        $data['password'] = bcrypt($request->input('password'));
        $data['is_active'] = 1;
        $data['userid_created'] = $user->id;
        $data['userid_updated'] = $user->id;

        $this->userRepo->store($data);

        return redirect()->route('user.index');
    }

    /**
     * Display the specified resource.
     *
     * @param int $id
     *
     * @return \Illuminate\Http\Response
     */
    public function show($id)
    {
    }

    /**
     * Show the form for editing the specified resource.
     *
     * @param int $id
     *
     * @return \Illuminate\Http\Response
     */
    public function edit($id)
    {
        $id = Crypt::decrypt($id);
        $user = $this->userRepo->findId($id);

        $data = [
            'user' => $user,
        ];

        return view('webprofile.backend.users.edit', $data)->withTitle(trans('feature.edit_user'));
    }

    /**
     * Update the specified resource in storage.
     *
     * @param \Illuminate\Http\Request $request
     * @param int                      $id
     *
     * @return \Illuminate\Http\Response
     */
    public function update(Request $request, $id)
    {
        $user = $this->userRepo->findId($id);

        if ($request->input('password') != null || $request->input('password') != '') {
            $data = $request->except('_token');
            $data['password'] = bcrypt($request->password);
            $this->userRepo->update($data, $user);
        } else {
            $data = $request->except('_token', 'password', 'password_confirmation');
            $this->userRepo->update($data, $user);
        }

        return redirect()->route('user.index');
    }

    /**
     * Remove the specified resource from storage.
     *
     * @param int $id
     *
     * @return \Illuminate\Http\Response
     */
    public function destroy($id)
    {
    }
}