Custom Backend OSPRO Surveyor Indonesia
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.

380 lines
11 KiB

<?php
namespace App\Http\Controllers;
use App\Helpers\MasterFunctionsHelper;
use App\Models\Divisi;
2 years ago
use App\Models\Project;
use App\Models\ProjectPhase;
2 years ago
use App\Models\User;
use App\Models\UserToVersionGantt;
use Illuminate\Support\Collection;
use Illuminate\Support\Facades\DB;
2 years ago
use Illuminate\Support\Facades\Log;
class DashboardBoDController extends Controller
{
1 year ago
private function interpolateYear($year)
{
if ($year)
$year = '%' . $year . '%';
return $year;
}
1 year ago
private function curlReq($url, $token)
{
$ch = curl_init();
$headers = [
1 year ago
'Authorization: ' . $token
];
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$response = curl_exec($ch);
if ($response === false)
$response = curl_error($ch);
curl_close($ch);
return json_decode($response);
}
1 year ago
private function getInvoiceIntegration($search)
{
if (empty($search))
return response()->json(['status' => 'error', 'message' => 'Empty query string!'], 400);
$url = str_replace("SEARCH", $search, config('api.adw') . '/project_cost?project_no=SEARCH');
$token = config('api.adw_token');
$response = $this->curlReq($url, $token);
if (@$response->data->project_no == "")
return null;
return $response;
}
2 years ago
// to do
1 year ago
public function getCompanyCashFlow($year = '%')
{
$year = $this->interpolateYear($year);
$totalExpenditure = $totalInvoice = $totalPaidInvoice = 0;
// we can't use eloquent's sum() method because someone decided to use varchar as datatype in rencana_biaya field
$totalBudgets = Project::select(DB::raw("SUM(CAST(REPLACE(rencana_biaya, ',', '.') AS DOUBLE PRECISION))"))
->where('mulai_proyek', 'like', $year)
1 year ago
/* ->orWhere('akhir_proyek', 'like', $year) */
->pluck('sum')
->first();
$projects = Project::where('mulai_proyek', 'like', $year)
/* ->orWhere('akhir_proyek', 'like', $year) */
->get();
1 year ago
foreach ($projects as $project) {
$project->expenses = 0;
$resp = null;
1 year ago
if ($project->kode_sortname != "") {
$resp = $this->getInvoiceIntegration($project->kode_sortname);
/* $resp = $project->kode_sortname; */
2 years ago
$cost = $resp->data->total_cost ?? 0;
$cost = substr($cost, 0, strpos($cost, "."));
1 year ago
$totalExpenditure += (int) $cost;
$totalInvoice += $resp->data->total_invoice_amount ?? 0;
$totalPaidInvoice += $resp->data->total_invoice_paid_amount ?? 0;
}
}
return response()->json([
'data' => [
'total_budget' => (int) $totalBudgets ?? 0,
'total_expenditure' => $totalExpenditure,
'total_invoice' => $totalInvoice,
1 year ago
'total_paid_invoice' => $totalPaidInvoice,
]
], 200);
}
1 year ago
public function getInvoiceOutstanding($year = '%')
{
$year = $this->interpolateYear($year);
$projects = Project::where('mulai_proyek', 'like', $year)
/* ->orWhere('akhir_proyek', 'like', $year) */
->get();
$return = [];
1 year ago
foreach ($projects as $project) {
$resp = null;
1 year ago
if ($project->kode_sortname != "") {
$resp = $this->getInvoiceIntegration($project->kode_sortname);
array_push($return, [
'project' => $project->nama,
'project_code' => $project->kode_sortname,
1 year ago
'nickname' => $project->nickname,
'invoiced' => $resp->data->total_invoice_amount ?? 0,
'paid' => $resp->data->total_invoice_paid_amount ?? 0,
'response' => $resp,
]);
}
}
2 years ago
return response()->json([
'data' => $return
2 years ago
], 200);
}
public function getTotalProjectPerScheduleHealth()
1 year ago
{
// $year = $this->interpolateYear($year);
$return = [
'behind-schedule' => 0,
'warning' => 0,
'on-schedule' => 0,
];
$projects = Project::get();
foreach ($projects as $index => $project) {
1 year ago
$project->scurve = MasterFunctionsHelper::getSCurve($project->id);
$selisihProgress = 0;
$planningProgress = 0;
$actualProgress = 0;
1 year ago
if ($project->scurve && $project->scurve[0]) {
$planningArray = $project->scurve[0]['data']['percentagePlan'];
$actualArray = $project->scurve[0]['data']['percentageReal'];
$planningProgress = !empty($planningArray) ? $planningArray[count($planningArray) - 1] : 0;
$actualProgress = !empty($actualArray) ? $actualArray[count($actualArray) - 1] : 0;
}
$selisihProgress = $planningProgress - $actualProgress;
2 years ago
try {
if ($selisihProgress > 0 && $selisihProgress <= 20) {
1 year ago
$return['warning'] += 1;
$projects[$index]->status = 'warning';
} elseif ($selisihProgress == 0) {
1 year ago
$return['on-schedule'] += 1;
$projects[$index]->status = 'on-schedule';
} else {
1 year ago
$return['behind-schedule'] += 1;
$projects[$index]->status = 'behind-schedule';
}
2 years ago
} catch (\Error $e) {
1 year ago
return response()->json(['msg' => $e->getMessage(), 'data' => $project], 200);
2 years ago
}
}
2 years ago
return response()->json(['data' => $return, 'q' => $projects], 200);
}
public function getTotalProjectScheduleHealthPerDivision()
1 year ago
{
// $year = $this->interpolateYear($year);
$divisions = Divisi::whereNull('parent')->get();
foreach ($divisions as $index => $division) {
$scheduleData = new Collection();
$behindSchedule = $warning = $onSchedule = 0;
$projects = Project::where('divisi_id', $division->id)->get();
1 year ago
foreach ($projects as $project) {
$project->scurve = MasterFunctionsHelper::getSCurve($project->id);
$selisihProgress = 0;
$planningProgress = 0;
$actualProgress = 0;
if ($project->scurve && $project->scurve[0]) {
$planningArray = $project->scurve[0]['data']['percentagePlan'];
$actualArray = $project->scurve[0]['data']['percentageReal'];
$planningProgress = !empty($planningArray) ? $planningArray[count($planningArray) - 1] : 0;
$actualProgress = !empty($actualArray) ? $actualArray[count($actualArray) - 1] : 0;
}
$selisihProgress = $planningProgress - $actualProgress;
if ($selisihProgress > 0 && $selisihProgress <= 5) {
$warning++;
} elseif ($selisihProgress == 0) {
$onSchedule++;
} else {
$behindSchedule++;
}
}
$scheduleData->prepend($behindSchedule, 'behindSchedule');
$scheduleData->prepend($warning, 'warning');
$scheduleData->prepend($onSchedule, 'onSchedule');
$divisions[$index]->scheduleData = $scheduleData;
}
return response()->json([
'data' => [
$divisions
]
], 200);
}
public function getTotalProjectPerBudgetHealth()
1 year ago
{
return response()->json([
'data' => [
'overrun' => Project::where('budget_health', 'overrun')->count(),
'warning' => Project::where('budget_health', 'warning')->count(),
'on-budget' => Project::where('budget_health', 'on-budget')->count(),
]
], 200);
}
private function countTotalProjectByBudgetHealthInDivision($divisi, $health)
1 year ago
{
2 years ago
return Project::where('divisi_id', $divisi)
// ->where('mulai_proyek', 'like', $year)
1 year ago
/* ->orWhere('akhir_proyek', 'like', $year) */
2 years ago
->where('budget_health', $health)
->count();
}
2 years ago
public function getTotalProjectBudgetHealthPerDivision()
1 year ago
{
// $year = $this->interpolateYear($year);
1 year ago
$divisions = Divisi::select('id', 'name')
2 years ago
->with('children')
->whereNull('parent')
->get();
// to do : count in more than 1 level child
1 year ago
foreach ($divisions as $division) {
$budgetData = new Collection();
$budgetData->prepend($this->countTotalProjectByBudgetHealthInDivision($division->id, 'overrun'), 'overrun');
$budgetData->prepend($this->countTotalProjectByBudgetHealthInDivision($division->id, 'warning'), 'warning');
$budgetData->prepend($this->countTotalProjectByBudgetHealthInDivision($division->id, 'on-budget'), 'on-budget');
1 year ago
foreach ($division->children as $d) {
$budgetData['overrun'] += $this->countTotalProjectByBudgetHealthInDivision($d->id, 'overrun');
$budgetData['warning'] += $this->countTotalProjectByBudgetHealthInDivision($d->id, 'warning');
$budgetData['on-budget'] += $this->countTotalProjectByBudgetHealthInDivision($d->id, 'on-budget');
2 years ago
}
unset($division->children);
$division->budgetData = $budgetData;
}
1 year ago
foreach ($divisions as $division) {
2 years ago
}
return response()->json([
'data' => [
$divisions
]
], 200);
}
public function getTotalProjectPerPhase()
1 year ago
{
// $year = $this->interpolateYear($year);
$projectPhases = ProjectPhase::orderBy('order')->get();
1 year ago
foreach ($projectPhases as $phase) {
2 years ago
$phase->totalProject = Project::where('phase_id', $phase->id)
// ->where('mulai_proyek', 'like', $year)
1 year ago
/* ->orWhere('akhir_proyek', 'like', $year) */
->count();
}
return response()->json([
'data' => [
$projectPhases
]
], 200);
}
private function countTotalProjectInDivision($id)
1 year ago
{
return Project::where('divisi_id', $id)
// ->where('mulai_proyek', 'like', $year)
->count();
}
public function getTotalProjectPerDivision()
1 year ago
{
// $year = $this->interpolateYear($year);
$divisions = Divisi::select('id', 'name', 'parent', 'color')
->with('children')
->whereNull('parent')
->get();
// to do : count in more than 1 level child
1 year ago
foreach ($divisions as $v) {
$v->total = $this->countTotalProjectInDivision($v->id);
1 year ago
foreach ($v->children as $d) {
$v->total += $this->countTotalProjectInDivision($d->id);
}
unset($v->children);
}
return response()->json([
2 years ago
'data' => $divisions
], 200);
}
private function countTotalProjectValueInDivision($id)
1 year ago
{
return Project::select(DB::raw("SUM(CAST(REPLACE(rencana_biaya, ',', '.') AS DOUBLE PRECISION))"))
// ->where('mulai_proyek', 'like', $year)
1 year ago
/* ->orWhere('akhir_proyek', 'like', $year) */
->where('divisi_id', $id)
->pluck('sum')
->first();
}
public function getTotalProjectValuePerDivision()
1 year ago
{
$divisions = Divisi::select('id', 'name', 'color')
->with('children')
->whereNull('parent')
->get();
// to do : count in more than 1 level child
1 year ago
foreach ($divisions as $v) {
$v->total = $this->countTotalProjectValueInDivision($v->id);
1 year ago
foreach ($v->children as $d) {
$v->total += $this->countTotalProjectValueInDivision($d->id);
}
unset($v->children);
}
return response()->json([
2 years ago
'data' => $divisions
], 200);
}
public function getDetailExpenditure()
1 year ago
{
// $year = $this->interpolateYear($year);
$projects = Project::select('m_proyek.*', 'md.name as divisi_name', 'tpy.name as project_type_name')
// ->where('mulai_proyek', 'like', $year)
->join('m_divisi as md', 'md.id', '=', 'm_proyek.divisi_id')
->join('m_type_proyek as tpy', 'tpy.id', '=', 'm_proyek.type_proyek_id')
->orderBy('id', 'desc')
2 years ago
->get();
1 year ago
foreach ($projects as $project) {
$lastGantt = MasterFunctionsHelper::getLatestGantt($project->id);
2 years ago
1 year ago
if ($project->kode_sortname != "") {
2 years ago
$resp = $this->getInvoiceIntegration($project->kode_sortname);
$project->invoice = [
'invoiced' => $resp->data->total_invoice_amount ?? 0,
'paid' => $resp->data->total_invoice_paid_amount ?? 0,
];
}
$project->pm = User::find($project->pm_id);
/* $project->header = Activity::where('proyek_id', $project->id)->where('version_gantt_id', $lastGantt['last_gantt_id'])->whereNull('parent_id')->first(); */
1 year ago
if (!isset($lastGantt['last_gantt_id'])) {
$project->manPowers = 0;
} else {
$project->manPowers = UserToVersionGantt::where('version_gantt_id', $lastGantt['last_gantt_id'])->count();
$project->scurve = MasterFunctionsHelper::getSCurve($project->id);
}
$project->lastGanttId = MasterFunctionsHelper::getLatestGantt($project->id);
2 years ago
}
return response()->json([
'data' => $projects,
'total_manpowers' => User::count()
], 200);
}
}