validate($request, [ 'name' => 'required' ]); $data = $request->all(); // Set Unique $result = ProjectExpenditure::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(!ProjectExpenditure::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 = ProjectExpenditure::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 = ProjectExpenditure::find($id)) return response()->json(['status'=>'failed','message'=>'data project expenditure not found!','code'=>400], 400); if(!$data->update($request->all())) return response()->json(['status'=>'failed','message'=>'data project expenditure failed updated!','code'=>400], 400); return response()->json(['status'=>'success','message'=>'Data berhasil disimpan!','code'=>200], 200); } public function delete($id) { if(!$data = ProjectExpenditure::find($id)) return response()->json(['status'=>'failed','message'=>'data project expenditure 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_expenditure'); $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 = ProjectExpenditure::all(); $countData = $data->count(); if(!$data) return response()->json(['status'=>'failed','message'=>'failed get list project expenditure, please try again later!','code'=>400], 400); return response()->json(['status'=>'success','code'=>200,'data'=>$data, 'totalRecord'=>$countData], 200); } }