<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Models\UserMonthlyShift;
use GuzzleHttp\Client;

class UserMonthlyShiftController extends Controller
{
    public function add(Request $request){
        $this->validate($request, [
            'user_id'       => 'required',
            'schedules'     => 'required',
            'start_time'    => 'required'
        ]);
        $data = $request->all(); 
        $data['created_by'] = $this->currentName;

        $result = UserMonthlyShift::create($data); 
        if($result){
            return response()->json(['status'=>'success','message'=>'monthly shift schedule successfull created','code'=>200]);
        }else{
            return response()->json(['status'=>'failed','message'=>'monthly shift schedule failed created','code'=>400]);
        }
    }

    public function import(Request $request)
    {
        $client = new Client();
        $res = $client->request('POST', config('api.golang') . "/monthly-shift-schedules/import",
            ['json' => $request->all()]
        );
        if ($res->getStatusCode() != 200) {
            return response()->json(['status'=>'failed','message'=>'failed to import schedules, please try again later!','code'=>400], 400);
        }

        $result= $res->getBody();
        return response($result, 200)
            ->header("content-type", $res->getHeaderLine('content-type'));
    }

    public function update(Request $request, $id){

        if(!$id || (int) $id < 0 || $id==""){
            return response()->json(['status'=>'failed','message'=>'id is required!','code'=>400], 400);
        }
        $data = UserMonthlyShift::find($id);
        if($data){
            $result = $data->update($request->all());
        }else{
            return response()->json(['status'=>'failed','message'=>'Data monthly shift schedule not found!','code'=>400], 400);
            die();
        }
        
        if($result){
            return response()->json(['status'=>'success','message'=>'monthly shift schedule successfully updated!','code'=>200], 200);
        }else{
            return response()->json(['status'=>'failed','message'=>'monthly shift schedule failed updated!','code'=>400], 400);
        }
    }

    public function delete($id)
    {
        $data = UserMonthlyShift::find($id);

        if($data){
            $delete = $data->delete();
        }else{
            return response()->json(['status'=>'failed','message'=>'data monthly shift schedule not found!','code'=>400], 400);
            die();
        }
        

        if($delete){
            return response()->json(['status'=>'success','message'=>'Shift schedule successfully deleted!','code'=>200], 200);
        }else{
            return response()->json(['status'=>'failed','message'=>'Shift schedule failed deleted!','code'=>400], 400);
        }
    }
    public function deleteYYYYMM($yyyymm) 
    {
        $delete = UserMonthlyShift::deleteYYYYMM($yyyymm);
        if($delete){
            return response()->json(['status'=>'success','message'=>'Shift schedule successfully deleted!','code'=>200], 200);
        }else{
            return response()->json(['status'=>'failed','message'=>'Shift schedule failed deleted!','code'=>400], 400);
        }
    }

    public function search(Request $request)
    {
        $payload = $request->all();
        $dataBuilder = $this->setUpPayload($payload, 'm_shift');
        $builder = $dataBuilder['builder'];
        $countBuilder = $dataBuilder['count'];
        $dataGet = $builder->get();
        $totalRecord = $countBuilder->count();
        return response()->json(['status'=>'success','code'=>200,'data'=>$dataGet, 'totalRecord'=>$totalRecord], 200);
    }

    public function list()
    {
        return $this->listYYYYMM(date('Ym'));
    }

    public function listYYYYMM($yyyymm)
    {
        /*
        $data = UserMonthlyShift::where("to_char(start_at+INTERVAL '1 day', 'YYYYMM')", $yyyymm)
            ->all();
        */
        $data = UserMonthlyShift::monthlyWithUserInfo($yyyymm);
        $countData = $data->count();
        if($data){
            return response()->json([
                'status'=>'success',
                'code'=>200,
                'data'=>$data, 
                'yyyymm' => $yyyymm,
                'totalRecord'=>$countData], 200);
        }else{
            return response()->json(['status'=>'failed','message'=>'failed get list tools request, please try again later!','code'=>400], 400);
        }
    }
}