Merge branch 'staging' into feature/senior-officer
This commit is contained in:
@@ -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)
|
||||||
{
|
{
|
||||||
@@ -117,6 +118,10 @@
|
|||||||
// nomor di set 0001
|
// nomor di set 0001
|
||||||
$noUrutAkhirString = sprintf("%04s", 1);
|
$noUrutAkhirString = sprintf("%04s", 1);
|
||||||
if($penawaran)
|
if($penawaran)
|
||||||
|
{
|
||||||
|
$isNum = substr($maxCode, 2); // memastikan string ke 3 s/d 8 adalan numiric
|
||||||
|
$isNP = substr($maxCode, 0, 2);
|
||||||
|
if((8 == strlen($maxCode)) && ("NP"==$isNP) && (isNumeric($isNum)))
|
||||||
{
|
{
|
||||||
$code_penawaran_last = substr ($maxCode, -4);
|
$code_penawaran_last = substr ($maxCode, -4);
|
||||||
$year_penawaran_last = Carbon::parse($penawaran->created_at)->year;
|
$year_penawaran_last = Carbon::parse($penawaran->created_at)->year;
|
||||||
@@ -127,9 +132,16 @@
|
|||||||
// 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();
|
||||||
|
}
|
||||||
|
|||||||
@@ -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'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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>
|
||||||
|
|||||||
Reference in New Issue
Block a user