Merge branch 'staging' into feature/senior-officer

This commit is contained in:
majid
2024-12-05 01:38:23 +07:00
3 changed files with 47 additions and 50 deletions

View File

@@ -5,6 +5,7 @@
use Modules\Lpj\Models\HolidayCalendar; use Modules\Lpj\Models\HolidayCalendar;
use Modules\Lpj\Models\PenawaranDetailTender; use Modules\Lpj\Models\PenawaranDetailTender;
use Modules\Lpj\Models\PenawaranTender; use Modules\Lpj\Models\PenawaranTender;
use Modules\Lpj\Models\Penilaian;
function formatTanggalIndonesia($date, $time = false) function formatTanggalIndonesia($date, $time = false)
{ {
@@ -118,18 +119,29 @@
$noUrutAkhirString = sprintf("%04s", 1); $noUrutAkhirString = sprintf("%04s", 1);
if($penawaran) if($penawaran)
{ {
$code_penawaran_last = substr ($maxCode, -4); $isNum = substr($maxCode, 2); // memastikan string ke 3 s/d 8 adalan numiric
$year_penawaran_last = Carbon::parse($penawaran->created_at)->year; $isNP = substr($maxCode, 0, 2);
$year_now = Carbon::now()->year; if((8 == strlen($maxCode)) && ("NP"==$isNP) && (isNumeric($isNum)))
if ($year_now == $year_penawaran_last) { {
$noUrutAkhirString = sprintf("%04s", abs($code_penawaran_last + 1)); $code_penawaran_last = substr ($maxCode, -4);
$year_penawaran_last = Carbon::parse($penawaran->created_at)->year;
$year_now = Carbon::now()->year;
if ($year_now == $year_penawaran_last) {
$noUrutAkhirString = sprintf("%04s", abs($code_penawaran_last + 1));
}
// jika ternyata tahun tdk sama (kurang dari tahun sekarang), maka nomor di set 0001
} }
// jika ternyata tahun tdk sama (kurang dari tahun sekarang), maka nomor di set 0001
} }
return 'NP' . Carbon::now()->format('y') . $noUrutAkhirString; return 'NP' . Carbon::now()->format('y') . $noUrutAkhirString;
} }
function isNumeric($str)
{
return ctype_digit($str);
}
// generate last penawaran.no_spk // generate last penawaran.no_spk
function onLastnumberCodePenawaranSPK($jenis_laporan_code): string function onLastnumberCodePenawaranSPK($jenis_laporan_code): string
{ {
@@ -272,3 +284,10 @@
}, },
)->toArray(); )->toArray();
} }
function countPermohonanForUser($userId)
{
return Penilaian::whereHas('userPenilai', function ($query) use ($userId) {
$query->where('user_id', $userId);
})->count();
}

View File

@@ -33,42 +33,27 @@ class ActivityController extends Controller
public function progres_activity() public function progres_activity()
{ {
// Ambil user yang sedang login // Ambil user yang sedang login dengan roles
$user = auth()->user(); $user = auth()->user()->load('roles');
$roles = $user->load('roles');
// Inisialisasi regionId dan teamId sebagai null agar bisa dinamis // Inisialisasi regionId dan teamId
$regionId = null; $regionId = $teamId = null;
$teamId = null;
if ($roles->roles->pluck('name')->contains('senior-officer')) { if ($user->roles->pluck('name')->contains('senior-officer')) {
$userTeam = TeamsUsers::with('team') $userTeam = TeamsUsers::with('team')->firstWhere('user_id', $user->id);
->where('user_id', $user->id)
->first();
$regionId = $userTeam?->team->regions_id; $regionId = $userTeam?->team->regions_id;
$teamId = $userTeam?->teams_id; $teamId = $userTeam?->teams_id;
} }
$teamsActivity = TeamsUsers::with(['user', 'team', 'team.regions', 'user.roles']) $teamsActivity = TeamsUsers::with(['user', 'team', 'team.regions', 'user.roles'])
->whereHas('team', function ($q) use ($regionId, $teamId) { ->whereHas('team', function ($q) use ($regionId, $teamId) {
if ($regionId) { $q->when($regionId, fn($q) => $q->where('regions_id', $regionId))
$q->where('regions_id', $regionId); ->when($teamId, fn($q) => $q->where('id', $teamId));
}
if ($teamId) {
$q->where('id', $teamId); // Hanya tim yang sama
}
}) })
->where('user_id', '!=', $user->id) ->where('user_id', '!=', $user->id)
->whereHas('user.roles', function ($query) { ->whereHas('user.roles', fn($q) => $q->whereIn('name', ['surveyor', 'surveyor-penilai']))
// Filter hanya peran 'surveyor' atau 'surveyor-penilai'
$query->whereIn('name', ['surveyor', 'surveyor-penilai']);
})
->get(); ->get();
return view('lpj::activity.progres_activity.index', compact('teamsActivity')); return view('lpj::activity.progres_activity.index', compact('teamsActivity'));
} }

View File

@@ -73,14 +73,7 @@
</th> </th>
<th class="min-w-[150px]"> <th class="min-w-[150px]">
<span class="text-base text-gray-900 font-normal"> <span class="text-base text-gray-900 font-normal">
@php <p>Total Task: {{ countPermohonanForUser($item->user->id) }}</p>
$totalTasks = $item->team->regions->penilaiTeam
->filter(function ($penilaiTeam) use ($item) {
return $penilaiTeam->user_id == $item->user->id;
})
->count();
@endphp
<p>Total Task: {{ $totalTasks }}</p>
</span> </span>
</th> </th>
<th> <th>