You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

135 lines
3.5 KiB

<?php
namespace App\Http\Controllers\Users;
use App\Entities\Users\User;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
/**
* Users Controller.
*
* @author Nafies Luthfi <nafiesL@gmail.com>
*/
class UsersController extends Controller
{
public function index(Request $request)
{
$query = $request->get('q');
$users = User::where('name', 'like', '%'.$query.'%')
->with('roles')
->paginate(25);
return view('users.index', compact('users'));
}
public function create()
{
return view('users.create');
}
public function store(Request $request)
{
$userData = $request->validate([
'name' => 'required|min:5',
'email' => 'required|email|unique:users,email',
'password' => 'nullable|between:6,15',
'role' => 'required|array',
]);
if (!$userData['password']) {
$userData['password'] = \Option::get('password_default', 'member');
}
$userData['api_token'] = str_random(32);
$user = User::create($userData);
$rolesData = array_map(function ($roleId) use ($user) {
return [
'user_id' => $user->id,
'role_id' => $roleId,
];
}, $userData['role']);
\DB::table('user_roles')->insert($rolesData);
flash(trans('user.created'), 'success');
return redirect()->route('users.index');
}
public function show(User $user)
{
$userCurrentJobs = $user->jobs()
->whereHas('project', function ($query) {
$query->whereIn('status_id', [2, 3]);
})->with('tasks')->get();
return view('users.show', compact('user', 'userCurrentJobs'));
}
public function edit(User $user)
{
$this->authorize('update', $user);
$langList = ['en' => trans('lang.en'), 'id' => trans('lang.id')];
return view('users.edit', compact('user', 'langList'));
}
public function update(Request $request, User $user)
{
$this->authorize('update', $user);
$userData = $request->validate([
'name' => 'required|min:5',
'email' => 'required|email|unique:users,email,'.$request->segment(2),
'password' => 'nullable|required_with:password_confirmation|between:6,15',
'role' => 'required|array',
'lang' => 'required|string|in:en,id',
]);
$user->update($userData);
\DB::table('user_roles')->where(['user_id' => $user->id])->delete();
$rolesData = array_map(function ($roleId) use ($user) {
return [
'user_id' => $user->id,
'role_id' => $roleId,
];
}, $userData['role']);
\DB::table('user_roles')->insert($rolesData);
flash(trans('user.updated'), 'success');
return redirect()->route('users.edit', $user->id);
}
public function delete(User $user)
{
$this->authorize('delete', $user);
return view('users.delete', compact('user'));
}
public function destroy(Request $request, User $user)
{
$this->authorize('delete', $user);
$request->validate([
'user_id' => 'required',
]);
if ($request->get('user_id')) {
$user->delete();
flash(trans('user.deleted'), 'success');
} else {
flash(trans('user.undeleted'), 'danger');
}
return redirect()->route('users.index');
}
}