<?php

namespace App\Http\Controllers;

use App\equipment;
use App\trainings;
use App\trainingsFirefighters;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\View;
use Illuminate\Support\Facades\Validator;

class trainingsController extends Controller
{
    public function create(){

        if(auth()->user() != null && auth()->user()->fireStationID != null ){
            $trainings = DB::table('trainings')->where("fireStationID", '=', auth()->user()->fireStationID)
                ->whereNull('deleted_at')->get();

            $fireFighters = array();
            foreach($trainings as $training) {
                $id = $training->id;
                $fireFighters[$id] = DB::table('users')->where("fireStationID", "=", auth()->user()->fireStationID)
                    ->leftJoin('trainingsFirefighters', function ($join) use ($id) {
                        $join->on('users.id', '=', 'trainingsFirefighters.firefighterID');
                        $join->where('trainingsFirefighters.trainingID', '=', $id);
                    })
                    ->select('trainingsFirefighters.*', 'users.name', 'users.surname', 'users.id as userID')
                    ->get();
            }
            return View::make("trainings")->with(compact( "trainings", "fireFighters"));
        } else{
            return view('trainings');
        }
    }

    public function store(){
        $this->validate(request(), [
            'name' => 'required',
        ],
            [
                'required' => ':attribute jest wymagany(a).',
            ]);


        $request = request();
        $equipment = trainings::create([
            'fireStationID' => auth()->user()->fireStationID,
            'trainingName' => $request-> name,
        ]);

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

    public function addForm(){

    }

    public function addTrainingsFireFighters($id){

        if(auth()->user() != null && auth()->user()->fireStationID != null ){
            $fireFighters = DB::table('users')->where("fireStationID", "=", auth()->user()->fireStationID )
                ->leftJoin('trainingsFirefighters', function ($join) use($id){
                    $join->on('users.id', '=', 'trainingsFirefighters.firefighterID');
                    $join->where('trainingsFirefighters.trainingID', '=', $id);
                })
                ->select('trainingsFirefighters.*', 'users.name', 'users.surname', 'users.id as userID')
                ->get();

            $training = DB::table('trainings')->where("id", '=', $id)
                ->whereNull('deleted_at')->first();
            return View::make("trainingsAddFireFighters")->with(compact( "training", "fireFighters"));
        } else{
            return view('trainings');
        }
    }

    public function ajaxRequest(Request $request){
        $validator = Validator::make($request->all(), [
            'firefighterID' => 'required',
            'trainingID' => 'required',
            'dateOfComplete' => 'required|date',
            'dateOfExpiry' => 'required|date',
        ],
            [
                'required' => ':attribute jest wymagany(a).',
                'dateOfComplete.required' => 'Data wystawienia szkolenia/badania jest wymagana.',
                'dateOfExpiry.required' => 'Data ważności szkolenia/badania jest wymagana.'
            ]);


        // WALIDACJA
        if ($validator->fails()) {

            if($request->ajax())
            {
                return response()->json(array(
                    'success' => false,
                    'message' => 'There are incorect values in the form!',
                    'errors' => $validator->getMessageBag()->toArray()
                ), 422);
            }

            $this->throwValidationException(

                $request, $validator

            );

        // WYKONANIE ZAPYTAŃ PO POPRAWNEJ WALIDACJI
        } else{

            $trainingFirefighter = trainingsFirefighters::where([
                ['firefighterID', '=', $request->firefighterID],
                ['trainingID', '=', $request-> trainingID]
            ])->first();

            if($trainingFirefighter == null){
                // CREATE
                $trainings = trainingsFirefighters::create([
                    'firefighterID' => $request-> firefighterID,
                    'trainingID' => $request-> trainingID,
                    'dateOfComplete' => $request-> dateOfComplete,
                    'dateOfExpiry' => $request-> dateOfExpiry,
                    'lifetime' => 1,
                ]);
            }else{
                // UPDATE
                $trainingFirefighter->update([
                    'dateOfComplete' => $request-> dateOfComplete,
                    'dateOfExpiry' => $request-> dateOfExpiry,
                ]);
            }

        }



    }

    public function deleteFireFighterTrainings(Request $request){
        $validator = Validator::make($request->all(), [
            'firefighterID' => 'required',
            'trainingID' => 'required',
        ]);

        trainingsFirefighters::where([
            ['fireFighterID', '=', $request->firefighterID],
            ['trainingID', '=', $request->trainingID],
        ])->delete();

    }

    public function update(){

    }

    public function destroy($id)
    {
        trainings::where('id',$id)->delete();

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

    public function trainingsRename(Request $request){
        $validator = Validator::make($request->all(), [
            'trainingID' => 'required',
            'trainingName' => 'required',
        ]);

        trainings::where('id', '=', $request->trainingID)
            ->update(['trainingName' => $request->trainingName]);
    }
}