<?php

namespace App\Http\Controllers;


use Illuminate\Http\Request;
use App\fireStation;
use DB;
use Illuminate\Support\Facades\View;

class fireStationController extends Controller
{
    public function create(){
        if(auth()->user() != null && auth()->user()->fireStationID != null ){
                $users = DB::table('users')
                    ->where('fireStationID', '=', auth()->user()->fireStationID)
                    ->count();
                $fireStation = fireStation::find(auth()->user()->fireStationID);
                return View::make('unit')->with(compact('fireStation', 'users'));

        } else{
            $voivodeships = DB::table('wojewodztwa')->pluck("name","id");
            return view('unit',compact('voivodeships'));
        }
    }

    public function editForm()
    {
        if(auth()->user() != null && auth()->user()->fireStationID != null )
        {
            $id = auth()->user()->fireStationID;
            $fireStation = DB::table('fireStations')->where("id", $id)->first();
            $voivodeships = DB::table('wojewodztwa')->pluck("name","id");
            return view('fireStationEdit', ["fireStation" => $fireStation], compact('voivodeships'));
        }
        else
            return "Brak dostępu";
    }

    public function store()
    {
        $this->validate(request(),[
            'fireStationName' => '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 -> fireStationName,
            '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');
    }
    public function update(){
        $this->validate(request(),[
            'fireStationName' => '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,email,'.auth()->user()->fireStationID,  //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.',
            '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();

            $fireStation = fireStation::find($request->fireStationID);
            $fireStation-> name = $request-> fireStationName;
            $fireStation-> number = $request-> number;
            $fireStation-> voivodeship = $voivodeship-> name;
            $fireStation-> county = $county-> name;
            $fireStation-> community = $community-> name;
            $fireStation-> postOffice = $request-> postOffice;
            $fireStation-> zipCode = $request-> zipCode;
            $fireStation-> address = $request-> address;
            $fireStation-> latitude = $request-> latitude;
            $fireStation-> longitude = $request-> longitude;
            $fireStation-> KRS = $request-> KRS;
            $fireStation-> NIP = $request-> NIP;
            $fireStation-> phoneNumber = $request-> phoneNumber;
            $fireStation-> email = $request-> email;
            $fireStation-> changingID = auth()->user()->id;
            $fireStation->save();

        return redirect()->to('/jednostka');;
    }
}