forked from s421507/eOSP2
100 lines
4.0 KiB
PHP
100 lines
4.0 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use Illuminate\Http\Request;
|
|
use DB;
|
|
use App\User;
|
|
use App\Rules\Pesel;
|
|
|
|
class userProfileController extends Controller
|
|
{
|
|
public function create(){
|
|
if(auth()->user() != null && auth()->user()->fireStationID != null ){
|
|
$userData = DB::table('users')->where("users.id", '=', auth()->user()->id)
|
|
->leftJoin('ranks', 'users.degreeID', '=', 'ranks.id')
|
|
->leftJoin('unitFunctions', 'users.functionID', '=', 'unitFunctions.id')
|
|
->select('users.id','users.name', 'users.surname', 'users.PESEL','users.phoneNumber', 'users.email', 'ranks.rank', 'unitFunctions.unitFunction', 'users.number')
|
|
->first();
|
|
return view("userProfile", ["userData" => $userData]);
|
|
} else{
|
|
return redirect()->to('/login');
|
|
}
|
|
}
|
|
|
|
public function editForm()
|
|
{
|
|
if(auth()->user() != null && auth()->user()->fireStationID != null )
|
|
{
|
|
|
|
$userData = DB::table('users')->where("id", '=', auth()->user()->id)
|
|
->first();
|
|
|
|
return view("userProfileEdit", ["userData" => $userData]);
|
|
}
|
|
else
|
|
return redirect()->to('/login');
|
|
|
|
}
|
|
|
|
public function update(){
|
|
$this->validate(request(), [
|
|
'name' => 'required|alpha|min:3|max:45',
|
|
'surname' => 'required|alpha|min:3|max:45',
|
|
'PESEL' => new Pesel,
|
|
'phoneNumber' => 'required|digits:9',
|
|
'email' => 'required|email|unique:users,email,'.auth()->user()->id, //wymagaj unikalnego adresu email ale pozwól na zachowanie starego adresu
|
|
],
|
|
[
|
|
'required' => ':attribute jest wymagany(e).',
|
|
'min' => ':attribute musi mieć przynajmniej :min znaki.',
|
|
'max' => ':attribute musi mieć nie więcej niż :max znaków.',
|
|
'alpha' => ':attribute może zawierać tylko litery.',
|
|
'alpha_num' => ':attribute może zawierać tylko litery i cyfry.',
|
|
'digits' => ':attribute musi składać się z :digits cyfr.',
|
|
'unique' =>':attribute jest już zajęty.',
|
|
'confirmed' =>':attribute się nie zgadza.',
|
|
'email' => 'Niepoprawny adres e-mail.'
|
|
]);
|
|
|
|
$request = request();
|
|
$user = User::find( $request->userID);
|
|
$user-> name = $request->name;
|
|
$user-> surname = $request->surname;
|
|
$user-> PESEL = $request->PESEL;
|
|
$user-> phoneNumber = $request->phoneNumber;
|
|
$user-> email = $request->email;
|
|
$user-> changingID = auth()->user()-> id;
|
|
$user->save();
|
|
|
|
return redirect()->to('/userprofile');;
|
|
}
|
|
|
|
public function userTrainings(){
|
|
|
|
if(auth()->user() != null && auth()->user()->fireStationID != null ){
|
|
$userTrainings = DB::table('trainingsFirefighters')->where("trainingsFirefighters.firefighterID", '=', auth()->user()->id)
|
|
->leftJoin('trainings', 'trainingsFirefighters.trainingID', '=', 'trainings.id')
|
|
->whereNull('deleted_at')
|
|
->select('trainingsFirefighters.id','trainings.trainingName','trainingsFirefighters.dateOfComplete', 'trainingsFirefighters.dateOfExpiry')
|
|
->get();
|
|
return view("userTrainings", ["userTrainings" => $userTrainings]);
|
|
}
|
|
else{
|
|
return redirect()->to('/login');;
|
|
}
|
|
}
|
|
|
|
public function userDecorations(){
|
|
if(auth()->user() != null && auth()->user()->fireStationID != null ){
|
|
$userDecorations = DB::table('decorationsFirefighters')->where("decorationsFirefighters.firefighterID", '=', auth()->user()->id)
|
|
->whereNull('decorationsFirefighters.deleted_at')
|
|
->leftJoin('decorations', 'decorationsFirefighters.decorationID', '=', 'decorations.id')
|
|
->get();
|
|
return view("userDecorations", ["userDecorations" => $userDecorations]);
|
|
} else{
|
|
return "Brak dostepu";
|
|
}
|
|
}
|
|
}
|