You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
126 lines
4.7 KiB
126 lines
4.7 KiB
<?php |
|
|
|
namespace App\Http\Controllers; |
|
|
|
use Illuminate\Http\Request; |
|
use App\Models\VersionGantt; |
|
|
|
class VersionGanttController extends Controller |
|
{ |
|
public function add(Request $request){ |
|
$this->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 |
|
$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') |
|
->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); |
|
} |
|
} |
|
}
|
|
|