validate($request, [ 'name_version' => 'required', 'proyek_id' => 'required' ]); $data = $request->all(); $data['created_by'] = $this->currentName; $result = VersionGantt::create($data); if($result){ return response()->json(['status'=>'success','message'=>'version gantt Project successfull created','code'=>200]); }else{ return response()->json(['status'=>'failed','message'=>'version gantt Project failed created','code'=>400]); } } 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 = VersionGantt::find($id); if($data){ $result = $data->update($request->all()); }else{ return response()->json(['status'=>'failed','message'=>'data version gantt Project not found!','code'=>400], 400); die(); } if($result){ return response()->json(['status'=>'success','message'=>'version gantt Project successfully updated!','code'=>200], 200); }else{ return response()->json(['status'=>'failed','message'=>'version gantt Project failed updated!','code'=>400], 400); } } public function delete($id) { $data = VersionGantt::find($id); if($data){ $delete = $data->delete(); }else{ return response()->json(['status'=>'failed','message'=>'data version gantt Project not found!','code'=>400], 400); die(); } if($delete){ return response()->json(['status'=>'success','message'=>'version gantt Project successfully deleted!','code'=>200], 200); }else{ return response()->json(['status'=>'failed','message'=>'version gantt Project failed deleted!','code'=>400], 400); } } public function edit($id){ if(!$id || (int) $id < 0 || $id==""){ return response()->json(['status'=>'failed','message'=>'id is required!','code'=>400], 400); die(); } $result = VersionGantt::find($id); if($result){ return response()->json(['status'=>'success','code'=>200,'data'=>$result], 200); }else{ return response()->json(['status'=>'failed','message'=>'failed get data version gantt, please try again later!','code'=>400], 400); } } public function search(Request $request) { $payload = $request->all(); $dataBuilder = $this->setUpPayload($payload, 'm_version_gantt'); $builder = $dataBuilder['builder']; // $countBuilder = $dataBuilder['count']; $progress = $this->ganttProgress($request->columns[0]["name"], $request->columns[0]["value"]); $dataGet = $builder->get(); // Loop through $dataGet collection foreach ($dataGet as $item) { // Loop through $progress collection foreach ($progress as $progressItem) { // Check if both have the same id if ($item->id == $progressItem->id) { // Set the progress of $item to the corresponding progress of $progressItem dd($progressItem); $item->progress = $progressItem->persentase_progress; break; } } } // $totalRecord = $countBuilder->count(); return response()->json(['status'=>'success','code'=>200,'data'=>$dataGet], 200); } public function ganttProgress($column, $value){ $progress = VersionGantt::select('m_version_gantt.id','m_activity.persentase_progress', 'm_activity.progress') ->join('m_activity', 'm_version_gantt.id', '=', 'm_activity.version_gantt_id') ->where("m_version_gantt.".$column, $value) ->where('m_activity.type_activity', "project") ->where('m_activity.parent_id', null) ->get(); return $progress; } public function list() { $data = VersionGantt::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 version gantt, please try again later!','code'=>400], 400); } } }