Merge branch 'staging' of https://git.putrakuningan.com/daengdeni/lpj into tender
This commit is contained in:
@@ -9,9 +9,11 @@
|
|||||||
use Modules\Lpj\Exports\JenisFasilitasKreditExport;
|
use Modules\Lpj\Exports\JenisFasilitasKreditExport;
|
||||||
use Modules\Lpj\Http\Requests\JenisFasilitasKreditRequest;
|
use Modules\Lpj\Http\Requests\JenisFasilitasKreditRequest;
|
||||||
use Modules\Lpj\Models\JenisFasilitasKredit;
|
use Modules\Lpj\Models\JenisFasilitasKredit;
|
||||||
|
use Modules\Lpj\Http\Library\LpjHelpers;
|
||||||
|
|
||||||
class JenisFasilitasKreditController extends Controller
|
class JenisFasilitasKreditController extends Controller
|
||||||
{
|
{
|
||||||
|
use LpjHelpers; // <---- Using the LpjHelpers Trait
|
||||||
public $user;
|
public $user;
|
||||||
|
|
||||||
public function index()
|
public function index()
|
||||||
@@ -26,11 +28,18 @@
|
|||||||
if ($validate) {
|
if ($validate) {
|
||||||
try {
|
try {
|
||||||
// Save to database
|
// Save to database
|
||||||
|
// andy add
|
||||||
|
$lastNumberCodeJFK = LpjHelpers::onLastCodeJFK();
|
||||||
|
|
||||||
|
$validate['name'] =strtoupper($request->name);
|
||||||
|
$validate['code'] =$lastNumberCodeJFK;
|
||||||
|
// andy add
|
||||||
|
|
||||||
JenisFasilitasKredit::create($validate);
|
JenisFasilitasKredit::create($validate);
|
||||||
return redirect()
|
return redirect()
|
||||||
->route('basicdata.jenis-fasilitas-kredit.index')
|
->route('basicdata.jenis-fasilitas-kredit.index')
|
||||||
->with('success', 'Jenis Fasilitas Kredit created successfully');
|
->with('success', 'Jenis Fasilitas Kredit created successfully');
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {dd($e);
|
||||||
return redirect()
|
return redirect()
|
||||||
->route('basicdata.jenis-fasilitas-kredit.create')
|
->route('basicdata.jenis-fasilitas-kredit.create')
|
||||||
->with('error', 'Failed to create jenis fasilitas kredit');
|
->with('error', 'Failed to create jenis fasilitas kredit');
|
||||||
@@ -57,11 +66,16 @@
|
|||||||
try {
|
try {
|
||||||
// Update in database
|
// Update in database
|
||||||
$jenisFasilitasKredit = JenisFasilitasKredit::find($id);
|
$jenisFasilitasKredit = JenisFasilitasKredit::find($id);
|
||||||
|
|
||||||
|
// andy add
|
||||||
|
$validate['name'] =strtoupper($request->name);
|
||||||
|
// andy add
|
||||||
|
|
||||||
$jenisFasilitasKredit->update($validate);
|
$jenisFasilitasKredit->update($validate);
|
||||||
return redirect()
|
return redirect()
|
||||||
->route('basicdata.jenis-fasilitas-kredit.index')
|
->route('basicdata.jenis-fasilitas-kredit.index')
|
||||||
->with('success', 'Jenis Fasilitas Kredit updated successfully');
|
->with('success', 'Jenis Fasilitas Kredit updated successfully');
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {dd($e);
|
||||||
return redirect()
|
return redirect()
|
||||||
->route('basicdata.jenis-fasilitas-kredit.edit', $id)
|
->route('basicdata.jenis-fasilitas-kredit.edit', $id)
|
||||||
->with('error', 'Failed to update jenis fasilitas kredit');
|
->with('error', 'Failed to update jenis fasilitas kredit');
|
||||||
|
|||||||
405
app/Http/Controllers/ProsesPenawaranController.php
Normal file
405
app/Http/Controllers/ProsesPenawaranController.php
Normal file
@@ -0,0 +1,405 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Http\Controllers;
|
||||||
|
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Illuminate\Http\Response;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Exception;
|
||||||
|
use Maatwebsite\Excel\Facades\Excel;
|
||||||
|
use Illuminate\Http\JsonResponse;
|
||||||
|
use Illuminate\Support\Facades\Validator;
|
||||||
|
use Illuminate\Support\Facades\Auth;
|
||||||
|
use Illuminate\Support\Facades\Storage;
|
||||||
|
use Illuminate\Support\Facades\DB;
|
||||||
|
use Modules\Lpj\Models\KJPP;
|
||||||
|
use Modules\Lpj\Models\PenawaranDetailTender;
|
||||||
|
use Modules\Lpj\Models\PenawaranTender;
|
||||||
|
|
||||||
|
use Modules\Lpj\Models\Permohonan;
|
||||||
|
|
||||||
|
class ProsesPenawaranController extends Controller
|
||||||
|
{
|
||||||
|
public $user;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Display a listing of the resource.
|
||||||
|
*/
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
// dd('hai');
|
||||||
|
return view('lpj::prosespenawaran.index');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function dataForDatatables(Request $request)
|
||||||
|
{
|
||||||
|
if (is_null($this->user) || !$this->user->can('debitur.view')) {
|
||||||
|
//abort(403, 'Sorry! You are not allowed to view users.');
|
||||||
|
}
|
||||||
|
|
||||||
|
// Retrieve data from the database
|
||||||
|
$query =PenawaranTender::query()->where('status','=','tender')->withCount('penawarandetails');
|
||||||
|
|
||||||
|
// 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->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();
|
||||||
|
$data = $query->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,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function edit($id)
|
||||||
|
{
|
||||||
|
return view('lpj::prosespenawaran.edit', compact('id'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setData(Request $request): JsonResponse
|
||||||
|
{
|
||||||
|
$data = array();
|
||||||
|
$penawaran = array();
|
||||||
|
$penawrandetails = array();
|
||||||
|
|
||||||
|
if (request()->ajax()) {
|
||||||
|
$id = $request->id;
|
||||||
|
$penawaran = PenawaranTender::findOrFail($id);
|
||||||
|
$penawrandetails = PenawaranDetailTender::where('penawaran_id','=',$id)
|
||||||
|
->leftJoin('kjpp', 'kjpp.id', '=', 'detail_penawaran.kjpp_rekanan_id')
|
||||||
|
->select('detail_penawaran.*', 'kjpp.code AS kjpp_code', 'kjpp.name AS kjpp_name')
|
||||||
|
->where('detail_penawaran.status','=',1)
|
||||||
|
->get();
|
||||||
|
$data['status'] = 'success';
|
||||||
|
if ($penawaran) {
|
||||||
|
$i=0;
|
||||||
|
foreach($penawrandetails as $obj)
|
||||||
|
{
|
||||||
|
// dd($obj->dokumen_persetujuan);
|
||||||
|
if($obj->dokumen_persetujuan && Storage::disk('public')->exists($obj->dokumen_persetujuan))
|
||||||
|
{
|
||||||
|
$penawrandetails_path = Storage::url($obj->dokumen_persetujuan);
|
||||||
|
$penawrandetails[$i]->dokumen_persetujuan = $penawrandetails_path;
|
||||||
|
$i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$kjpp=null;
|
||||||
|
$kjpp = KJPP::pluck('name', 'id');
|
||||||
|
$data['penawaran'] = $penawaran;
|
||||||
|
$data['penawrandetails'] = $penawrandetails;
|
||||||
|
$data['message'] = 'data successfully found';
|
||||||
|
} else {
|
||||||
|
$data['penawaran'] = null;
|
||||||
|
$data['penawrandetails'] = null;
|
||||||
|
$data['message'] = 'data not found';
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$data['status'] = 'error';
|
||||||
|
$data['message'] = 'no ajax request';
|
||||||
|
}
|
||||||
|
|
||||||
|
return response()->json($data);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update the specified resource in storage.
|
||||||
|
*/
|
||||||
|
public function update(Request $request, $id): JsonResponse
|
||||||
|
{
|
||||||
|
// init
|
||||||
|
$data = array();
|
||||||
|
$dataku = array();
|
||||||
|
$tindakan = null;
|
||||||
|
if (request()->ajax()) {
|
||||||
|
$validator = ProsesPenawaranController::rulesEditnya($request, $id);
|
||||||
|
|
||||||
|
if ($validator['fails']) {
|
||||||
|
$data['message'] = $validator['errors'];
|
||||||
|
$data['status'] = 'error';
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
|
||||||
|
$dataku = ['updated_by' => Auth::id(),
|
||||||
|
'updated_at' => now(),
|
||||||
|
'biaya_penawaran' => str_replace(".","",$request->biaya_penawaran)
|
||||||
|
];
|
||||||
|
|
||||||
|
if ($request->hasFile('dokumen_persetujuan'))
|
||||||
|
{
|
||||||
|
$file_tmp = $request->file('dokumen_persetujuan');
|
||||||
|
$folderPath = 'uploads/penawaran/';
|
||||||
|
if ($file_tmp->isValid())
|
||||||
|
{
|
||||||
|
$myFile=$file_tmp->getClientOriginalName(); // nama file with extension
|
||||||
|
$file_name = pathinfo($myFile, PATHINFO_FILENAME); // nama file without extension
|
||||||
|
|
||||||
|
$extension = $file_tmp->getClientOriginalExtension();
|
||||||
|
// kjppID_penawaranID_namaFile_userID_time
|
||||||
|
$newFileName = $request->kjpp_rekanan_id.'_'.$id.'_'.$file_name.'_'.Auth::user()->id."_".time() .'.'. $extension;
|
||||||
|
Storage::disk('public')->put($folderPath.'/'.$newFileName,file_get_contents($file_tmp));
|
||||||
|
|
||||||
|
$newFileNameWithPath = $folderPath . $newFileName;
|
||||||
|
$dataku['attachment'] = $myFile;
|
||||||
|
$dataku['dokumen_persetujuan'] = $newFileNameWithPath;
|
||||||
|
|
||||||
|
$model = PenawaranDetailTender::findOrFail($id);
|
||||||
|
$model->update($dataku);
|
||||||
|
|
||||||
|
$data['status'] = 'success';
|
||||||
|
$data['detailpenawaran_id'] = $id;
|
||||||
|
$data['message'] = 'Proses Penawarn KJPP successfully';
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$data['status'] = 'error';
|
||||||
|
$data['message'] = 'Silahkan upload file pdf';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$data['status'] = 'error';
|
||||||
|
$data['message'] = 'Silahkan upload file';
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (Exception $e) {
|
||||||
|
|
||||||
|
$data['status'] = 'error';
|
||||||
|
$data['message'] = 'Proses Penawarn KJPP failed.';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
$data['status'] = 'error';
|
||||||
|
$data['message'] = 'no ajax request';
|
||||||
|
}
|
||||||
|
|
||||||
|
return response()->json($data);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function rulesEditnya($request, $id)
|
||||||
|
{
|
||||||
|
$validateIt = [
|
||||||
|
// 'name' diambil dari definisi parameter yang di kirim pada POST Data
|
||||||
|
'biaya_penawaran' => 'required',
|
||||||
|
'dokumen_persetujuan' => 'required|file|mimes:pdf'
|
||||||
|
];
|
||||||
|
|
||||||
|
$messageIt = [
|
||||||
|
'biaya_penawaran.required' => 'Silahkan isi Biaya Penawaran',
|
||||||
|
'dokumen_persetujuan.required' => 'Silahkan isi dokumen',
|
||||||
|
'dokumen_persetujuan.file' => 'Silahkan isi file',
|
||||||
|
'dokumen_persetujuan.mimes' => 'Silahkan upload pdf'
|
||||||
|
];
|
||||||
|
|
||||||
|
$validator = Validator::make($request->all(), $validateIt, $messageIt);
|
||||||
|
|
||||||
|
$data['fails'] = $validator->fails();
|
||||||
|
$data['errors'] = $validator->errors();
|
||||||
|
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update the specified resource in storage.
|
||||||
|
*/
|
||||||
|
public function updateAll(Request $request, $id): JsonResponse
|
||||||
|
{
|
||||||
|
// init
|
||||||
|
$data = array();
|
||||||
|
$dataku = array();
|
||||||
|
$model = PenawaranTender::findOrFail($id);
|
||||||
|
$checkActiveDateRange = $this->checkActiveDateRangePenawaran($model->start_date, $model->end_date);
|
||||||
|
|
||||||
|
// cek masa aktif penawaran
|
||||||
|
if($checkActiveDateRange)
|
||||||
|
{
|
||||||
|
|
||||||
|
$checkKelengkapanDetailKJPP = $this->checkKelengkapanDetailKJPP($id);
|
||||||
|
if($checkKelengkapanDetailKJPP)
|
||||||
|
{
|
||||||
|
DB::beginTransaction();
|
||||||
|
try {
|
||||||
|
$dataku = ['status' => 'tendered',
|
||||||
|
'updated_by' => Auth::id(),
|
||||||
|
'updated_at' => now()
|
||||||
|
];
|
||||||
|
|
||||||
|
$dataPermohonan = ['status' => 'tendered',
|
||||||
|
'updated_by' => Auth::id(),
|
||||||
|
'updated_at' => now()
|
||||||
|
];
|
||||||
|
|
||||||
|
$permohonan = Permohonan::where('nomor_registrasi','=', $model->nomor_registrasi)->first();
|
||||||
|
|
||||||
|
$model->update($dataku);
|
||||||
|
$permohonan->update($dataPermohonan);
|
||||||
|
|
||||||
|
DB::commit();
|
||||||
|
|
||||||
|
$data['message'] = "Sukses melakukan Proses Penawaran";
|
||||||
|
$data['status'] = 'success';
|
||||||
|
|
||||||
|
} catch (Exception $e) {
|
||||||
|
DB::rollBack();
|
||||||
|
// dd($e);
|
||||||
|
$data['message'] = "Gagal melakukan Proses Penawaran";
|
||||||
|
$data['status'] = 'error';
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$data['message'] = "Silahkan lengkapi data KJPP";
|
||||||
|
$data['status'] = 'error';
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$data['message'] = "Penawaran sudah di tutup";
|
||||||
|
$data['status'] = 'error';
|
||||||
|
}
|
||||||
|
|
||||||
|
return response()->json($data);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function checkActiveDateRangePenawaran($start_date1, $end_date1)
|
||||||
|
{
|
||||||
|
$start_date = strtotime($start_date1);
|
||||||
|
$end_date = strtotime($end_date1);
|
||||||
|
$todays_date = strtotime(now());
|
||||||
|
|
||||||
|
$allow=true;
|
||||||
|
if ($todays_date >= $start_date && $todays_date <= $end_date)
|
||||||
|
{
|
||||||
|
//Penawaran dibuka
|
||||||
|
$allow=true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if($todays_date < $start_date)
|
||||||
|
{
|
||||||
|
//Penawaran Belum dibuka
|
||||||
|
$allow=true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//Penawaran sudah ditutup
|
||||||
|
$allow=false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $allow;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public function checkKelengkapanDetailKJPP($id)
|
||||||
|
{
|
||||||
|
$allow=true;
|
||||||
|
// DB::enableQueryLog();
|
||||||
|
// detail_penawaran apakah isian biaya_penawaran, attachment, dokumen_persetujuan sudah lengkap?
|
||||||
|
$query = PenawaranDetailTender::select('id')
|
||||||
|
->where('penawaran_id','=',$id)
|
||||||
|
->where(function($query) {
|
||||||
|
$query->orWhere('biaya_penawaran', '', "");
|
||||||
|
$query->orWhereNull('biaya_penawaran');
|
||||||
|
|
||||||
|
$query->orWhere('attachment', '', "");
|
||||||
|
$query->orWhereNull('attachment');
|
||||||
|
|
||||||
|
$query->orWhere('dokumen_persetujuan', '', "");
|
||||||
|
$query->orWhereNull('dokumen_persetujuan');
|
||||||
|
})->get();
|
||||||
|
// $sql = DB::getQueryLog();
|
||||||
|
|
||||||
|
|
||||||
|
if (sizeof($query)>0)
|
||||||
|
{
|
||||||
|
$allow=false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $allow;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public function updateStatusPenawaranKJPP(Request $request, $id): JsonResponse
|
||||||
|
{
|
||||||
|
// init
|
||||||
|
$data = array();
|
||||||
|
$dataku = array();
|
||||||
|
|
||||||
|
try {
|
||||||
|
$model = PenawaranDetailTender::findOrFail($id);
|
||||||
|
$data['id']=$id;
|
||||||
|
|
||||||
|
$dataku = ['status' => '0',
|
||||||
|
'updated_by' => Auth::id(),
|
||||||
|
'updated_at' => now()
|
||||||
|
];
|
||||||
|
|
||||||
|
$model->update($dataku);
|
||||||
|
|
||||||
|
$data['message'] = "Sukses delete Penawaran KJPP";
|
||||||
|
$data['status'] = 'success';
|
||||||
|
} catch (Exception $e) {
|
||||||
|
|
||||||
|
// dd($e);
|
||||||
|
$data['message'] = "Gagal delete Penawaran KJPP";
|
||||||
|
$data['status'] = 'error';
|
||||||
|
}
|
||||||
|
return response()->json($data);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function show($id)
|
||||||
|
{
|
||||||
|
$prosespenawaran = PenawaranTender::find($id);
|
||||||
|
return view('lpj::prosespenawaran.show', compact('id','prosespenawaran'));
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -25,7 +25,7 @@
|
|||||||
use Illuminate\Http\JsonResponse;
|
use Illuminate\Http\JsonResponse;
|
||||||
use Illuminate\Support\Facades\Validator;
|
use Illuminate\Support\Facades\Validator;
|
||||||
use Illuminate\Support\Facades\Auth;
|
use Illuminate\Support\Facades\Auth;
|
||||||
|
|
||||||
|
|
||||||
class RegistrasiController extends Controller
|
class RegistrasiController extends Controller
|
||||||
{
|
{
|
||||||
@@ -101,7 +101,7 @@
|
|||||||
'data' => $data,
|
'data' => $data,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function edit($id)
|
public function edit($id)
|
||||||
{
|
{
|
||||||
return view('lpj::registrasi.edit', compact('id'));
|
return view('lpj::registrasi.edit', compact('id'));
|
||||||
@@ -121,7 +121,7 @@
|
|||||||
$regions=null;
|
$regions=null;
|
||||||
$regions=Regions::pluck('name', 'id');
|
$regions=Regions::pluck('name', 'id');
|
||||||
$jenisPenilaians=JenisPenilaian::pluck('name', 'id');
|
$jenisPenilaians=JenisPenilaian::pluck('name', 'id');
|
||||||
|
|
||||||
$data['regions'] = $regions;
|
$data['regions'] = $regions;
|
||||||
$data['jenisPenilaians'] = $jenisPenilaians;
|
$data['jenisPenilaians'] = $jenisPenilaians;
|
||||||
$data['datas'] = $datas;
|
$data['datas'] = $datas;
|
||||||
@@ -146,11 +146,11 @@
|
|||||||
$tindakan = null;
|
$tindakan = null;
|
||||||
if (request()->ajax()) {
|
if (request()->ajax()) {
|
||||||
$validator = RegistrasiController::rulesEditnya($request, $id);
|
$validator = RegistrasiController::rulesEditnya($request, $id);
|
||||||
|
|
||||||
if ($validator['fails']) {
|
if ($validator['fails']) {
|
||||||
$data['message'] = $validator['errors'];
|
$data['message'] = $validator['errors'];
|
||||||
$data['status'] = 'error';
|
$data['status'] = 'error';
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
@@ -173,20 +173,20 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
$data['dataku'] =$dataku;
|
$data['dataku'] =$dataku;
|
||||||
|
|
||||||
$modal = Permohonan::find($id);
|
$modal = Permohonan::find($id);
|
||||||
|
|
||||||
$modal->update($dataku);
|
$modal->update($dataku);
|
||||||
//
|
//
|
||||||
$data['status'] = 'success';
|
$data['status'] = 'success';
|
||||||
$data['message'] = 'Regitrasi '.$modal->nomor_registrasi.' successfully';
|
$data['message'] = 'Regitrasi '.$modal->nomor_registrasi.' successfully';
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {
|
||||||
|
|
||||||
$data['status'] = 'error';
|
$data['status'] = 'error';
|
||||||
$data['message'] = 'Jenis Fasilitas Kredit updated failed.';
|
$data['message'] = 'Jenis Fasilitas Kredit updated failed.';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
$data['status'] = 'error';
|
$data['status'] = 'error';
|
||||||
$data['message'] = 'no ajax request';
|
$data['message'] = 'no ajax request';
|
||||||
@@ -203,7 +203,7 @@
|
|||||||
$validate_catatan='';
|
$validate_catatan='';
|
||||||
$tindakan=$request->tindakan;
|
$tindakan=$request->tindakan;
|
||||||
$jenis_penilaian=$request->jenis_penilaian;
|
$jenis_penilaian=$request->jenis_penilaian;
|
||||||
|
|
||||||
$validateIt = [
|
$validateIt = [
|
||||||
// 'name' diambil dari definisi parameter yang di kirim pada POST Data
|
// 'name' diambil dari definisi parameter yang di kirim pada POST Data
|
||||||
'tindakan' => 'required',
|
'tindakan' => 'required',
|
||||||
@@ -218,7 +218,7 @@
|
|||||||
$validateIt['jenis_penilaian'] = ['required'];
|
$validateIt['jenis_penilaian'] = ['required'];
|
||||||
$messageIt ['jenis_penilaian.required']= 'Silahkan pilih Jenis Penilaian';
|
$messageIt ['jenis_penilaian.required']= 'Silahkan pilih Jenis Penilaian';
|
||||||
|
|
||||||
// INTERNAL
|
// INTERNAL
|
||||||
if(1==$jenis_penilaian)
|
if(1==$jenis_penilaian)
|
||||||
{
|
{
|
||||||
$validateIt['region'] = ['required'];
|
$validateIt['region'] = ['required'];
|
||||||
|
|||||||
27
app/Http/Library/LpjHelpers.php
Normal file
27
app/Http/Library/LpjHelpers.php
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Lpj\Http\Library;
|
||||||
|
|
||||||
|
use Modules\Lpj\Models\JenisFasilitasKredit;
|
||||||
|
use Illuminate\Support\Facades\DB;
|
||||||
|
|
||||||
|
trait LpjHelpers
|
||||||
|
{
|
||||||
|
|
||||||
|
public static function onLastCodeJFK(): string
|
||||||
|
{
|
||||||
|
// max(code)
|
||||||
|
$noUrutAkhir2 = JenisFasilitasKredit::withTrashed()->max('code');
|
||||||
|
|
||||||
|
$noUrutAkhir=sprintf("%06s", 1);
|
||||||
|
$noUrutAwal = 'JFK';
|
||||||
|
$noUrutAkhirString = $noUrutAkhir;
|
||||||
|
if($noUrutAkhir2){
|
||||||
|
$noUrutAkhir = substr($noUrutAkhir2, 3, 6);
|
||||||
|
// $noUrutAwal = substr($noUrutAkhir2, 0, 3);
|
||||||
|
$noUrutAkhirString = sprintf("%06s", abs($noUrutAkhir + 1));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $noUrutAwal . $noUrutAkhirString;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -13,14 +13,16 @@
|
|||||||
: array
|
: array
|
||||||
{
|
{
|
||||||
$rules = [
|
$rules = [
|
||||||
'name' => 'required|max:255',
|
'name' => 'required|max:255|unique:jenis_fasilitas_kredit,name'
|
||||||
];
|
];
|
||||||
|
|
||||||
if ($this->method() == 'PUT') {
|
if ($this->method() == 'PUT') {
|
||||||
$rules['code'] = 'required|max:50|unique:jenis_fasilitas_kredit,code,' . $this->id;
|
$rules['code'] = 'max:50|unique:jenis_fasilitas_kredit,code,' . $this->id;
|
||||||
|
$rules['name'] = 'required|unique:jenis_fasilitas_kredit,name,' . $this->id;
|
||||||
} else {
|
} else {
|
||||||
$rules['code'] = 'required|max:50|unique:jenis_fasilitas_kredit,code';
|
$rules['code'] = 'max:50|unique:jenis_fasilitas_kredit,code';
|
||||||
}
|
}
|
||||||
|
|
||||||
return $rules;
|
return $rules;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ namespace Modules\Lpj\Models;
|
|||||||
|
|
||||||
use Illuminate\Database\Eloquent\Model;
|
use Illuminate\Database\Eloquent\Model;
|
||||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||||
|
use Illuminate\Database\Eloquent\Relations\BelongsTo;
|
||||||
// use Modules\Lpj\Database\Factories\PenawaranDetailTenderFactory;
|
// use Modules\Lpj\Database\Factories\PenawaranDetailTenderFactory;
|
||||||
|
|
||||||
class PenawaranDetailTender extends Model
|
class PenawaranDetailTender extends Model
|
||||||
@@ -16,4 +17,9 @@ class PenawaranDetailTender extends Model
|
|||||||
protected $table = 'detail_penawaran';
|
protected $table = 'detail_penawaran';
|
||||||
|
|
||||||
protected $guarded = ['id'];
|
protected $guarded = ['id'];
|
||||||
|
|
||||||
|
public function penawaran(): BelongsTo
|
||||||
|
{
|
||||||
|
return $this->belongsTo(PenawaranTender::class, 'penawaran_id', 'id');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ namespace Modules\Lpj\Models;
|
|||||||
use Illuminate\Database\Eloquent\Model;
|
use Illuminate\Database\Eloquent\Model;
|
||||||
use Modules\Lpj\Models\PenawaranDetailTender;
|
use Modules\Lpj\Models\PenawaranDetailTender;
|
||||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||||
|
use Illuminate\Database\Eloquent\Relations\HasMany; // andy add
|
||||||
|
|
||||||
class PenawaranTender extends Model
|
class PenawaranTender extends Model
|
||||||
{
|
{
|
||||||
@@ -16,6 +17,13 @@ class PenawaranTender extends Model
|
|||||||
protected $table = 'penawaran';
|
protected $table = 'penawaran';
|
||||||
|
|
||||||
protected $guarded = ['id'];
|
protected $guarded = ['id'];
|
||||||
|
|
||||||
|
// andy add
|
||||||
|
public function penawarandetails(): HasMany
|
||||||
|
{
|
||||||
|
return $this->hasMany(PenawaranDetailTender::class, 'penawaran_id', 'id')->where('status', '=', 1);
|
||||||
|
}
|
||||||
|
// andy add
|
||||||
|
|
||||||
public function penawaranKjpp()
|
public function penawaranKjpp()
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -27,6 +27,13 @@ class Permohonan extends Base
|
|||||||
'authorized_at',
|
'authorized_at',
|
||||||
'authorized_status',
|
'authorized_status',
|
||||||
'authorized_by',
|
'authorized_by',
|
||||||
|
// andy add
|
||||||
|
'registrasi_catatan',
|
||||||
|
'registrasi_by',
|
||||||
|
'registrasi_at',
|
||||||
|
'jenis_penilaian_id',
|
||||||
|
'region_id',
|
||||||
|
// andy add
|
||||||
'status_bayar',
|
'status_bayar',
|
||||||
'nilai_njop',
|
'nilai_njop',
|
||||||
// andy add
|
// andy add
|
||||||
|
|||||||
64
module.json
64
module.json
@@ -16,7 +16,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo"]
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Registrasi",
|
"title": "Registrasi",
|
||||||
@@ -25,7 +25,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "admin"]
|
"roles": ["administrator", "admin"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Tender",
|
"title": "Tender",
|
||||||
@@ -34,7 +34,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "admin"],
|
"roles": ["administrator", "admin"],
|
||||||
"sub": [
|
"sub": [
|
||||||
{
|
{
|
||||||
"title": "Data Penawaran",
|
"title": "Data Penawaran",
|
||||||
@@ -42,15 +42,15 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "admin"]
|
"roles": ["administrator", "admin"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Data Proses Penawaran",
|
"title": "Data Proses Penawaran",
|
||||||
"path": "tender.proses_penawaran",
|
"path": "tender.prosespenawaran",
|
||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "admin"]
|
"roles": ["administrator", "admin"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Data Penawaran Ulang",
|
"title": "Data Penawaran Ulang",
|
||||||
@@ -58,7 +58,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "admin"]
|
"roles": ["administrator", "admin"]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
@@ -69,7 +69,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo"]
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Data Debitur",
|
"title": "Data Debitur",
|
||||||
@@ -78,7 +78,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo"]
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Authorization",
|
"title": "Authorization",
|
||||||
@@ -87,7 +87,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-eo"]
|
"roles": ["administrator", "pemohon-eo"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Assignment",
|
"title": "Assignment",
|
||||||
@@ -96,7 +96,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "so"]
|
"roles": ["administrator", "so"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Team Activity",
|
"title": "Team Activity",
|
||||||
@@ -158,7 +158,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo", "admin"]
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo", "admin"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Laporan",
|
"title": "Laporan",
|
||||||
@@ -167,7 +167,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo", "admin", "so"]
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo", "admin", "so"]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"master": [
|
"master": [
|
||||||
@@ -178,7 +178,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo", "admin"],
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo", "admin"],
|
||||||
"sub": [
|
"sub": [
|
||||||
{
|
{
|
||||||
"title": "Cabang",
|
"title": "Cabang",
|
||||||
@@ -186,7 +186,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo"]
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Mata Uang",
|
"title": "Mata Uang",
|
||||||
@@ -194,7 +194,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo"]
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Jenis Fasilitas Kredit",
|
"title": "Jenis Fasilitas Kredit",
|
||||||
@@ -202,7 +202,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo"]
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Jenis Legalitas Jaminan",
|
"title": "Jenis Legalitas Jaminan",
|
||||||
@@ -210,7 +210,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo"]
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Jenis Aset",
|
"title": "Jenis Aset",
|
||||||
@@ -218,7 +218,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo"]
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Jenis Dokumen",
|
"title": "Jenis Dokumen",
|
||||||
@@ -226,7 +226,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo"]
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Tujuan Penilaian",
|
"title": "Tujuan Penilaian",
|
||||||
@@ -234,7 +234,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo"]
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Nilai Plafond",
|
"title": "Nilai Plafond",
|
||||||
@@ -242,7 +242,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo"]
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Hubungan Pemilik Jaminan",
|
"title": "Hubungan Pemilik Jaminan",
|
||||||
@@ -250,7 +250,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo"]
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Hubungan Penghuni Jaminan",
|
"title": "Hubungan Penghuni Jaminan",
|
||||||
@@ -258,7 +258,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "pemohon-ao", "pemohon-eo"]
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Arah Mata Angin",
|
"title": "Arah Mata Angin",
|
||||||
@@ -266,7 +266,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator"]
|
"roles": ["administrator"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Status Permohonan",
|
"title": "Status Permohonan",
|
||||||
@@ -274,7 +274,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator"]
|
"roles": ["administrator"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Region",
|
"title": "Region",
|
||||||
@@ -282,7 +282,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "admin", "so"]
|
"roles": ["administrator", "admin", "so"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Staff Appraisal",
|
"title": "Staff Appraisal",
|
||||||
@@ -290,7 +290,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "so"]
|
"roles": ["administrator", "so"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Jenis Penilaian",
|
"title": "Jenis Penilaian",
|
||||||
@@ -298,7 +298,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "admin", "so"]
|
"roles": ["administrator", "admin", "so"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "KJPP",
|
"title": "KJPP",
|
||||||
@@ -306,7 +306,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "admin"]
|
"roles": ["administrator", "admin"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Jenis Laporan",
|
"title": "Jenis Laporan",
|
||||||
@@ -322,7 +322,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "admin"]
|
"roles": ["administrator", "admin"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Ijin Usaha",
|
"title": "Ijin Usaha",
|
||||||
@@ -330,7 +330,7 @@
|
|||||||
"classes": "",
|
"classes": "",
|
||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["Administrator", "admin"]
|
"roles": ["administrator", "admin"]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -68,7 +68,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -58,7 +58,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
102
resources/views/assetsku/includenya.blade.php
Normal file
102
resources/views/assetsku/includenya.blade.php
Normal file
@@ -0,0 +1,102 @@
|
|||||||
|
<script tipe="module">
|
||||||
|
function removeErrorCssMsg() {
|
||||||
|
$(".inputku").removeClass("border-danger");
|
||||||
|
$("em").text('');
|
||||||
|
}
|
||||||
|
|
||||||
|
function tandaPemisahTitik(b){
|
||||||
|
var _minus = false;
|
||||||
|
if (b<0) _minus = true;
|
||||||
|
|
||||||
|
b = b.toString();
|
||||||
|
b=b.replace(".","");
|
||||||
|
b=b.replace("-","");
|
||||||
|
c = "";
|
||||||
|
panjang = b.length;
|
||||||
|
j = 0;
|
||||||
|
|
||||||
|
for (i = panjang; i > 0; i--){
|
||||||
|
j = j + 1;
|
||||||
|
if (((j % 3) == 1) && (j != 1)){
|
||||||
|
c = b.substr(i-1,1) + "." + c;
|
||||||
|
} else {
|
||||||
|
c = b.substr(i-1,1) + c;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_minus) c = "-" + c ;
|
||||||
|
|
||||||
|
return c;
|
||||||
|
}
|
||||||
|
|
||||||
|
function numbersonly(ini, e){
|
||||||
|
if (e.keyCode>=49){
|
||||||
|
|
||||||
|
if(e.keyCode<=57){
|
||||||
|
a = ini.value.toString().replace(".","");
|
||||||
|
b = a.replace(/[^\d]/g,"");
|
||||||
|
b = (b=="0")?String.fromCharCode(e.keyCode):b + String.fromCharCode(e.keyCode);
|
||||||
|
ini.value = tandaPemisahTitik(b);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
else if(e.keyCode<=105){
|
||||||
|
if(e.keyCode>=96){
|
||||||
|
//e.keycode = e.keycode - 47;
|
||||||
|
a = ini.value.toString().replace(".","");
|
||||||
|
b = a.replace(/[^\d]/g,"");
|
||||||
|
b = (b=="0")?String.fromCharCode(e.keyCode-48):b + String.fromCharCode(e.keyCode-48);
|
||||||
|
ini.value = tandaPemisahTitik(b);
|
||||||
|
//alert(e.keycode);
|
||||||
|
return false;
|
||||||
|
}else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}else if (e.keyCode==48){
|
||||||
|
a = ini.value.replace(".","") + String.fromCharCode(e.keyCode);
|
||||||
|
b = a.replace(/[^\d]/g,"");
|
||||||
|
|
||||||
|
if (parseFloat(b)!=0){
|
||||||
|
ini.value = tandaPemisahTitik(b);
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
}else if (e.keyCode==95){
|
||||||
|
a = ini.value.replace(".","") + String.fromCharCode(e.keyCode-48);
|
||||||
|
b = a.replace(/[^\d]/g,"");
|
||||||
|
|
||||||
|
if (parseFloat(b)!=0){
|
||||||
|
ini.value = tandaPemisahTitik(b);
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}else if (e.keyCode==8 || e.keycode==46){
|
||||||
|
a = ini.value.replace(".","");
|
||||||
|
b = a.replace(/[^\d]/g,"");
|
||||||
|
b = b.substr(0,b.length -1);
|
||||||
|
|
||||||
|
if (tandaPemisahTitik(b)!=""){
|
||||||
|
ini.value = tandaPemisahTitik(b);
|
||||||
|
} else {
|
||||||
|
ini.value = "";
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
} else if (e.keyCode==9){
|
||||||
|
return true;
|
||||||
|
} else if (e.keyCode==17){
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
//alert (e.keyCode);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
</script>
|
||||||
@@ -74,7 +74,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="module">
|
<script type="module">
|
||||||
const element = document.querySelector('#authorization-table');
|
const element = document.querySelector('#authorization-table');
|
||||||
const searchInput = document.getElementById('search');
|
const searchInput = document.getElementById('search');
|
||||||
|
|||||||
@@ -62,7 +62,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -66,7 +66,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -128,7 +128,6 @@
|
|||||||
|
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -85,7 +85,7 @@
|
|||||||
alamat
|
alamat
|
||||||
</span>
|
</span>
|
||||||
<p class="text-2xs text-gray-600 text-right max-w-[250px]">
|
<p class="text-2xs text-gray-600 text-right max-w-[250px]">
|
||||||
{{ $pemilik->address ?? '' }}, {{ $pemilik->village->name ?? ''}}, {{ $pemilik->city->name ?? ''}}, {{ $pemilik->province->name ?? '' }}, {{ $pemilik->postal_code ?? '' }}
|
{{ $pemilik->address ?? '' }}, {{ $pemilik->village->name ?? ''}}, {{ $pemilik->city->name ?? ''}}, {{ $pemilik->province->name ?? '' }}, {{ $pemilik->postal_code ?? '' }}
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -136,7 +136,6 @@
|
|||||||
|
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -90,7 +90,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
window.addEventListener('DOMContentLoaded', function () {
|
window.addEventListener('DOMContentLoaded', function () {
|
||||||
|
|
||||||
|
|||||||
@@ -58,7 +58,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -58,7 +58,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -62,7 +62,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -66,7 +66,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -1,3 +1,7 @@
|
|||||||
|
@php
|
||||||
|
$route = explode('.', Route::currentRouteName());
|
||||||
|
@endphp
|
||||||
|
|
||||||
@extends('layouts.main')
|
@extends('layouts.main')
|
||||||
|
|
||||||
@section('breadcrumbs')
|
@section('breadcrumbs')
|
||||||
|
|||||||
@@ -62,7 +62,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -62,7 +62,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -68,7 +68,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -62,7 +62,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -72,7 +72,6 @@
|
|||||||
|
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -71,7 +71,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -62,7 +62,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -87,7 +87,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function formatDate(date) {
|
function formatDate(date) {
|
||||||
const day = date.getDate().toString().padStart(2, '0');
|
const day = date.getDate().toString().padStart(2, '0');
|
||||||
@@ -126,20 +125,20 @@
|
|||||||
// Jika penawaran ada, ganti tombol menjadi "Penawaran Ulang"
|
// Jika penawaran ada, ganti tombol menjadi "Penawaran Ulang"
|
||||||
actionDiv.innerHTML = `
|
actionDiv.innerHTML = `
|
||||||
<a class="btn btn-sm btn-icon btn-clear btn-warning" title="Detail" href="/tender/penawaran/${nomor_registrasi}/show">
|
<a class="btn btn-sm btn-icon btn-clear btn-warning" title="Detail" href="/tender/penawaran/${nomor_registrasi}/show">
|
||||||
<i class="ki-outline ki-abstract-26"></i>
|
<i class="ki-outline ki-eye"></i>
|
||||||
</a>
|
</a>
|
||||||
<a href="/tender/penawaran/${nomor_registrasi}/edit" class="btn btn-sm btn-icon btn-clear btn-info" title="Penawaran">
|
<a href="/tender/penawaran/${nomor_registrasi}/edit" class="btn btn-sm btn-icon btn-clear btn-info" title="Penawaran">
|
||||||
<i class="ki-outline ki-arrow-circle-right"></i>
|
<i class="ki-outline ki-notepad-edit"></i>
|
||||||
</a>
|
</a>
|
||||||
`;
|
`;
|
||||||
} else {
|
} else {
|
||||||
// Jika tidak ada, tampilkan tombol "Tambah Penawaran"
|
// Jika tidak ada, tampilkan tombol "Tambah Penawaran"
|
||||||
actionDiv.innerHTML = `
|
actionDiv.innerHTML = `
|
||||||
<a class="btn btn-sm btn-icon btn-clear btn-warning" title="Detail" href="/tender/penawaran/${nomor_registrasi}/show">
|
<a class="btn btn-sm btn-icon btn-clear btn-warning" title="Detail" href="/tender/penawaran/${nomor_registrasi}/show">
|
||||||
<i class="ki-outline ki-abstract-26"></i>
|
<i class="ki-outline ki-eye"></i>
|
||||||
</a>
|
</a>
|
||||||
<a href="/tender/penawaran/${nomor_registrasi}/create" class="btn btn-sm btn-icon btn-clear btn-primary" title="Penawaran">
|
<a href="/tender/penawaran/${nomor_registrasi}/create" class="btn btn-sm btn-icon btn-clear btn-primary" title="Penawaran">
|
||||||
<i class="ki-outline ki-arrow-circle-right"></i>
|
<i class="ki-outline ki-notepad-edit"></i>
|
||||||
</a>
|
</a>
|
||||||
`;
|
`;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -88,7 +88,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function formatDate(date) {
|
function formatDate(date) {
|
||||||
const day = date.getDate().toString().padStart(2, '0');
|
const day = date.getDate().toString().padStart(2, '0');
|
||||||
|
|||||||
@@ -86,7 +86,6 @@
|
|||||||
|
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></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');
|
||||||
|
|||||||
@@ -86,7 +86,6 @@
|
|||||||
|
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></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');
|
||||||
|
|||||||
@@ -82,7 +82,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -81,7 +81,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
window.addEventListener('DOMContentLoaded', function () {
|
window.addEventListener('DOMContentLoaded', function () {
|
||||||
|
|
||||||
|
|||||||
@@ -86,7 +86,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
82
resources/views/prosespenawaran/edit.blade.php
Normal file
82
resources/views/prosespenawaran/edit.blade.php
Normal file
@@ -0,0 +1,82 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
@section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render(request()->route()->getName()) }}
|
||||||
|
@endsection
|
||||||
|
@php
|
||||||
|
// $route = Route::currentRouteName();
|
||||||
|
// dd($route);
|
||||||
|
$route = explode('.', Route::currentRouteName());
|
||||||
|
@endphp
|
||||||
|
|
||||||
|
@section('content')
|
||||||
|
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
||||||
|
|
||||||
|
|
||||||
|
<input type="hidden" id="id" name="id" value="{{ $id }}">
|
||||||
|
|
||||||
|
<div class="card pb-2.5">
|
||||||
|
<div class="card-header" id="basic_settings">
|
||||||
|
<h3 class="card-title">
|
||||||
|
Tambah Data Proses Penawaran
|
||||||
|
</h3>
|
||||||
|
<div class="flex items-center gap-2">
|
||||||
|
<a href="{{ route('tender.prosespenawaran.show', $id) }}" class="btn btn-xs btn-primary" title="Detail"><i class="ki-filled ki-abstract-26"></i> Detail</a>
|
||||||
|
<a href="{{ route('tender.prosespenawaran.index') }}" class="btn btn-xs btn-info"><i class="ki-filled ki-exit-left"></i> Back</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="card-body grid gap-5">
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">
|
||||||
|
No. registrasi
|
||||||
|
</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<label class="card-title" id="textReg">
|
||||||
|
No. registrasi
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
||||||
|
<label class="form-label max-w-56">
|
||||||
|
Kode Penawaran
|
||||||
|
</label>
|
||||||
|
<div class="flex flex-wrap items-baseline w-full">
|
||||||
|
<label class="card-title" id="textCodePenawaran">
|
||||||
|
Kode Penawaran
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- datatables -->
|
||||||
|
<div class="grid">
|
||||||
|
<div class="card min-w-full">
|
||||||
|
<div class="card-header">
|
||||||
|
<h3 class="card-title">Data KJPP</h3>
|
||||||
|
</div>
|
||||||
|
<div class="card-table scrollable-x-auto">
|
||||||
|
<table class="table table-border align-middle text-gray-700 font-medium text-sm">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="w-14 text-center">No</th>
|
||||||
|
<th class="min-w-[250px]">KJPP</th>
|
||||||
|
<th>Biaya Penawaran</th>
|
||||||
|
<th>Upload Penawaran</th>
|
||||||
|
<th class="min-w-[50px] text-center">Action</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody id="tbodyKJPP1">
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- datatables -->
|
||||||
|
<div class="flex justify-end">
|
||||||
|
<button type="button" class="btn btn-primary" id="{{$route[1]}}_toEdit">
|
||||||
|
Save
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@endsection
|
||||||
|
@include('lpj::prosespenawaran.js.editjs')
|
||||||
153
resources/views/prosespenawaran/index.blade.php
Normal file
153
resources/views/prosespenawaran/index.blade.php
Normal file
@@ -0,0 +1,153 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
@section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render('tender.prosespenawaran') }}
|
||||||
|
@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="prosespenawaran-table" data-api-url="{{ route('tender.prosespenawaran.datatables') }}">
|
||||||
|
<div class="card-header py-5 flex-wrap">
|
||||||
|
<h3 class="card-title">
|
||||||
|
Daftar Proses Penawaran
|
||||||
|
</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 Proses penawaran" 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="#"> Export to Excel </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-[150px]" data-datatable-column="nomor_registrasi">
|
||||||
|
<span class="sort"> <span class="sort-label"> Nomor Registrasi </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="code">
|
||||||
|
<span class="sort"> <span class="sort-label"> Kode Penawaran </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="start_date">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tanggal Penawaran </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="tujuan_penilaian_kjpp_id">
|
||||||
|
<span class="sort"> <span class="sort-label"> Tujuan Penilaian </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="penawarandetails_count">
|
||||||
|
<span class="sort"> <span class="sort-label"> Total KJPP </span>
|
||||||
|
<span class="sort-icon"> </span> </span>
|
||||||
|
</th>
|
||||||
|
<th class="min-w-[150px]" data-datatable-column="status">
|
||||||
|
<span class="sort"> <span class="sort-label"> Status </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')
|
||||||
|
<script type="text/javascript">
|
||||||
|
function showPenawaranData(regId)
|
||||||
|
{
|
||||||
|
var url = "{{ url('tender/prosespenawaran') }}/"+regId;
|
||||||
|
$(location).attr('href',url);
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
<script type="module">
|
||||||
|
const element = document.querySelector('#prosespenawaran-table');
|
||||||
|
const searchInput = document.getElementById('search');
|
||||||
|
|
||||||
|
const apiUrl = element.getAttribute('data-api-url');
|
||||||
|
const dataTableOptions = {
|
||||||
|
apiEndpoint: apiUrl,
|
||||||
|
pageSize: 5,
|
||||||
|
columns: {
|
||||||
|
select: {
|
||||||
|
render: (item, data, context) => {
|
||||||
|
const checkbox = document.createElement('input');
|
||||||
|
checkbox.className = 'checkbox checkbox-sm';
|
||||||
|
checkbox.type = 'checkbox';
|
||||||
|
checkbox.value = data.id.toString();
|
||||||
|
checkbox.setAttribute('data-datatable-row-check', 'true');
|
||||||
|
return checkbox.outerHTML.trim();
|
||||||
|
},
|
||||||
|
},
|
||||||
|
'nomor_registrasi': {
|
||||||
|
title: 'Nomor Registrasi',
|
||||||
|
},
|
||||||
|
code: {
|
||||||
|
title: 'Kode Penawaran',
|
||||||
|
},
|
||||||
|
start_date: {
|
||||||
|
title: 'Tanggal Penawaran',
|
||||||
|
},
|
||||||
|
tujuan_penilaian_kjpp_id: {
|
||||||
|
title: 'Tujuan Penilaian',
|
||||||
|
},
|
||||||
|
penawarandetails_count: {
|
||||||
|
title: 'Total KJPP',
|
||||||
|
createdCell(cell) {
|
||||||
|
cell.classList.add('text-center');
|
||||||
|
},
|
||||||
|
},
|
||||||
|
status: {
|
||||||
|
title: 'Status'
|
||||||
|
},
|
||||||
|
actions: {
|
||||||
|
title: 'Status',
|
||||||
|
render: (item, data) => {
|
||||||
|
return `<div class="flex flex-nowrap justify-center">
|
||||||
|
<a onclick="showPenawaranData(${data.id})" class="btn btn-sm btn-icon btn-clear btn-primary" title="Detail">
|
||||||
|
<i class="ki-outline ki-eye"></i>
|
||||||
|
</a>
|
||||||
|
<a class="btn btn-sm btn-icon btn-clear btn-info" title="Proses Penawaran" href="tender/prosespenawaran/${data.id}/edit">
|
||||||
|
<i class="ki-outline ki-notepad-edit"></i>
|
||||||
|
</a>
|
||||||
|
</div>`;
|
||||||
|
},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
let dataTable = new KTDataTable(element, dataTableOptions);
|
||||||
|
// Custom search functionality
|
||||||
|
searchInput.addEventListener('input', function () {
|
||||||
|
const searchValue = this.value.trim();
|
||||||
|
dataTable.search(searchValue, true);
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
</script>
|
||||||
|
@endpush
|
||||||
147
resources/views/prosespenawaran/js/editextjs.blade.php
Normal file
147
resources/views/prosespenawaran/js/editextjs.blade.php
Normal file
@@ -0,0 +1,147 @@
|
|||||||
|
<script tipe="module">
|
||||||
|
function switchProses(id)
|
||||||
|
{
|
||||||
|
|
||||||
|
let c = $('#{{$route[1]}}_check_'+id).val();
|
||||||
|
|
||||||
|
if($('input[name="{{$route[1]}}_check_'+id+'"]').is(':checked'))
|
||||||
|
{
|
||||||
|
// checked
|
||||||
|
// alert('aktif nih');
|
||||||
|
setActiveElement(id);
|
||||||
|
}else
|
||||||
|
{
|
||||||
|
// unchecked
|
||||||
|
//alert('tdk aktif nih');
|
||||||
|
setNonActiveElement(id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function setActiveElement(id)
|
||||||
|
{
|
||||||
|
$('#{{$route[1]}}_biayaPenawaran_'+id).removeAttr('disabled');
|
||||||
|
$('#{{$route[1]}}_dokumenPersetujuan_'+id).removeAttr('disabled');
|
||||||
|
$('#{{$route[1]}}_icon_update_'+id).removeAttr('disabled');
|
||||||
|
$('#{{$route[1]}}_icon_delete_'+id).removeAttr('disabled');
|
||||||
|
}
|
||||||
|
|
||||||
|
function setNonActiveElement(id)
|
||||||
|
{
|
||||||
|
$('#{{$route[1]}}_biayaPenawaran_'+id).attr('disabled', 'disabled');
|
||||||
|
$('#{{$route[1]}}_dokumenPersetujuan_'+id).attr('disabled', 'disabled');
|
||||||
|
$('#{{$route[1]}}_icon_update_'+id).attr('disabled', 'disabled');
|
||||||
|
$('#{{$route[1]}}_icon_delete_'+id).attr('disabled', 'disabled');
|
||||||
|
}
|
||||||
|
|
||||||
|
function updateData(id, kjpp_id, kjppName){
|
||||||
|
removeErrorCssMsg();
|
||||||
|
let biaya = $("#{{$route[1]}}_biayaPenawaran_"+id).val();
|
||||||
|
let filepdf = $("#{{$route[1]}}_dokumenPersetujuan_"+id).val();
|
||||||
|
let passednih = true;
|
||||||
|
if(!biaya){
|
||||||
|
$("#{{$route[1]}}_biayaPenawaran_"+id).addClass(" border-danger");
|
||||||
|
$("#{{$route[1]}}_biayaPenawaran_msg_"+id).text("Silahkan isi Biaya Penawaran nya");
|
||||||
|
passednih = false;
|
||||||
|
}
|
||||||
|
if(!filepdf){
|
||||||
|
$("#{{$route[1]}}_dokumenPersetujuan_"+id).addClass(" border-danger");
|
||||||
|
$("#{{$route[1]}}_dokumenPersetujuan_msg_"+id).text("Silahkan isi dokumen nya");
|
||||||
|
$("#{{$route[1]}}_dokumenPersetujuan_"+id).val("");
|
||||||
|
passednih = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(passednih)
|
||||||
|
{
|
||||||
|
var file_data = $("#{{$route[1]}}_dokumenPersetujuan_"+id).prop("files")[0];
|
||||||
|
let useURL = "{{ route($route[0].'.'.$route[1].'.update', '') }}/"+id;
|
||||||
|
let formData = new FormData();
|
||||||
|
let token = "{{ csrf_token() }}";alert(token);
|
||||||
|
formData.append("dokumen_persetujuan", file_data);
|
||||||
|
formData.append("biaya_penawaran", biaya);
|
||||||
|
formData.append("kjpp_rekanan_id", kjpp_id);
|
||||||
|
formData.append("_method", "PUT");
|
||||||
|
formData.append("_token", token);
|
||||||
|
$.ajax({
|
||||||
|
url: useURL,
|
||||||
|
type: "POST",
|
||||||
|
data: formData,
|
||||||
|
processData: false,
|
||||||
|
contentType: false,
|
||||||
|
success:function(response){
|
||||||
|
if('success' == response.status)
|
||||||
|
{
|
||||||
|
toastr.success(response.message);
|
||||||
|
|
||||||
|
setTimeout(function () {
|
||||||
|
location.reload(true);
|
||||||
|
}, 2000);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
toastr.error(_data.message);
|
||||||
|
|
||||||
|
},
|
||||||
|
error: function (response, textStatus, errorThrown) {
|
||||||
|
var errors = response.responseJSON.errors;
|
||||||
|
$.each(errors, function (key, value) {
|
||||||
|
console.log("v = " + value);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
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) {
|
||||||
|
|
||||||
|
//define variable
|
||||||
|
let token = "{{ csrf_token() }}";
|
||||||
|
let useURL = "{{ route($route[0].'.'.$route[1].'.updateStatusPenawaranKJPP','') }}/"+data;
|
||||||
|
|
||||||
|
alert(useURL);
|
||||||
|
var input_data = new Object();
|
||||||
|
input_data._token = token;
|
||||||
|
input_data.id =1;
|
||||||
|
$.ajax({
|
||||||
|
url: useURL,
|
||||||
|
type: "PUT",
|
||||||
|
cache: false,
|
||||||
|
data: input_data,
|
||||||
|
dataType: "json",
|
||||||
|
success: function(response) {
|
||||||
|
console.log(response);
|
||||||
|
if('success' == response.status)
|
||||||
|
{
|
||||||
|
swal.fire('Deleted!', response.message, 'success').then(() => {
|
||||||
|
window.location.reload();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Swal.fire('Error!', response.message, 'error');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
},
|
||||||
|
error: function(response, textStatus, errorThrown) {
|
||||||
|
// var errors = response.responseJSON.errors;
|
||||||
|
// console.log(errors);
|
||||||
|
console.log(response);
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
</script>
|
||||||
136
resources/views/prosespenawaran/js/editjs.blade.php
Normal file
136
resources/views/prosespenawaran/js/editjs.blade.php
Normal file
@@ -0,0 +1,136 @@
|
|||||||
|
@push('scripts')
|
||||||
|
@include('lpj::assetsku.includenya')
|
||||||
|
@include('lpj::prosespenawaran.js.editextjs')
|
||||||
|
<script type="module">
|
||||||
|
|
||||||
|
$(document).ready(function() {
|
||||||
|
prepareForm();
|
||||||
|
});
|
||||||
|
|
||||||
|
function prepareForm()
|
||||||
|
{
|
||||||
|
setData();
|
||||||
|
}
|
||||||
|
|
||||||
|
function setData()
|
||||||
|
{
|
||||||
|
let id = $("#id").val();
|
||||||
|
let token = "{{ csrf_token() }}";
|
||||||
|
// alert('token = ' + token);
|
||||||
|
var useURL = "{{ route('tender.prosespenawaran.setData') }}";
|
||||||
|
var input_data = new Object();
|
||||||
|
input_data._token = token;
|
||||||
|
input_data.id = id;
|
||||||
|
|
||||||
|
$.ajax({
|
||||||
|
url: useURL,
|
||||||
|
type: "POST",
|
||||||
|
data: input_data,
|
||||||
|
dataType: "json",
|
||||||
|
beforeSend: function() {
|
||||||
|
// if ($("#myLoader").hasClass("pre-loader hidden")) {
|
||||||
|
// pleaseStartLoader();
|
||||||
|
// }
|
||||||
|
},
|
||||||
|
success: function(response) {
|
||||||
|
console.log(response);
|
||||||
|
|
||||||
|
$("#textReg").text(response.penawaran.nomor_registrasi);
|
||||||
|
$("#textCodePenawaran").text(response.penawaran.code);
|
||||||
|
setTablesKJPP1(response.penawrandetails);
|
||||||
|
},
|
||||||
|
error: function(xhr) {
|
||||||
|
},
|
||||||
|
complete: function() {
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function setTablesKJPP1(datas)
|
||||||
|
{
|
||||||
|
let i=1;
|
||||||
|
$.each(datas, function(key, value){
|
||||||
|
var kjppName = value.kjpp_code+' - '+value.kjpp_name;
|
||||||
|
var biaya_penawaran = value.biaya_penawaran;// alert(biaya_penawaran);
|
||||||
|
var htmlDokumenPersetujuanDownload='';
|
||||||
|
var dokumenPersetujuanDownload = value.dokumen_persetujuan;
|
||||||
|
if(dokumenPersetujuanDownload)
|
||||||
|
{
|
||||||
|
htmlDokumenPersetujuanDownload='<div class="flex items-center justify-between flex-wrap my-2.5 gap-2"><a href="'+value.dokumen_persetujuan+'" class="badge badge-sm badge-outline" download="'+value.attachment+'">'+value.attachment+'<i class="ki-filled ki-cloud-download"></i></a></div>';
|
||||||
|
}
|
||||||
|
|
||||||
|
var markup = '<tr>';
|
||||||
|
markup +='<td valign="top">'+i+'</td>';
|
||||||
|
markup +='<td valign="top"><label id="{{$route[1]}}_kjppName_'+value.id+'">'+kjppName+'</label></td>';
|
||||||
|
markup +='<td valign="top"><div class="input-group"><span class="btn btn-input">Rp.</span><input type="text" disabled="" style="text-align: right;" onkeydown="return numbersonly(this, event);" onkeyup="javascript:tandaPemisahTitik(this);" class="inputku input" id="{{$route[1]}}_biayaPenawaran_'+value.id+'" name="{{$route[1]}}_biayaPenawaran_'+value.id+'"></div><em id="{{$route[1]}}_biayaPenawaran_msg_'+value.id+'" class="alert text-danger text-sm"></em></td>';
|
||||||
|
markup +='<td><input type="file" disabled="" class="inputku file-input" id="{{$route[1]}}_dokumenPersetujuan_'+value.id+'" name="{{$route[1]}}_dokumenPersetujuan_'+value.id+'" accept="application/pdf" /><em id="{{$route[1]}}_dokumenPersetujuan_msg_'+value.id+'" class="alert text-danger text-sm"></em>'+htmlDokumenPersetujuanDownload+'</td>';
|
||||||
|
markup +='<td><div class="flex flex-nowrap justify-center">';
|
||||||
|
markup +='<a disabled="" class="btn btn-sm btn-icon btn-clear btn-info" href="javascript:void(0)" id="{{$route[1]}}_icon_update_'+value.id+'" title="Proses Penawaran '+kjppName+'" onclick="updateData('+value.id+','+value.kjpp_rekanan_id+',\''+kjppName+'\')"><i class="ki-outline ki-notepad-edit"></i></a>';
|
||||||
|
markup +='<a disabled="" class="delete btn btn-sm btn-icon btn-clear btn-danger" id="{{$route[1]}}_icon_delete_'+value.id+'" onclick="deleteData('+value.id+')" title="Hapus Proses Penawaran '+kjppName+'"><i class="ki-outline ki-trash"></i></a>';
|
||||||
|
markup +='<label class="switch"><input name="{{$route[1]}}_check_'+value.id+'" id="{{$route[1]}}_check_'+value.id+'" onclick="switchProses('+value.id+')" type="checkbox" value="0"/><span class="switch-label">Proses</span></label></div></td>';
|
||||||
|
markup += '</tr>';
|
||||||
|
|
||||||
|
$('#tbodyKJPP1').append(markup);
|
||||||
|
$("#{{$route[1]}}_biayaPenawaran_"+value.id).val(tandaPemisahTitik(biaya_penawaran));
|
||||||
|
i++;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
$(document).on("input", "input:file", function(e) {
|
||||||
|
let fileName = e.target.files[0].name;
|
||||||
|
let inputFile = e.target.id;
|
||||||
|
const myArray = inputFile.split("_");
|
||||||
|
let penawaranID = myArray[myArray.length-1];
|
||||||
|
let kjppName = $("#{{$route[1]}}_kjppName_"+penawaranID).text();
|
||||||
|
let upld = fileName.split(".").pop();
|
||||||
|
if(upld == "pdf" || upld =="PDF"){}
|
||||||
|
else{
|
||||||
|
removeErrorCssMsg();
|
||||||
|
$("#{{$route[1]}}_dokumenPersetujuan_"+penawaranID).addClass(" border-danger");
|
||||||
|
$("#{{$route[1]}}_dokumenPersetujuan_msg_"+penawaranID).text("Silahkan Masukan tipe file PDF Mas");
|
||||||
|
$("#"+inputFile).val("");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// update penawaran & permohonan status
|
||||||
|
$("#{{$route[1]}}_toEdit").click(function(e) {
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
//define variable
|
||||||
|
let token = "{{ csrf_token() }}";
|
||||||
|
let useURL = "{{ route($route[0].'.'.$route[1].'.updateAll',$id) }}";
|
||||||
|
|
||||||
|
var input_data = new Object();
|
||||||
|
input_data._token = token;
|
||||||
|
input_data.id = "{{ $id }}";
|
||||||
|
$.ajax({
|
||||||
|
url: useURL,
|
||||||
|
type: "PUT",
|
||||||
|
cache: false,
|
||||||
|
data: input_data,
|
||||||
|
dataType: "json",
|
||||||
|
success: function(response) {
|
||||||
|
console.log(response);
|
||||||
|
if('success' == response.status)
|
||||||
|
{
|
||||||
|
toastr.success(response.message);
|
||||||
|
setTimeout(function () {
|
||||||
|
var url = "{{ route('tender.prosespenawaran.index') }}";
|
||||||
|
$(location).attr('href',url);
|
||||||
|
// window.location.href = "https://www.newurl.com";
|
||||||
|
}, 2000);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
toastr.error(_data.message);
|
||||||
|
|
||||||
|
},
|
||||||
|
error: function(response, textStatus, errorThrown) {
|
||||||
|
// var errors = response.responseJSON.errors;
|
||||||
|
// console.log(errors);
|
||||||
|
console.log(response);
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
@endpush
|
||||||
43
resources/views/prosespenawaran/show.blade.php
Normal file
43
resources/views/prosespenawaran/show.blade.php
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
@extends('layouts.main')
|
||||||
|
|
||||||
|
@section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render(request()->route()->getName()) }}
|
||||||
|
@endsection
|
||||||
|
@php
|
||||||
|
$route = explode('.', Route::currentRouteName());
|
||||||
|
@endphp
|
||||||
|
@section('content')
|
||||||
|
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
||||||
|
<div class="card pb-2.5">
|
||||||
|
<div class="card-header" id="basic_settings">
|
||||||
|
<h3 class="card-title">
|
||||||
|
Detail Data Proses Penawaran
|
||||||
|
</h3>
|
||||||
|
<div class="flex items-center gap-2">
|
||||||
|
<a href="{{ route('tender.prosespenawaran.edit', $id) }}" class="btn btn-xs btn-primary" title="Register"><i class="ki-filled ki-arrow-circle-right"></i> Proses Penawaran</a>
|
||||||
|
<a href="{{ route('tender.prosespenawaran.index') }}" class="btn btn-xs btn-info"><i class="ki-filled ki-exit-left"></i> Back</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="card-body lg:py-7.5 grid grid-cols-3">
|
||||||
|
<div class="mb-5">
|
||||||
|
<h3 class="text-md font-medium text-gray-900">
|
||||||
|
Nomor Register Permohonan:
|
||||||
|
</h3>
|
||||||
|
<span class="text-2sm text-gray-700">
|
||||||
|
{{ $prosespenawaran->nomor_registrasi }}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<div class="mb-5">
|
||||||
|
<h3 class="text-md font-medium text-gray-900">
|
||||||
|
Kode Penawaran:
|
||||||
|
</h3>
|
||||||
|
<span class="text-2sm text-gray-700">
|
||||||
|
{{ $prosespenawaran->code }}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
@endsection
|
||||||
@@ -64,7 +64,6 @@
|
|||||||
|
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script type="module">
|
@include('lpj::assetsku.includenya')
|
||||||
|
<script type="module">
|
||||||
|
|
||||||
$(document).ready(function() {
|
$(document).ready(function() {
|
||||||
prepareForm();
|
prepareForm();
|
||||||
});
|
});
|
||||||
@@ -72,7 +73,8 @@
|
|||||||
|
|
||||||
$('input[type=radio][name={{ $route[0] }}_tindakan]').change(function() {
|
$('input[type=radio][name={{ $route[0] }}_tindakan]').change(function() {
|
||||||
|
|
||||||
|
removeErrorCssMsg();
|
||||||
|
$("#{{ $route[0] }}_div_region").hide();
|
||||||
if($(this).val()==0)
|
if($(this).val()==0)
|
||||||
{
|
{
|
||||||
// show jenis pilihan
|
// show jenis pilihan
|
||||||
|
|||||||
@@ -66,7 +66,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -68,7 +68,6 @@
|
|||||||
|
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -62,7 +62,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -69,7 +69,6 @@
|
|||||||
@endsection
|
@endsection
|
||||||
|
|
||||||
@push('scripts')
|
@push('scripts')
|
||||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function deleteData(data) {
|
function deleteData(data) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
|
|||||||
@@ -370,7 +370,6 @@ Breadcrumbs::for('penilaian.assignment', function (BreadcrumbTrail $trail) {
|
|||||||
$trail->push('Assignment');
|
$trail->push('Assignment');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
Breadcrumbs::for('authorization.index', function (BreadcrumbTrail $trail) {
|
Breadcrumbs::for('authorization.index', function (BreadcrumbTrail $trail) {
|
||||||
$trail->push('Permohonan', route('authorization.index'));
|
$trail->push('Permohonan', route('authorization.index'));
|
||||||
});
|
});
|
||||||
@@ -450,6 +449,23 @@ Breadcrumbs::for('registrasi.show', function (BreadcrumbTrail $trail) {
|
|||||||
$trail->parent('registrasi');
|
$trail->parent('registrasi');
|
||||||
$trail->push('Detail Permohona');
|
$trail->push('Detail Permohona');
|
||||||
});
|
});
|
||||||
|
// andy add
|
||||||
|
// andy add 20241009
|
||||||
|
Breadcrumbs::for('tender.prosespenawaran', function (BreadcrumbTrail $trail) {
|
||||||
|
$trail->parent('tender');
|
||||||
|
$trail->push('Data Proses Penawaran', route('tender.prosespenawaran.index'));
|
||||||
|
});
|
||||||
|
|
||||||
|
Breadcrumbs::for('tender.prosespenawaran.edit', function (BreadcrumbTrail $trail) {
|
||||||
|
$trail->parent('tender.prosespenawaran');
|
||||||
|
$trail->push('Tambah Data Proses Penawaran');
|
||||||
|
});
|
||||||
|
|
||||||
|
Breadcrumbs::for('tender.prosespenawaran.show', function (BreadcrumbTrail $trail) {
|
||||||
|
$trail->parent('tender.prosespenawaran');
|
||||||
|
$trail->push('Detail Data Proses Penawaran');
|
||||||
|
});
|
||||||
|
// andy add 20241009
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Modules\Lpj\Http\Controllers\RegistrasiController;
|
use Modules\Lpj\Http\Controllers\RegistrasiController;
|
||||||
|
use Modules\Lpj\Http\Controllers\ProsesPenawaranController;
|
||||||
|
|
||||||
Route::middleware(['auth'])->group(function () {
|
Route::middleware(['auth'])->group(function () {
|
||||||
|
|
||||||
@@ -21,5 +22,28 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
|
|
||||||
});
|
});
|
||||||
// andy add
|
// andy add
|
||||||
|
|
||||||
|
|
||||||
|
Route::name('tender.')->prefix('tender')->group(function () {
|
||||||
|
|
||||||
|
// Proses Penawaran
|
||||||
|
Route::controller(ProsesPenawaranController::class)->group(function(){
|
||||||
|
|
||||||
|
Route::get('prosespenawaran', 'index')->name('prosespenawaran.index');
|
||||||
|
Route::get('prosespenawaran/datatables', 'dataForDatatables')->name('prosespenawaran.datatables');
|
||||||
|
Route::get('prosespenawaran/datatableskjppList_1', 'dataForDatatablesKJPPList_1')->name('prosespenawaran.datatableskjppList_1');
|
||||||
|
|
||||||
|
// show data
|
||||||
|
Route::get('/prosespenawaran/{prosespenawaran}', 'show')->name('prosespenawaran.show');
|
||||||
|
Route::post('prosespenawaran/setData', 'setData')->name('prosespenawaran.setData');
|
||||||
|
|
||||||
|
Route::get('prosespenawaran/{prosespenawaran}/edit', 'edit')->name('prosespenawaran.edit');
|
||||||
|
|
||||||
|
Route::put('/prosespenawaran/{prosespenawaran}', 'update')->name('prosespenawaran.update');
|
||||||
|
Route::put('/prosespenawaranAll/{prosespenawaran}', 'updateAll')->name('prosespenawaran.updateAll');
|
||||||
|
Route::put('/prosespenawaranStatusKJPP/{prosespenawaran}', 'updateStatusPenawaranKJPP')->name('prosespenawaran.updateStatusPenawaranKJPP');
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user