diff --git a/app/Exports/JenisLampiranExport.php b/app/Exports/JenisLampiranExport.php new file mode 100644 index 0000000..5873a6e --- /dev/null +++ b/app/Exports/JenisLampiranExport.php @@ -0,0 +1,46 @@ +id, + $row->nama, + $row->deskripsi, + $row->created_at + ]; + } + + public function headings(): array + { + return [ + 'ID', + 'Nama', + 'Deskripsi', + 'Created At' + ]; + } + + public function columnFormats(): array + { + return [ + 'A' => NumberFormat::FORMAT_NUMBER, + 'D' => NumberFormat::FORMAT_DATE_DATETIME + ]; + } +} diff --git a/app/Http/Controllers/ActivityController.php b/app/Http/Controllers/ActivityController.php index f0ad060..8c04b89 100644 --- a/app/Http/Controllers/ActivityController.php +++ b/app/Http/Controllers/ActivityController.php @@ -73,7 +73,8 @@ class ActivityController extends Controller public function updateTeamAssingment(Request $request) { try { - // Validasi input + + // dd($request->all()); $validatedData = $request->validate([ 'id' => 'required|integer', // penilaian_id 'team_member_id' => 'nullable|integer', @@ -81,6 +82,7 @@ class ActivityController extends Controller 'permohonan_id' => 'required|integer', 'user_id' => 'required|integer', 'team_id' => 'required|integer', + 'penugasan' => 'required|string', ], [ 'team_member_id.required_without' => 'Field team harus diisi.', '.required_without' => 'Field harus diisi.', @@ -93,6 +95,7 @@ class ActivityController extends Controller $permohonanId = $validatedData['permohonan_id']; $userId = $validatedData['user_id']; $teamId = $validatedData['team_id']; + $penugasan = $validatedData['penugasan']; // Cek apakah permohonan ada $permohonan = Permohonan::findOrFail($permohonanId); @@ -106,55 +109,101 @@ class ActivityController extends Controller // } // Ambil tim berdasarkan penilaian_id dan user_id - $teams = PenilaianTeam::where('penilaian_id', $penilaianId) + + if ($penugasan === 'sama') { + $teams = PenilaianTeam::where('penilaian_id', $penilaianId) ->where('user_id', $userId) ->get(); + // Cek apakah tim ditemukan + if ($teams->isEmpty()) { + return response()->json([ + 'status' => 'error', + 'message' => 'Data tim tidak ditemukan.', + ]); + } - // Cek apakah tim ditemukan - if ($teams->isEmpty()) { - return response()->json([ - 'status' => 'error', - 'message' => 'Data tim tidak ditemukan.', - ]); - } + // Mulai transaksi + DB::beginTransaction(); + $updated = false; - // Mulai transaksi - DB::beginTransaction(); - $updated = false; + $status_permohonan = $permohonan->status; - // Proses update berdasarkan region_id - if ($regionId) { - foreach ($teams as $team) { - if ($team->role === 'surveyor') { - $team->update([ - 'team_id' => $regionId, - 'user_id' => null]); - $permohonan->update([ - 'status' => 'registered']); - $updated = true; + // Proses update berdasarkan region_id + if ($regionId) { + foreach ($teams as $team) { + if ($team->role === 'surveyor') { + $team->update([ + 'team_id' => $regionId, + 'user_id' => null, + 'status' => $status_permohonan, + ]); + $permohonan->update([ + 'status' => 'reassign' + ]); + $updated = true; + } + + if ($team->role === 'penilai') { + $team->update([ + 'team_id' => $regionId, + 'user_id' => null, + 'status' => $status_permohonan + ]); + $permohonan->update([ + 'status' => 'reassign', + 'region_id' => $regionId, + ]); + $updated = true; + } } + } - if ($team->role === 'penilai') { - $team->update([ - 'team_id' => $regionId, - 'user_id' => null, - ]); - $permohonan->update([ - 'status' => 'registered', - 'region_id' => $regionId, - ]); - $updated = true; + // Proses update berdasarkan team_member_id + if ($teamMemberId) { + foreach ($teams as $team) { + if ($team->role === 'surveyor' || $team->role === 'penilai') { + $team->update(['user_id' => $teamMemberId]); + $updated = true; + } } } } - // Proses update berdasarkan team_member_id - if ($teamMemberId) { - foreach ($teams as $team) { - if ($team->role === 'surveyor' || $team->role === 'penilai') { - $team->update(['user_id' => $teamMemberId]); - $updated = true; - } + if ($penugasan === 'surveyor' || $penugasan === 'penilai') { + $teams = PenilaianTeam::where('penilaian_id', $penilaianId) + ->where('user_id', $userId) + ->where('role', $penugasan) + ->first(); + + // Cek apakah tim ditemukan + if (!$teams) { + return response()->json([ + 'status' => 'error', + 'message' => 'Data tim tidak ditemukan.', + ]); + } + + // Mulai transaksi + DB::beginTransaction(); + $updated = false; + + // Proses update berdasarkan region_id + if ($regionId) { + $teams->update([ + 'team_id' => $regionId, + 'user_id' => null + ]); + $permohonan->update([ + 'status' => $status_permohonan, + 'region_id' => $regionId, + ]); + $updated = true; + } + + // Proses update berdasarkan team_member_id + if ($teamMemberId) { + $teams->update(['user_id' => $teamMemberId]); + $updated = true; } } @@ -306,7 +355,7 @@ class ActivityController extends Controller } // Filter for specific roles - if (in_array($userRole, ['surveyor', 'surveyor-penilai'])) { + if (in_array($userRole, ['surveyor', 'penilai'])) { $query->whereHas('penilaian.userPenilai', function ($q) use ($user) { $q->where('user_id', $user->id); }); @@ -451,17 +500,17 @@ class ActivityController extends Controller $hari = $hariPaparan = 0; - if($type_report == "sederhana"){ + if ($type_report == "sederhana") { $hari = 2; $item->paparan = 'Tidak Ada'; - } else{ + } else { if ($plafond == '< 2M') { $item->paparan = 'Tidak Ada'; $hari = 3; - }else if($plafond == '2 M - 5 M'){ + } elseif ($plafond == '2 M - 5 M') { $hari = 3; $hariPaparan = 2; - }else { + } else { $hari = 5; $hariPaparan = 3; } @@ -495,7 +544,7 @@ class ActivityController extends Controller if (!$tanggalMulai instanceof Carbon) { $tanggalMulai = Carbon::parse($tanggalMulai); } - $hariKerjaBerikutnya = hitungHariKerja($tanggalMulai->toDateString(),$tanggalMulai->copy()->addDays(1)); + $hariKerjaBerikutnya = hitungHariKerja($tanggalMulai->toDateString(), $tanggalMulai->copy()->addDays(1)); $hariKerjaBerikutnya = max($hariKerjaBerikutnya, 1); $tanggalMulai = $tanggalMulai->copy()->addDays($hariKerjaBerikutnya); diff --git a/app/Http/Controllers/JenisLampiranController.php b/app/Http/Controllers/JenisLampiranController.php new file mode 100644 index 0000000..6588dd7 --- /dev/null +++ b/app/Http/Controllers/JenisLampiranController.php @@ -0,0 +1,172 @@ +validated(); + $validated['created_by'] = Auth::id(); + + $jenisLampiran = JenisLampiran::create($validated); + + DB::commit(); + return redirect() + ->route('basicdata.jenis-lampiran.index') + ->with('success', 'Jenis Lampiran berhasil ditambahkan.'); + } catch (Exception $e) { + DB::rollBack(); + return redirect() + ->back() + ->with('error', 'Gagal menambahkan Jenis Lampiran: ' . $e->getMessage()) + ->withInput(); + } + } + + public function create() + { + return view('lpj::jenis_lampiran.create'); + } + + public function show($id) + { + $jenisLampiran = JenisLampiran::findOrFail($id); + return view('lpj::jenis_lampiran.show', compact('jenisLampiran')); + } + + public function edit($id) + { + $jenisLampiran = JenisLampiran::findOrFail($id); + return view('lpj::jenis_lampiran.create', compact('jenisLampiran')); + } + + public function update(JenisLampiranRequest $request, $id) + { + DB::beginTransaction(); + try { + $jenisLampiran = JenisLampiran::findOrFail($id); + $validated = $request->validated(); + $validated['updated_by'] = Auth::id(); + + $jenisLampiran->update($validated); + + DB::commit(); + return redirect() + ->route('basicdata.jenis-lampiran.index') + ->with('success', 'Jenis Lampiran berhasil diperbarui.'); + } catch (Exception $e) { + DB::rollBack(); + return redirect() + ->back() + ->with('error', 'Gagal memperbarui Jenis Lampiran: ' . $e->getMessage()) + ->withInput(); + } + } + + public function destroy($id) + { + DB::beginTransaction(); + try { + $jenisLampiran = JenisLampiran::findOrFail($id); + $jenisLampiran->deleted_by = Auth::id(); + $jenisLampiran->save(); + + $jenisLampiran->delete(); + + DB::commit(); + echo json_encode(['success' => true, 'message' => 'Jenis Lampiran berhasil dihapus.']); + + } catch (Exception $e) { + DB::rollBack(); + echo json_encode([ + 'success' => false, + 'message' => 'Gagal menghapus Jenis Lampiran: ' . $e->getMessage() + ]); + } + } + + public function dataForDatatables(Request $request) + { + // Retrieve data from the database + $query = JenisLampiran::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('nama', 'LIKE', "%$search%") + ->orWhere('deskripsi', '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->get(); + + // Calculate the page count + $pageCount = ceil($totalRecords / $request->get('size')); + + // Calculate the current page number + $currentPage = $request->get('page', 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, + ]); + } + + public function export() + { + if (is_null($this->user) || !$this->user->can('jenis_lampiran.export')) { + abort(403, 'Sorry! You are not allowed to export jenis lampiran.'); + } + + return Excel::download(new JenisLampiranExport, 'jenis_lampiran.xlsx'); + } + } diff --git a/app/Http/Controllers/LampiranDokumenController.php b/app/Http/Controllers/LampiranDokumenController.php index 5e1a1ec..d187a82 100644 --- a/app/Http/Controllers/LampiranDokumenController.php +++ b/app/Http/Controllers/LampiranDokumenController.php @@ -18,10 +18,11 @@ public function upload(Request $request) { $request->validate([ - 'permohonan_id' => 'required|exists:permohonan,id', - 'nama_file' => 'nullable|string|max:255', - 'file' => 'required|file|max:10240', - 'keterangan' => 'nullable|string|max:255', + 'permohonan_id' => 'required|exists:permohonan,id', + 'jenis_lampiran_id' => 'required|exists:jenis_lampiran,id', + 'nama_file' => 'nullable|string|max:255', + 'file' => 'required|file|max:10240', + 'keterangan' => 'nullable|string|max:255', ]); $lampiran = LampiranDokumen::uploadLampiran($request->all()); diff --git a/app/Http/Controllers/PenilaiController.php b/app/Http/Controllers/PenilaiController.php index 8eb6ead..e46ea62 100644 --- a/app/Http/Controllers/PenilaiController.php +++ b/app/Http/Controllers/PenilaiController.php @@ -558,6 +558,7 @@ class PenilaiController extends Controller $query = Permohonan::query(); // Apply search filter if provided + $query = $query->orderBy('nomor_registrasi', 'desc'); if ($request->has('search') && !empty($request->get('search'))) { $search = $request->get('search'); $columns = ['debiture.name', 'branch.name', 'user.name', 'tujuanPenilaian.name', 'jenisfasilitasKredit.name']; @@ -575,7 +576,7 @@ class PenilaiController extends Controller if (!Auth::user()->hasRole('administrator')) { $query->whereHas('penilaian.userPenilai', function ($q) { $q - ->where('role', 'penilai') + ->where('role', ['surveyor','penilai']) ->where('user_id', Auth::user()->id); }); } diff --git a/app/Http/Controllers/PenilaianController.php b/app/Http/Controllers/PenilaianController.php index 78849d4..3c88325 100644 --- a/app/Http/Controllers/PenilaianController.php +++ b/app/Http/Controllers/PenilaianController.php @@ -253,7 +253,7 @@ class PenilaianController extends Controller $teamPenilai = $userTeam->flatMap(function ($team) { return $team->teamsUsers->filter(function ($teamUser) { return $teamUser->user->roles->contains(function ($role) { - return $role->name === 'surveyor' || $role->name === 'surveyor-penilai' || $role->name === 'administrator'; + return $role->name === 'surveyor' || $role->name === 'penilai' || $role->name === 'administrator'; }); })->map(function ($teamUser) { return $teamUser->user; @@ -279,6 +279,8 @@ class PenilaianController extends Controller $penilaianTeam = PenilaianTeam::where('penilaian_id', $penilaian->id)->get(); } + // dd($penilaianTeam); + return view( 'lpj::penilaian.form', compact( @@ -347,8 +349,9 @@ class PenilaianController extends Controller $query->whereIn('status', ['registered', 'registrasi-final', 'reassign']); - // Filter berdasarkan role + if (Auth::user()->roles[0]->name !== 'administrator') { + $query->whereHas('region.teams.teamsUsers.user', function ($q) { $q->where('id', Auth::user()->id); }); @@ -376,7 +379,8 @@ class PenilaianController extends Controller $filteredRecords = $query->count(); $data = $query->with( - ['user', 'debiture', 'branch', 'tujuanPenilaian', 'jenisPenilaian', 'region.teams.teamsUsers.user'], + ['user', 'debiture', 'branch', 'tujuanPenilaian', 'jenisPenilaian', 'region.teams.teamsUsers.user', + ] )->get(); $pageCount = ceil($totalRecords / $size); @@ -433,10 +437,10 @@ class PenilaianController extends Controller $header = $headers[$type] ?? 'Pelaporan'; $authorization = null; if ($header === 'SLA') { - $authorization = Authorization::with(['user'])->find($id); - $permohonan = Permohonan::find($authorization->permohonan_id); + $authorization = Authorization::with(['user','permohonan.lampiranDokumen.jenisLampiran'])->find($id); + $permohonan = Permohonan::with(['lampiranDokumen.jenisLampiran'])->find($authorization->permohonan_id); } else { - $permohonan = Permohonan::find($id); + $permohonan = Permohonan::with(['lampiranDokumen.jenisLampiran'])->find($id); } if ($header === 'SLA') { return view('lpj::penilaian.otorisator.sla', compact('permohonan', 'header', 'authorization')); @@ -738,8 +742,8 @@ class PenilaianController extends Controller 'tujuanPenilaian', 'nilaiPlafond', 'penilaian.userPenilai' => function ($q) { - $q->where('role', 'penilai')->with(['user', 'team.regions']); -}, + $q->where('role', 'penilai')->with(['user', 'team.regions']); + }, 'penilai', 'approveSo', 'approveEo', @@ -900,7 +904,7 @@ class PenilaianController extends Controller public function revisiLaporan(Request $request, $id) { // dd($id); - if($request->dataHeader=='Paparan' || $request->dataHeader=='Freze SLA'){ + if ($request->dataHeader == 'Paparan' || $request->dataHeader == 'Freze SLA') { $authorization = Authorization::find($id); $permohonan = Permohonan::find($authorization->permohonan_id); } else { @@ -914,13 +918,13 @@ class PenilaianController extends Controller } $status = 'revisi-paparan'; - }else if($permohonan->status === 'request-freeze'){ + } elseif ($permohonan->status === 'request-freeze') { if ($authorization) { $authorization->delete(); } $status = 'reject-freeze'; - }elseif ($permohonan->status === 'proses-laporan' && $userRole === 'EO Appraisal') { + } elseif ($permohonan->status === 'proses-laporan' && $userRole === 'EO Appraisal') { $permohonan->update([ 'approval_so' => 0, 'approval_so_at' => null, diff --git a/app/Http/Controllers/SurveyorController.php b/app/Http/Controllers/SurveyorController.php index f695013..b4efc41 100644 --- a/app/Http/Controllers/SurveyorController.php +++ b/app/Http/Controllers/SurveyorController.php @@ -2008,7 +2008,7 @@ class SurveyorController extends Controller } $query = Permohonan::query(); - + $query = $query->orderBy('nomor_registrasi', 'desc'); if ($request->has('search') && !empty($request->get('search'))) { $search = $request->get('search'); $query->where(function ($q) use ($search) { @@ -2028,7 +2028,7 @@ class SurveyorController extends Controller if (!Auth::user()->hasRole('administrator')) { $query->whereHas('penilaian.userPenilai', function ($q) { $q->where('user_id', Auth::user()->id); - $q->where('role', 'surveyor'); + $q->where('role', ['surveyor', 'penilai']); }); } diff --git a/app/Http/Requests/JenisLampiranRequest.php b/app/Http/Requests/JenisLampiranRequest.php new file mode 100644 index 0000000..7ba379b --- /dev/null +++ b/app/Http/Requests/JenisLampiranRequest.php @@ -0,0 +1,54 @@ + [ + 'required', + 'string', + 'max:255', + Rule::unique('jenis_lampiran')->where(function ($query) { + return $query->whereNull('deleted_at'); + })->ignore($this->route('jenis_lampiran')), + ], + 'deskripsi' => 'nullable|string', + ]; + + return $rules; + } + + /** + * Get custom messages for validator errors. + * + * @return array + */ + public function messages() + { + return [ + 'nama.required' => 'Nama jenis lampiran harus diisi.', + 'nama.max' => 'Nama jenis lampiran tidak boleh lebih dari 255 karakter.', + ]; + } + } diff --git a/app/Models/JenisLampiran.php b/app/Models/JenisLampiran.php new file mode 100644 index 0000000..dbd52bc --- /dev/null +++ b/app/Models/JenisLampiran.php @@ -0,0 +1,20 @@ +hasMany(LampiranDokumen::class); + } +} diff --git a/app/Models/LampiranDokumen.php b/app/Models/LampiranDokumen.php index af514f5..7a0654d 100644 --- a/app/Models/LampiranDokumen.php +++ b/app/Models/LampiranDokumen.php @@ -9,7 +9,7 @@ class LampiranDokumen extends Base { protected $table = 'lampiran_dokumen'; - protected $fillable = ['permohonan_id', 'nama_file', 'path_file', 'keterangan']; + protected $fillable = ['permohonan_id', 'nama_file', 'path_file', 'keterangan','jenis_lampiran_id']; public function permohonan() { @@ -34,6 +34,7 @@ class LampiranDokumen extends Base return self::create([ 'permohonan_id' => $fileData['permohonan_id'] ?? null, + 'jenis_lampiran_id' => $fileData['jenis_lampiran_id'] ?? null, 'nama_file' => $fileName, 'path_file' => $filePath, 'keterangan' => $fileData['keterangan'] ?? null, @@ -62,4 +63,9 @@ class LampiranDokumen extends Base return false; } + + public function jenisLampiran() + { + return $this->belongsTo(JenisLampiran::class); + } } diff --git a/database/migrations/2025_03_14_013452_create_jenis_lampiran_table.php b/database/migrations/2025_03_14_013452_create_jenis_lampiran_table.php new file mode 100644 index 0000000..5b4d73a --- /dev/null +++ b/database/migrations/2025_03_14_013452_create_jenis_lampiran_table.php @@ -0,0 +1,34 @@ +id(); + $table->string('nama'); + $table->text('deskripsi')->nullable(); + $table->timestamps(); + $table->softDeletes(); + + $table->unsignedBigInteger('created_by')->nullable(); + $table->unsignedBigInteger('updated_by')->nullable(); + $table->unsignedBigInteger('deleted_by')->nullable(); + }); + } + + /** + * Reverse the migrations. + */ + public function down(): void + { + Schema::dropIfExists('jenis_lampiran'); + } +}; diff --git a/database/migrations/2025_03_14_013537_add_jenis_lampiran_id_to_lampiran_dokumen_table.php b/database/migrations/2025_03_14_013537_add_jenis_lampiran_id_to_lampiran_dokumen_table.php new file mode 100644 index 0000000..ebd6637 --- /dev/null +++ b/database/migrations/2025_03_14_013537_add_jenis_lampiran_id_to_lampiran_dokumen_table.php @@ -0,0 +1,30 @@ +foreignIdFor(JenisLampiran::class)->constrained('jenis_lampiran')->onDelete('cascade')->nullable(); + }); + } + + /** + * Reverse the migrations. + */ + public function down(): void + { + Schema::table('lampiran_dokumen', function (Blueprint $table) { + $table->dropForeign(['jenis_lampiran_id']); + $table->dropColumn('jenis_lampiran_id'); + }); + } +}; diff --git a/module.json b/module.json index 74efc94..694f353 100644 --- a/module.json +++ b/module.json @@ -880,6 +880,17 @@ "administrator", "admin" ] + }, + { + "title": "Jenis Lampiran", + "path": "basicdata.jenis-lampiran", + "classes": "", + "attributes": [], + "permission": "", + "roles": [ + "administrator", + "admin" + ] } ] } diff --git a/resources/views/activity/activitydetail.blade.php b/resources/views/activity/activitydetail.blade.php index 3ecbaa8..220c55f 100644 --- a/resources/views/activity/activitydetail.blade.php +++ b/resources/views/activity/activitydetail.blade.php @@ -93,71 +93,7 @@ @endforeach @endif - -
Keterangan : {{ $lampiran->keterangan }}
-Tidak ada lampiran dokumen.
- @endforelse -Keterangan : {{ $lampiran->keterangan }}
-Tidak ada lampiran dokumen.
- @endforelse -Keterangan : {{ $lampiran->keterangan }}
+Jenis Lampiran : {{ str_replace('-',' ',$lampiran->jenisLampiran->nama) }}
+Tidak ada lampiran dokumen.
+ @endforelse +| + + | ++ Nama + + | ++ Deskripsi + + | +Action | +
|---|
| A. STATUS KEPEMILIKAN, HUBUNGAN DAN PENGHUNI | @@ -689,7 +692,7 @@
| Pemohon | -{{ $authorization->user->name }} | -
| Alasan | -{{ $authorization->keterangan }} | -
| Tanggal Permohonan | -{{ formatTanggalIndonesia($authorization->created_at, 1) }} | -
| Pemohon | +{{ $authorization->user->name }} | +
| Alasan | +{{ $authorization->keterangan }} | +
| Tanggal Permohonan | +{{ formatTanggalIndonesia($authorization->created_at, 1) }} | +
| Diperiksa Oleh | +{{ getUser($authorization->approve_so)->name ?? 'N/A' }} | +{{ $authorization->approve_so_at ? formatTanggalIndonesia($authorization->approve_so_at, 1) : 'N/A' }} + | +|||
| Diperiksa Oleh | -{{ getUser($authorization->approve_so)->name ?? 'N/A' }} | -{{ $authorization->approve_so_at ? formatTanggalIndonesia($authorization->approve_so_at, 1) : 'N/A' }} + | Disetujui Oleh (EO) | +{{ getUser($authorization->approve_eo)->name ?? 'N/A' }} | +{{ $authorization->approve_eo_at ? formatTanggalIndonesia($authorization->approve_eo_at, 1) : 'N/A' }} |
| Disetujui Oleh (EO) | -{{ getUser($authorization->approve_eo)->name ?? 'N/A' }} | -{{ $authorization->approve_eo_at ? formatTanggalIndonesia($authorization->approve_eo_at, 1) : 'N/A' }} - | -|||
| Disetujui Oleh (DD) | -{{ getUser($authorization->approve_dd)->name ?? 'N/A' }} | -{{ $authorization->approve_dd_at ? formatTanggalIndonesia($authorization->approve_dd_at, 1) : 'N/A' }} - | -|||
| Disetujui Oleh (DD) | +{{ getUser($authorization->approve_dd)->name ?? 'N/A' }} | +{{ $authorization->approve_dd_at ? formatTanggalIndonesia($authorization->approve_dd_at, 1) : 'N/A' }} + | +