<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Models\ProjectScheduleHealth;

class ProjectScheduleHealthController extends Controller
{
    public function add(Request $request)
    {
        $this->validate($request, [
            'name' => 'required'
        ]);
        $data = $request->all();
        // Set Unique
        $result = ProjectScheduleHealth::query()
        ->where([
            ['company_id',$data['company_id']],
            ['name', $data['name']]
        ])->first();
        if($result) {
            return response()->json(['status'=>'failed','message'=>'Name is already exists!','code'=> 500], 500);
            die;
        }

        $data['created_by'] = $this->currentName;

        if(!ProjectScheduleHealth::create($data))
            return response()->json(['status'=>'failed','message'=>'Failed to add data','code'=> 500], 500);

        return response()->json(['status'=>'success','message'=>'data added!','code'=>200], 200);
    }

    public function edit($id){
        if(!$id || (int) $id < 0 || $id=="")
            return response()->json(['status'=>'failed','message'=>'id is required!','code'=>400], 400);

        if(!$result = ProjectScheduleHealth::find($id))
            return response()->json(['status'=>'failed','message'=>'Failed to get data!','code'=> 404], 404);

        return response()->json(['status'=>'success','code'=>200,'data'=>$result], 200);
    }

    public function update(Request $request, $id)
    {
        if(!$id || (int) $id < 0 || $id=="")
            return response()->json(['status'=>'failed','message'=>'id is required!','code'=>400], 400);

        if(!$data = ProjectScheduleHealth::find($id))
            return response()->json(['status'=>'failed','message'=>'data schedule health not found!','code'=>400], 400);

        if(!$data->update($request->all()))
            return response()->json(['status'=>'failed','message'=>'data schedule health failed updated!','code'=>400], 400);

        return response()->json(['status'=>'success','message'=>'Data berhasil disimpan!','code'=>200], 200);
    }

    public function delete($id)
    {

        if(!$data = ProjectScheduleHealth::find($id))
            return response()->json(['status'=>'failed','message'=>'data schedule health not found!','code'=>400], 400);

        if(!$data->delete())
            return response()->json(['status'=>'failed','message'=>'Data gagal dihapus!','code'=> 500], 500);

        return response()->json(['status'=>'success','message'=>'Data berhasil dihapus!','code'=>200], 200);
    }

    public function search(Request $request)
    {
        $payload = $request->all();
        $dataBuilder = $this->setUpPayload($payload, 'm_proyek_schedule_health');
        $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()
    {
        $data = ProjectScheduleHealth::all();
        $countData = $data->count();

        if(!$data)
            return response()->json(['status'=>'failed','message'=>'failed get list schedule health, please try again later!','code'=>400], 400);

        return response()->json(['status'=>'success','code'=>200,'data'=>$data, 'totalRecord'=>$countData], 200);

    }
}