forked from s421507/eOSP2
85 lines
3.3 KiB
PHP
85 lines
3.3 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
|
|
use Illuminate\Http\Request;
|
|
use App\fireStation;
|
|
use DB;
|
|
|
|
class fireStationController extends Controller
|
|
{
|
|
public function create(){
|
|
if(auth()->user() != null && auth()->user()->fireStationID != null ){
|
|
$fireStation = fireStation::find(auth()->user()->fireStationID);
|
|
return view('unit', ["fireStation" => $fireStation]);
|
|
} else{
|
|
$voivodeships = DB::table('wojewodztwa')->pluck("name","id");
|
|
return view('unit',compact('voivodeships'));
|
|
//return view('unit');
|
|
}
|
|
}
|
|
public function store()
|
|
{
|
|
$this->validate(request(),[
|
|
'unitName' => 'required|min:3|max:45',
|
|
'number' => 'required|numeric',
|
|
'voivodeship' => 'required',
|
|
'county' => 'required',
|
|
'community' => 'required',
|
|
'postOffice' => 'required|min:3|max:45',
|
|
'zipCode' => 'required|digits:5',
|
|
'latitude' => ['required', 'regex:/^[-]?(([0-8]?[0-9])\.(\d+))|(90(\.0+)?)$/'],
|
|
'longitude' => ['required', 'regex:/^[-]?((((1[0-7][0-9])|([0-9]?[0-9]))\.(\d+))|180(\.0+)?)$/'],
|
|
'address' => 'required|min:3|max:45',
|
|
'KRS' => 'required|digits:10',
|
|
'NIP' => 'required|digits:10',
|
|
'phoneNumber' => 'required|digits:9',
|
|
'email' => 'required|email|unique:fireStations',
|
|
],
|
|
[
|
|
'required' => ':attribute jest wymagany(e).',
|
|
'min' => ':attribute musi mieć przynajmniej :min znaki.',
|
|
'max' => ':attribute musi mieć nie więcej niż :max znaków.',
|
|
'numeric' => ':attribute może zawierać tylko cyfry.',
|
|
'digits' => ':attribute musi składać się z :digits cyfr.',
|
|
'unique' =>':attribute jest już zajęty.',
|
|
'email' => 'Niepoprawny adres e-mail.',
|
|
'latitude.regex' =>':attribute ma zakres od -90.0 do 90.0',
|
|
'longitude.regex' =>':attribute ma zakres od -180.0 do 180.0'
|
|
]);
|
|
|
|
|
|
$request = request();
|
|
|
|
$voivodeship = DB::table('wojewodztwa')->select('name')->where('id', $request -> voivodeship)->first();
|
|
$county = DB::table('powiaty')->select('name')->where('id', $request -> county)->first();
|
|
$community = DB::table('gminy')->select('name')->where('id', $request -> community)->first();
|
|
|
|
$jednostka = fireStation::create([
|
|
'name' => $request -> unitName,
|
|
'number' => $request -> number,
|
|
'voivodeship' => $voivodeship -> name,
|
|
'county' => $county -> name,
|
|
'community' => $community -> name,
|
|
'postOffice' => $request -> postOffice,
|
|
'zipCode' => $request -> zipCode,
|
|
'address' => $request -> address,
|
|
'latitude' => $request -> latitude,
|
|
'longitude' => $request -> longitude,
|
|
'KRS' => $request -> KRS,
|
|
'NIP' => $request -> NIP,
|
|
'phoneNumber' => $request -> phoneNumber,
|
|
'email' => $request -> email,
|
|
'creatorID' => auth()->user()->id,
|
|
'changingID' => auth()->user()->id
|
|
]);
|
|
|
|
$user = auth()->user();
|
|
$user->fireStationID = $jednostka->id;
|
|
$user->save();
|
|
|
|
return redirect()->to('/jednostka');
|
|
}
|
|
}
|