penambahan form assign so
This commit is contained in:
parent
53ccf7de11
commit
eb92e1b8f7
@ -13,11 +13,16 @@ use Modules\Lpj\Models\Permohonan;
|
|||||||
use Modules\Lpj\Models\TujuanPenilaian;
|
use Modules\Lpj\Models\TujuanPenilaian;
|
||||||
use Modules\Lpj\Models\JenisPenilaian;
|
use Modules\Lpj\Models\JenisPenilaian;
|
||||||
use Modules\Lpj\Models\Teams;
|
use Modules\Lpj\Models\Teams;
|
||||||
|
use Modules\Lpj\Models\TeamsUsers;
|
||||||
|
use Modules\Lpj\Models\Penilaian;
|
||||||
use Modules\Lpj\Models\JenisJaminan;
|
use Modules\Lpj\Models\JenisJaminan;
|
||||||
use Modules\Lpj\Models\NilaiPlafond;
|
use Modules\Lpj\Models\NilaiPlafond;
|
||||||
use Modules\Lpj\Models\JenisFasilitasKredit;
|
use Modules\Lpj\Models\JenisFasilitasKredit;
|
||||||
|
use Modules\Usermanagement\Models\User;
|
||||||
|
use Modules\Lpj\Http\Requests\PenilaianRequest;
|
||||||
|
use Modules\Lpj\Models\DetailDokumenJaminan;
|
||||||
|
use Modules\Lpj\Models\DokumenJaminan;
|
||||||
|
use Modules\Lpj\Exports\PermohonanExport;
|
||||||
|
|
||||||
class PenilaianController extends Controller
|
class PenilaianController extends Controller
|
||||||
{
|
{
|
||||||
@ -42,11 +47,28 @@ class PenilaianController extends Controller
|
|||||||
/**
|
/**
|
||||||
* Store a newly created resource in storage.
|
* Store a newly created resource in storage.
|
||||||
*/
|
*/
|
||||||
public function store(Request $request): RedirectResponse
|
public function store(PenilaianRequest $request)
|
||||||
{
|
{
|
||||||
//
|
$validatedData = $request->validated();
|
||||||
|
|
||||||
|
if ($validatedData) {
|
||||||
|
try {
|
||||||
|
|
||||||
|
$penilaian = Penilaian::create($validatedData);
|
||||||
|
|
||||||
|
$permohonan = Permohonan::findOrFail($request->permohonan_id);
|
||||||
|
$permohonan->update([
|
||||||
|
'status' => 'assign',
|
||||||
|
]);
|
||||||
|
|
||||||
|
return redirect()->route('penilaian.index')->with('success', 'Penilaian berhasil disimpan');
|
||||||
|
} catch (Exception $e) {
|
||||||
|
return redirect()->route('penilaian.index')->with('error', $e->getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Show the specified resource.
|
* Show the specified resource.
|
||||||
*/
|
*/
|
||||||
@ -66,26 +88,36 @@ class PenilaianController extends Controller
|
|||||||
$jenisPenilaian = JenisPenilaian::all();
|
$jenisPenilaian = JenisPenilaian::all();
|
||||||
$teamPenilai = Teams::with(['regions', 'teamsUsers'])->get();
|
$teamPenilai = Teams::with(['regions', 'teamsUsers'])->get();
|
||||||
|
|
||||||
$jenisJaminan = JenisJaminan::all();
|
$penilaian = Penilaian::where('permohonan_id', $id)->first();
|
||||||
|
|
||||||
$nilaiPlafond = NilaiPlafond::all();
|
return view('lpj::penilaian.form', compact('permohonan', 'teamPenilai', 'jenisPenilaian', 'penilaian'));
|
||||||
$jenisFasilitas = JenisFasilitasKredit::all();
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
return view('lpj::penilaian.form', compact('permohonan', 'jenisPenilaian', 'teamPenilai', 'jenisJaminan', 'nilaiPlafond', 'jenisFasilitas'));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update the specified resource in storage.
|
* Update the specified resource in storage.
|
||||||
*/
|
*/
|
||||||
public function update(Request $request, $id): RedirectResponse
|
public function update(PenilaianRequest $request, $id)
|
||||||
{
|
{
|
||||||
//
|
$validate = $request->validated();
|
||||||
|
|
||||||
|
if ($validate) {
|
||||||
|
try {
|
||||||
|
$penilaian = Penilaian::where('permohonan_id', $id)->firstOrFail();
|
||||||
|
|
||||||
|
$penilaian->update($validate);
|
||||||
|
$permohonan = Permohonan::findOrFail($id);
|
||||||
|
$permohonan->update([
|
||||||
|
'status' => 'assign',
|
||||||
|
]);
|
||||||
|
|
||||||
|
return redirect()->route('penilaian.index', $id)->with('success', 'Penilaian berhasil diubah');
|
||||||
|
} catch (Exception $e) {
|
||||||
|
return redirect()->route('penilaian.index', $id)->with('error', $e->getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Remove the specified resource from storage.
|
* Remove the specified resource from storage.
|
||||||
*/
|
*/
|
||||||
@ -95,68 +127,85 @@ class PenilaianController extends Controller
|
|||||||
}
|
}
|
||||||
|
|
||||||
public function dataForDatatables(Request $request)
|
public function dataForDatatables(Request $request)
|
||||||
{
|
{
|
||||||
if (is_null($this->user) || !$this->user->can('debitur.view')) {
|
if (is_null($this->user) || !$this->user->can('debitur.view')) {
|
||||||
//abort(403, 'Sorry! You are not allowed to view users.');
|
// abort(403, 'Sorry! You are not allowed to view users.');
|
||||||
}
|
|
||||||
|
|
||||||
// Retrieve data from the database
|
|
||||||
$query = Permohonan::query();
|
|
||||||
|
|
||||||
// Apply search filter if provided
|
|
||||||
if ($request->has('search') && !empty($request->get('search'))) {
|
|
||||||
$search = $request->get('search');
|
|
||||||
$query->where(function ($q) use ($search) {
|
|
||||||
$q->where('nomor_registrasi', 'LIKE', '%' . $search . '%');
|
|
||||||
$q->orWhere('tanggal_permohonan', 'LIKE', '%' . $search . '%');
|
|
||||||
$q->orWhereRelation('user', 'name', 'LIKE', '%' . $search . '%');
|
|
||||||
$q->orWhereRelation('debiture', 'name', 'LIKE', '%' . $search . '%');
|
|
||||||
$q->orWhereRelation('tujuanPenilaian', 'name', 'LIKE', '%' . $search . '%');
|
|
||||||
$q->orWhereRelation('branch', 'name', 'LIKE', '%' . $search . '%');
|
|
||||||
$q->orWhere('status', 'LIKE', '%' . $search . '%');
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// Apply sorting if provided
|
|
||||||
if ($request->has('sortOrder') && !empty($request->get('sortOrder'))) {
|
|
||||||
$order = $request->get('sortOrder');
|
|
||||||
$column = $request->get('sortField');
|
|
||||||
$query->orderBy($column, $order);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get the total count of records
|
|
||||||
$totalRecords = $query->count();
|
|
||||||
|
|
||||||
// Apply pagination if provided
|
|
||||||
if ($request->has('page') && $request->has('size')) {
|
|
||||||
$page = $request->get('page');
|
|
||||||
$size = $request->get('size');
|
|
||||||
$offset = ($page - 1) * $size; // Calculate the offset
|
|
||||||
|
|
||||||
$query->skip($offset)->take($size);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get the filtered count of records
|
|
||||||
$filteredRecords = $query->count();
|
|
||||||
|
|
||||||
// Get the data for the current page
|
|
||||||
$data = $query->with(['user', 'debiture', 'branch', 'tujuanPenilaian'])->get();
|
|
||||||
|
|
||||||
// Calculate the page count
|
|
||||||
$pageCount = ceil($totalRecords / $request->get('size'));
|
|
||||||
|
|
||||||
// Calculate the current page number
|
|
||||||
$currentPage = 0 + 1;
|
|
||||||
|
|
||||||
// Return the response data as a JSON object
|
|
||||||
return response()->json([
|
|
||||||
'draw' => $request->get('draw'),
|
|
||||||
'recordsTotal' => $totalRecords,
|
|
||||||
'recordsFiltered' => $filteredRecords,
|
|
||||||
'pageCount' => $pageCount,
|
|
||||||
'page' => $currentPage,
|
|
||||||
'totalCount' => $totalRecords,
|
|
||||||
'data' => $data,
|
|
||||||
]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
$query = Permohonan::query();
|
||||||
|
|
||||||
|
if ($request->has('search') && !empty($request->get('search'))) {
|
||||||
|
$search = $request->get('search');
|
||||||
|
$query->where(function ($q) use ($search) {
|
||||||
|
$q->where('nomor_registrasi', 'LIKE', '%' . $search . '%');
|
||||||
|
$q->orWhere('tanggal_permohonan', 'LIKE', '%' . $search . '%');
|
||||||
|
$q->orWhereRelation('user', 'name', 'LIKE', '%' . $search . '%');
|
||||||
|
$q->orWhereRelation('debiture', 'name', 'LIKE', '%' . $search . '%');
|
||||||
|
$q->orWhereRelation('tujuanPenilaian', 'name', 'LIKE', '%' . $search . '%');
|
||||||
|
$q->orWhereRelation('branch', 'name', 'LIKE', '%' . $search . '%');
|
||||||
|
$q->orWhere('status', 'LIKE', '%' . $search . '%');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// Filter to show only records with status 'register'
|
||||||
|
$query->where('status', 'register');
|
||||||
|
|
||||||
|
|
||||||
|
if ($request->has('sortOrder') && !empty($request->get('sortOrder'))) {
|
||||||
|
$order = $request->get('sortOrder');
|
||||||
|
$column = $request->get('sortField');
|
||||||
|
$query->orderBy($column, $order);
|
||||||
|
}
|
||||||
|
|
||||||
|
$totalRecords = $query->count();
|
||||||
|
|
||||||
|
// Apply pagination if provided
|
||||||
|
if ($request->has('page') && $request->has('size')) {
|
||||||
|
$page = $request->get('page');
|
||||||
|
$size = $request->get('size');
|
||||||
|
$offset = ($page - 1) * $size; // Calculate the offset
|
||||||
|
|
||||||
|
$query->skip($offset)->take($size);
|
||||||
|
}
|
||||||
|
|
||||||
|
$filteredRecords = $query->count();
|
||||||
|
|
||||||
|
$data = $query->with(['user', 'debiture', 'branch', 'tujuanPenilaian'])->get();
|
||||||
|
|
||||||
|
$pageCount = ceil($totalRecords / $request->get('size'));
|
||||||
|
|
||||||
|
$currentPage = $page;
|
||||||
|
|
||||||
|
|
||||||
|
return response()->json([
|
||||||
|
'draw' => $request->get('draw'),
|
||||||
|
'recordsTotal' => $totalRecords,
|
||||||
|
'recordsFiltered' => $filteredRecords,
|
||||||
|
'pageCount' => $pageCount,
|
||||||
|
'page' => $currentPage,
|
||||||
|
'totalCount' => $totalRecords,
|
||||||
|
'data' => $data,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public function getUserTeams($id)
|
||||||
|
{
|
||||||
|
|
||||||
|
$teamsUser = TeamsUsers::where('teams_id', $id)->get();
|
||||||
|
$userIds = $teamsUser->pluck('user_id');
|
||||||
|
$users = User::whereIn('id', $userIds)->get();
|
||||||
|
|
||||||
|
if ($users->isNotEmpty()) {
|
||||||
|
return response()->json($users, 200);
|
||||||
|
}
|
||||||
|
|
||||||
|
return response()->json([], 200);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -12,7 +12,13 @@ class PenilaianRequest extends FormRequest
|
|||||||
public function rules(): array
|
public function rules(): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
//
|
'jenis_penilaian_id' => 'required|max:255',
|
||||||
|
'teams_id' => 'required|max:255',
|
||||||
|
'user_id' => 'required|max:255',
|
||||||
|
'tanggal_kunjungan' => 'required|max:255',
|
||||||
|
'status' => 'required|max:10',
|
||||||
|
'keterangan' => 'nullable',
|
||||||
|
'permohonan_id' => 'required',
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -23,4 +29,12 @@ class PenilaianRequest extends FormRequest
|
|||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function prepareForValidation()
|
||||||
|
{
|
||||||
|
// Menetapkan nilai default untuk 'status' jika tidak ada dalam request
|
||||||
|
$this->merge([
|
||||||
|
'status' => $this->status ?? 'assign',
|
||||||
|
]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -17,7 +17,7 @@ class Penilaian extends Model
|
|||||||
*/
|
*/
|
||||||
protected $table = 'penilaian';
|
protected $table = 'penilaian';
|
||||||
protected $fillable = [
|
protected $fillable = [
|
||||||
'jenis_penilaian_id', 'team_id', 'user_id', 'tanggal_kunjungan', 'keterangan',
|
'jenis_penilaian_id', 'teams_id', 'user_id', 'tanggal_kunjungan', 'keterangan','permohonan_id',
|
||||||
'status', 'authorized_status', 'authorized_at', 'authorized_by', 'created_at',
|
'status', 'authorized_status', 'authorized_at', 'authorized_by', 'created_at',
|
||||||
'created_by', 'updated_at', 'updated_by', 'deleted_at', 'deleted_by'
|
'created_by', 'updated_at', 'updated_by', 'deleted_at', 'deleted_by'
|
||||||
];
|
];
|
||||||
@ -27,7 +27,7 @@ class Penilaian extends Model
|
|||||||
}
|
}
|
||||||
|
|
||||||
public function teams(){
|
public function teams(){
|
||||||
return $this->belongsTo(Teams::class, 'team_id', 'id');
|
return $this->belongsTo(Teams::class, 'teams_id', 'id');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function users(){
|
public function users(){
|
||||||
|
@ -6,8 +6,7 @@ use Illuminate\Support\Facades\Schema;
|
|||||||
use Modules\Lpj\Models\JenisPenilaian;
|
use Modules\Lpj\Models\JenisPenilaian;
|
||||||
use Modules\Lpj\Models\Teams;
|
use Modules\Lpj\Models\Teams;
|
||||||
|
|
||||||
return new class extends Migration
|
return new class () extends Migration {
|
||||||
{
|
|
||||||
/**
|
/**
|
||||||
* Run the migrations.
|
* Run the migrations.
|
||||||
*/
|
*/
|
||||||
@ -19,8 +18,9 @@ return new class extends Migration
|
|||||||
$table->foreignIdFor(Teams::class);
|
$table->foreignIdFor(Teams::class);
|
||||||
$table->unsignedBigInteger('user_id');
|
$table->unsignedBigInteger('user_id');
|
||||||
$table->datetime('tanggal_kunjungan');
|
$table->datetime('tanggal_kunjungan');
|
||||||
$table->text('keterangan');
|
$table->text('keterangan')->nullable();
|
||||||
$table->char('status');
|
$table->char('status');
|
||||||
|
$table->integer('permohonan_id');
|
||||||
$table->timestamps();
|
$table->timestamps();
|
||||||
$table->char('authorized_status', 1)->nullable();
|
$table->char('authorized_status', 1)->nullable();
|
||||||
$table->timestamp('authorized_at')->nullable();
|
$table->timestamp('authorized_at')->nullable();
|
||||||
|
21
module.json
21
module.json
@ -20,7 +20,7 @@
|
|||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": [
|
"roles": [
|
||||||
"Administrator"
|
"Administrator"
|
||||||
|
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -56,6 +56,17 @@
|
|||||||
"Administrator"
|
"Administrator"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"title": "Penilaian Jaminan",
|
||||||
|
"path": "penilaian",
|
||||||
|
"icon": "ki-filled ki-some-files text-lg",
|
||||||
|
"classes": "",
|
||||||
|
"attributes": [],
|
||||||
|
"permission": "",
|
||||||
|
"roles": [
|
||||||
|
"Administrator"
|
||||||
|
]
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"title": "Laporan",
|
"title": "Laporan",
|
||||||
"path": "",
|
"path": "",
|
||||||
@ -207,14 +218,6 @@
|
|||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": []
|
"roles": []
|
||||||
},
|
|
||||||
{
|
|
||||||
"title": "Penilaian Jaminan",
|
|
||||||
"path": "basicdata.penilaian",
|
|
||||||
"classes": "",
|
|
||||||
"attributes": [],
|
|
||||||
"permission": "",
|
|
||||||
"roles": []
|
|
||||||
}
|
}
|
||||||
|
|
||||||
]
|
]
|
||||||
|
@ -12,12 +12,6 @@
|
|||||||
background-color: #ddd;
|
background-color: #ddd;
|
||||||
margin: 20px 0;
|
margin: 20px 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.h1 {
|
|
||||||
font-size: 16px;
|
|
||||||
font-weight: 600;
|
|
||||||
margin-bottom: 10px;
|
|
||||||
}
|
|
||||||
</style>
|
</style>
|
||||||
@endpush
|
@endpush
|
||||||
|
|
||||||
@ -28,484 +22,194 @@
|
|||||||
<div class="card pb-2.5">
|
<div class="card pb-2.5">
|
||||||
<div class="card-header" id="basic_settings">
|
<div class="card-header" id="basic_settings">
|
||||||
<h3 class="card-title">
|
<h3 class="card-title">
|
||||||
Form Data Jaminan
|
Form Penilai Jaminan
|
||||||
</h3>
|
</h3>
|
||||||
<div class="flex items-center gap-2">
|
<div class="flex items-center gap-2">
|
||||||
<a href="{{ route('basicdata.penilaian.index') }}" class="btn btn-xs btn-info"><i
|
<a href="{{ route('penilaian.index') }}" class="btn btn-xs btn-info"><i class="ki-filled ki-exit-left"></i>
|
||||||
class="ki-filled ki-exit-left"></i>
|
|
||||||
Back</a>
|
Back</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
|
<form
|
||||||
|
action="{{ isset($penilaian->permohonan_id) ? route('penilaian.update', $permohonan) : route('penilaian.store') }}"
|
||||||
|
method="POST" class="">
|
||||||
|
|
||||||
<form action="" method="POST" class="">
|
@if (isset($penilaian->permohonan_id))
|
||||||
<div class="grid grid-cols-1 lg:grid-cols-2 xl:grid-cols-3 gap-5 lg:gap-7.5">
|
@method('PUT')
|
||||||
<div class="grid gap-2.5">
|
<input type="hidden" name="permohonan_id" value="{{ $permohonan->id }}">
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
@else
|
||||||
<label class="form-label max-w-24">
|
<input type="number" name="permohonan_id" value="{{ $permohonan->id }}">
|
||||||
Nomor Registrasi
|
@endif
|
||||||
</label>
|
@csrf
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<div class="pl-1 lg:pl-5 xl:pl-5 grid gap-2.5 p-5">
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
<input class="input @error('nomor_registrasi') border-danger bg-danger-light @enderror"
|
<label class="form-label max-w-56">
|
||||||
type="text" name="nomor_registrasi" value="{{ $permohonan->nomor_registrasi }}">
|
Penilai yang Dilakukan oleh
|
||||||
</div>
|
</label>
|
||||||
</div>
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<select
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
class="input tomselect w-full @error('jenis_penilaian_id') border-danger bg-danger-light @enderror"
|
||||||
<label class="form-label max-w-12">
|
name="jenis_penilaian_id" id="jenis_penilaian_id">
|
||||||
Nama Pemohon
|
<option value="">Jenis Penilaian</option>
|
||||||
</label>
|
@foreach ($jenisPenilaian as $item)
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
@if (isset($penilaian->permohonan_id))
|
||||||
<input class="input @error('cif') border-danger bg-danger-light @enderror"
|
<option value="{{ $item->id }}"
|
||||||
type="text" name="cif" value="{{ $permohonan->user->name }}">
|
{{ $penilaian->teams_id == $item->id ? 'selected' : '' }}>
|
||||||
</div>
|
{{ $item->name }}</option>
|
||||||
</div>
|
@else
|
||||||
|
<option value="{{ $item->id }}">{{ $item->name }}</option>
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
@endif
|
||||||
<label class="form-label max-w-12">
|
@endforeach
|
||||||
Tanggal Pemohon
|
</select>
|
||||||
</label>
|
@error('jenis_penilaian_id')
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
<input class="input @error('cif') border-danger bg-danger-light @enderror"
|
@enderror
|
||||||
type="date" name="cif" value="{{ $permohonan->tanggal_permohonan }}">
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="grid gap-2.5">
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<label class="form-label max-w-56">
|
||||||
<label class="form-label ">
|
Tim Penilai yang di tunjuk
|
||||||
Status
|
</label>
|
||||||
</label>
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<select
|
||||||
<input class="input @error('cif') border-danger bg-danger-light @enderror"
|
class="input tomselect w-full @error('teams_id') border-danger bg-danger-light @enderror"
|
||||||
type="text" name="cif" value="{{ $permohonan->status }}">
|
name="teams_id" id="teams_id">
|
||||||
</div>
|
<option value="">Pilih Tim Penilai</option>
|
||||||
|
@foreach ($teamPenilai as $item)
|
||||||
|
@if (isset($penilaian->permohonan_id))
|
||||||
|
<option value="{{ $item->id }}"
|
||||||
|
{{ $penilaian->teams_id == $item->id ? 'selected' : '' }}>
|
||||||
|
{{ $item->regions->name }}</option>
|
||||||
|
@else
|
||||||
|
<option value="{{ $item->id }}">{{ $item->regions->name }}</option>
|
||||||
|
@endif
|
||||||
|
@endforeach
|
||||||
|
</select>
|
||||||
|
@error('teams_id')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
<label class="form-label">
|
<label class="form-label max-w-56">
|
||||||
Cabang Pemohon
|
Penilai yang di tunjuk
|
||||||
</label>
|
</label>
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
<input class="input @error('cif') border-danger bg-danger-light @enderror"
|
<select id="user_id" name="user_id"
|
||||||
type="text" name="cif" value="{{ $permohonan->branch->name }}">
|
class="input @error('user_id') border-danger bg-danger-light @enderror w-full">
|
||||||
</div>
|
<option value="">Pilih Penilai</option>
|
||||||
</div>
|
</select>
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-24">
|
|
||||||
Cabang Penilai
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input class="input @error('cif') border-danger bg-danger-light @enderror"
|
|
||||||
type="number" name="cif" value="">
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<div class="grid gap-2.5">
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<label class="form-label max-w-56">
|
||||||
<label class="form-label max-w-24">
|
Jadwal Kunjungan
|
||||||
Nomor Registrasi cabang
|
</label>
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input class="input @error('cif') border-danger bg-danger-light @enderror"
|
|
||||||
type="number" name="cif" value="">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
<label class="form-label max-w-24">
|
<input class="input @error('tanggal_kunjungan') border-danger bg-danger-light @enderror"
|
||||||
Nama Bagian
|
type="datetime-local" name="tanggal_kunjungan"
|
||||||
</label>
|
value="{{ isset($penilaian->tanggal_kunjungan) ? \Carbon\Carbon::createFromTimestamp($penilaian->tanggal_kunjungan)->format('Y-m-d\TH:i') : '' }}">
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
@error('tanggal_kunjungan')
|
||||||
<input class="input @error('cif') border-danger bg-danger-light @enderror"
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
type="number" name="cif" value="">
|
@enderror
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">
|
||||||
|
Catatan
|
||||||
|
</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<textarea class="textarea @error('keterangan') border-danger bg-danger-light @enderror" rows="3" type="text"
|
||||||
|
name="keterangan">{{ $penilaian->keterangan ?? '' }}</textarea>
|
||||||
|
</div>
|
||||||
|
@error('keterangan')
|
||||||
|
<em class="alert text-danger text-sm">{{ $message }}</em>
|
||||||
|
@enderror
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="flex justify-end card-footer">
|
||||||
</br>
|
<button type="submit"
|
||||||
<div class="divider"></div>
|
@if ($permohonan->status == 'Assign') class="btn btn-success"
|
||||||
<div class="grid gap-5">
|
@else
|
||||||
<div>
|
class="btn btn-warning" @endif>
|
||||||
<h1 class="h1">1. IDENTITAS DEBITUR</h1>
|
|
||||||
<div class="pl-1 lg:pl-5 xl:pl-5 grid gap-2.5">
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Nama Debitur
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input class="input @error('cif') border-danger bg-danger-light @enderror"
|
|
||||||
type="text" name="cif" value="{{ $permohonan->debiture->name }}">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Alamat
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<p>
|
|
||||||
{{ $permohonan->debiture->address . ' ' . $permohonan->debiture->village->name . ', ' . $permohonan->debiture->district->name . ', ' . $permohonan->debiture->city->name . ', ' . $permohonan->debiture->province->name . ' ' . '(' . $permohonan->debiture->postal_code . ')' }}
|
|
||||||
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Nomor Cif
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input class="input @error('cif') border-danger bg-danger-light @enderror"
|
|
||||||
type="number" name="cif" value="{{ $permohonan->debiture->cif }}">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div>
|
|
||||||
<h1 class="h1">2. LETAK JAMINAN</h1>
|
|
||||||
<div class="pl-1 lg:pl-5 xl:pl-5 grid gap-2.5">
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Alamat jaminan
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<textarea class="textarea @error('cif') border-danger bg-danger-light @enderror" rows="3" type="number"
|
|
||||||
name="cif" value=""></textarea>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Kode Dati II
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<section class="input w-full">
|
|
||||||
<option value="">1</option>
|
|
||||||
</section>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Debitur/Wakil Debitur
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input class="input @error('cif') border-danger bg-danger-light @enderror"
|
|
||||||
type="number" name="cif" value="">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Telepon
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input class="input @error('cif') border-danger bg-danger-light @enderror"
|
|
||||||
type="number" name="cif" value="">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div>
|
|
||||||
<h1 class="h1">3. FASILITAS KREDIT</h1>
|
|
||||||
<div class="pl-1 lg:pl-5 xl:pl-5 grid gap-2.5">
|
|
||||||
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Jenis Fasilitas
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<select
|
|
||||||
class="input tomselect w-full @error('branch_id') border-danger bg-danger-light @enderror"
|
|
||||||
name="tujuan_penilaian_id" id="tujuan_penilaian_id">
|
|
||||||
@foreach ($jenisFasilitas as $item)
|
|
||||||
<option value="">{{ $item->name }}</option>
|
|
||||||
@endforeach
|
|
||||||
|
|
||||||
</select>
|
|
||||||
@error('tujuan_penilaian_id')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Nilai Plafond
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<select
|
|
||||||
class="input tomselect w-full @error('branch_id') border-danger bg-danger-light @enderror"
|
|
||||||
name="tujuan_penilaian_id" id="tujuan_penilaian_id">
|
|
||||||
@foreach ($nilaiPlafond as $item)
|
|
||||||
<option value="">{{ $item->name }}</option>
|
|
||||||
@endforeach
|
|
||||||
|
|
||||||
</select>
|
|
||||||
@error('tujuan_penilaian_id')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
<div>
|
|
||||||
<h1 class="h1">4. TUJUAN PENILAIAN</h1>
|
|
||||||
<div class="pl-1 lg:pl-5 xl:pl-5 grid gap-2.5">
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Jenis jaminan
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<select
|
|
||||||
class="input tomselect w-full @error('branch_id') border-danger bg-danger-light @enderror"
|
|
||||||
name="tujuan_penilaian_id" id="tujuan_penilaian_id">
|
|
||||||
<option value="">{{ $permohonan->tujuanPenilaian->name }}</option>
|
|
||||||
|
|
||||||
</select>
|
|
||||||
@error('tujuan_penilaian_id')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div>
|
|
||||||
<h1 class="h1">5. JENIS JAMINAN</h1>
|
|
||||||
<div class="pl-1 lg:pl-5 xl:pl-5 grid gap-2.5">
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Jenis jaminan
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<select
|
|
||||||
class="input tomselect w-full @error('branch_id') border-danger bg-danger-light @enderror"
|
|
||||||
name="tujuan_penilaian_id" id="tujuan_penilaian_id">
|
|
||||||
@foreach ($jenisJaminan as $item)
|
|
||||||
<option value="{{ $item->id }}">{{ $item->name }}</option>
|
|
||||||
@endforeach
|
|
||||||
</select>
|
|
||||||
@error('tujuan_penilaian_id')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div>
|
|
||||||
<h1 class="h1">6. TIPE JAMINAN</h1>
|
|
||||||
<div class="pl-1 lg:pl-5 xl:pl-5 grid gap-2.5">
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
tipe jaminan
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<select
|
|
||||||
class="input tomselect w-full @error('branch_id') border-danger bg-danger-light @enderror"
|
|
||||||
name="tujuan_penilaian_id" id="tujuan_penilaian_id">
|
|
||||||
@foreach ($jenisJaminan as $item)
|
|
||||||
<option value="{{ $item->id }}">{{ $item->name }}</option>
|
|
||||||
@endforeach
|
|
||||||
</select>
|
|
||||||
@error('tujuan_penilaian_id')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div>
|
|
||||||
<h1 class="h1">7. DATA-DATA</h1>
|
|
||||||
<div class="pl-1 lg:pl-5 xl:pl-5 grid gap-2.5 border">
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5"">
|
|
||||||
<label class="form-label max-w-56 ">
|
|
||||||
Update By
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-col lg:flex-row gap-2 w-full">
|
|
||||||
<div class="flex flex-col lg:flex-row gap-2 w-full">
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input
|
|
||||||
class="input @error('user') border-danger bg-danger-light @enderror"
|
|
||||||
type="text" name="user" value="">
|
|
||||||
@error('province_code')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input
|
|
||||||
class="input @error('update_at') border-danger bg-danger-light @enderror"
|
|
||||||
type="text" name="update_at" value="">
|
|
||||||
@error('city_code')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div>
|
|
||||||
<h1 class="h1">6. TIPE JAMINAN</h1>
|
|
||||||
<div class="pl-1 lg:pl-5 xl:pl-5 grid gap-2.5 p-5">
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Penilai yang Dilakukan oleh
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<select
|
|
||||||
class="input tomselect w-full @error('branch_id') border-danger bg-danger-light @enderror"
|
|
||||||
name="tujuan_penilaian_id" id="tujuan_penilaian_id">
|
|
||||||
@foreach ($jenisPenilaian as $item)
|
|
||||||
<option value="{{ $item->id }}">{{ $item->name }}</option>
|
|
||||||
@endforeach
|
|
||||||
</select>
|
|
||||||
@error('tujuan_penilaian_id')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Tim Penilai yang di tunjuk
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<select
|
|
||||||
class="input tomselect w-full @error('branch_id') border-danger bg-danger-light @enderror"
|
|
||||||
name="tujuan_penilaian_id" id="tujuan_penilaian_id">
|
|
||||||
@foreach ($teamPenilai as $item)
|
|
||||||
<option value="{{ $item->id }}">{{ $item->regions->name }}</option>
|
|
||||||
@endforeach
|
|
||||||
</select>
|
|
||||||
@error('tujuan_penilaian_id')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Penilai yang di tunjuk
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input
|
|
||||||
class="input @error('tanggal_kunjungan') border-danger bg-danger-light @enderror"
|
|
||||||
type="text" name="penilai_tunjuk" value="">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Jadwal Kunjungan
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input
|
|
||||||
class="input @error('tanggal_kunjungan') border-danger bg-danger-light @enderror"
|
|
||||||
type="date" name="tanggal_kunjungan" value="">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Tanggal
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input
|
|
||||||
class="input @error('tanggal_kunjungan') border-danger bg-danger-light @enderror"
|
|
||||||
type="date" name="tanggal_kunjungan" value="">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Catatan
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<textarea class="textarea @error('keterangan') border-danger bg-danger-light @enderror" rows="3"
|
|
||||||
type="text" name="keterangan" value=""></textarea>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5"">
|
|
||||||
<label class="form-label max-w-56 ">
|
|
||||||
Update By
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-col lg:flex-row gap-2 w-full">
|
|
||||||
<div class="flex flex-col lg:flex-row gap-2 w-full">
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input
|
|
||||||
class="input @error('user') border-danger bg-danger-light @enderror"
|
|
||||||
type="text" name="user" value="">
|
|
||||||
@error('province_code')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input
|
|
||||||
class="input @error('update_at') border-danger bg-danger-light @enderror"
|
|
||||||
type="text" name="update_at" value="">
|
|
||||||
@error('city_code')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="divider"></div>
|
|
||||||
<div class="flex justify-end gap-2">
|
|
||||||
<button type="submit" class="btn btn-primary">
|
|
||||||
Save
|
|
||||||
</button>
|
|
||||||
|
|
||||||
<button type="submit" class="btn btn-info">
|
|
||||||
Assign
|
Assign
|
||||||
</button>
|
</button>
|
||||||
|
|
||||||
<button type="submit" class="btn btn-light">
|
|
||||||
Print From
|
|
||||||
</button>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
|
|
||||||
|
@push('scripts')
|
||||||
|
<script>
|
||||||
|
document.addEventListener('DOMContentLoaded', function() {
|
||||||
|
let teamsSelect = document.getElementById('teams_id');
|
||||||
|
let penilaiSelect = document.getElementById('user_id');
|
||||||
|
|
||||||
|
// Mengambil nilai user_id dari variabel PHP
|
||||||
|
let selectedUserId = @json($penilaian->user_id ?? null); // Gunakan null jika tidak ada
|
||||||
|
|
||||||
|
function fetchPenilai(teamId) {
|
||||||
|
penilaiSelect.innerHTML = '';
|
||||||
|
|
||||||
|
if (teamId) {
|
||||||
|
fetch(`/penilaian/getUserTeams/${teamId}`)
|
||||||
|
.then(response => response.json())
|
||||||
|
.then(data => {
|
||||||
|
if (data && data.length > 0) {
|
||||||
|
data.forEach((user) => {
|
||||||
|
let option = document.createElement('option');
|
||||||
|
option.value = user.id;
|
||||||
|
option.text = user.name;
|
||||||
|
|
||||||
|
if (selectedUserId && selectedUserId == user.id) {
|
||||||
|
option.selected = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
penilaiSelect.appendChild(option);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
let option = document.createElement('option');
|
||||||
|
option.value = '';
|
||||||
|
option.text = 'Tidak ada penilai.';
|
||||||
|
penilaiSelect.appendChild(option);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.catch(error => {
|
||||||
|
console.error('Error fetching team members:', error);
|
||||||
|
let option = document.createElement('option');
|
||||||
|
option.value = '';
|
||||||
|
option.text = 'Terjadi kesalahan.';
|
||||||
|
penilaiSelect.appendChild(option);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
let option = document.createElement('option');
|
||||||
|
option.value = '';
|
||||||
|
option.text = 'Pilih tim terlebih dahulu.';
|
||||||
|
penilaiSelect.appendChild(option);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
teamsSelect.addEventListener('change', function() {
|
||||||
|
let teamId = this.value;
|
||||||
|
fetchPenilai(teamId);
|
||||||
|
});
|
||||||
|
|
||||||
|
let selectedTeamId = teamsSelect.value;
|
||||||
|
if (selectedTeamId) {
|
||||||
|
fetchPenilai(selectedTeamId);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
@endpush
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
@extends('layouts.main')
|
@extends('layouts.main')
|
||||||
|
|
||||||
@section('breadcrumbs')
|
@section('breadcrumbs')
|
||||||
{{ Breadcrumbs::render('basicdata.penilaian') }}
|
{{ Breadcrumbs::render('penilaian') }}
|
||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@section('content')
|
@section('content')
|
||||||
@ -9,15 +9,8 @@
|
|||||||
<div class="card pb-2.5">
|
<div class="card pb-2.5">
|
||||||
<div class="card-header" id="basic_settings">
|
<div class="card-header" id="basic_settings">
|
||||||
<div class="card-title flex flex-row gap-1.5">
|
<div class="card-title flex flex-row gap-1.5">
|
||||||
@if (isset($status_permohonan))
|
Daftar Penilaian
|
||||||
@foreach ($status_permohonan as $item)
|
|
||||||
<a href="" class="btn btn-xs btn-outline btn-primary"> {{ $item->name }} </a>
|
|
||||||
@endforeach
|
|
||||||
@endif
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class=" card-grid min-w-full" data-datatable="false" data-datatable-page-size="5" data-datatable-state-save="false" id="permohonan-table" data-api-url="{{ route('permohonan.datatables') }}">
|
|
||||||
<div class="card-header py-5 flex-wrap">
|
<div class="card-header py-5 flex-wrap">
|
||||||
<h3 class="card-title">
|
<h3 class="card-title">
|
||||||
{{-- Daftar {{}} --}}
|
{{-- Daftar {{}} --}}
|
||||||
@ -25,16 +18,19 @@
|
|||||||
<div class="flex flex-wrap gap-2 lg:gap-5">
|
<div class="flex flex-wrap gap-2 lg:gap-5">
|
||||||
<div class="flex">
|
<div class="flex">
|
||||||
<label class="input input-sm"> <i class="ki-filled ki-magnifier"> </i>
|
<label class="input input-sm"> <i class="ki-filled ki-magnifier"> </i>
|
||||||
<input placeholder="Search Permohonan" id="search" type="text" value="">
|
<input placeholder="Search Penilaian" id="search" type="text" value="">
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex flex-wrap gap-2.5">
|
<div class="flex flex-wrap gap-2.5">
|
||||||
<div class="h-[24px] border border-r-gray-200"></div>
|
<div class="h-[24px] border border-r-gray-200"></div>
|
||||||
<a class="btn btn-sm btn-light" href="{{ route('permohonan.export') }}"> Export to Excel </a>
|
<a class="btn btn-sm btn-light" href="{{ route('permohonan.export') }}"> Export to Excel </a>
|
||||||
<a class="btn btn-sm btn-primary" href="{{ route('permohonan.create') }}"> Tambah Permohonan </a>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class=" card-grid min-w-full" data-datatable="false" data-datatable-page-size="5" data-datatable-state-save="false" id="permohonan-table" data-api-url="{{ route('permohonan.datatables') }}">
|
||||||
|
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<div class="scrollable-x-auto">
|
<div class="scrollable-x-auto">
|
||||||
<table class="table table-auto table-border align-middle text-gray-700 font-medium text-sm" data-datatable-table="true">
|
<table class="table table-auto table-border align-middle text-gray-700 font-medium text-sm" data-datatable-table="true">
|
||||||
@ -93,99 +89,10 @@
|
|||||||
</div>
|
</div>
|
||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
{{-- @section('content')
|
|
||||||
<div class="grid">
|
|
||||||
<div class="card card-grid min-w-full" data-datatable="false" data-datatable-page-size="5" data-datatable-state-save="false" id="penilaian-table" data-api-url="{{ route('basicdata.penilaian.datatables') }}">
|
|
||||||
<div class="card-header py-5 flex-wrap">
|
|
||||||
<h3 class="card-title">
|
|
||||||
Daftar penilaian
|
|
||||||
</h3>
|
|
||||||
<div class="flex flex-wrap gap-2 lg:gap-5">
|
|
||||||
<div class="flex">
|
|
||||||
<label class="input input-sm"> <i class="ki-filled ki-magnifier"> </i>
|
|
||||||
<input placeholder="Search penilaian" id="search" type="text" value="">
|
|
||||||
</label>
|
|
||||||
</div>
|
|
||||||
<div class="flex flex-wrap gap-2.5">
|
|
||||||
<div class="h-[24px] border border-r-gray-200"></div>
|
|
||||||
<a class="btn btn-sm btn-light" href="{{ route('basicdata.penilaian.export') }}"> Export to Excel </a>
|
|
||||||
<a class="btn btn-sm btn-primary" href="{{ route('basicdata.penilaian.create') }}"> Tambah penilaian </a>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="card-body">
|
|
||||||
<div class="scrollable-x-auto">
|
|
||||||
<table class="table table-auto table-border align-middle text-gray-700 font-medium text-sm" data-datatable-table="true">
|
|
||||||
<thead>
|
|
||||||
<tr>
|
|
||||||
<th class="w-14">
|
|
||||||
<input class="checkbox checkbox-sm" data-datatable-check="true" type="checkbox"/>
|
|
||||||
</th>
|
|
||||||
<th class="min-w-[250px]" data-datatable-column="code">
|
|
||||||
<span class="sort"> <span class="sort-label"> Code </span>
|
|
||||||
<span class="sort-icon"> </span> </span>
|
|
||||||
</th>
|
|
||||||
<th class="min-w-[250px]" data-datatable-column="name">
|
|
||||||
<span class="sort"> <span class="sort-label"> penilaian </span>
|
|
||||||
<span class="sort-icon"> </span> </span>
|
|
||||||
</th>
|
|
||||||
<th class="min-w-[50px] text-center" data-datatable-column="actions">Action</th>
|
|
||||||
</tr>
|
|
||||||
</thead>
|
|
||||||
</table>
|
|
||||||
</div>
|
|
||||||
<div class="card-footer justify-center md:justify-between flex-col md:flex-row gap-3 text-gray-600 text-2sm font-medium">
|
|
||||||
<div class="flex items-center gap-2">
|
|
||||||
Show
|
|
||||||
<select class="select select-sm w-16" data-datatable-size="true" name="perpage"> </select> per page
|
|
||||||
</div>
|
|
||||||
<div class="flex items-center gap-4">
|
|
||||||
<span data-datatable-info="true"> </span>
|
|
||||||
<div class="pagination" data-datatable-pagination="true">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
@endsection --}}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
||||||
<script type="text/javascript">
|
|
||||||
function deleteData(data) {
|
|
||||||
Swal.fire({
|
|
||||||
title: 'Are you sure?',
|
|
||||||
text: "You won't be able to revert this!",
|
|
||||||
icon: 'warning',
|
|
||||||
showCancelButton: true,
|
|
||||||
confirmButtonColor: '#3085d6',
|
|
||||||
cancelButtonColor: '#d33',
|
|
||||||
confirmButtonText: 'Yes, delete it!'
|
|
||||||
}).then((result) => {
|
|
||||||
if (result.isConfirmed) {
|
|
||||||
$.ajaxSetup({
|
|
||||||
headers: {
|
|
||||||
'X-CSRF-TOKEN': '{{ csrf_token() }}'
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$.ajax(`basic-data/penilaian/${data}`, {
|
|
||||||
type: 'DELETE'
|
|
||||||
}).then((response) => {
|
|
||||||
swal.fire('Deleted!', 'User has been deleted.', 'success').then(() => {
|
|
||||||
window.location.reload();
|
|
||||||
});
|
|
||||||
}).catch((error) => {
|
|
||||||
console.error('Error:', error);
|
|
||||||
Swal.fire('Error!', 'An error occurred while deleting the file.', 'error');
|
|
||||||
});
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
<script type="module">
|
<script type="module">
|
||||||
const element = document.querySelector('#permohonan-table');
|
const element = document.querySelector('#permohonan-table');
|
||||||
const searchInput = document.getElementById('search');
|
const searchInput = document.getElementById('search');
|
||||||
@ -242,8 +149,8 @@
|
|||||||
title: 'Status',
|
title: 'Status',
|
||||||
render: (item, data) => {
|
render: (item, data) => {
|
||||||
return `<div class="flex flex-nowrap justify-center">
|
return `<div class="flex flex-nowrap justify-center">
|
||||||
<a class="btn btn-sm btn-icon btn-clear btn-info" href="basic-data/penilaian/${data.id}/edit">
|
<a class="btn btn-sm btn-icon btn-clear btn-warning " href="penilaian/${data.id}/edit">
|
||||||
<i class="ki-outline ki-notepad-edit"></i>
|
<i class="ki-outline ki-eye"></i>
|
||||||
</a>
|
</a>
|
||||||
</div>`;
|
</div>`;
|
||||||
},
|
},
|
||||||
|
@ -312,11 +312,11 @@
|
|||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
Breadcrumbs::for('basicdata.penilaian', function (BreadcrumbTrail $trail) {
|
Breadcrumbs::for('penilaian', function (BreadcrumbTrail $trail) {
|
||||||
$trail->parent('basicdata');
|
$trail->parent('basicdata');
|
||||||
$trail->push('Penilaian', route('basicdata.penilaian.index'));
|
$trail->push('Penilaian', route('penilaian.index'));
|
||||||
});
|
});
|
||||||
Breadcrumbs::for('basicdata.penilaian.edit', function (BreadcrumbTrail $trail) {
|
Breadcrumbs::for('penilaian.edit', function (BreadcrumbTrail $trail) {
|
||||||
$trail->parent('basicdata.penilaian');
|
$trail->parent('penilaian');
|
||||||
$trail->push('Buat Penilaian');
|
$trail->push('Buat Penilaian');
|
||||||
});
|
});
|
||||||
|
@ -224,25 +224,6 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
],
|
],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
Route::name('penilaian.')->prefix('penilaian')->group(function () {
|
|
||||||
Route::get('restore/{id}', [PenilaianController::class, 'restore'])->name('restore');
|
|
||||||
Route::get('datatables', [PenilaianController::class, 'dataForDatatables'])->name('datatables');
|
|
||||||
Route::get('export', [PenilaianController::class, 'export'])->name('export');
|
|
||||||
});
|
|
||||||
|
|
||||||
Route::resource('penilaian', PenilaianController::class, [
|
|
||||||
'names' => [
|
|
||||||
'index' => 'penilaian.index',
|
|
||||||
'show' => 'penilaian.show',
|
|
||||||
'create' => 'penilaian.create',
|
|
||||||
'store' => 'penilaian.store',
|
|
||||||
'edit' => 'penilaian.edit',
|
|
||||||
'update' => 'penilaian.update',
|
|
||||||
'destroy' => 'penilaian.destroy',
|
|
||||||
],
|
|
||||||
]);
|
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
/** END ROUTE BASIC DATA ***/
|
/** END ROUTE BASIC DATA ***/
|
||||||
|
|
||||||
@ -257,22 +238,22 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
|
|
||||||
Route::resource('permohonan', PermohonanController::class);
|
Route::resource('permohonan', PermohonanController::class);
|
||||||
|
|
||||||
Route::name('debitur.')->prefix('debitur')->group(function () {
|
Route::name('debitur.')->prefix('debitur')->group(function () {
|
||||||
Route::get('restore/{id}', [DebitureController::class, 'restore'])->name('restore');
|
Route::get('restore/{id}', [DebitureController::class, 'restore'])->name('restore');
|
||||||
Route::get('datatables', [DebitureController::class, 'dataForDatatables'])
|
Route::get('datatables', [DebitureController::class, 'dataForDatatables'])
|
||||||
->name('datatables');
|
->name('datatables');
|
||||||
Route::get('export', [DebitureController::class, 'export'])->name('export');
|
Route::get('export', [DebitureController::class, 'export'])->name('export');
|
||||||
|
|
||||||
|
|
||||||
Route::name('jaminan.')->prefix('{id}/jaminan')->group(function () {
|
Route::name('jaminan.')->prefix('{id}/jaminan')->group(function () {
|
||||||
Route::get('download/{dokumen}', [DokumenJaminanController::class, 'download'])->name('download');
|
Route::get('download/{dokumen}', [DokumenJaminanController::class, 'download'])->name('download');
|
||||||
Route::get('/', [DokumenJaminanController::class, 'index'])->name('index');
|
Route::get('/', [DokumenJaminanController::class, 'index'])->name('index');
|
||||||
Route::get('create', [DokumenJaminanController::class, 'create'])->name('create');
|
Route::get('create', [DokumenJaminanController::class, 'create'])->name('create');
|
||||||
Route::get('{jaminan}/edit', [DokumenJaminanController::class, 'edit'])->name('edit');
|
Route::get('{jaminan}/edit', [DokumenJaminanController::class, 'edit'])->name('edit');
|
||||||
Route::put('{jaminan}', [DokumenJaminanController::class, 'update'])->name('update');
|
Route::put('{jaminan}', [DokumenJaminanController::class, 'update'])->name('update');
|
||||||
Route::post('store', [DokumenJaminanController::class, 'store'])->name('store');
|
Route::post('store', [DokumenJaminanController::class, 'store'])->name('store');
|
||||||
Route::delete('{jaminan}', [DokumenJaminanController::class, 'destroy'])->name('destroy');
|
Route::delete('{jaminan}', [DokumenJaminanController::class, 'destroy'])->name('destroy');
|
||||||
});
|
});
|
||||||
|
|
||||||
Route::name('pemilik.')->prefix('{id}/pemilik')->group(function () {
|
Route::name('pemilik.')->prefix('{id}/pemilik')->group(function () {
|
||||||
Route::get('/', [PemilikJaminanController::class, 'index'])->name('index');
|
Route::get('/', [PemilikJaminanController::class, 'index'])->name('index');
|
||||||
@ -286,4 +267,22 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
|
|
||||||
Route::resource('debitur', DebitureController::class);
|
Route::resource('debitur', DebitureController::class);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Route::name('penilaian.')->prefix('penilaian')->group(function () {
|
||||||
|
Route::get('restore/{id}', [PenilaianController::class, 'restore'])->name('restore');
|
||||||
|
Route::get('datatables', [PenilaianController::class, 'dataForDatatables'])->name('datatables');
|
||||||
|
Route::get('export', [PenilaianController::class, 'export'])->name('export');
|
||||||
|
Route::get('/getUserTeams/{id}', [PenilaianController::class, 'getUserTeams']);
|
||||||
|
|
||||||
|
Route::get('/', [PenilaianController::class, 'index'])->name('index');
|
||||||
|
Route::get('{id}/edit', [PenilaianController::class, 'edit'])->name('edit');
|
||||||
|
Route::put('{id}', [PenilaianController::class, 'update'])->name('update');
|
||||||
|
Route::post('create', [PenilaianController::class, 'create'])->name('create');
|
||||||
|
Route::post('store', [PenilaianController::class, 'store'])->name('store');
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user