<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Models\ToolsRequest;
use App\Models\ToolsResource;

class ToolsRequestController extends Controller
{ 
    public function add(Request $request){
        $this->validate($request, [
            'asset_type'    => 'required',
            'asset_name'    => 'required',
            'required_date' => 'required',
            'qty'           => 'required',
            'uom'           => 'required',
            'description'   => 'required'
        ]);
        $data = $request->all();
        $data['status'] = "fot";
        $data['created_by'] = $this->currentName;

        $result = ToolsRequest::create($data);
        if($result){
            return response()->json(['status'=>'success','message'=>'Tools Request Project successfull created','code'=>200]);
        }else{
            return response()->json(['status'=>'failed','message'=>'Tools Request Project failed created','code'=>400]);
        }
    }


        

    public function update(Request $request, $id)
    {
        $dataForm = $request->all();
        if(!$id || (int) $id < 0 || $id==""){
            return response()->json(['status'=>'failed','message'=>'id is required!','code'=>400], 400);
            die();
        }
        if(!isset($dataForm['status'])){
            return response()->json(['status'=>'failed','message'=>'status is required!','code'=>400], 400);
            die();
        }
        $data = ToolsRequest::find($id);
        if($data){ 
            if($dataForm['status']=="receipt to warehouse"){
                 
                $dataT = ToolsResource::where('name', $data->asset_name)->first();
                if($dataT){
                    $result = $data->update($request->all());
                    $payloadMQty = $dataT->qty + $data->qty_received; 
                    $resultUpdateM = ToolsResource::where('id', $dataT->id)->update(['qty' => $payloadMQty]);
                    return response()->json(['status'=>'success', 'message'=>'request material successfully updated!','code'=>200], 200);
                }else{
                    $result = $data->update($request->all());
                    $dataPayloadM = array(
                        "name"          => $dataForm['asset_name'],
                        "uom"           => $dataForm['uom'],
                        "unit_price"    => 0,
                        "description"   => $dataForm['description'],
                        "qty"           => $data->qty_received,
                        "asset_type"    => $dataForm['asset_type'],
                        "created_by"    => $this->currentName
                    );
                    $result = ToolsResource::create($dataPayloadM);
                    if($result){
                        return response()->json(['status'=>'success','message'=>'add data material resource successfully!','code'=>200], 200);
                    }else{
                        return response()->json(['status'=>'failed','message'=>'add data material resource failed!','code'=>400], 400);
                    }
                }
            }else if($dataForm['status']=="receipt to site"){
                 
                $dataT = ToolsResource::where('name', $data->asset_name)->first();
                if($dataT){
                    $result = $data->update($request->all());
                    $payloadMQty = $dataT->qty - $data->qty_received; 
                    if($payloadMQty < 0){
                        return response()->json(['status'=>'failed','message'=>'update status receipt to site request material resource failed, because material is not exist in warehouse!','code'=>400], 400);
                        die();
                    }
                    $resultUpdateM = ToolsResource::where('id', $dataT->id)->update(['qty' => $payloadMQty]);
                    return response()->json(['status'=>'success', 'message'=>'request material status receipt to site successfully updated!','code'=>200], 200);
                }else{
                    return response()->json(['status'=>'failed','message'=>'update status receipt to site request material resource failed, because tools is not exist in warehouse!','code'=>400], 400);
                }
            }else{ 
                $resultUpdate = $data->update($request->all());
                if($resultUpdate){
                    return response()->json(['status'=>'success','message'=>'request material successfully updated!','code'=>200], 200);
                }else{
                    return response()->json(['status'=>'failed','message'=>'request material failed updated!','code'=>400], 400);
                }
            }
        }else{
            return response()->json(['status'=>'failed','message'=>'data request material not found!','code'=>400], 400);
            die();
        } 
    }

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

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

        if($delete){
            return response()->json(['status'=>'success','message'=>'Tools Request Project successfully deleted!','code'=>200], 200);
        }else{
            return response()->json(['status'=>'failed','message'=>'Tools Request Project failed deleted!','code'=>400], 400);
        }
    }

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

        if($data){
            return response()->json(['status'=>'success','code'=>200,'data'=>$data, 'totalRecord'=>$countData], 200);
        }else{
            return response()->json(['status'=>'failed','message'=>'failed get list tools request, please try again later!','code'=>400], 400);
        }
    }
}