penggabungan feature proses penawaran dan feature proses penawaran ulang, dan terkait keinginan user

This commit is contained in:
Andy Chaerudin
2024-11-13 16:40:52 +07:00
27 changed files with 1850 additions and 403 deletions

View File

@@ -12,7 +12,7 @@
@section('content')
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
<!-- $id = penawaran.id -->
<input type="hidden" id="id" name="id" value="{{ $id }}">
<div class="card pb-2.5">
@@ -46,18 +46,34 @@
</label>
</div>
</div>
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
<label class="form-label max-w-56">
Tambah KJPP
</label>
<div class="flex flex-wrap items-baseline w-full">
<select class="select " style="width: 25.5em" name="select" id="{{$route[1]}}_kjpps">
<option value="0"> - Pilih KJPP - </option>
</select>&nbsp;&nbsp;
<button class="btn btn-primary" id="{{$route[1]}}_toAddKJPP">
Tambah
</button>
</div>
</div>
<!-- datatables -->
<div class="grid">
<div class="grid">
<form enctype="multipart/form-data" id="form_{{$route[1]}}">
<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">
<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 class="min-w-[80px]">KJPP</th>
<th>No Proposal</th>
<th>Tanggal Proposal</th>
<th>Biaya Penawaran</th>
<th>Upload Penawaran</th>
<th class="min-w-[50px] text-center">Action</th>
@@ -65,14 +81,18 @@
</thead>
<tbody id="tbodyKJPP1">
</tbody>
</table>
</table>
</div>
</div>
</div>
<!-- datatables -->
<div class="flex justify-end">
<button type="submit" class="btn btn-success" id="{{$route[1]}}_toEditDraft">
Simpan Draft
</form>
</button>&nbsp;&nbsp;
<button type="button" class="btn btn-primary" id="{{$route[1]}}_toEdit">
Save
Pengajuan Penawaran
</button>
</div>
</div>

View File

@@ -0,0 +1,159 @@
@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">
<!-- id ==> penawaran.id -->
<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 Ulang
</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 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">
<label class="card-title" id="textReg">
No. registrasi
</label>
</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">
<label class="card-title" id="textCodePenawaran">
Kode Penawaran
</label>
</span>
</div>
<div class="mb-5">
<h3 class="text-md font-medium text-gray-900">
Status Penawaran:
</h3>
<span class="text-2sm text-gray-700">
<label class="card-title" id="textStatusPenawaran">
Status
</label>
</span>
</div>
</div>
<!-- add kjpp -->
<div class="card-body grid gap-5">
<!-- datatables -->
<div class="grid">
<div class="card min-w-full">
<div class="card-header">
<h3 class="card-title">Tambah 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="min-w-[180px]">KJPP</th>
<th>No Proposal</th>
<th>Tanggal Proposal</th>
<th>Biaya Penawaran</th>
<th>Upload Penawaran</th>
<th class="min-w-[50px] text-center">Action</th>
</tr>
</thead>
<tbody id="tbodyKJPP0">
<tr>
<td valign="top">
<select class="inputku select " style="width: 25.5em" name="select" id="{{$route[1]}}_kjpps1">
<option value="0"> - Pilih KJPP - </option>
</select>
<em id="{{$route[1]}}_kjpp1_msg" class="alert text-danger text-sm"></em>
</td>
<td valign="top">
<input type="text" class="inputku file-input" id="{{$route[1]}}_no_proposal" name="{{$route[1]}}_no_proposal">
<em id="{{$route[1]}}_no_proposal_msg" class="alert text-danger text-sm"></em>
</td>
<td valign="top">
<input type="date" class="inputku file-input" id="{{$route[1]}}_tgl_proposal" name="{{$route[1]}}_tgl_proposal" >
<em id="{{$route[1]}}_tgl_proposal_msg" class="alert text-danger text-sm"></em>
</td>
<td valign="top">
<div class="input-group">
<span class="inputku btn btn-input" id="{{$route[1]}}_rp">Rp.</span>
<input type="text" style="text-align: right;" onkeydown="return numbersonly(this, event);" onkeyup="javascript:tandaPemisahTitik(this);" class="inputku input" id="{{$route[1]}}_biayaPenawaran" name="{{$route[1]}}_biayaPenawaran">
</div>
<em id="{{$route[1]}}_biayaPenawaran_msg" class="alert text-danger text-sm"></em>
</td>
<td valign="top">
<input type="file" class="inputku file-input" id="{{$route[1]}}_dokumenPersetujuan" name="{{$route[1]}}_dokumenPersetujuan" accept="application/pdf" />
<em id="{{$route[1]}}_dokumenPersetujuan_msg" class="alert text-danger text-sm"></em>
</td>
<td valign="top" class="min-w-[50px] text-center">
<div class="flex flex-nowrap justify-center">
<a class="btn btn-sm btn-icon btn-clear btn-info" href="javascript:void(0)" id="{{$route[1]}}_icon_update_'+value.id+'" title="Tambah KJPP" onclick="addDataUlang()"><i class="ki-outline ki-bookmark"></i></a>
</div>
</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
<!-- datatables -->
<div class="flex justify-end">
&nbsp;
</div>
</div>
<!-- add kjpp -->
<div class="card-body grid gap-5">
<!-- 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-[80px]">KJPP</th>
<th>No Proposal</th>
<th>Tanggal Proposal</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">
&nbsp;
</div>
</div>
</div>
</div>
@endsection
@include('lpj::prosespenawaran.js.editulangjs')

View File

@@ -149,10 +149,10 @@
return `${formatDate(new Date(data.start_date))} - ${formatDate(new Date(data.end_date))}`
}
},
tujuan_penilaian_k_j_p_p: {
tujuan_penilaian_kjpp: {
title: 'Tujuan Penilaian KJPP',
render: (item, data) => {
return data.tujuan_penilaian_k_j_p_p.name
return data.tujuan_penilaian_kjpp.name
}
},
penawarandetails_count: {
@@ -170,13 +170,25 @@
actions: {
title: 'Status',
render: (item, data) => {
// data.id ==> penawaran.id
var iconProses ='';
if('tender'==data.status)
{
iconProses=`<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>`;
}
else if('proposal-tender'==data.status)
{
iconProses=`<a class="btn btn-sm btn-icon btn-clear btn-info" title="Proses Penawaran Ulang" href="tender/prosespenawaran/${data.id}/editulang">
<i class="ki-outline ki-arrow-circle-right"></i>
</a>`;
}
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>
</a>`+iconProses+`
</div>`;
},
}

View File

@@ -0,0 +1,337 @@
<script tipe="module">
function switchProses(id)
{
removeErrorCssMsg();
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]}}_no_proposal_'+id).removeAttr('disabled');
$('#{{$route[1]}}_tgl_proposal_'+id).removeAttr('disabled');
$('#{{$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]}}_no_proposal_'+id).attr('disabled', 'disabled');
$('#{{$route[1]}}_tgl_proposal_'+id).attr('disabled', 'disabled');
$('#{{$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 updateDataUlang(id, kjpp_id, kjppName){
// id ==> detail_penawaran.id
removeErrorCssMsg();
let no_proposal = $("#{{$route[1]}}_no_proposal_"+id).val();
let tgl_proposal = $("#{{$route[1]}}_tgl_proposal_"+id).val();
let biaya = $("#{{$route[1]}}_biayaPenawaran_"+id).val();
let filepdf = $("#{{$route[1]}}_dokumenPersetujuan_"+id).val();
let passednih = true;
if(!no_proposal){
$("#{{$route[1]}}_no_proposal_"+id).addClass(" border-danger");
$("#{{$route[1]}}_no_proposal_msg_"+id).text("Silahkan isi No Proposal");
passednih = false;
}
if(!tgl_proposal){
$("#{{$route[1]}}_tgl_proposal_"+id).addClass(" border-danger");
$("#{{$route[1]}}_tgl_proposal_msg_"+id).text("Silahkan isi Tanggal Proposal");
passednih = false;
}
if(!biaya){
$("#{{$route[1]}}_rp_"+id).addClass(" border-danger");
$("#{{$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].'.updateulang', '') }}/"+id;
let formData = new FormData();
let token = "{{ csrf_token() }}";
formData.append("dokumen_persetujuan", file_data ?? "");
formData.append("no_proposal", no_proposal);
formData.append("tgl_proposal", tgl_proposal);
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);
// success
var message = response.message;
toastrku("success", message);
setTimeout(function () {
location.reload(true);
}, 2000);
}
else if('error' == response.status)
{
// toastr.error(response.message);
var message = response.message;
toastrku("error", message);
}
},
error: function (response, textStatus, errorThrown) {
var errors = response.responseJSON.errors;
$.each(errors, function (key, value) {
console.log("v = " + value);
});
}
});
}
}
function deleteData(data, kjppName) {
Swal.fire({
title: 'Are you sure?',
text: "You won't be able to revert KJPP "+kjppName+"!",
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].'.updateKJPPStatus','') }}/"+data;
var input_data = new Object();
input_data._token = token;
input_data.id =data;
input_data.kjppName =kjppName;
$.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.message_success[0], 'success').then(() => {
window.location.reload();
});
}
else
{
Swal.fire('Error!', response.message.message_error_try_catch[0], 'error');
}
},
error: function(response, textStatus, errorThrown) {
// var errors = response.responseJSON.errors;
// console.log(errors);
console.log(response);
}
});
}
})
}
function addDataUlang()
{
removeErrorCssMsg();
// id ==> penawaran.id
let id = $("#id").val();
let kjpp_id = $("#{{$route[1]}}_kjpps1").val();
let no_proposal = $("#{{$route[1]}}_no_proposal").val();
let tgl_proposal = $("#{{$route[1]}}_tgl_proposal").val();
let biaya = $("#{{$route[1]}}_biayaPenawaran").val();
let filepdf = $("#{{$route[1]}}_dokumenPersetujuan").val();
let passednih = true;
if("0"==kjpp_id){
$("#{{$route[1]}}_kjpps1").addClass(" border-danger");
$("#{{$route[1]}}_kjpp1_msg").text("Silahkan pilih KJPP");
passednih = false;
}
if(!no_proposal){
$("#{{$route[1]}}_no_proposal").addClass(" border-danger");
$("#{{$route[1]}}_no_proposal_msg").text("Silahkan isi No Proposal");
passednih = false;
}
if(!tgl_proposal){
$("#{{$route[1]}}_tgl_proposal").addClass(" border-danger");
$("#{{$route[1]}}_tgl_proposal_msg").text("Silahkan isi Tanggal Proposal");
passednih = false;
}
if(!biaya){
$("#{{$route[1]}}_rp").addClass(" border-danger");
$("#{{$route[1]}}_biayaPenawaran").addClass(" border-danger");
$("#{{$route[1]}}_biayaPenawaran_msg").text("Silahkan isi Biaya Penawaran");
passednih = false;
}
if(!filepdf){
$("#{{$route[1]}}_dokumenPersetujuan").addClass(" border-danger");
$("#{{$route[1]}}_dokumenPersetujuan_msg").text("Silahkan isi dokumen");
$("#{{$route[1]}}_dokumenPersetujuan").val("");
passednih = false;
}
if(passednih)
{
var file_data = $("#{{$route[1]}}_dokumenPersetujuan").prop("files")[0];
let useURL = "{{ route($route[0].'.'.$route[1].'.storeUlang') }}";
let formData = new FormData();
let token = "{{ csrf_token() }}";
formData.append("dokumen_persetujuan", file_data ?? "");
formData.append("penawaran_id", id);
formData.append("no_proposal", no_proposal);
formData.append("tgl_proposal", tgl_proposal);
formData.append("biaya_penawaran", biaya);
formData.append("kjpp_rekanan_id", kjpp_id);
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);
// success
var message = response.message;
toastrku("success", message);
setTimeout(function () {
location.reload(true);
}, 2000);
}
else if('error' == response.status)
{
// toastr.error(response.message);
var message = response.message;
toastrku("error", message);
}
},
error: function (response, textStatus, errorThrown) {
var errors = response.responseJSON.errors;
$.each(errors, function (key, value) {
console.log("v = " + value);
});
}
});
}
}
function deleteDataUlang(data, kjppName) {
Swal.fire({
title: 'Are you sure?',
text: "You won't be able to revert KJPP "+kjppName+"!",
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].'.updateKJPPStatusUlang','') }}/"+data;
var input_data = new Object();
input_data._token = token;
input_data.id =data;
input_data.kjppName =kjppName;
$.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.message_success[0], 'success').then(() => {
window.location.reload();
});
}
else
{
var arr =response.message; // JSON Object
const keyToCheck1 = "active_date_range";
const keyToCheck2 = "message_error_try_catch";
const exists1 = keyToCheck1 in arr;
const exists2 = keyToCheck2 in arr;
if(exists1)
{
Swal.fire('Error!', response.message.active_date_range[0], 'error').then(() => {
// window.location.reload();
setTimeout(function () {
var url = "{{ route('tender.prosespenawaran.index') }}";
$(location).attr('href',url);
}, 2000);
});
}
else if(exists2)
{
Swal.fire('Error!', response.message.message_error_try_catch[0], 'error').then(() => {
window.location.reload();
});
}
}
},
error: function(response, textStatus, errorThrown) {
// var errors = response.responseJSON.errors;
// console.log(errors);
console.log(response);
}
});
}
})
}
</script>

View File

@@ -35,21 +35,11 @@
function updateData(id, kjpp_id, kjppName){
removeErrorCssMsg();
let no_proposal = $("#{{$route[1]}}_no_proposal_"+id).val();
let tgl_proposal = $("#{{$route[1]}}_tgl_proposal_"+id).val();
let biaya = $("#{{$route[1]}}_biayaPenawaran_"+id).val();
let filepdf = $("#{{$route[1]}}_dokumenPersetujuan_"+id).val();
let passednih = true;
if(!biaya){
$("#{{$route[1]}}_rp_"+id).addClass(" border-danger");
$("#{{$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)
{
@@ -58,7 +48,9 @@
let formData = new FormData();
let token = "{{ csrf_token() }}";
formData.append("dokumen_persetujuan", file_data ?? "");
formData.append("biaya_penawaran", biaya);
formData.append("no_proposal", no_proposal);
formData.append("tgl_proposal", tgl_proposal);
formData.append("biaya_penawaran", biaya);
formData.append("kjpp_rekanan_id", kjpp_id);
formData.append("_method", "PUT");
formData.append("_token", token);
@@ -149,7 +141,5 @@
}
})
}
}
</script>

View File

@@ -39,6 +39,7 @@
$("#textReg").text(response.penawaran.nomor_registrasi);
$("#textCodePenawaran").text(response.penawaran.code);
setTablesKJPP1(response.penawrandetails);
setKJPPList(response.kjpps);
}
else if('error' == response.status)
{
@@ -53,28 +54,64 @@
});
}
function setKJPPList(datas)
{
$('#{{$route[1]}}_kjpps').empty().append('<option value="0"> - Pilih KJPP - </option>');
$.each(datas, function(key, value){
var stringVal = value.code+' - '+value.name;
$('#{{$route[1]}}_kjpps').append(new Option(stringVal, value.id));
});
}
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 no_proposal = (value.no_proposal)??'';// alert(no_proposal);
var tgl_proposal = (value.tgl_proposal)??'';// alert(tgl_proposal);
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>';
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+' &nbsp;<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="inputku btn btn-input" id="{{$route[1]}}_rp_'+value.id+'">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-bookmark"></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+',\''+kjppName+'\')" 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>';
// No Proposal
markup +='<td valign="top">';
markup +='<input type="hidden" id="{{$route[1]}}_penawarandetail_id_'+value.id+'" name="{{$route[1]}}_penawarandetail_id[]" value="'+value.id+'">';
markup +='<input type="text" value="'+no_proposal+'" class="inputku file-input" id="{{$route[1]}}_no_proposal_'+value.id+'" name="{{$route[1]}}_no_proposal[]">';
markup +='<em id="{{$route[1]}}_no_proposal_msg_'+value.id+'" class="alert text-danger text-sm"></em>';
markup +='</td>';
// No Proposal
// Tanggal Proposal
markup +='<td valign="top">';
markup +='<input type="date" value="'+tgl_proposal+'" class="inputku file-input" id="{{$route[1]}}_tgl_proposal_'+value.id+'" name="{{$route[1]}}_tgl_proposal[]" >';
markup +='<em id="{{$route[1]}}_tgl_proposal_msg_'+value.id+'" class="alert text-danger text-sm"></em>';
markup +='</td>';
// Tanggal Proposal
// Biaya Penawaran
markup +='<td valign="top">';
markup +='<div class="input-group"><span class="inputku btn btn-input" id="{{$route[1]}}_rp_'+value.id+'">Rp.</span><input type="text" 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[]"></div>';
markup +='<em id="{{$route[1]}}_biayaPenawaran_msg_'+value.id+'" class="alert text-danger text-sm"></em>';
markup +='</td>';
// Biaya Penawaran
// Upload Penawaran
markup +='<td valign="top">';
markup +='<input type="file" class="inputku file-input" id="{{$route[1]}}_dokumenPersetujuan_'+value.id+'" name="{{$route[1]}}_dokumenPersetujuan[]" accept="application/pdf" />';
markup +='<em id="{{$route[1]}}_dokumenPersetujuan_msg_'+value.id+'" class="alert text-danger text-sm"></em>'+htmlDokumenPersetujuanDownload;
markup +='</td>';
// Upload Penawaran
markup +='<td valign="top"><div class="flex flex-nowrap justify-center">';
markup +='<a 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-bookmark"></i></a>';
markup +='<a class="delete btn btn-sm btn-icon btn-clear btn-danger" id="{{$route[1]}}_icon_delete_'+value.id+'" onclick="deleteData('+value.id+',\''+kjppName+'\')" title="Hapus Proses Penawaran '+kjppName+'"><i class="ki-outline ki-trash"></i></a>';
markup +='</div></td>';
markup += '</tr>';
$('#tbodyKJPP1').append(markup);
@@ -84,10 +121,11 @@
if(biaya_penawaran)
biaya_penawaran_format=tandaPemisahTitik(biaya_penawaran);
$("#{{$route[1]}}_biayaPenawaran_"+value.id).val(biaya_penawaran_format);
i++;
});
}
$(document).on("input", "input:file", function(e) {
let fileName = e.target.files[0].name;
let inputFile = e.target.id;
@@ -107,7 +145,7 @@
// updateAll penawaran & permohonan status
$("#{{$route[1]}}_toEdit").click(function(e) {
e.preventDefault();
// $id = penawaran.id
//define variable
let token = "{{ csrf_token() }}";
let useURL = "{{ route($route[0].'.'.$route[1].'.updateAll',$id) }}";
@@ -150,5 +188,106 @@
});
});
$('#form_{{$route[1]}}').submit(function(e) {
e.preventDefault();
var formData = new FormData(this);
//define variable
let token = "{{ csrf_token() }}";
let useURL = "{{ route($route[0].'.'.$route[1].'.updateDraft',$id) }}";
formData.append('_token', token);
formData.append('_method', 'PUT');
$.ajax({
url: useURL,
type: "POST",
data: formData,
cache: false,
processData: false,
contentType: false,
success: function(response) {
console.log(response);
if ('success' == response.status)
{
// toastr.success(response.message);
// success
var message = response.message;
toastrku("success", message);
setTimeout(function () {
location.reload(true);
}, 2000);
//
}
else if('error' == response.status)
{
var message = response.message;
toastrku("error", message);
}
},
error: function(response, textStatus, errorThrown) {
// var errors = response.responseJSON.errors;
// console.log(errors);
console.log(response);
}
});
});
$("#{{$route[1]}}_toAddKJPP").click(function(e) {
e.preventDefault();
let kjpp_id = $("#{{$route[1]}}_kjpps").val();
let id = $("#id").val();
let token = "{{ csrf_token() }}";
let useURL = "{{ route($route[0].'.'.$route[1].'.store') }}";
var input_data = new Object();
input_data._token= token;
input_data.kjpp_id= kjpp_id;
input_data.penawaran_id= id;
if(kjpp_id>0)
{
$.ajax({
url: useURL,
type: "POST",
cache: false,
data: input_data,
success:function(response){
if ('success' == response.status)
{
// toastr.success(response.message);
// success
var message = response.message;
toastrku("success", message);
setTimeout(function () {
location.reload(true);
}, 2000);
}
else if('error' == response.status)
{
var message = response.message;
toastrku("error", message);
}
},
error: function (response, textStatus, errorThrown) {
console.log(response);
}
});
}
else
{
swal.fire({
title: "Perhatikan",
text: "Silahkan pilih KJPP terlebih dahulu",
icon: "error"
});
}
});
</script>
@endpush
@endpush

View File

@@ -0,0 +1,151 @@
@push('scripts')
@include('lpj::assetsku.includenya')
@include('lpj::prosespenawaran.js.editeulangxtjs')
<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.setDataUlang') }}";
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);
if("success"==response.status)
{
var statusText = response.penawaran.status;
$("#textReg").text(response.penawaran.nomor_registrasi);
$("#textCodePenawaran").text(response.penawaran.code);
$("#textStatusPenawaran").text(statusText);
setTablesKJPP1(response.penawrandetails);
setKJPPList1(response.kjpps);
}
else
{
// toastr.error(response.message);
var message = response.message;
toastrku("error", message);
}
},
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 no_proposal = (value.no_proposal)??'';// alert(no_proposal);
var tgl_proposal = (value.tgl_proposal)??'';// alert(tgl_proposal);
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+' &nbsp;<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>';
// No Proposal
markup +='<td valign="top">';
markup +='<input type="hidden" id="{{$route[1]}}_penawarandetail_id_'+value.id+'" name="{{$route[1]}}_penawarandetail_id[]" value="'+value.id+'">';
markup +='<input disabled="" type="text" value="'+no_proposal+'" class="inputku file-input" id="{{$route[1]}}_no_proposal_'+value.id+'" name="{{$route[1]}}_no_proposal[]">';
markup +='<em id="{{$route[1]}}_no_proposal_msg_'+value.id+'" class="alert text-danger text-sm"></em>';
markup +='</td>';
// No Proposal
// Tanggal Proposal
markup +='<td valign="top">';
markup +='<input disabled="" type="date" value="'+tgl_proposal+'" class="inputku file-input" id="{{$route[1]}}_tgl_proposal_'+value.id+'" name="{{$route[1]}}_tgl_proposal[]" >';
markup +='<em id="{{$route[1]}}_tgl_proposal_msg_'+value.id+'" class="alert text-danger text-sm"></em>';
markup +='</td>';
// Tanggal Proposal
// Biaya Penawaran
markup +='<td valign="top">';
markup +='<div class="input-group"><span class="inputku btn btn-input" id="{{$route[1]}}_rp_'+value.id+'">Rp.</span><input disabled="" type="text" 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[]"></div>';
markup +='<em id="{{$route[1]}}_biayaPenawaran_msg_'+value.id+'" class="alert text-danger text-sm"></em>';
markup +='</td>';
// Biaya Penawaran
// Upload Penawaran
markup +='<td valign="top">';
markup +='<input disabled="" type="file" class="inputku file-input" id="{{$route[1]}}_dokumenPersetujuan_'+value.id+'" name="{{$route[1]}}_dokumenPersetujuan[]" accept="application/pdf" />';
markup +='<em id="{{$route[1]}}_dokumenPersetujuan_msg_'+value.id+'" class="alert text-danger text-sm"></em>'+htmlDokumenPersetujuanDownload;
markup +='</td>';
// Upload Penawaran
markup +='<td valign="top"><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="updateDataUlang('+value.id+','+value.kjpp_rekanan_id+',\''+kjppName+'\')"><i class="ki-outline ki-bookmark"></i></a>';
markup +='<a disabled="" class="delete btn btn-sm btn-icon btn-clear btn-danger" id="{{$route[1]}}_icon_delete_'+value.id+'" onclick="deleteDataUlang('+value.id+',\''+kjppName+'\')" 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>';
markup +='</div></td>';
markup += '</tr>';
$('#tbodyKJPP1').append(markup);
// pengecekan kondisi format number
var biaya_penawaran_format = "";
if(biaya_penawaran)
biaya_penawaran_format=tandaPemisahTitik(biaya_penawaran);
$("#{{$route[1]}}_biayaPenawaran_"+value.id).val(biaya_penawaran_format);
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("");
}
});
function setKJPPList1(datas)
{
$('#{{$route[1]}}_kjpps1').empty().append('<option value="0"> - Pilih KJPP - </option>');
$.each(datas, function(key, value){
var stringVal = value.code+' - '+value.name;
$('#{{$route[1]}}_kjpps1').append(new Option(stringVal, value.id));
});
}
</script>
@endpush

View File

@@ -14,7 +14,18 @@
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>
@php
$buttonProses='';
if('tender'==$prosespenawaran->status)
{
$buttonProses='<a href="'. route('tender.prosespenawaran.edit', $id) .'" class="btn btn-xs btn-primary" title="Proses Penawaran"><i class="ki-outline ki-notepad-edit"></i> Proses Penawaran</a>';
}
elseif ('proposal-tender'==$prosespenawaran->status)
{
$buttonProses='<a href="'. route('tender.prosespenawaran.editulang', $id) .'" class="btn btn-xs btn-primary" title="Proses Penawaran Ulang"><i class="ki-filled ki-arrow-circle-right"></i> Proses Penawaran Ulang</a>';
}
@endphp
{!! $buttonProses !!}
<a href="{{ route('tender.prosespenawaran.index') }}" class="btn btn-xs btn-info"><i class="ki-filled ki-exit-left"></i> Back</a>
</div>
</div>