Custom user fields during registration and profile edit #711
This commit is contained in:
@@ -158,11 +158,12 @@ class UserController extends Controller
|
||||
*/
|
||||
public function edit($id)
|
||||
{
|
||||
$user = $this->userRepo->findWithoutFail($id);
|
||||
$user = $this->userRepo
|
||||
->with(['fields', 'rank'])
|
||||
->findWithoutFail($id);
|
||||
|
||||
if (empty($user)) {
|
||||
Flash::error('User not found');
|
||||
|
||||
return redirect(route('admin.users.index'));
|
||||
}
|
||||
|
||||
|
||||
154
app/Http/Controllers/Admin/UserFieldController.php
Normal file
154
app/Http/Controllers/Admin/UserFieldController.php
Normal file
@@ -0,0 +1,154 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Admin;
|
||||
|
||||
use App\Contracts\Controller;
|
||||
use App\Repositories\UserFieldRepository;
|
||||
use Illuminate\Http\Request;
|
||||
use Laracasts\Flash\Flash;
|
||||
use Prettus\Repository\Criteria\RequestCriteria;
|
||||
|
||||
class UserFieldController extends Controller
|
||||
{
|
||||
/** @var \App\Repositories\UserFieldRepository */
|
||||
private $userFieldRepo;
|
||||
|
||||
/**
|
||||
* @param UserFieldRepository $userFieldRepo
|
||||
*/
|
||||
public function __construct(UserFieldRepository $userFieldRepo)
|
||||
{
|
||||
$this->userFieldRepo = $userFieldRepo;
|
||||
}
|
||||
|
||||
/**
|
||||
* Display a listing of the UserField.
|
||||
*
|
||||
* @param Request $request
|
||||
*
|
||||
* @throws \Prettus\Repository\Exceptions\RepositoryException
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
public function index(Request $request)
|
||||
{
|
||||
$this->userFieldRepo->pushCriteria(new RequestCriteria($request));
|
||||
$fields = $this->userFieldRepo->all();
|
||||
|
||||
return view('admin.userfields.index', ['fields' => $fields]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for creating a new UserField.
|
||||
*/
|
||||
public function create()
|
||||
{
|
||||
return view('admin.userfields.create');
|
||||
}
|
||||
|
||||
/**
|
||||
* Store a newly created UserField in storage.
|
||||
*
|
||||
* @param Request $request
|
||||
*
|
||||
* @throws \Prettus\Validator\Exceptions\ValidatorException
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
$this->userFieldRepo->create($request->all());
|
||||
|
||||
Flash::success('Field added successfully.');
|
||||
return redirect(route('admin.userfields.index'));
|
||||
}
|
||||
|
||||
/**
|
||||
* Display the specified UserField.
|
||||
*
|
||||
* @param int $id
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
public function show($id)
|
||||
{
|
||||
$field = $this->userFieldRepo->findWithoutFail($id);
|
||||
|
||||
if (empty($field)) {
|
||||
Flash::error('Flight field not found');
|
||||
return redirect(route('admin.userfields.index'));
|
||||
}
|
||||
|
||||
return view('admin.userfields.show', ['field' => $field]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for editing the specified UserField.
|
||||
*
|
||||
* @param int $id
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
public function edit($id)
|
||||
{
|
||||
$field = $this->userFieldRepo->findWithoutFail($id);
|
||||
|
||||
if (empty($field)) {
|
||||
Flash::error('Field not found');
|
||||
return redirect(route('admin.userfields.index'));
|
||||
}
|
||||
|
||||
return view('admin.userfields.edit', ['field' => $field]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the specified UserField in storage.
|
||||
*
|
||||
* @param $id
|
||||
* @param Request $request
|
||||
*
|
||||
* @throws \Prettus\Validator\Exceptions\ValidatorException
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
public function update($id, Request $request)
|
||||
{
|
||||
$field = $this->userFieldRepo->findWithoutFail($id);
|
||||
|
||||
if (empty($field)) {
|
||||
Flash::error('UserField not found');
|
||||
return redirect(route('admin.userfields.index'));
|
||||
}
|
||||
|
||||
$this->userFieldRepo->update($request->all(), $id);
|
||||
|
||||
Flash::success('Field updated successfully.');
|
||||
return redirect(route('admin.userfields.index'));
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the specified UserField from storage.
|
||||
*
|
||||
* @param int $id
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
public function destroy($id)
|
||||
{
|
||||
$field = $this->userFieldRepo->findWithoutFail($id);
|
||||
if (empty($field)) {
|
||||
Flash::error('Field not found');
|
||||
return redirect(route('admin.userfields.index'));
|
||||
}
|
||||
|
||||
if ($this->userFieldRepo->isInUse($id)) {
|
||||
Flash::error('This field cannot be deleted, it is in use. Deactivate it instead');
|
||||
return redirect(route('admin.userfields.index'));
|
||||
}
|
||||
|
||||
$this->userFieldRepo->delete($id);
|
||||
|
||||
Flash::success('Field deleted successfully.');
|
||||
return redirect(route('admin.userfields.index'));
|
||||
}
|
||||
}
|
||||
@@ -3,19 +3,20 @@
|
||||
namespace App\Http\Controllers\Auth;
|
||||
|
||||
use App\Contracts\Controller;
|
||||
use App\Http\Requests\CreateUserRequest;
|
||||
use App\Models\Enums\UserState;
|
||||
use App\Models\User;
|
||||
use App\Models\UserField;
|
||||
use App\Models\UserFieldValue;
|
||||
use App\Repositories\AirlineRepository;
|
||||
use App\Repositories\AirportRepository;
|
||||
use App\Services\UserService;
|
||||
use App\Support\Countries;
|
||||
use App\Support\Timezonelist;
|
||||
use Illuminate\Contracts\Validation\Validator;
|
||||
use Illuminate\Foundation\Auth\RegistersUsers;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Hash;
|
||||
use Illuminate\Support\Facades\Log;
|
||||
use Illuminate\Support\Facades\Validator;
|
||||
|
||||
class RegisterController extends Controller
|
||||
{
|
||||
@@ -61,12 +62,14 @@ class RegisterController extends Controller
|
||||
{
|
||||
$airports = $this->airportRepo->selectBoxList(false, setting('pilots.home_hubs_only'));
|
||||
$airlines = $this->airlineRepo->selectBoxList();
|
||||
$userFields = UserField::where(['show_on_registration' => true])->get();
|
||||
|
||||
return view('auth.register', [
|
||||
'airports' => $airports,
|
||||
'airlines' => $airlines,
|
||||
'countries' => Countries::getSelectList(),
|
||||
'timezones' => Timezonelist::toArray(),
|
||||
'airports' => $airports,
|
||||
'airlines' => $airlines,
|
||||
'countries' => Countries::getSelectList(),
|
||||
'timezones' => Timezonelist::toArray(),
|
||||
'userFields' => $userFields,
|
||||
]);
|
||||
}
|
||||
|
||||
@@ -88,6 +91,12 @@ class RegisterController extends Controller
|
||||
'toc_accepted' => 'accepted',
|
||||
];
|
||||
|
||||
// Dynamically add the required fields
|
||||
$userFields = UserField::where(['show_on_registration' => true, 'required' => true])->get();
|
||||
foreach ($userFields as $field) {
|
||||
$rules['field_'.$field->slug] = 'required';
|
||||
}
|
||||
|
||||
if (config('captcha.enabled')) {
|
||||
$rules['g-recaptcha-response'] = 'required|captcha';
|
||||
}
|
||||
@@ -119,6 +128,15 @@ class RegisterController extends Controller
|
||||
|
||||
Log::info('User registered: ', $user->toArray());
|
||||
|
||||
$userFields = UserField::all();
|
||||
foreach ($userFields as $field) {
|
||||
$field_name = 'field_'.$field->slug;
|
||||
UserFieldValue::updateOrCreate([
|
||||
'user_field_id' => $field->id,
|
||||
'user_id' => $user->id,
|
||||
], ['value' => $opts[$field_name]]);
|
||||
}
|
||||
|
||||
return $user;
|
||||
}
|
||||
|
||||
@@ -131,8 +149,10 @@ class RegisterController extends Controller
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
public function register(CreateUserRequest $request)
|
||||
public function register(Request $request)
|
||||
{
|
||||
$this->validator($request->all())->validate();
|
||||
|
||||
$user = $this->create($request->all());
|
||||
if ($user->state === UserState::PENDING) {
|
||||
return view('auth.pending');
|
||||
|
||||
@@ -4,6 +4,8 @@ namespace App\Http\Controllers\Frontend;
|
||||
|
||||
use App\Contracts\Controller;
|
||||
use App\Models\User;
|
||||
use App\Models\UserField;
|
||||
use App\Models\UserFieldValue;
|
||||
use App\Repositories\AirlineRepository;
|
||||
use App\Repositories\AirportRepository;
|
||||
use App\Repositories\UserRepository;
|
||||
@@ -63,16 +65,22 @@ class ProfileController extends Controller
|
||||
*/
|
||||
public function index()
|
||||
{
|
||||
/** @var User $user */
|
||||
$user = Auth::user();
|
||||
|
||||
if (setting('pilots.home_hubs_only')) {
|
||||
$airports = $this->airportRepo->findWhere(['hub' => true]);
|
||||
} else {
|
||||
$airports = $this->airportRepo->all();
|
||||
}
|
||||
|
||||
$userFields = $this->userRepo->getUserFields($user);
|
||||
|
||||
return view('profile.index', [
|
||||
'acars' => $this->acarsEnabled(),
|
||||
'user' => Auth::user(),
|
||||
'airports' => $airports,
|
||||
'acars' => $this->acarsEnabled(),
|
||||
'user' => $user,
|
||||
'airports' => $airports,
|
||||
'userFields' => $userFields,
|
||||
]);
|
||||
}
|
||||
|
||||
@@ -83,10 +91,12 @@ class ProfileController extends Controller
|
||||
*/
|
||||
public function show($id)
|
||||
{
|
||||
$user = User::where('id', $id)->first();
|
||||
$user = User::with(['fields', 'fields.field'])
|
||||
->where('id', $id)
|
||||
->first();
|
||||
|
||||
if (empty($user)) {
|
||||
Flash::error('User not found!');
|
||||
|
||||
return redirect(route('frontend.dashboard.index'));
|
||||
}
|
||||
|
||||
@@ -109,22 +119,27 @@ class ProfileController extends Controller
|
||||
*/
|
||||
public function edit(Request $request)
|
||||
{
|
||||
$user = User::where('id', Auth::user()->id)->first();
|
||||
/** @var \App\Models\User $user */
|
||||
$user = User::with(['fields', 'fields.field'])
|
||||
->where('id', Auth::user()->id)
|
||||
->first();
|
||||
|
||||
if (empty($user)) {
|
||||
Flash::error('User not found!');
|
||||
|
||||
return redirect(route('frontend.dashboard.index'));
|
||||
}
|
||||
|
||||
$airlines = $this->airlineRepo->selectBoxList();
|
||||
$airports = $this->airportRepo->selectBoxList(false, setting('pilots.home_hubs_only'));
|
||||
$userFields = $this->userRepo->getUserFields($user);
|
||||
|
||||
return view('profile.edit', [
|
||||
'user' => $user,
|
||||
'airlines' => $airlines,
|
||||
'airports' => $airports,
|
||||
'countries' => Countries::getSelectList(),
|
||||
'timezones' => Timezonelist::toArray(),
|
||||
'user' => $user,
|
||||
'airlines' => $airlines,
|
||||
'airports' => $airports,
|
||||
'countries' => Countries::getSelectList(),
|
||||
'timezones' => Timezonelist::toArray(),
|
||||
'userFields' => $userFields,
|
||||
]);
|
||||
}
|
||||
|
||||
@@ -140,13 +155,20 @@ class ProfileController extends Controller
|
||||
$id = Auth::user()->id;
|
||||
$user = $this->userRepo->findWithoutFail($id);
|
||||
|
||||
$validator = Validator::make($request->toArray(), [
|
||||
$rules = [
|
||||
'name' => 'required',
|
||||
'email' => 'required|unique:users,email,'.$id,
|
||||
'airline_id' => 'required',
|
||||
'password' => 'confirmed',
|
||||
'avatar' => 'nullable|mimes:jpeg,png,jpg',
|
||||
]);
|
||||
];
|
||||
|
||||
$userFields = UserField::where(['show_on_registration' => true, 'required' => true])->get();
|
||||
foreach ($userFields as $field) {
|
||||
$rules['field_'.$field->slug] = 'required';
|
||||
}
|
||||
|
||||
$validator = Validator::make($request->toArray(), $rules);
|
||||
|
||||
if ($validator->fails()) {
|
||||
Log::info('validator failed for user '.$user->ident);
|
||||
@@ -167,6 +189,7 @@ class ProfileController extends Controller
|
||||
if (isset($req_data['avatar']) !== null) {
|
||||
Storage::delete($user->avatar);
|
||||
}
|
||||
|
||||
if ($request->hasFile('avatar')) {
|
||||
$avatar = $request->file('avatar');
|
||||
$file_name = $user->ident.'.'.$avatar->getClientOriginalExtension();
|
||||
@@ -190,6 +213,16 @@ class ProfileController extends Controller
|
||||
|
||||
$this->userRepo->update($req_data, $id);
|
||||
|
||||
// Save all of the user fields
|
||||
$userFields = UserField::all();
|
||||
foreach ($userFields as $field) {
|
||||
$field_name = 'field_'.$field->slug;
|
||||
UserFieldValue::updateOrCreate([
|
||||
'user_field_id' => $field->id,
|
||||
'user_id' => $id,
|
||||
], ['value' => $request->get($field_name)]);
|
||||
}
|
||||
|
||||
Flash::success('Profile updated successfully!');
|
||||
|
||||
return redirect(route('frontend.profile.index'));
|
||||
|
||||
Reference in New Issue
Block a user