user()->hasRole([RoleEnum::ADMIN->value, RoleEnum::SUPERVISOR->value], 'web')) { abort(403, 'Unauthorized action.'); } if ($request->ajax()) { $supervisor = User::role(RoleEnum::SUPERVISOR->value)->first(); $users = User::query() ->when( !auth()->user()->hasRole(RoleEnum::SUPERVISOR->value), function (Builder $builder) use ($supervisor) { $builder->whereNotIn('id', [$supervisor->id]); } ) ->select(['id', 'name', 'email', 'is_active', 'created_at']); if (! empty($request->input('status'))) { $is_active = ($request->input('status') == 'active') ? 1 : 0; $users->where('is_active', $is_active); } return DataTables::of($users) ->addColumn( 'action', ' @if($is_active) @else @endif @if(1 === 0) @endif ' ) ->editColumn( 'is_active', ' @if($is_active) @lang(\'messages.active\') @else @lang(\'messages.inactive\') @endif ' ) ->editColumn( 'created_at', ' @php $date = \Carbon\Carbon::parse($created_at)->isoFormat("D/M/YY HH:mm A"); @endphp {{$date}} ' ) ->removeColumn('id') ->rawColumns(['action', 'is_active', 'created_at']) ->make(true); } return view('superadmin.users.index'); } /** * Show the form for creating a new resource. * * @return \Illuminate\Http\Response */ public function create() { if (request()->ajax()) { $user = request()->user(); $forms = Form::where('is_template', 0) ->pluck('name', 'id') ->toArray(); return view('superadmin.users.create') ->with(compact('forms')); } } /** * Store a newly created resource in storage. * * @param \Illuminate\Http\Request $request * @return \Illuminate\Http\Response */ public function store(Request $request) { try { if (! empty($this->notAllowedInDemo())) { return $this->notAllowedInDemo(); } $input = $request->only('name', 'email', 'is_active', 'is_admin', 'can_create_form'); if (! empty($request->input('password'))) { $input['password'] = bcrypt($request->input('password')); } $input['is_active'] = ! empty($input['is_active']) ? 1 : 0; $input['can_create_form'] = ! empty($input['can_create_form']) ? 1 : 0; $user = User::query()->create($input); if ($request->filled('is_admin')) { $user->assignRole(RoleEnum::ADMIN->value); } else { $user->assignRole(RoleEnum::USER->value); } //save user forms (assgined) $permissions = $request->input('permissions'); $form_ids = $request->input('form_id'); $user_forms = []; if (! empty($form_ids) && ! empty($permissions)) { foreach ($form_ids as $key => $form_id) { $user_forms[] = [ 'form_id' => $form_id, 'assigned_by' => \Auth::id(), 'permissions' => $permissions, ]; } } $user->userForms()->createMany($user_forms); if (! empty($request->input('send_email'))) { $input['password'] = $request->input('password'); $user->notify(new UserNotification($input)); } $output = $this->respondSuccess(); } catch (Exception $e) { $output = $this->respondWentWrong($e); } return $output; } /** * 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) { if (request()->ajax()) { $user = User::findOrFail($id); if (auth()->user()->hasRole([RoleEnum::SUPERVISOR->value, RoleEnum::ADMIN->value])) { $forms = Form::where('is_template', 0) ->pluck('name', 'id') ->toArray(); $assigned_forms = UserForm::with('form') ->where('assigned_to', $id) ->get(); } else { $logged_in_user = request()->user(); $forms = Form::where('is_template', 0) ->where('created_by', $logged_in_user->id) ->pluck('name', 'id') ->toArray(); $assigned_forms = UserForm::with('form') ->where('assigned_by', \Auth::id()) ->where('assigned_to', $id) ->get(); } return view('superadmin.users.edit') ->with(compact('user', 'forms', 'assigned_forms')); } } /** * Update the specified resource in storage. * * @param \Illuminate\Http\Request $request * @param int $id * @return \Illuminate\Http\Response */ public function update(Request $request, $id) { try { if (! empty($this->notAllowedInDemo())) { return $this->notAllowedInDemo(); } $input = $request->only('name', 'email', 'is_active', 'is_admin', 'can_create_form'); $input['is_active'] = ! empty($input['is_active']) ? 1 : 0; $input['can_create_form'] = ! empty($input['can_create_form']) ? 1 : 0; if (! empty($request->input('password'))) { $input['password'] = bcrypt($request->input('password')); } $user = User::findOrFail($id); $user->update($input); if ($request->filled('is_admin') && $request->input('is_admin') === 'on') { $user->assignRole(RoleEnum::ADMIN->value); $user->removeRole(RoleEnum::USER->value); } else { $user->removeRole(RoleEnum::ADMIN->value); $user->assignRole(RoleEnum::USER->value); } //update user forms (assgined) $edit_permissions = $request->input('edit_permissions'); $assgined_form_ids = $request->input('edit_assigned_form_id'); if (! empty($assgined_form_ids)) { $non_existing_ids = []; foreach ($assgined_form_ids as $key => $id) { if (! empty($edit_permissions[$id])) { $user_form = UserForm::find($id); $user_form->permissions = $edit_permissions[$id]; $user_form->save(); } else { $non_existing_ids[] = $id; } } UserForm::whereIn('id', $non_existing_ids) ->delete(); } //save user forms (assgined) $permissions = $request->input('permissions'); $form_ids = $request->input('form_id'); $user_forms = []; if (! empty($form_ids) && ! empty($permissions)) { foreach ($form_ids as $key => $form_id) { $user_forms[] = [ 'form_id' => $form_id, 'assigned_by' => \Auth::id(), 'permissions' => $permissions, ]; } } $user->userForms()->createMany($user_forms); if (! empty($request->input('send_email'))) { $input['password'] = $request->input('password'); $user->notify(new UserNotification($input)); } $output = $this->respondSuccess(); } catch (Exception $e) { $output = $this->respondWentWrong($e); } return $output; } /** * Remove the specified resource from storage. * * @param int $id * @return \Illuminate\Http\Response */ public function destroy($id) { try { if (request()->ajax()) { if (! empty($this->notAllowedInDemo())) { return $this->notAllowedInDemo(); } $user = User::findOrFail($id); if (\Auth::id() != $user->id) { $user->createdForms()->delete(); $user->userForms()->delete(); $user->delete(); $output = $this->respondSuccess(); } else { $output = $this->respondWithError(__('messages.something_went_wrong')); } } } catch (Exception $e) { $output = $this->respondWentWrong($e); } return $output; } /** * toggle users status(active/inactive) * * @param int $id * @return \Illuminate\Http\Response */ public function toggleUserActiveStatus($id) { try { if (request()->ajax()) { if (! empty($this->notAllowedInDemo())) { return $this->notAllowedInDemo(); } $user = User::findOrFail($id); if (\Auth::id() != $user->id) { $user->is_active = ! $user->is_active; $user->save(); $output = $this->respondSuccess(); } else { $output = $this->respondWithError(__('messages.something_went_wrong')); } } } catch (Exception $e) { $output = $this->respondWentWrong($e); } return $output; } /** * check if email exist or not * * @return \Illuminate\Http\Response */ public function checkIfEmailExist(Request $request) { $email = $request->input('email'); $query = User::where('email', $email); if (! empty($request->input('user_id'))) { $user_id = $request->input('user_id'); $query->where('id', '!=', $user_id); } $exists = $query->exists(); if (! $exists) { echo 'true'; exit; } else { echo 'false'; exit; } } /** * Upgrade modal for upgrade the specified resource. * * @param int $id * @return \Illuminate\Http\Response */ public function upgrade($id) { if (request()->ajax()) { $user = User::findOrFail($id); $active_packages = Package::where('is_active', 1) ->orderBy('sort_order', 'asc') ->paginate(20); return view('superadmin.users.upgrade') ->with(compact('user', 'active_packages')); } } }