Initial commit

This commit is contained in:
meusinfirmary
2025-04-22 14:33:37 +07:00
commit b9891d2f81
1305 changed files with 452033 additions and 0 deletions

View File

@ -0,0 +1,142 @@
@extends('app.app')
@section('title')
Finance - Dana
@endsection
@section('content')
<div class="container-fluid">
<div class="content">
<div class="row">
<div class="col-sm-12 col-md-6">
<div class="card">
<div class="card-body">
<p class="text-dark text-bold mb-2">Konfigurasi Dana</p>
<p class="mb-2 border-bottom"></p>
<form id="formDanaUpdt">
<div class="form-group mb-3 d-none">
<label for="dana_id" class="form-label">Saldo Dana <span class="text-danger">*</span></label>
<input type="number" id="dana_id" name="dana_id" class="form-control" value="{{ $dana->id }}" required />
</div>
<div class="form-group mb-3">
<label for="amt" class="form-label">Saldo Dana <span class="text-danger">*</span></label>
<input type="text" id="amt" name="amt" class="form-control" value="{{ $dana->amt }}" required />
</div>
<div class="form-group mb-3 text-end">
<button type="button" id="btnUpdtDana" class="btn btn-sm btn-primary">Simpan</button>
<div id="btnUpdtDanaSpinner" class="d-none">
<div class="spinner-border" role="status">
<span class="visually-hidden">Loading...</span>
</div>
</div>
</div>
</form>
</div>
</div>
</div>
</div>
</div>
</div>
@endsection
@section('customjs')
<script>
'use strict'
const State = {
delay_type_number: 1000,
storage_lara: "{{ asset('storage') }}/",
file_jimp_worker: "{{ asset('assets/js/worker/jimp.js') }}",
};
const Wrapper = {
activate: function() {
DanaUpdt.activate();
},
};
const DanaUpdt = {
activate: function() {
DanaUpdt.event();
},
event: function() {
$('#btnUpdtDana').on('click', async function(e) {
e.preventDefault();
const data = DanaUpdt.getData();
if (!DanaUpdt.checkData(data, true)) return false;
DanaUpdt.submitData(data);
});
// input
$('#amt').on('keyup', function() {
let price = $('#amt').val().split('.').join('');
$('#amt').val((new Intl.NumberFormat('id-ID')).format(price));
});
},
getData: function(props) {
const data = Helper.objectifyForm($('#formDanaUpdt').serializeArray());
data.amt = $('#amt').val().split('.').join('');
return data;
},
checkData: function(data, isAlert = false) {
if (data.amt.length < 4) {
if (isAlert) Helper.toast('Warning', 'just now', 'Saldo Dana wajib diisi');
return false;
}
return true;
},
submitData: async function(data) {
return new Promise((resolve, reject) => {
if (typeof $('#btnUpdtDana').attr('disabed') != 'undefined') {
resolve({
type: 'fail'
});
return false;
}
$('#btnUpdtDana').attr('disabed', true);
$('#btnUpdtDanaSpinner').removeClass('d-none');
$.ajax({
url: "{{ route('api_edit_dana', '') }}/" + data.dana_id,
method: 'PUT',
crossDomain: true,
processData: true,
headers: {
'x-api-key': Helper.getCookie('_trtk'),
'x-csrf-token': $('meta[name="csrf-token"]').attr('content'),
},
data,
success: (data, textStatus, jqXHR) => {
$('#btnUpdtDana').removeAttr('disabed');
$('#btnUpdtDanaSpinner').addClass('d-none');
if (data.meta.type != 'success') {
resolve({
type: 'fail'
});
Helper.toast('Warning', 'just now', data.meta.message);
return false;
}
resolve({
type: 'success'
});
Helper.toast('Success', 'sukses update saldo', data.meta.message);
},
error: (jqXHR, textStatus, error) => {
$('#btnUpdtDana').removeAttr('disabed');
$('#btnUpdtDanaSpinner').addClass('d-none');
if (jqXHR.status >= 500) {
Helper.toast('Error', 'just now', 'Please try again');
} else {
Helper.toast('Error', 'just now', jqXHR.responseJSON.meta
.message);
}
resolve({
type: 'error'
});
}
})
})
},
}
Wrapper.activate();
</script>
@endsection

View File

@ -0,0 +1,491 @@
<?php
// https://stackoverflow.com/questions/1328036/php-date-in-foreign-languages-e-g-mar-25-ao%C3%BB-09
// https://www.educative.io/edpresso/how-to-change-the-timezone-in-a-laravel-application
// https://stackoverflow.com/questions/22059495/strftime-for-indonesia-locale
// https://askubuntu.com/questions/76013/how-do-i-add-locale-to-ubuntu-server
setlocale(LC_TIME, 'id_ID.UTF8', 'id_ID.UTF-8', 'id_ID.8859-1', 'id_ID', 'IND.UTF8', 'IND.UTF-8', 'IND.8859-1', 'IND', 'Indonesian.UTF8', 'Indonesian.UTF-8', 'Indonesian.8859-1', 'Indonesian', 'Indonesia', 'id', 'ID', 'en_US.UTF8', 'en_US.UTF-8', 'en_US.8859-1', 'en_US', 'American', 'ENG', 'English');
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>INVOICE #{{ $ord_invc->code }}</title>
<link href="{{ base_path() . '/public/assets/vendor/bootstrap-5.0.2-dist/css/bootstrap.css' }}" rel="stylesheet">
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<style>
@page {
margin: 0;
}
@import url('https://fonts.googleapis.com/css2?family=Poppins&display=swap');
/* devanagari */
* {
/* margin: 0; */
/* line-height: 1.2; */
line-height: 0.8;
color: #000;
}
/* html { margin: 0} */
body {
font-weight: 400;
margin: 1cm 1.3cm 1cm 1.3cm;
font-family: 'Poppins';
}
.table-border-dark th,
.table-border-dark td,
{
border: 1px solid #000;
}
.table-border-none th,
.table-border-none td,
{
border: 0 solid #000;
}
.table-padding-paragraph td {
padding: 0.25rem 0.35rem;
}
.table-padding-paragraph2 td {
padding: 0.25rem;
}
.table-padding-vertical td {
padding: 0.25rem 0;
}
.word-break {
word-wrap: break-word;
overflow-wrap: break-word;
}
.page-break {
page-break-after: always;
}
strong {
font-weight: 1000;
}
.general-photo {
max-width: 600px;
max-height: 400px;
}
.dynamic-photo {
max-width: 80%;
max-height: 40%;
}
.mx-garis-tepi {
margin-left: 3.5rem;
margin-right: 3.5rem;
}
.ol-without-left {
padding-left: 1.5em;
}
</style>
</head>
<body>
<table class="table mb-4">
<tbody>
<tr>
<td class="">
{{-- <img src="{{ base_path() . '/public/images/bonceng-red.png' }}" --}}
{{-- alt="PT. BONCENG INDONESIA" style="width:150px; height:40px; margin:0 1rem 0 0;"></td> --}}
<img src="{{ base_path() . '/public/images/logo-bonceng-big.png' }}"
alt="PT. BONCENG INDONESIA" style="width:150px; height:45px; margin:0 1rem 0 0;">
</td>
<td class="text-start" style="padding-left:0;">
{{-- padding-left:345px; --}}
<p class="mb-1 text-end"><strong>PT. BONCENG INDONESIA</strong></p>
{{-- <p class="mb-1 text-end">{{ implode(str_split(''.env('BINGCORP_PHONE'), 4), ' ') }}</p> --}}
<p class="mb-0 text-end" style="font-size:10px;">{{ substr(env('BINGCORP_ADDR'), 0, 37) }}</p>
<p class="mb-1 text-end" style="font-size:10px;">{{ substr(env('BINGCORP_ADDR'), 39) }}</p>
<p class="mb-1 text-end" style="color:#0d6efd;text-decoration:underline;">{{ env('BINGCORP_WEB') }}</p>
</td>
</tr>
</tbody>
</table>
<div class="mb-4" style="text-align: center;">
<p style="font-size: 18px;">
{{-- <strong>INVOICE #{{ $order->ord_code }}</strong> --}}
{{-- <strong>INVOICE #{{ $ord_invc->code }}</strong> --}}
<strong>INVOICE</strong>
</p>
</div>
<div class="" style="margin-bottom: 1rem; font-size: 12px;">
<table class="table table-border-dark table-padding-paragraph mb-3">
<tbody>
<tr>
<td style="width:65%;">
<p class="mb-1">Kepada</p>
<p class="mb-1"><strong>{{ $order->c_pt_name }}</strong></p>
<p style="margin-bottom: 1rem;">{{ $order->c_pt_addr }}</p>
<p class="mb-1">U.P: {{ $order->c_pt_pic_name.' ( '.implode(str_split('0'.$order->c_pt_pic_phone_val, 4), ' ').' )' }}</p>
</td>
<td style="width:35%;">
<table class="table table-border-none table-padding-vertical mx-0 my-0">
<tr>
<td class="text-start">Tanggal Invoice</td>
<td class="text-end">{{ date('d-m-Y', $ord_invc->invc_at) }}</td>
</tr>
{{-- <tr>
<td class="text-start">Tanggal Pengiriman</td>
<td class="text-end">{{ date('d-m-Y', $order->set_pck_at) }}</td>
</tr> --}}
<tr>
<td class="text-start">Jatuh Tempo</td>
<td class="text-end">{{ date('d-m-Y', strtotime('+30 day', $ord_invc->invc_at)) }}</td>
</tr>
</table>
{{-- <p style="margin-bottom: 0.5rem;">Tanggal Invoice &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; {{ date('d-m-Y', $ord_invc->invc_at) }}</p>
<p style="margin-bottom: 0.5rem;">Tanggal Pengiriman &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; {{ date('d-m-Y', $order->set_pck_at) }}</p> --}}
<br>
<p class="mb-1">No Invoice</p>
<p class="mb-0" style="font-size: 18px;"><strong>{{ $ord_invc->code }}</strong></p>
</td>
</tr>
</tbody>
</table>
</div>
<div class="" style="margin-bottom: 1rem; font-size: 12px;">
<p class="mb-1"><strong>Informasi Order</strong></p>
<table class="table table-border-dark table-padding-paragraph2 mb-3">
<tbody>
<tr>
<td class="text-center" style="vertical-align: middle;">#</td>
<td style="vertical-align: middle;">Item</td>
<td class="text-center" style="vertical-align: middle;">Jumlah</td>
<td class="text-center" style="vertical-align: middle;">Satuan</td>
<td class="text-center" style="vertical-align: middle;">Harga (Rp)</td>
<td class="text-center" style="vertical-align: middle;">Total (Rp)</td>
</tr>
@foreach ($items as $i => $item)
<tr>
<td class="text-center" style="vertical-align: top;">{{ $i + 1 }}</td>
<td style="vertical-align: top;">{!! $item->desc !!}</td>
<td class="text-end" style="vertical-align: top;">{{ $item->unit_qty }}</td>
<td style="vertical-align: top;">{{ $item->unit_type_name }}</td>
<td class="text-end" style="vertical-align: top;">
@if ($ord_invc->amt_tax_type_kind === App\Models\OrdersAItems::AMT_TAX_TYPE_INCLUDE)
{{ number_format($item->amt_bill_total_tax_flat, 0, ',', '.') }}
@else
{{ number_format($item->amt_bill_base_flat, 0, ',', '.') }}
@endif
</td>
<td class="text-end" style="vertical-align: top;">{{ number_format($item->amt_bill_total_flat, 0, ',', '.') }}</td>
</tr>
@endforeach
@if ($ord_invc->amt_tax_type_kind === App\Models\OrdersAItems::AMT_TAX_TYPE_INCLUDE)
<tr>
<td colspan="5" class="text-end" style="border-bottom:0;border-right:1;"><strong>Sub Total</strong></td>
{{-- jika ppn pph minus --}}
{{-- <td class="text-end" style="border-bottom:0;border-left:1;"><strong>{{ number_format($ord_invc->amt_base_flat + $ord_invc->amt_tax_ppn_flat + $ord_invc->amt_tax_pph_flat, 0, ',', '.') }}</strong></td> --}}
{{-- jika ppn pph positif --}}
{{-- <td class="text-end"><strong>{{ number_format($ord_invc->amt_base_flat - $ord_invc->amt_tax_ppn_flat - $ord_invc->amt_tax_pph_flat, 0, ',', '.') }}</strong></td> --}}
{{-- normal --}}
<td class="text-end" style="border-bottom:0; border-left:1;"><strong>{{ number_format($ord_invc->amt_base_flat, 0, ',', '.') }}</strong></td>
</tr>
<tr>
@if ($ord_invc->amt_disc_flat != 0)
@if ($ord_invc->amt_disc_type === \App\Models\OrdersInvoices::AMT_TYPE_FLAT)
<td colspan="5" class="text-end" style="border-top:0; border-right:1; border-bottom:0;"><strong>Diskon</strong></td>
<td class="text-end" style="border-top:0; border-left:1; border-bottom:0;"><strong>{{ '-'.number_format($ord_invc->amt_disc_flat, 0, ',', '.') }}</strong></td>
@else
<td colspan="5" class="text-end" style="border-top:0; border-right:1; border-bottom:0;"><strong>Diskon ({{ $ord_invc->amt_disc_percent }}%)</strong></td>
<td class="text-end" style="border-top:0; border-left:1; border-bottom:0;"><strong>{{ '-'.number_format($ord_invc->amt_disc_flat, 0, ',', '.') }}</strong></td>
@endif
@else
<td colspan="5" class="text-end" style="border-top:0; border-right:1; border-bottom:0;"><strong>Diskon</strong></td>
<td class="text-end" style="border-top:0; border-left:1; border-bottom:0;"><strong>0</strong></td>
@endif
</tr>
<tr>
<td colspan="5" class="text-end" style="border-top:0; border-right:1; border-bottom:0;"><strong>PPN ({{ $ord_invc->amt_tax_ppn_percent }}%)</strong></td>
<td class="text-end" style="border-top:0; border-left:1; border-bottom:0;"><strong>{{ number_format($ord_invc->amt_tax_ppn_flat, 0, ',', '.') }}</strong></td>
</tr>
@if ($ord_invc->amt_tax_pph_percent > 0)
<tr>
<td colspan="5" class="text-end" style="border-top:0; border-right:1; border-bottom:0;"><strong>PPH ({{ $ord_invc->amt_tax_pph_percent }}%)</strong></td>
<td class="text-end" style="border-top:0; border-left:1; border-bottom:0;"><strong>{{ number_format(-1*$ord_invc->amt_tax_pph_flat, 0, ',', '.') }}</strong></td>
</tr>
@endif
{{-- <tr>
<td colspan="5" class="text-end"><strong>Sebelum Pajak</strong></td>
<td class="text-end"><strong>{{ number_format($ord_invc->amt_base_flat-$ord_invc->amt_tax_ppn_flat-$ord_invc->amt_tax_pph_flat, 0, ',', '.') }}</strong></td>
</tr> --}}
@elseif ($ord_invc->amt_tax_type_kind === App\Models\OrdersAItems::AMT_TAX_TYPE_EXCLUDE)
<tr>
<td colspan="5" class="text-end" style="border-bottom:0; border-right:1;"><strong>Sub Total</strong></td>
<td class="text-end" style="border-bottom:0; border-left:1;"><strong>{{ number_format($ord_invc->amt_base_flat, 0, ',', '.') }}</strong></td>
</tr>
<tr>
@if ($ord_invc->amt_disc_flat != 0)
@if ($ord_invc->amt_disc_type === \App\Models\OrdersInvoices::AMT_TYPE_FLAT)
<td colspan="5" class="text-end" style="border-top:0; border-right:1; border-bottom:0;"><strong>Diskon</strong></td>
<td class="text-end" style="border-top:0; border-left:1; border-bottom:0;"><strong>{{ '-'.number_format($ord_invc->amt_disc_flat, 0, ',', '.') }}</strong></td>
@else
<td colspan="5" class="text-end" style="border-top:0; border-right:1; border-bottom:0;"><strong>Diskon ({{ $ord_invc->amt_disc_percent }}%)</strong></td>
<td class="text-end" style="border-top:0; border-left:1; border-bottom:0;"><strong>{{ '-'.number_format($ord_invc->amt_disc_flat, 0, ',', '.') }}</strong></td>
@endif
@else
<td colspan="5" class="text-end" style="border-top:0; border-right:1; border-bottom:0;"><strong>Diskon</strong></td>
<td class="text-end" style="border-top:0; border-left:1; border-bottom:0;"><strong>0</strong></td>
@endif
</tr>
{{-- <tr>
<td colspan="5" class="text-end"><strong>Setelah Diskon</strong></td>
<td class="text-end"><strong>{{ number_format($ord_invc->amt_base_flat-$ord_invc->amt_disc_flat, 0, ',', '.') }}</strong></td>
</tr> --}}
<tr>
<td colspan="5" class="text-end" style="border-top:0; border-right:1; border-bottom:0;"><strong>PPN ({{ $ord_invc->amt_tax_ppn_percent }}%)</strong></td>
<td class="text-end" style="border-top:0; border-left:1; border-bottom:0;"><strong>{{ number_format($ord_invc->amt_tax_ppn_flat, 0, ',', '.') }}</strong></td>
</tr>
@if ($ord_invc->amt_tax_pph_percent > 0)
<tr>
<td colspan="5" class="text-end" style="border-top:0; border-right:1; border-bottom:0;"><strong>PPH ({{ $ord_invc->amt_tax_pph_percent }}%)</strong></td>
<td class="text-end" style="border-top:0; border-left:1; border-bottom:0;"><strong>{{ number_format($ord_invc->amt_tax_pph_flat, 0, ',', '.') }}</strong></td>
</tr>
@endif
@else
<tr>
<td colspan="5" class="text-end" style="border-bottom:0; border-right:1;"><strong>Sub Total</strong></td>
<td class="text-end" style="border-bottom:0; border-left:1;"><strong>{{ number_format($ord_invc->amt_base_flat, 0, ',', '.') }}</strong></td>
</tr>
<tr>
@if ($ord_invc->amt_disc_flat != 0)
@if ($ord_invc->amt_disc_type === \App\Models\OrdersInvoices::AMT_TYPE_FLAT)
<td colspan="5" class="text-end" style="border-top:0; border-right:1; border-bottom:0;"><strong>Diskon</strong></td>
<td class="text-end" style="border-top:0; border-left:1; border-bottom:0;"><strong>{{ '-'.number_format($ord_invc->amt_disc_flat, 0, ',', '.') }}</strong></td>
@else
<td colspan="5" class="text-end" style="border-top:0; border-right:1; border-bottom:0;"><strong>Diskon ({{ $ord_invc->amt_disc_percent }}%)</strong></td>
<td class="text-end" style="border-top:0; border-left:1; border-bottom:0;"><strong>{{ '-'.number_format($ord_invc->amt_disc_flat, 0, ',', '.') }}</strong></td>
@endif
@else
<td colspan="5" class="text-end" style="border-top:0; border-right:1; border-bottom:0;"><strong>Diskon</strong></td>
<td class="text-end" style="border-top:0; border-left:1; border-bottom:0;"><strong>0</strong></td>
@endif
</tr>
@endif
<tr>
<td colspan="5" class="text-end" style="border-top:0; border-right:1;"><strong>Total</strong></td>
<td class="text-end" style="border-top:0; border-left:1;"><strong>
@if ($ord_invc->amt_tax_type_kind === App\Models\OrdersAItems::AMT_TAX_TYPE_INCLUDE)
{{-- {{ number_format($ord_invc->amt_base_flat + $ord_invc->amt_tax_ppn_flat + $ord_invc->amt_tax_pph_flat - $ord_invc->amt_disc_flat, 0, ',', '.') }} --}}
{{ number_format($ord_invc->amt_total_flat, 0, ',', '.') }}
@elseif ($ord_invc->amt_tax_type_kind === App\Models\OrdersAItems::AMT_TAX_TYPE_EXCLUDE)
{{ number_format($ord_invc->amt_total_flat, 0, ',', '.') }}
@else
{{ number_format($ord_invc->amt_total_flat, 0, ',', '.') }}
@endif
</strong></td>
</tr>
</tbody>
</table>
</div>
<div class="" style="margin-bottom: 1rem; font-size: 12px;">
<p class="mb-1"><strong style="font-weight: 900;">Terbilang</strong></p>
<p class="mb-0"><em>
@php
echo strtoupper(\App\Helper::terbilang(round($ord_invc->amt_total_flat))).' RUPIAH';
@endphp
</em></p>
</div>
{{-- <div class="" style="margin-bottom: 1rem; font-size: 12px;">
<p class="mb-1"><strong style="font-weight: 900;">Syarat & Ketentuan</strong></p>
<p class="mb-0">Pembayaran jatuh tempo 30 hari setelah invoice diterima</p>
</div> --}}
<div class="" style="margin-bottom: 1rem; font-size: 12px;">
<p class="mb-1"><strong style="font-weight: 900;">Informasi Pembayaran</strong></p>
<table class="table table-border-none">
<tbody>
<tr>
<td style="width:25%;">Metode Pembayaran</td>
<td>{{ ($ord_invc->paid_method === \App\Models\OrdersInvoices::PAID_TYPE_TF) ? 'Transfer' : '-' }}</td>
</tr>
<tr>
<td style="width:25%;">Bank Tujuan</td>
<td>{{ $ord_invc->bank_name }} ({{ $ord_invc->bank_short_name }})</td>
</tr>
<tr>
<td style="width:25%;">Cabang</td>
<td>{{ env('BANK_KCP_NAME') }}</td>
</tr>
<tr>
<td style="width:25%;">No. Rekening</td>
{{-- <td>527 0860 721</td> --}}
<td>{{ implode(' ', str_split('0' . $ord_invc->bank_acc_number, 3)) }}</td>
</tr>
<tr>
<td style="width:25%;">Atas Nama</td>
<td>{{ $ord_invc->bank_acc_name }}</td>
</tr>
</tbody>
</table>
</div>
<div class="" style="margin-bottom: 1rem; font-size: 12px;">
<table class="table table-border-none">
<tbody>
<tr>
<td style="width:70%;"></td>
<td class="text-center" style="width:30%;">PT. Bonceng Indonesia</td>
</tr>
<tr>
<td style="width:70%;"></td>
<td class="text-center" style="width:30%;"><div style="height:8rem;"></div></td>
</tr>
<tr>
<td style="width:70%;"></td>
<td class="text-center" style="width:30%;"><u>Cahyo Nurindah</u></td>
</tr>
<tr>
<td style="width:70%;"></td>
<td class="text-center" style="width:30%;">Accounts Receivable Manager</td>
</tr>
</tbody>
</table>
</div>
@php
$endFooterDrvUp = 0; // buat footer di berkas driver
$penentuFooterDrvUp = 2; // penentu munculnya footer di berkas driver
$absoluteLeftBottom = date('d/m/Y H:i:s');
$currentPage = 1;
$totalPage = (count($drvs_ups) / 2) + 1;
@endphp
<table class="table" style="position: absolute; left: 2.3rem; bottom: 1cm; padding-right: 4.5rem;">
<tbody>
<tr>
<td class="text-start">{{ $absoluteLeftBottom }}</td>
<td class="text-end">{{ $currentPage }}/{{ $totalPage }}</td>
</tr>
</tbody>
</table>
@if (count($drvs_ups) > 0)
{{-- example --}}
{{-- <div class="page-break"></div>
<div class="mb-4" style="text-align: center;">
<p style="font-size: 18px;">
<strong>BERKAS DRIVER</strong>
</p>
</div>
<div class="" style="margin-bottom: 1rem; font-size: 12px;">
<table class="table table-border-none">
<tbody>
<tr>
<td style="width:50%;">
<table class="table table-border-none" style="margin-bottom:0;padding-bottom:0;">
<tr>
<td style="width:50%;" class="text-start"><p class="mb-0 text-start"><strong style="font-weight: 900;">Foto Label</strong></p></td>
<td style="width:50%;" class="text-end"><p class="mb-0 text-end"><strong style="font-weight: 900;">{{ $drvs_ups[0]->crt }}</strong></p></td>
</tr>
</table>
</td>
<td style="width:50%;"></td>
</tr>
<tr>
<td style="width:50%;">
<img style="object-fit: none;" src="{{ isset($drvs_ups[0]->img)? $drvs_ups[0]->img: 'https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQDVPuMlKfGrFErmCt6hCuECLbbhekJF-GCtAJvPIZpHX5upTT-hABFlp8qZY8rkgaZ0DE&usqp=CAU' }}" alt="" class="img-fluid img-report">
</td>
</tr>
</tbody>
</table>
</div> --}}
@foreach ($drvs_ups as $i => $drvUp)
@if (($i % 2) === 0)
@php
$endFooterDrvUp = 0;
@endphp
<div class="page-break"></div>
<div class="mb-4" style="text-align: center;">
<p style="font-size: 18px;">
<strong>BERKAS DRIVER</strong>
</p>
</div>
<div class="" style="margin-bottom: 1rem; font-size: 12px;">
<table class="table table-border-none">
<tbody>
@endif
@php
$endFooterDrvUp += 1;
@endphp
<tr>
<td style="width:50%;margin-bottom:5px;padding-bottom:5px;">
<table class="table table-border-none" style="margin-bottom:0;padding-bottom:0;">
<tr>
<td style="width:50%;" class="text-start"><p class="mb-0 text-start"><strong style="font-weight: 900;">
@if ($drvUp->stts === \App\Models\OrdersDriversUploads::STTS_UP_ARRIVED_PICKUP)
Foto Sampai dilokasi Pickup
@elseif ($drvUp->stts === \App\Models\OrdersDriversUploads::STTS_UP_PROCESS_PICKUP)
Foto Mulai Memuat Barang
@elseif ($drvUp->stts === \App\Models\OrdersDriversUploads::STTS_UP_FINISH_PICKUP)
Foto Selesai Memuat
@elseif ($drvUp->stts === \App\Models\OrdersDriversUploads::STTS_UP_TRAVEL_DOCUMENT)
Foto Dokumen Perjalanan
@elseif ($drvUp->stts === \App\Models\OrdersDriversUploads::STTS_UP_OTW_DROP)
Foto Saat diperjalanan
@elseif ($drvUp->stts === \App\Models\OrdersDriversUploads::STTS_UP_ARRIVED_DROP)
Foto Tiba dilokasi Bongkar
@elseif ($drvUp->stts === \App\Models\OrdersDriversUploads::STTS_UP_PROCESS_DROP)
Foto Proses Bongkar
@elseif ($drvUp->stts === \App\Models\OrdersDriversUploads::STTS_UP_FINISH_DROP)
Foto Selesai Bongkar
@elseif ($drvUp->stts === \App\Models\OrdersDriversUploads::STTS_UP_HANDOVER_DOCUMENT)
Foto Serah Terima
@elseif ($drvUp->stts === \App\Models\OrdersDriversUploads::STTS_UP_ACCIDENT)
Foto Mengalami Trouble / Kecelakaan
@endif
</strong></p></td>
<td style="width:50%;" class="text-end"><p class="mb-0 text-end"><strong style="font-weight: 900;">{{ date('d-m-Y H:m:s', $drvUp->crt) }} WIB</strong></p></td>
</tr>
</table>
</td>
<td style="width:50%;margin-bottom:5px;padding-bottom:5px;"></td>
</tr>
<tr>
<td style="width:50%;margin-bottom:5px;padding-bottom:5px;">
<img src="{{ isset($drvUp->img)? $drvUp->img: 'https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQDVPuMlKfGrFErmCt6hCuECLbbhekJF-GCtAJvPIZpHX5upTT-hABFlp8qZY8rkgaZ0DE&usqp=CAU' }}" alt="" class="img-fluid img-report">
</td>
</tr>
@if ($i !==0 && $endFooterDrvUp === $penentuFooterDrvUp)
@php
$currentPage += 1;
@endphp
</tbody>
</table>
</div>
<table class="table" style="position: absolute; left: 2.3rem; bottom: 1cm; padding-right: 4.5rem;">
<tbody>
<tr>
<td class="text-start">{{ $absoluteLeftBottom }}</td>
<td class="text-end">{{ $currentPage }}/{{ $totalPage }}</td>
</tr>
</tbody>
</table>
@endif
@endforeach
@endif
</body>
</html>

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,991 @@
@extends('app.app')
@section('title')
Finance - Payment
@endsection
@section('content')
<div class="container-fluid">
<div class="content">
<div class="row">
<div class="col-sm-6" id="">
<div class="card">
<div class="card-header">
<div class="row d-flex align-items-center">
<div class="col">
<p class="card-title text-bold mb-0">Detail Pesanan (#{{ $order->ord_code }})</p>
@if ($order->crt_type_order === \App\Models\Orders::CRT_TYPE_ORDER_ADMIN_SPECIAL)
<span class="badge bg-warning text-dark">Pesanan Khusus</span>
@endif
</div>
<div class="col text-end">
<button class="btn btn-secondary btn-sm"
onclick="location.href='{{ route('view_keuangan_billing') }}'">Kembali</button>
</div>
</div>
</div>
<div class="card-body pb-0">
<div class="row d-flex">
<div class="col-5 mb-3">
<div class="row">
<div class="col-sm-12 mb-3">
<p class="text-danger text-bold mb-0">Penjemputan dan Pengantaran</p>
</div>
<div class="col-sm-12 mb-3">
<label for="" class="form-label">Tanggal Penjemputan</label>
<div class="card bg-light border mb-0">
<div class="card-body">
<p class="mb-0"><span id="view-pickup_date_at">22 Apr 2022</span></p>
</div>
</div>
</div>
<div class="col-sm-12 mb-3">
<label for="" class="form-label">Waktu Penjemputan</label>
<div class="card bg-light border mb-0">
<div class="card-body">
<p class="mb-0"><span id="view-pickup_time_at">19.20</span></p>
</div>
</div>
</div>
</div>
</div>
<div class="col-sm-2"></div>
<div class="col-sm-5 mb-3">
<div class="row">
<div class="col-sm-12 col-12 mb-3">
<p class="text-danger text-bold mb-0">Layanan Yang Dipilih</p>
</div>
<div class="col-sm-12 col-6 mb-3">
<label for="" class="form-label">Durasi Pengantaran & Harga</label>
<div class="card bg-light border mb-0 w-100">
<div class="card-body d-flex justify-content-between">
<p class="mb-0">{{ $order->lead_time }} Hari</p>
<p class="mb-0">
Rp{{ number_format($order->price, 0, ',', '.') }}
</p>
</div>
</div>
</div>
<div class="col-sm-12 col-6 mb-3">
<label for="" class="form-label">Tipe Kendaraan</label>
<div class="card bg-light border mb-0 w-100">
<div class="card-body d-flex justify-content-between">
{{-- <p class="mb-0">{{ $order->prefer_truck_type_name }}</p> --}}
<p class="mb-0">{{ $order->vhc_type_name }}</p>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="row mb-3 d-flex align-items-center">
<div class="col-5 mb-3">
<label for="" class="form-label">Lokasi Penjemputan</label>
<div class="card bg-light border mb-0">
<div class="card-body">
{{-- <p class="text-bold mb-2">Gudang Pluit SiCepat (Jakarta)</p> --}}
<p class="text-bold mb-2">{{ $order->pck_name }}</p>
{{-- <p class="mb-0">Jl. Pluit Karang Karya 2 No.33, RT.7/RW.16, Pejagalan, Kec. Penjaringan, Kota Jkt Utara, Daerah Khusus Ibukota Jakarta 14440</p> --}}
<p class="mb-0">{{ $order->pck_addr }}</p>
</div>
</div>
</div>
<div class="col-2 text-center">
<label for="" class="form-label mb-0 mt-0">&nbsp;</label>
{{-- <p class="mb-0">to</p> --}}
<span class="ion-arrow-right-c text-danger" style="font-size: 15px"></span>
</div>
<div class="col-5 mb-3">
<label for="" class="form-label">Lokasi Pengantaran</label>
<div class="card bg-light border mb-0">
<div class="card-body">
{{-- <p class="text-bold mb-2">Kantor Pusat SiCepat (yogyakarta)</p> --}}
<p class="text-bold mb-2">{{ $order->drop_name }}</p>
{{-- <p class="mb-0">Jl. Prof. Herman Yohanes No.989, Terban, Gondokusuman, Kota Yogyakarta, Daerah Istimewa Yogyakarta 55223, Indonesia</p> --}}
<p class="mb-0">{{ $order->drop_addr }}</p>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-sm-5">
<div class="row d-flex align-items-center mb-3">
<div class="col-12 mb-3">
<p class="text-danger text-bold mb-0">Infomasi Client</p>
</div>
<div class="col-sm-12 mb-3">
<label for="" class="form-label">Nama Client</label>
<div class="card bg-light border mb-0">
<div class="card-body">
<p class="mb-0">{{ $order->c_pt_name }}</p>
</div>
</div>
</div>
<div class="col-sm-12">
<label for="" class="form-label">PIC</label>
<div class="card bg-light border mb-0">
<div class="card-body">
<p class="mb-0">{{ $order->c_pt_pic_name }}</p>
<p class="mb-0">
<a href="tel:0{{ $order->c_pt_pic_phone_val }}">
<i class="text-dark ion-ios-telephone me-2"></i>
{{ implode(' ', str_split('0' . $order->c_pt_pic_phone_val, 4)) }}
</a>
</p>
<p class="mb-0">
<a href="https://api.whatsapp.com/send/?phone=0{{ $order->c_pt_pic_phone_val }}&amp;text=Halo&amp;app_absent=0" class="" target="_blank"><i class="text-success ion-social-whatsapp me-1"></i>
{{ implode(' ', str_split('0' . $order->c_pt_pic_phone_val, 4)) }}
</a>
</p>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="col-sm-6">
{{-- invoicing termin 1 --}}
@php
$current_group_termin_id = 0;
$prev_group_termin_id = 0;
@endphp
@foreach ($group_termins as $yi => $y)
@if ($y->c_group_termin_id !== $current_group_termin_id)
@php
$prev_group_termin_id = $current_group_termin_id;
$prev_group_termin_is_paid = $y->termin_is_paid;
$result_is_enable_btn = App\Helper::viewBillFncIsEnableBtn($y->termin_ddln_type, $y->drop_chk_at, $prev_group_termin_id, $prev_group_termin_is_paid);
$sub_total = 0;
$invc_items = '';
@endphp
<div class="card">
<div class="card-header">
<div class="row d-flex align-items-center justify-content-between">
<div class="col">
<p class="card-title text-bold mb-0">Data Penagihan | Termin {{ $y->termin_sequence }}</p>
</div>
@if ($result_is_enable_btn === 0)
<div class="col-auto text-end ps-0">
<small class="text-danger">Menunggu Pengantaran Selesai</small>
</div>
@elseif ($result_is_enable_btn === 1)
<div class="col-auto text-end ps-0">
<button class="btn btn-sm btn-warning" data-bs-toggle="modal" data-bs-target="#mdlDiskon">Diskon</button>
</div>
<div class="col-auto text-end ps-0">
<button class="btn btn-sm btn-primary" id="btnMdlNewAdtItem">Tambah Item</button>
</div>
@elseif ($result_is_enable_btn === 2)
<div class="col-auto text-end ps-0">
<button class="btn btn-sm btn-warning" data-bs-toggle="modal" data-bs-target="#mdlDiskon">Diskon</button>
</div>
<div class="col-auto text-end ps-0">
<button class="btn btn-sm btn-primary" id="btnMdlNewAdtItem">Tambah Item</button>
</div>
<div class="col-auto text-end ps-0">
<small class="text-success">Pengantaran Selesai pada {{ date('Y-m-d H:i', $y->drop_chk_a) }}</small>
</div>
@elseif ($result_is_enable_btn === 3)
<div class="col-auto text-end ps-0">
<small class="text-danger">Termin sebelumnya belum selesai</small>
</div>
@endif
</div>
</div>
<div class="card-body">
<div class="table-responsive">
<table class="table" id="tblInvoice">
<thead>
<tr class="">
<th class="">#</th>
<th class="">Item</th>
<th class="text-nowrap text-end">Jumlah</th>
<th class="">Satuan</th>
<th class="text-nowrap text-end">Harga (Rp)</th>
<th class="text-nowrap text-end">Total (Rp)</th>
</tr>
</thead>
<tbody>
@endif
@foreach ($ord_a_items as $xi => $x)
@if ($x->c_group_termin_id === $y->c_group_termin_id)
<tr class="">
<td class="small">1</td>
<td class="small">
{!! $x->desc !!}
</td>
<td class="small text-nowrap text-end">{{ $x->unit_qty }}</td>
<td class="small">{{ \App\Models\OrdersAItems::getUnitTypeText($x->unit_type) }}</td>
<td class="small text-nowrap text-end">{{ number_format($x->amt_base_flat, 0, ',', '.') }}</td>
<td class="small text-nowrap text-end">{{ number_format($x->amt_total_flat, 0, ',', '.') }}</td>
@php
$sub_total += $x->amt_total_flat;
$invc_items .= "$x->ord_a_item_id,";
@endphp
</tr>
@endif
@endforeach
@if ($y->c_group_termin_id !== $current_group_termin_id)
@php
$current_group_termin_id = $y->c_group_termin_id;
@endphp
</tbody>
<tfooter>
@php
$tax = $sub_total * \App\Models\OrdersInvoices::DFT_TAX_PERCENT / 100;
@endphp
<tr class=" border-0">
<td class="text-nowrap text-end border-0" colspan="5">Sub total</td>
@if ($result_is_enable_btn === 1 || $result_is_enable_btn === 2)
<td id="subTotal" class="text-nowrap text-end border-0"
data-items="{{ $invc_items }}"
data-subtotal="{{ $sub_total }}"
data-terminid="{{ $current_group_termin_id }}"
data-taxpercent="{{ \App\Models\OrdersInvoices::DFT_TAX_PERCENT }}"
data-taxflat="{{ $tax }}"
data-discount="{{ (round($x->invc_disc_flat) ?? 0) }}"
data-total="{{ number_format($sub_total + $tax - (round($x->invc_disc_flat) ?? 0), 0, ',', '.') }}">
{{ number_format($sub_total, 0, ',', '.') }}</td>
@else
<td class="text-nowrap text-end border-0"
data-items="{{ $invc_items }}"
data-subtotal="{{ $sub_total }}"
data-terminid="{{ $current_group_termin_id }}"
data-taxpercent="{{ \App\Models\OrdersInvoices::DFT_TAX_PERCENT }}"
data-taxflat="{{ $tax }}"
data-discount="{{ (round($x->invc_disc_flat) ?? 0) }}"
data-total="{{ number_format($sub_total + $tax - (round($x->invc_disc_flat) ?? 0), 0, ',', '.') }}">
{{ number_format($sub_total, 0, ',', '.') }}</td>
@endif
</tr>
<tr class=" border-0">
<td class="text-nowrap text-end border-0" colspan="5">
@if ($x->invc_disc_type === \App\Models\OrdersInvoices::AMT_TYPE_PERCENT)
Diskon ({{ $x->c_group_termin_id }}%)
@else
Diskon
@endif
</td>
<td class="text-nowrap text-end border-0">-{{ number_format(round($x->invc_disc_flat) ?? 0, 0, ',', '.') }}</td>
</tr>
<tr class="border-bottom">
<td class="text-nowrap text-end boder-bottom" style="border-bottom: 1px solid" colspan="5">PPN ({{ \App\Models\OrdersInvoices::DFT_TAX_PERCENT }}%)</td>
<td class="text-nowrap text-end boder-bottom" style="border-bottom: 1px solid">{{ number_format($tax, 0, ',', '.') }}</td>
</tr>
</tfooter>
<tfooter>
<tr class="bg-light">
<td class="text-nowrap text-end border-0 text-bold" colspan="5">TOTAL</td>
<td class="text-nowrap text-end border-0 text-bold">{{ number_format($sub_total + $tax - (round($x->invc_disc_flat) ?? 0), 0, ',', '.') }}</td>
</tr>
</tfooter>
</table>
</div>
</div>
@if ($result_is_enable_btn === 0)
@elseif ($result_is_enable_btn === 1)
<div class="card-footer">
<div class="row d-flex align-items-center">
<div class="col-8">
<p class="mb-0">
Apakah item diatas sudah seluruhnya di masukkan?
</p>
</div>
<div class="col-4 text-end">
<a href="{{ asset('pdf/invoice.pdf') }}" target="_blank" class="btn btn-primary btn-block btn-sm" id="btnCalculate">Generate Invoice</a>
</div>
</div>
</div>
@elseif ($result_is_enable_btn === 2)
<div class="card-footer">
<div class="row d-flex align-items-center">
<div class="col-8">
<p class="mb-0">
Apakah item diatas sudah seluruhnya di masukkan?
</p>
</div>
<div class="col-4 text-end">
<a href="{{ asset('pdf/invoice.pdf') }}" target="_blank" class="btn btn-primary btn-block btn-sm" id="btnCalculate">Generate Invoice</a>
</div>
</div>
</div>
@elseif ($result_is_enable_btn === 3)
@endif
</div>
@endif
@endforeach
</div>
</div>
</div>
</div>
{{-- Modal --}}
<div class="modal" id="mdlDiskon" tabindex="-1" data-bs-backdrop="static" data-bs-keyboard="false" aria-labelledby="mdlDiskonLabel" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="mdlDiskonLabel">Tambah Diskon</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
</div>
<div class="modal-body">
<div class="mb-3">
<label for="addDisc" class="form-label">Tipe Diskon</label>
<select name="addDisc" id="addDisc" class="select2 form-control" style="width: 100% !important">
<option value="none" selected>Tidak ada tipe diskon yang dipilih</option>
<option value="{{ \App\Models\OrdersInvoices::AMT_TYPE_FLAT }}">Fixed</option>
<option value="{{ \App\Models\OrdersInvoices::AMT_TYPE_PERCENT }}">Percent</option>
</select>
</div>
<div id="disFieldWrapper" class="d-none">
<div id="groupDiscPercent" class="mb-3">
<label for="discPercent" class="form-label">Masukkan Diskon (%)</label>
<input class="form-control" type="number" min="1" max="100" name="discPercent" id="discPercent">
</div>
<div id="groupDiscFlat" class="mb-3">
<label for="discFlat" class="form-label">Besaran Diskon (Rp)</label>
<input class="form-control" type="text" name="discFlat" id="discFlat">
</div>
</div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-sm btn-secondary" data-bs-dismiss="modal">Tutup</button>
<button type="button" class="btn btn-sm btn-primary" id="btnSaveDisc">Simpan</button>
</div>
</div>
</div>
</div>
<div class="modal" id="mdlAddItem" tabindex="-1" data-bs-backdrop="static" data-bs-keyboard="false" aria-labelledby="mdlAddItemLabel" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered modal-dialog-scrollable">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="mdlAddItemLabel"></h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
</div>
<div class="modal-body">
<div class="mb-3">
<label for="slcItem" class="form-label w-100">Pilih Item <span class="text-danger">*</span></label>
<select name="slcItem" id="slcItem" class="select2 form-control" style="width: 100% !important">
<option value="" selected disabled>Belum ada item yang dipilih</option>
@foreach ($items as $item)
<option value="{{ $item->id }}" data-name="{{ $item->name }}" data-type="{{ $item->type }}" data-price="{{ $item->price }}" data-is_adm_price="{{ $item->is_adm_price }}">{{ $item->name }}</option>
@endforeach
<option value="new"><span class="text-danger">Tambah item baru</span></option>
</select>
<small id="slcItemPrice"></small>
</div>
<div id="addNewItemWrapper" class="d-none">
<div class="mb-3">
<label for="add-item_name" class="form-label">Nama Item <span class="text-danger">*</span></label>
<input type="text" name="add-item_name" id="add-item_name" class="form-control">
</div>
<div class="mb-3">
<label for="add-item_type" class="form-label">Satuan <span class="text-danger">*</span></label>
<select name="add-item_type" id="add-item_type" class="select2 form-control" style="width: 100% !important">
<option value="" selected disabled>Belum ada satuan yang dipilih</option>
@foreach ($unitTypes as $type)
<option value="{{ $type['id'] }}">{{ $type['name'] }}</option>
@endforeach
</select>
</div>
<div>
<label for="add-item_price" class="form-label">Harga Satuan <span class="text-danger">*</span></label>
<input type="text" name="add-item_price" id="add-item_price" class="form-control">
</div>
<div class="mb-3">
<div class="form-check">
<input class="form-check-input" name="add-item_isAdmPrice" type="checkbox" value="yes" id="add-item_isAdmPrice">
<label class="form-check-label text-danger" for="add-item_isAdmPrice">
Biaya admin bank ?
</label>
</div>
</div>
</div>
<div class="mb-3">
<label for="add-item_qty" class="form-label">Jumlah Item <span class="text-danger">*</span></label>
<input type="number" name="add-item_qty" id="add-item_qty" class="form-control">
</div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-sm btn-secondary" data-bs-dismiss="modal">Tutup</button>
<button type="button" class="btn btn-sm btn-primary" id="btnSubmitAddItem">Simpan</button>
</div>
</div>
</div>
</div>
{{-- ./Modal --}}
@endsection
@section('customcss')
@endsection
@section('customjs')
<script>
// $('#tblInvoice').DataTable({
// bSort: false,
// searching: false,
// paging: false,
// info: false
// });
// $('#slctItem').select2({
// dropdownParent: $('#mdlAddItem')
// });
// $('#addDisc').select2({
// dropdownParent: $('#mdlDiskon')
// });
// $('#slctItem').on('change', function() {
// var data = $("#slctItem option:selected").val();
// console.log(data)
// if(data == 99999999){
// let a = `
// <div id="addNewItemContent">
// <div class="mb-3">
// <label for="" class="form-label">Nama Item</label>
// <input type="text" class="form-control">
// </div>
// <div class="mb-3">
// <label for="" class="form-label">Satuan</label>
// <select name="" id="" class="select2 form-control" style="width: 100% !important">
// <option value="none" selected disabled>Belum ada satuan yang dipilih</option>
// <option value="">Paket</option>
// <option value="">Unit</option>
// <option value="">Pcs</option>
// </select>
// </div>
// <div class="mb-3">
// <label for="" class="form-label">Harga</label>
// <input type="number" class="form-control">
// </div>
// `
// $('#addNewItemWrapper').html(a)
// $('.select2').select2({
// dropdownParent: $('#mdlAddItem')
// });
// } else {
// $('#addNewItemContent').remove()
// }
// })
// $('#addDisc').on('change', function() {
// var data = $("#addDisc option:selected").val();
// console.log(data)
// // fixed
// if(data == 1){
// let a = `
// <div id="disFieldContent">
// <div class="mb-3">
// <label for="" class="form-label">Besaran Diskon (Rp)</label>
// <input class="form-control" type="number" id="">
// </div>
// </div>
// `
// $('#disFieldContent').remove()
// $('#disFieldWrapper').html(a)
// } else if (data == 2) {
// let a = `
// <div id="disFieldContent">
// <div class="mb-3">
// <label for="" class="form-label">Masukkan Diskon (%)</label>
// <input class="form-control" type="number" min="1" max="100" id="">
// </div>
// <div class="mb-3">
// <label for="" class="form-label">Besaran Diskon (Rp)</label>
// <input class="form-control" type="number" id="" readonly>
// </div>
// </div>
// `
// $('#disFieldContent').remove()
// $('#disFieldWrapper').html(a)
// } else {
// $('#disFieldContent').remove()
// }
// if(data == 99999999){
// let a = `
// <div id="addNewItemContent">
// <div class="mb-3">
// <label for="" class="form-label">Nama Item</label>
// <input type="text" class="form-control">
// </div>
// <div class="mb-3">
// <label for="" class="form-label">Satuan</label>
// <select name="" id="" class="select2 form-control" style="width: 100% !important">
// <option value="none" selected disabled>Belum ada satuan yang dipilih</option>
// <option value="">Paket</option>
// <option value="">Unit</option>
// <option value="">Pcs</option>
// </select>
// </div>
// <div class="mb-3">
// <label for="" class="form-label">Harga</label>
// <input type="number" class="form-control">
// </div>
// `
// $('#addNewItemWrapper').html(a)
// $('.select2').select2({
// dropdownParent: $('#mdlAddItem')
// });
// } else {
// $('#addNewItemContent').remove()
// }
// })
</script>
<script>
'use strict'
const State = {
ord_id: "{{ $order->ord_id }}",
ord_code: "{{ $order->ord_code }}",
set_pck_at: "{{ $order->set_pck_at }}",
fix_price_at: "{{ $order->fix_price_at }}",
order_place_at: "{{ $order->crt }}",
is_paid: {
not: "{{ App\Models\OrdersAItems::IS_PAID_NO }}",
paid: "{{ App\Models\OrdersAItems::IS_PAID_YES }}",
},
ddln_pay_type: {
time: "{{ App\Models\OrdersAItems::DDLN_PAY_TYPE_TIME }}",
ord_finish: "{{ App\Models\OrdersAItems::DDLN_PAY_TYPE_ORD_FINISH }}",
},
invc_to_client: {
not: "{{ App\Models\OrdersAItems::INVC_TO_CLIENT_NO }}",
yes: "{{ App\Models\OrdersAItems::INVC_TO_CLIENT_YES }}",
},
only_client: {
not: "{{ App\Models\OrdersAItems::ONLY_CLIENT_NO }}",
yes: "{{ App\Models\OrdersAItems::ONLY_CLIENT_YES }}",
},
calc_to_vdr: {
not: "{{ App\Models\OrdersAItems::CALC_TO_VDR_NO }}",
yes: "{{ App\Models\OrdersAItems::CALC_TO_VDR_YES }}",
},
is_adm_price: {
no: "{{ App\Models\AItems::IS_ADM_PRICE_NO }}",
yes: "{{ App\Models\AItems::IS_ADM_PRICE_YES }}",
},
crt_type: {
system: "{{ App\Models\OrdersAItems::CRT_TYPE_SYSTEM }}",
admin: "{{ App\Models\OrdersAItems::CRT_TYPE_ADMIN }}",
finance: "{{ App\Models\OrdersAItems::CRT_TYPE_FINANCE }}",
},
flow_type: {
payment: "{{ App\Models\OrdersAItems::FLOW_TYPE_PAYMENT }}",
billing: "{{ App\Models\OrdersAItems::FLOW_TYPE_BILLING }}",
hybrid: "{{ App\Models\OrdersAItems::FLOW_TYPE_HYBRID }}",
},
cash_type: {
out: "{{ App\Models\OrdersAItems::TYPE_CASH_OUT }}",
in: "{{ App\Models\OrdersAItems::TYPE_CASH_IN }}",
hybrid: "{{ App\Models\OrdersAItems::TYPE_CASH_HYBRID }}",
},
invc_amt_type: {
flat: "{{ \App\Models\OrdersInvoices::AMT_TYPE_FLAT }}",
percent: "{{ \App\Models\OrdersInvoices::AMT_TYPE_PERCENT }}",
},
storage_lara: "{{ asset('storage') }}/",
file_jimp_worker: "{{ asset('assets/js/worker/jimp.js') }}",
};
const Wrapper = {
activate: function() {
Wrapper.event();
OrdView.activate();
OrdAItem.activate();
OrdInvc.activate();
},
event: function() {
$('#view-pickup_at').text(moment.unix(State.set_pck_at).format('DD MMM YYYY HH:mm:ss'));
$('#view-pickup_date_at').text(moment.unix(State.set_pck_at).format('DD MMM YYYY'));
$('#view-pickup_time_at').text(moment.unix(State.set_pck_at).format('HH:mm:ss'));
$('#btnMdlNewAdtItem').on('click', function() {
$('#inpt-is_paid_proof-base64').val('');
$('#inpt-is_paid_proof-file').val('');
$('#inpt-group_rotate_is_paid_proof').addClass('d-none');
$('#inpt-is_paid_proof-img').addClass('d-none');
$('#inpt-submission_proof-base64').val('');
$('#inpt-submission_proof-file').val('');
$('#inpt-group_rotate_submission_proof').addClass('d-none');
$('#inpt-submission_proof-img').addClass('d-none');
$('#mdlAddItem').modal('show');
});
},
};
const OrdView = {
activate: function() {
OrdView.event();
},
event: function() { },
};
const OrdAItem = {
activate: function() {
OrdAItem.event();
},
event: function() {
// init select2
$('#slcItem').select2({
dropdownParent: $('#mdlAddItem'),
});
$('#add-item_type').select2({
dropdownParent: $('#mdlAddItem'),
});
// event select
$('#slcItem').on('change', function() {
let slc = $('#slcItem option:selected');
if (slc.val() === 'new') {
$('#addNewItemWrapper').removeClass('d-none');
OrdAItem.toggleAddItemIsAdmPrice('unchecked');
$('#slcItemPrice').text('');
} else {
$('#addNewItemWrapper').addClass('d-none');
OrdAItem.clearInputAddNewItem();
$('#slcItemPrice').text('Harga: Rp' + (new Intl.NumberFormat('id-ID')).format(slc.data('price')));
}
});
// input
$('#add-item_price').on('keyup', function() {
let price = $('#add-item_price').val().split('.').join('').replace(/[$,]+/g,".");
$('#add-item_price').val((new Intl.NumberFormat('id-ID')).format(price));
});
// submit
$('#btnSubmitAddItem').on('click', function(e) {
e.preventDefault();
let data = OrdAItem.getData();
let isValid = OrdAItem.checkData(data, true);
if (!isValid) return false;
OrdAItem.submitData(data);
});
},
getData: function() {
const data = {};
let slcType = $('#slcItem option:selected');
if (slcType.val() === 'new') {
data.a_id = '00';
data.a_name = $('#add-item_name').val();
data.a_type = $('#add-item_type').val();
data.a_price = $('#add-item_price').val().split('.').join('').replace(/[$,]+/g,".");
if($('#add-item_isAdmPrice').prop('checked')) {
data.is_adm_price = State.is_adm_price.yes
} else {
data.is_adm_price = State.is_adm_price.no
}
} else if (slcType.val() === '') {
} else {
data.a_id = slcType.val(); // id
data.a_name = slcType.data('name');
data.a_type = slcType.data('type');
data.a_price = slcType.data('price');
data.is_adm_price = slcType.data('is_adm_price');
}
data.a_qty = $('#add-item_qty').val();
data.is_invc_to_client = State.invc_to_client.yes;
data.only_client = State.only_client.yes;
data.cash_type = State.cash_type.in;
data.flow_type = State.flow_type.billing;
data.ord_id = State.ord_id;
data.ddln_pay_type = State.ddln_pay_type.time;
data.is_calc_to_vdr = State.calc_to_vdr.yes;
data.crt_type = State.crt_type.finance;
return data;
},
checkData: function(data, isAlert = false) {
if (typeof data.a_id == 'undefined') {
if (isAlert) Helper.toast('Warning', 'just now', 'Item wajib diisi');
return false;
}
if (data.a_name == '' || data.a_name == null) {
if (isAlert) Helper.toast('Warning', 'just now', 'Item nama wajib diisi');
return false;
}
if (data.a_type == '' || data.a_type == null) {
if (isAlert) Helper.toast('Warning', 'just now', 'Item satuan wajib diisi');
return false;
}
if (data.a_price == '' || data.a_price == null) {
if (isAlert) Helper.toast('Warning', 'just now', 'Item harga wajib diisi');
return false;
}
if (typeof data.a_qty == 'undefined' || Number(data.a_qty) < 1) {
if (isAlert) Helper.toast('Warning', 'just now', 'Jumlah wajib diisi');
return false;
}
return true;
},
submitData: async function(data) {
return new Promise((resolve, reject) => {
if (typeof $('#btnSubmitAddItem').attr('disabed') != 'undefined') {
resolve({
type: 'fail'
});
return false;
}
$('#btnSubmitAddItem').attr('disabed', true);
$.ajax({
url: "{{ route('api_finance_add_a_items') }}",
method: 'POST',
crossDomain: true,
processData: true,
headers: {
'x-api-key': Helper.getCookie('_trtk'),
'x-csrf-token': $('meta[name="csrf-token"]').attr('content'),
},
data: data,
success: (data, textStatus, jqXHR) => {
$('#btnSubmitAddItem').removeAttr('disabed');
if (data.meta.type != 'success') {
resolve({
type: 'fail'
});
Helper.toast('Warning', 'just now', data.meta.message);
return false;
}
Helper.toast('Success', 'just now', 'success add item');
$('#mdlAddItem').modal('hide');
window.location.href = window.location.href;
resolve({
type: 'success'
});
},
error: (jqXHR, textStatus, error) => {
$('#btnSubmitAddItem').removeAttr('disabed');
if (jqXHR.status >= 500) {
Helper.toast('Error', 'just now', 'Please try again');
} else {
Helper.toast('Error', 'just now', jqXHR.responseJSON.meta
.message);
}
resolve({
type: 'error'
});
}
})
})
},
toggleAddItemIsAdmPrice: function(toggle = 'checked') {
if (toggle === 'checked') {
$('#add-item_isAdmPrice').prop('checked', true).trigger('change');
} else {
$('#add-item_isAdmPrice').prop('checked', false).trigger('change');
}
},
clearInputAddNewItem: function() {
$('#add-item_name').val('');
$('#add-item_type').val('').trigger('change');
$('#add-item_price').val('');
$('#add-item_qty').val('');
OrdAItem.toggleAddItemIsAdmPrice('unchecked');
},
};
const OrdInvc = {
activate: function() {
OrdInvc.event();
},
event: function() {
// init select2
$('#addDisc').select2({
dropdownParent: $('#mdlDiskon')
});
// event select
$('#addDisc').on('change', function() {
let slc = $('#addDisc option:selected');
$('#disFieldWrapper').removeClass('d-none');
$('#discPercent').val('');
$('#discFlat').val('');
$('#groupDiscFlat').removeClass('d-none');
if (slc.val() == State.invc_amt_type.percent) {
$('#groupDiscPercent').removeClass('d-none');
$('#discFlat').attr('readonly', true);
} else if (slc.val() == State.invc_amt_type.flat) {
$('#groupDiscPercent').addClass('d-none');
$('#discFlat').removeAttr('readonly');
} else {
$('#groupDiscPercent').addClass('d-none');
$('#discFlat').attr('readonly', true);
$('#groupDiscFlat').addClass('d-none');
}
});
// input
$('#discFlat').on('keyup', function() {
let price = $('#discFlat').val().split('.').join('').replace(/[$,]+/g,".");
if (Number(price) < 1) {
Helper.toast('Warning', 'just now', 'Besaran diskon wajib diisi');
}
$('#discFlat').val((new Intl.NumberFormat('id-ID')).format(price));
});
$('#discPercent').on('keyup', function() {
let percent = $('#discPercent').val();
let subTotal = $('#subTotal').data('subtotal');
if (Number(percent) < 0) {
Helper.toast('Warning', 'just now', 'Diskon percent wajib diisi');
return true;
}
if (Number(percent) > 100) {
Helper.toast('Warning', 'just now', 'Diskon percent maksimal 100%');
return false;
}
let price = subTotal * percent / 100;
$('#discFlat').val((new Intl.NumberFormat('id-ID')).format(price));
});
// submit
$('#btnSaveDisc').on('click', async function(e) {
e.preventDefault();
let data = OrdInvc.getData();
let isValid = OrdInvc.checkData(data, true);
if (!isValid) return false;
let result = await OrdInvc.submitDataDisc(data);
if (result.type != 'success') return false;
Helper.toast('Success', 'just now', 'success update discount');
$('#mdlDiskon').modal('hide');
window.location.href = window.location.href;
});
},
getData: function() {
const data = {};
data.ord_id = State.ord_id;
data.ord_code = State.ord_code;
data.termin_id = $('#subTotal').data('terminid');
data.items = $('#subTotal').data('items');
data.subtotal = Number($('#subTotal').data('subtotal'));
data.tax_type = State.invc_amt_type.percent;
data.tax_percent = Number($('#subTotal').data('taxpercent'));
data.tax_flat = Number($('#subTotal').data('taxflat'));
let discType = $('#addDisc option:selected');
data.disc_type = discType.val();
if (data.disc_type == State.invc_amt_type.flat || data.disc_type == State.invc_amt_type.percent) { } else {
data.disc_type = 0;
}
data.disc_percent = Number($('#discPercent').val());
data.disc_flat = Number($('#discFlat').val().split('.').join('').replace(/[$,]+/g,"."));
data.total = data.subtotal + data.tax_flat - data.disc_flat;
return data;
},
checkData: function(data, isAlert = false) {
if (data.disc_type == State.invc_amt_type.percent) {
if (data.disc_percent < 0) {
if (isAlert) Helper.toast('Warning', 'just now', 'Diskon percent wajib diisi');
return false;
}
if (data.disc_percent > 100) {
if (isAlert) Helper.toast('Warning', 'just now', 'Diskon percent maksimal 100%');
return false;
}
} else if (data.disc_type == State.invc_amt_type.flat) {
if (data.disc_flat < 1) {
Helper.toast('Warning', 'just now', 'Besaran diskon wajib diisi');
}
}
return true;
},
submitDataDisc: async function(data) {
return new Promise((resolve, reject) => {
if (typeof $('#btnSaveDisc').attr('disabed') != 'undefined') {
resolve({
type: 'fail'
});
return false;
}
$('#btnSaveDisc').attr('disabed', true);
$.ajax({
url: "{{ route('api_finance_crt_updt_invc') }}",
method: 'POST',
crossDomain: true,
processData: true,
headers: {
'x-api-key': Helper.getCookie('_trtk'),
'x-csrf-token': $('meta[name="csrf-token"]').attr('content'),
},
data: data,
success: (data, textStatus, jqXHR) => {
$('#btnSaveDisc').removeAttr('disabed');
if (data.meta.type != 'success') {
resolve({
type: 'fail'
});
Helper.toast('Warning', 'just now', data.meta.message);
return false;
}
resolve({
type: 'success'
});
},
error: (jqXHR, textStatus, error) => {
$('#btnSaveDisc').removeAttr('disabed');
if (jqXHR.status >= 500) {
Helper.toast('Error', 'just now', 'Please try again');
} else {
Helper.toast('Error', 'just now', jqXHR.responseJSON.meta
.message);
}
resolve({
type: 'error'
});
}
})
})
},
gnrtInvc: async function(data) {
return new Promise((resolve, reject) => {
if (typeof $('#btnCalculate').attr('disabed') != 'undefined') {
resolve({
type: 'fail'
});
return false;
}
$('#btnCalculate').attr('disabed', true);
$.ajax({
url: "{{ route('api_finance_crt_updt_invc') }}",
method: 'POST',
crossDomain: true,
processData: true,
headers: {
'x-api-key': Helper.getCookie('_trtk'),
'x-csrf-token': $('meta[name="csrf-token"]').attr('content'),
},
data: data,
success: (data, textStatus, jqXHR) => {
$('#btnCalculate').removeAttr('disabed');
if (data.meta.type != 'success') {
resolve({
type: 'fail'
});
Helper.toast('Warning', 'just now', data.meta.message);
return false;
}
resolve({
type: 'success'
});
},
error: (jqXHR, textStatus, error) => {
$('#btnCalculate').removeAttr('disabed');
if (jqXHR.status >= 500) {
Helper.toast('Error', 'just now', 'Please try again');
} else {
Helper.toast('Error', 'just now', jqXHR.responseJSON.meta
.message);
}
resolve({
type: 'error'
});
}
})
})
},
};
Wrapper.activate();
</script>
@endsection

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,734 @@
@extends('app.app')
@section('title')
Master Additional Items
@endsection
@section('customcss')
<style>
/* .select2-container {
z-index: 99999;
} */
</style>
@endsection
@section('content')
<div class="container-fluid">
<div class="content">
<div class="card">
<div class="card-header">
<div class="row d-flex align-items-center">
<div class="col-3">
<p class="card-title text-bold mb-0">Item (<span id="count_a_items">0</span>)</p>
</div>
<div class="col text-end">
<button id="btnMdlNewItem" class="btn btn-sm btn-danger">Tambah Item Baru</button>
</div>
<div class="col-auto text-end ps-0">
{{-- <button class="btn btn-sm btn-danger">Upload</button> --}}
{{-- <button class="btn btn-sm btn-danger">Download</button> --}}
</div>
</div>
</div>
<div class="card-body">
<div class="table-responsive">
<table id="tItems" class="table table-hover dataTable">
<thead>
<tr class="">
<th class="">#</th>
<th class="text-center"></th>
<th class="">Nama Item</th>
<th class="text-end">Satuan</th>
<th class="text-end">Harga</th>
<th class="text-center">Status</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
</div>
</div>
</div>
</div>
</div>
<div class="modal fade" data-bs-backdrop="static" data-bs-keyboard="false" id="mdlNewItem"
aria-labelledby="mdlNewItemLabel" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered modal-dialog-scrollable">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="mdlNewItemLabel">Tambah Item Baru</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
</div>
<div class="modal-body">
<form>
{{-- Primary --}}
<div class="mb-3">
<div class="border-bottom">
<h6>Data Item</h6>
</div>
<div class="row">
<div class="col-sm-12">
<label for="add-name" class="col-form-label">Nama<span
class="text-danger">*</span></label>
<input type="text" name="add-name" id="add-name" class="form-control">
</div>
<div class="col-sm-12">
<label for="add-type" class="col-form-label">Satuan<span
class="text-danger">*</span></label>
<select name="add-type" id="add-type" class="form-control" style="width:100%;">
<option value="" selected disabled>Belum dipilih</option>
@foreach ($unitTypes as $type)
<option value="{{ $type->id }}">{{ $type->name }}</option>
@endforeach
</select>
</div>
<div class="col-sm-12">
<label for="add-price" class="col-form-label">Harga Satuan<span
class="text-danger">*</span></label>
<input type="text" name="add-price" id="add-price" class="form-control">
</div>
</div>
</div>
{{-- Utilites --}}
<div class="mb-3">
<div class="border-bottom">
<h6>Utilities</h6>
</div>
<div class="row">
<div class="col-sm-12">
<label for="add-status" class="form-label">Status<span
class="text-danger">*</span></label>
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" id="add-status">
<label class="form-check-label" for="add-status"><span class="text-dark"
id="add-txtStatus">Inactive</span></label>
</div>
</div>
</div>
</div>
@if ($user->role === \App\Models\Users::ROLE_FINANCE)
<div>
<div class="form-check">
<input class="form-check-input" name="add-isAdmPrice" type="checkbox" value="yes" id="add-isAdmPrice">
<label class="form-check-label text-danger" for="add-isAdmPrice">
Biaya admin ?
</label>
</div>
</div>
@endif
</form>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-sm btn-secondary" data-bs-dismiss="modal">Close</button>
<button id="btnSubmitNewItem" type="button" class="btn btn-sm btn-danger">Submit data</button>
</div>
</div>
</div>
</div>
<div class="modal fade" data-bs-backdrop="static" data-bs-keyboard="false" id="mdlUpdtItem"
aria-labelledby="mdlUpdtItemLabel" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered modal-dialog-scrollable">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="mdlUpdtItemLabel">Edit Item</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
</div>
<div class="modal-body">
<form>
{{-- Primary --}}
<div class="mb-3">
<div class="border-bottom">
<h6>Data Item</h6>
</div>
<div class="row">
<div class="col-sm-12">
<label for="updt-name" class="col-form-label">Nama<span
class="text-danger">*</span></label>
<input type="text" name="updt-name" id="updt-name" class="form-control">
</div>
<div class="col-sm-12">
<label for="updt-type" class="col-form-label">Satuan<span
class="text-danger">*</span></label>
<select name="updt-type" id="updt-type" class="form-control" style="width:100%;">
<option value="" selected disabled>Belum dipilih</option>
@foreach ($unitTypes as $type)
<option value="{{ $type->id }}">{{ $type->name }}</option>
@endforeach
</select>
</div>
<div class="col-sm-12">
<label for="updt-price" class="col-form-label">Harga Satuan<span
class="text-danger">*</span></label>
<input type="text" name="updt-price" id="updt-price" class="form-control">
</div>
</div>
</div>
{{-- Utilites --}}
<div class="mb-3">
<div class="border-bottom">
<h6>Utilities</h6>
</div>
<div class="row">
<div class="col-sm-12">
<label for="updt-status" class="form-label">Status<span
class="text-danger">*</span></label>
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" id="updt-status">
<label class="form-check-label" for="updt-status"><span class="text-dark"
id="updt-txtStatus">Inactive</span></label>
</div>
</div>
</div>
</div>
@if ($user->role === \App\Models\Users::ROLE_FINANCE)
<div>
<div class="form-check">
<input class="form-check-input" name="updt-isAdmPrice" type="checkbox" value="yes" id="updt-isAdmPrice">
<label class="form-check-label text-danger" for="updt-isAdmPrice">
Biaya admin ?
</label>
</div>
</div>
@endif
</form>
</div>
<div class="modal-footer">
<button type="button" id="btnDelItem_updt" class="btn btn-sm btn-warning">Hapus ?</button>
<button type="button" class="btn btn-sm btn-secondary" data-bs-dismiss="modal">Tutup</button>
<button id="btnSubmitUpdtItems" type="button" class="btn btn-sm btn-danger">Ubah data</button>
</div>
</div>
</div>
</div>
<div class="modal fade" data-bs-backdrop="static" data-bs-keyboard="false" id="mdlDelItem"
aria-labelledby="mdlDelItemLabel" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered modal-sm">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="mdlDelItemLabel">Delete Item</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
</div>
<div class="modal-body">
<div class="d-flex justify-content-center">
<p class="mb-0">
Kamu yakin ingin menghapus item
<a href="#" class="text-danger">
<span id="del-name"></span>
</a>
?
</p>
</div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-sm btn-danger" data-bs-dismiss="modal">Tutup</button>
<button id="btnSubmitDelItem" type="button" class="btn btn-sm btn-secondary">Iya, hapus</button>
</div>
</div>
</div>
</div>
@endsection
@section('customjs')
<script src="{{ asset('assets/js/load-image.all.min.js') }}"></script>
<script>
'use strict';
const State = {
file_jimp_worker: "{{ asset('assets/js/worker/jimp.js') }}",
storage_lara: "{{ asset('storage') }}/",
stts_isact: {
active: "{{ App\Models\AItems::IS_ACTIVE }}",
inactive: "{{ App\Models\AItems::IS_INACTIVE }}",
},
is_adm_price: {
no: "{{ App\Models\AItems::IS_ADM_PRICE_NO }}",
yes: "{{ App\Models\AItems::IS_ADM_PRICE_YES }}",
},
delay_typing_front: 1000,
};
const Wrapper = {
activate: function() {
Wrapper.event();
DTable.activate();
ANew.activate();
AUpdt.activate();
ADel.activate();
},
event: function() {
$('#add-status').bind('change', function() {
if ($(this).is(':checked'))
$('#add-txtStatus').html('Active')
else
$('#add-txtStatus').html('Inactive')
});
$('#updt-status').bind('change', function() {
if ($(this).is(':checked'))
$('#updt-txtStatus').html('Active')
else
$('#updt-txtStatus').html('Inactive')
});
// fix modal select2
$('#add-type').select2({
dropdownParent: $('#mdlNewItem'),
});
$('#updt-type').select2({
dropdownParent: $('#mdlUpdtItem'),
});
},
};
const DTable = {
activate: function() {
DTable.reload();
},
reload: function() {
// $('#tItems').DataTable();
// if (Driver.Table.firstInitDataTable == 1) { loadTableSkeletonLoading() } else { Driver.Table.firstInitDataTable = 1; }
$('#tItems').DataTable({
processing: true,
serverSide: false,
bLengthChange: true,
deferRender: true,
destroy: true,
ajax: {
url: "{{ route('api_list_a_items') }}",
type: 'GET',
complete: function(jqXHR, textStatus, c) {
let count = jqXHR.responseJSON.count;
if (typeof count != 'undefined') {
$('#count_a_items').text(count);
}
// removeTableSkeletonLoading()
},
},
deferRender: true,
columns: [{
data: 'DT_RowIndex',
className: 'text-end',
visible: true,
orderable: true,
searchable: true,
},
{
data: 'action',
className: 'text-center',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
let action = `
<a href="#" class="text-decoration-none me-1 btnUpdtItem">
<span class="icon ion-edit fz-16"></span>
</a>
`;
// <a href="#" class="text-decoration-none text-danger btnDelItem">
// <span class="icon ion-trash-b fz-16"></span>
// </a>
return action;
}
},
{
data: 'name',
className: 'text-end text-nowrap',
visible: true,
orderable: true,
searchable: true,
createdCell: function(td, cellData, rowData, row, col) {
$(td).attr('data-id', rowData.id);
$(td).attr('data-name', rowData.name);
$(td).attr('data-price', rowData.price);
},
},
{
data: 'type_name',
className: 'text-end text-nowrap',
visible: true,
orderable: true,
searchable: true,
},
{
data: 'price',
className: 'text-end text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
return (new Intl.NumberFormat('id-ID')).format(data);
},
},
{
data: 'is_active',
className: 'text-center text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (data == State.stts_isact.active) return '<span class="badge rounded-pill bg-success">Active</span>';
return '<span class="badge rounded-pill bg-danger">Inactive</span>';
}
},
],
});
},
};
const ANew = {
activate: function() {
ANew.event();
},
event: function() {
// modal
$('#btnMdlNewItem').on('click', function() {
$('#mdlNewItem').modal('show');
});
$('#mdlNewItem').on('shown.bs.modal', function() {
});
// button
$('#btnSubmitNewItem').on('click', function() {
let data = ANew.getData();
ANew.submitData(data);
});
// input
$('#add-price').on('keyup', function() {
let price = $('#add-price').val().split('.').join('');
$('#add-price').val((new Intl.NumberFormat('id-ID')).format(price));
});
},
getData: function() {
let data = {};
data.name = $('#add-name').val();
data.type = $('#add-type').val();
data.price = $('#add-price').val().split('.').join('');
if ($('#add-status').prop('checked')) {
data.status = State.stts_isact.active;
} else {
data.status = State.stts_isact.inactive;
}
if($('#add-isAdmPrice').prop('checked')) {
data.is_adm_price = State.is_adm_price.yes
} else {
data.is_adm_price = State.is_adm_price.no
}
return data;
},
submitData: async function(data) {
return new Promise((resolve, reject) => {
if (typeof $('#btnSubmitNewItem').attr('disabed') != 'undefined') {
resolve({
type: 'fail'
});
return false;
}
$('#btnSubmitNewItem').attr('disabed', true);
$.ajax({
url: "{{ route('api_add_a_items') }}",
method: 'POST',
crossDomain: true,
processData: true,
headers: {
'x-api-key': Helper.getCookie('_trtk'),
'x-csrf-token': $('meta[name="csrf-token"]').attr('content'),
},
data: data,
success: (data, textStatus, jqXHR) => {
$('#btnSubmitNewItem').removeAttr('disabed');
if (data.meta.type != 'success') {
resolve({
type: 'fail'
});
Helper.toast('Warning', 'just now', data.meta.message);
return false;
}
Helper.toast('Success', 'just now', 'success add new additional item');
$('#mdlNewItem').modal('hide');
DTable.reload();
resolve({
type: 'success'
});
},
error: (jqXHR, textStatus, error) => {
$('#btnSubmitNewItem').removeAttr('disabed');
if (jqXHR.status >= 500) {
Helper.toast('Error', 'just now', 'Please try again');
} else {
Helper.toast('Error', 'just now', jqXHR.responseJSON.meta
.message);
}
resolve({
type: 'error'
});
}
})
})
},
}
const AUpdt = {
activate: function() {
AUpdt.event();
},
event: function() {
// modal
$('#tItems').on('click', '.btnUpdtItem', async function(e) {
let id = $(e.target).closest('tr').find('td[data-id]').data('id');
let resp = await AUpdt.reqData({
id
});
if (resp.type != 'success') {
Helper.toast('Item Not Found', 'just now', 'please try again');
return false;
}
AUpdt.passDataToView(resp.data);
});
$('#mdlUpdtItem').on('shown.bs.modal', function() {
});
// button
$('#btnSubmitUpdtItems').on('click', function() {
let data = AUpdt.getData();
AUpdt.submitData(data);
});
// input
$('#updt-price').on('keyup', function() {
let price = $('#updt-price').val().split('.').join('');
$('#updt-price').val((new Intl.NumberFormat('id-ID')).format(price));
});
},
reqData: function(params) {
return new Promise((resolve, reject) => {
$.ajax({
url: "{{ route('api_show_a_items', '') }}/" + params.id,
method: 'GET',
crossDomain: true,
processData: true,
headers: {
'x-api-key': Helper.getCookie('_trtk'),
},
data: params,
success: (data, textStatus, jqXHR) => {
if (data.meta.type != 'success') {
resolve({
type: 'fail'
});
Helper.toast('Warning', 'just now', data.meta.message);
return false;
}
resolve({
type: 'success',
data: data.data
});
},
error: (jqXHR, textStatus, error) => {
if (jqXHR.status >= 500) {
Helper.toast('Error', 'just now', 'please try again');
} else {
Helper.toast('Error', 'just now', jqXHR.responseJSON.meta
.message);
}
resolve({
type: 'error'
});
}
})
});
},
passDataToView: async function(data) {
$('#updt-name').val(data.name);
$('#updt-type').val(data.type).trigger('change');
$('#updt-price').val(data.price);
if (data.is_active == State.stts_isact.active) {
$('#updt-status').prop('checked', true).trigger('change');
} else {
$('#updt-status').prop('checked', false).trigger('change');
}
if(data.is_adm_price == State.is_adm_price.yes) {
$('#updt-isAdmPrice').prop('checked', true).trigger('change');
} else {
$('#updt-isAdmPrice').prop('checked', false).trigger('change');
}
$('#mdlUpdtItem').data('id', data.id);
$('#mdlUpdtItem').modal('show');
},
getData: function() {
let data = {};
data.id = $('#mdlUpdtItem').data('id');
data.name = $('#updt-name').val();
data.type = $('#updt-type').val();
data.price = $('#updt-price').val().split('.').join('');
if ($('#updt-status').prop('checked')) {
data.status = State.stts_isact.active;
} else {
data.status = State.stts_isact.inactive;
}
if($('#updt-isAdmPrice').prop('checked')) {
data.is_adm_price = State.is_adm_price.yes
} else {
data.is_adm_price = State.is_adm_price.no
}
return data;
},
submitData: async function(data) {
return new Promise((resolve, reject) => {
if (typeof $('#btnSubmitUpdtItems').attr('disabed') != 'undefined') {
resolve({
type: 'fail'
});
return false;
}
$('#btnSubmitUpdtItems').attr('disabed', true);
$.ajax({
url: "{{ route('api_updt_a_items', '') }}/" + data.id,
method: 'PUT',
crossDomain: true,
processData: true,
headers: {
'x-api-key': Helper.getCookie('_trtk'),
'x-csrf-token': $('meta[name="csrf-token"]').attr('content'),
},
data: data,
success: (data, textStatus, jqXHR) => {
$('#btnSubmitUpdtItems').removeAttr('disabed');
if (data.meta.type != 'success') {
resolve({
type: 'fail'
});
Helper.toast('Warning', 'just now', data.meta.message);
return false;
}
Helper.toast('Success', 'just now', 'success update additional item');
$('#mdlUpdtItem').modal('hide');
DTable.reload();
resolve({
type: 'success'
});
},
error: (jqXHR, textStatus, error) => {
$('#btnSubmitUpdtItems').removeAttr('disabed');
if (jqXHR.status >= 500) {
Helper.toast('Error', 'just now', 'Please try again');
} else {
Helper.toast('Error', 'just now', jqXHR.responseJSON.meta
.message);
}
resolve({
type: 'error'
});
}
})
})
},
}
const ADel = {
activate: function() {
ADel.event();
},
event: function() {
// on table
$('#tItems').on('click', '.btnDelItem', function(e) {
let row = $(e.target).closest('tr');
let id = row.find('td[data-id]').data('id');
let name = row.find('td[data-name]').data('name');
let price = row.find('td[data-price]').data('price');
ADel.passDataToView({
id,
name,
price,
});
$('#mdlDelItem').data('id', id);
$('#mdlDelItem').modal('show');
});
$('#btnSubmitDelItem').on('click', function() {
let data = {
id: $('#mdlDelItem').data('id'),
};
ADel.submitData(data);
});
// on modal update
$('#btnDelItem_updt').on('click', function(e) {
const { id, name, price } = AUpdt.getData();
ADel.passDataToView({
id,
name,
price,
});
$('#mdlDelItem').data('id', id);
$('#mdlDelItem').modal('show');
});
},
passDataToView: function(data) {
$('#del-name').text(data.name);
$('#del-price').text(data.price);
},
submitData: async function(data) {
return new Promise((resolve, reject) => {
if (typeof $('#btnSubmitDelItem').attr('disabed') != 'undefined') {
resolve({
type: 'fail'
});
return false;
}
$('#btnSubmitDelItem').attr('disabed', true);
$.ajax({
url: "{{ route('api_del_a_items', '') }}/" + data.id,
method: 'DELETE',
crossDomain: true,
processData: true,
headers: {
'x-api-key': Helper.getCookie('_trtk'),
'x-csrf-token': $('meta[name="csrf-token"]').attr('content'),
},
data: data,
success: (data, textStatus, jqXHR) => {
$('#btnSubmitDelItem').removeAttr('disabed');
if (data.meta.type != 'success') {
resolve({
type: 'fail'
});
Helper.toast('Warning', 'just now', data.meta.message);
return false;
}
Helper.toast('Success', 'just now', 'success delete additional item');
$('#mdlDelItem').modal('hide');
$('#mdlUpdtItem').modal('hide');
DTable.reload();
resolve({
type: 'success'
});
},
error: (jqXHR, textStatus, error) => {
$('#btnSubmitDelItem').removeAttr('disabed');
if (jqXHR.status >= 500) {
Helper.toast('Error', 'just now', 'Please try again');
} else {
Helper.toast('Error', 'just now', jqXHR.responseJSON.meta
.message);
}
resolve({
type: 'error'
});
}
})
})
},
}
Wrapper.activate();
</script>
@endsection

View File

@ -0,0 +1,382 @@
@extends('app.app')
@section('title')
Finance - Billing
@endsection
@section('content')
<div class="container-fluid">
<div class="content">
<div class="row">
<div class="col-12">
<label for="" class="form-label">Periode</label>
</div>
<div class="col-sm-12 col-md-6 col-lg-4">
<div class="mb-3 d-flex align-items-center">
<input class="form-control" type="date" id="filter-startDate">
<div class="mx-3">-</div>
<input class="form-control" type="date" id="filter-endDate">
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12 col-md-4 col-lg-3">
<div class="card">
<div class="card-body">
<h6 class="mb-3">Total</h6>
<h4 class="text-end mb-0">Rp<span id="totAllBilling">2.500.000</span></h4>
</div>
</div>
</div>
<div class="col-sm-12 col-md-4 col-lg-3">
<div class="card">
<div class="card-body">
<h6 class="mb-3">Uang Masuk</h6>
<h4 class="text-end mb-0">Rp<span id="totAllBillingPayed">2.500.000</span></h4>
</div>
</div>
</div>
<div class="col-sm-12 col-md-4 col-lg-3">
<div class="card">
<div class="card-body">
<h6 class="mb-3">Belum Diterima</h6>
<h4 class="text-end mb-0">Rp<span id="totAllBillingRemaining">2.500.000</span></h4>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12">
<div class="card">
<div class="card-header">
<div class="row d-flex align-items-center">
<div class="col">
<p class="card-title text-bold mb-0">Penagihan</p>
<p class="card-subtitle text-muted">Daftar Penagihan</p>
</div>
</div>
</div>
<div class="card-body">
<div class="table-responsive">
<table id="tBillings" class="table table-hover dataTable w-100">
<thead>
<tr class="">
<th class="">#</th>
<th class=""></th>
<th class="text-nowrap">Kode Transaksi</th>
<th class="text-nowrap">Nama Client</th>
<th class="w-25">item</th>
<th class="text-center text-nowrap">Total Tagihan (Rp)</th>
{{-- <th class="text-nowrap">Lokasi Penjemputan</th>
<th class="text-nowrap">Lokasi Tujuan</th> --}}
<th class="text-center">Dibayar (Rp)</th>
<th class="text-center">Sisa (Rp)</th>
<th class="text-center">Status</th>
</tr>
</thead>
<tbody>
<tr class="">
<td class="">1</td>
<td class="">
<a href="{{ route('view_keuangan_billing_view') }}"
class="">
<span class="icon ion-eye text-danger fz-16"></span>
</a>
</td>
<td class="text-nowrap">#89901280921890</td>
<td class="text-nowrap">NinjaXpress</td>
<td class="text-nowrap">
<p class="mb-0">Pengantaran Logistik</p>
<p class="mb-0">Jakarta - yogyakarta</p>
<p class="mb-0">22 Apr 2022</p>
</td>
<td class="text-end">2.500.000</td>
<td class="text-end text-success">
<p class="mb-0">500 .000</p>
</td>
<td class="text-end text-danger">0</td>
<td class="text-center"><span class="text-success">sLunas</span></td>
{{-- <td class="">WORK-BONCENG01
<p class="mb-0 text-success text-bold">WORK-BONCENG01</p>
<p class="mb-0">Jl. Letjen Mt. Haryono No.Kav. 20, RW.1, Cawang, Kec. Kramat jati, Kota Jakarta Timur, Daerah Khusus Ibukota Jakarta 13630</p>
</td> --}}
{{-- <td class="">Besi_Prambanan
<p class="mb-0 text-success text-bold">Besi_Prambanan</p>
<p class="mb-0">Jl. Laksda Adisucipto No.80, Ambarukmo, Caturtunggal, Kec. Depok, Kabupaten Sleman, Daerah Istimewa Yogyakarta 55281</p>
</td> --}}
</tr>
</tbody>
</table>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
@endsection
@section('customcss')
@endsection
@section('customjs')
<script>
// $('.dataTable').DataTable({
// "columnDefs": [ {
// "targets": 1,
// "orderable": false
// } ]
// });
</script>
<script>
'use strict';
const State = {
file_jimp_worker: "{{ asset('assets/js/worker/jimp.js') }}",
storage_lara: "{{ asset('storage') }}/",
periodeStartDate: '', // unix timestamps
periodeEndDate: '', // unix timestamps
stts_order: {
wait: "{{ App\Models\Orders::STTS_WAIT }}",
confirm: "{{ App\Models\Orders::STTS_CONFIRM }}",
have_get_vhc: "{{ App\Models\Orders::STTS_HAVE_GET_VHC }}",
pck: "{{ App\Models\Orders::STTS_PCK }}",
go: "{{ App\Models\Orders::STTS_GO }}",
arv: "{{ App\Models\Orders::STTS_ARV }}",
drop: "{{ App\Models\Orders::STTS_DROP }}",
client_pay: "{{ App\Models\Orders::STTS_CLIENT_PAY }}",
vendor_payed: "{{ App\Models\Orders::STTS_VENDOR_PAYED }}",
close: "{{ App\Models\Orders::STTS_CLOSE }}",
cancel: "{{ App\Models\Orders::STTS_CANCEL }}",
},
is_paid: {
yes: "{{ App\Models\Orders::IS_PAID_YES }}",
no: "{{ App\Models\Orders::IS_PAID_NO }}",
},
url_view_detail: "{{ route('view_keuangan_billing_view') }}",
delay_typing_front: 1000,
};
const Wrapper = {
activate: function() {
Filter.activate();
Wrapper.event();
DTable.activate();
},
event: function() {},
};
const Filter = {
activate: function() {
const startDate = moment().startOf('month');
const endDate = moment().endOf('month');
$('#filter-startDate').val(startDate.format('YYYY-MM-DD')).trigger('change');
$('#filter-endDate').val(endDate.format('YYYY-MM-DD')).trigger('change');
State.periodeStartDate = startDate.unix();
State.periodeEndDate = endDate.unix();
Filter.evPeriodeDate();
},
evPeriodeDate: function() {
$('#filter-startDate').on('change', function(e) {
const { isValid, data } = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
if (!isValid) return false;
State.periodeStartDate = data.startDate.unix();
State.periodeEndDate = data.endDate.unix();
DTable.reload();
});
$('#filter-endDate').on('change', function(e) {
const { isValid, data } = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
if (!isValid) return false;
State.periodeStartDate = data.startDate.unix();
State.periodeEndDate = data.endDate.unix();
DTable.reload();
});
},
calcPeriodeDate: function(startDate, endDate) {
if (startDate.format('YYYY-MM-DD') === 'Invalid date') {
Helper.toast('Warning', 'just now', 'Tanggal mulai periode tidak valid');
return { isValid: false };
}
if (endDate.format('YYYY-MM-DD') === 'Invalid date') {
Helper.toast('Warning', 'just now', 'Tanggal akhir periode tidak valid');
return { isValid: false };
}
const duration = moment.duration(endDate.diff(startDate));
const diffDays = duration.days();
if (diffDays > 30) {
Helper.toast('Warning', 'just now', 'Maksimal periode 1 bulan');
return { isValid: false };
}
if (diffDays < 0) {
Helper.toast('Warning', 'just now', 'Rentang periode tidak valid');
return { isValid: false };
}
return { isValid: true, data: { startDate, endDate } };
},
}
const DTable = {
activate: function() {
DTable.reload();
},
reload: function() {
// $('#tBillings').DataTable();
// if (Driver.Table.firstInitDataTable == 1) { loadTableSkeletonLoading() } else { Driver.Table.firstInitDataTable = 1; }
DTable.setSummary({
total_billing: 0,
total_payed: 0,
total_remaining: 0,
});
$('#tBillings').DataTable({
processing: true,
serverSide: false,
bLengthChange: true,
deferRender: true,
destroy: true,
ajax: {
url: "{{ route('api_finance_list_billings') }}?start_date=" + State.periodeStartDate + "&end_date=" + State.periodeEndDate,
type: 'GET',
complete: function(jqXHR, textStatus, c) {
const {
total_billing,
total_payed,
total_remaining,
} = jqXHR.responseJSON.summary;
DTable.setSummary({
total_billing,
total_payed,
total_remaining,
});
// removeTableSkeletonLoading()
},
},
deferRender: true,
columns: [{
data: 'DT_RowIndex',
className: 'text-end',
visible: true,
orderable: true,
searchable: true,
},
{
data: 'action',
className: 'text-center',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
let action = `
<a href="${State.url_view_detail}?code=${row.ord_code}" class="">
<span class="icon ion-eye text-danger fz-16"></span>
</a>
`;
return action;
}
},
{
data: 'ord_code',
className: 'text-start text-nowrap',
visible: true,
orderable: true,
searchable: true,
createdCell: function(td, cellData, rowData, row, col) {
$(td).attr('data-ord_id', rowData.ord_id);
$(td).attr('data-ord_code', rowData.ord_code);
},
render: function(data, type, row, meta) {
return `#${data}`;
},
},
{
data: 'c_pt_name',
className: 'text-start text-nowrap',
visible: true,
orderable: true,
searchable: true,
},
{
data: 'main_item',
className: 'text-start',
visible: true,
orderable: true,
searchable: true,
},
{
data: 'total_billing',
className: 'text-end text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
return (new Intl.NumberFormat('id-ID')).format(data);
},
},
{
data: 'total_payed',
className: 'text-end text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
return '<span class="text-success">' + (new Intl.NumberFormat('id-ID')).format(data) + '</span>';
},
},
{
data: 'total_remaining',
className: 'text-end text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
return '<span class="text-danger">' + (new Intl.NumberFormat('id-ID')).format(data) + '</span>';
},
},
{
data: 'ord_status',
className: 'text-end text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.total_billing === row.total_payed) {
return '<span class="text-success">Lunas</span>';
} else if (State.is_paid.yes == row.is_invc_paid) {
if (row.total_billing !== row.total_payed) {
return '<span class="text-danger">Belum lunas</span>';
}
return '<span class="text-success">Lunas</span>';
} else if (State.stts_order.drop == data) {
// return '<span class="text-dark">Selesai Melakukan Pengantaran</span>';
return '<span class="text-danger">Belum lunas</span>';
} else if (State.stts_order.client_pay == data) {
// return '<span class="text-danger">Invoicing to Client</span>';
return '<span class="text-danger">Belum lunas</span>';
} else if (State.stts_order.vendor_payed == data) {
// return '<span class="text-success">Payment to Vendor</span>';
return '<span class="text-success">Lunas</span>';
} else if (State.stts_order.close == data) {
return '<span class="text-success">Lunas</span>';
} else if (State.stts_order.cancel == data) {
return '<span class="text-danger">Dibatalkan</span>';
} else {
// return '<span class="text-dark">-</span>';
return '<span class="text-danger">Belum lunas</span>';
}
},
},
],
});
},
setSummary: function({
total_billing,
total_payed,
total_remaining,
}) {
$('#totAllBilling').text((new Intl.NumberFormat('id-ID')).format(total_billing));
$('#totAllBillingPayed').text((new Intl.NumberFormat('id-ID')).format(total_payed));
$('#totAllBillingRemaining').text((new Intl.NumberFormat('id-ID')).format(total_remaining));
},
};
Wrapper.activate();
</script>
@endsection

View File

@ -0,0 +1,427 @@
@extends('app.app')
@section('title')
Finance - Ledger Balance
@endsection
@section('content')
<div class="container-fluid">
<div class="content">
<div class="row">
<div class="col-12">
<label for="" class="form-label">Periode</label>
</div>
<div class="col-sm-12 col-md-6 col-lg-4">
<div class="mb-3 d-flex align-items-center">
<input class="form-control" type="date" id="filter-startDate">
<div class="mx-3">-</div>
<input class="form-control" type="date" id="filter-endDate">
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12 col-md-4 col-lg-3">
<div class="card">
<div class="card-body">
<h6 class="mb-3">Uang Masuk</h6>
<h4 class="text-end mb-0">Rp<span id="totAllIn">2.500.000</span></h4>
</div>
</div>
</div>
<div class="col-sm-12 col-md-4 col-lg-3">
<div class="card">
<div class="card-body">
<h6 class="mb-3">Uang Keluar</h6>
<h4 class="text-end mb-0">Rp<span id="totAllOut">2.500.000</span></h4>
</div>
</div>
</div>
<div class="col-sm-12 col-md-4 col-lg-3">
<div class="card">
<div class="card-body">
<h6 class="mb-3">Balance</h6>
<h4 class="text-end mb-0">Rp<span id="totAllBl">2.500.000</span></h4>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12">
<div class="card">
<div class="card-header">
<div class="row d-flex align-items-center">
<div class="col">
<p class="card-title text-bold mb-0">Ledger Balance</p>
<p class="card-subtitle text-muted">Daftar Ledger Balance</p>
</div>
</div>
</div>
<div class="card-body">
<div class="table-responsive">
<table id="tLedgerBl" class="table table-hover dataTable w-100">
<thead>
<tr class="">
<th class="">#</th>
<th class=""></th>
<th class="text-nowrap">Kode Transaksi</th>
<th class="w-25">item</th>
<th class="text-center">Uang Masuk (Rp)</th>
<th class="text-center">Uang Keluar (Rp)</th>
<th class="text-center">Balance (Rp)</th>
</tr>
</thead>
<tbody>
<tr class="">
<td class="">1</td>
<td class="">
<a href="{{ route('view_keuangan_payment_view') }}" class="">
<span class="icon ion-eye text-danger fz-16"></span>
</a>
</td>
<td class="text-nowrap">#89901280921890</td>
<td class="text-nowrap">
<p class="mb-0">Pengantaran Logistik</p>
<p class="mb-0">Jakarta - yogyakarta</p>
<p class="mb-0">22 Apr 2022</p>
</td>
<td class="text-end">2.500.000</td>
<td class="text-end text-success">
<p class="mb-0">500 .000</p>
</td>
<td class="text-end text-danger">0</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
@endsection
@section('customcss')
@endsection
@section('customjs')
<script>
// $('.dataTable').DataTable({
// "columnDefs": [ {
// "targets": 1,
// "orderable": false
// } ]
// });
</script>
<script>
'use strict';
const State = {
file_jimp_worker: "{{ asset('assets/js/worker/jimp.js') }}",
storage_lara: "{{ asset('storage') }}/",
periodeStartDate: '', // unix timestamps
periodeEndDate: '', // unix timestamps
stts_order: {
wait: "{{ App\Models\Orders::STTS_WAIT }}",
confirm: "{{ App\Models\Orders::STTS_CONFIRM }}",
have_get_vhc: "{{ App\Models\Orders::STTS_HAVE_GET_VHC }}",
pck: "{{ App\Models\Orders::STTS_PCK }}",
go: "{{ App\Models\Orders::STTS_GO }}",
arv: "{{ App\Models\Orders::STTS_ARV }}",
drop: "{{ App\Models\Orders::STTS_DROP }}",
client_pay: "{{ App\Models\Orders::STTS_CLIENT_PAY }}",
vendor_payed: "{{ App\Models\Orders::STTS_VENDOR_PAYED }}",
close: "{{ App\Models\Orders::STTS_CLOSE }}",
cancel: "{{ App\Models\Orders::STTS_CANCEL }}",
},
flow_type: {
payment: "{{ App\Models\OrdersAItems::FLOW_TYPE_PAYMENT }}",
billing: "{{ App\Models\OrdersAItems::FLOW_TYPE_BILLING }}",
hybrid: "{{ App\Models\OrdersAItems::FLOW_TYPE_HYBRID }}",
},
cash_type: {
out: "{{ App\Models\OrdersAItems::TYPE_CASH_OUT }}",
in: "{{ App\Models\OrdersAItems::TYPE_CASH_IN }}",
hybrid: "{{ App\Models\OrdersAItems::TYPE_CASH_HYBRID }}",
},
invc_to_client: {
not: "{{ App\Models\OrdersAItems::INVC_TO_CLIENT_NO }}",
yes: "{{ App\Models\OrdersAItems::INVC_TO_CLIENT_YES }}",
},
only_client: {
not: "{{ App\Models\OrdersAItems::ONLY_CLIENT_NO }}",
yes: "{{ App\Models\OrdersAItems::ONLY_CLIENT_YES }}",
},
calc_to_vdr: {
not: "{{ App\Models\OrdersAItems::CALC_TO_VDR_NO }}",
yes: "{{ App\Models\OrdersAItems::CALC_TO_VDR_YES }}",
},
is_a_item_paid: {
not: "{{ App\Models\OrdersAItems::IS_PAID_NO }}",
paid: "{{ App\Models\OrdersAItems::IS_PAID_YES }}",
},
is_aprv: {
not: "{{ App\Models\OrdersAItems::IS_APRV_NO }}",
yes: "{{ App\Models\OrdersAItems::IS_APRV_YES }}",
},
url_view_detail: "{{ route('view_keuangan_payment_view') }}",
delay_typing_front: 1000,
};
const Wrapper = {
activate: function() {
Filter.activate();
Wrapper.event();
DTable.activate();
},
event: function() {},
};
const Filter = {
activate: function() {
const startDate = moment().startOf('month');
const endDate = moment().endOf('month');
$('#filter-startDate').val(startDate.format('YYYY-MM-DD')).trigger('change');
$('#filter-endDate').val(endDate.format('YYYY-MM-DD')).trigger('change');
State.periodeStartDate = startDate.unix();
State.periodeEndDate = endDate.unix();
Filter.evPeriodeDate();
},
evPeriodeDate: function() {
$('#filter-startDate').on('change', function(e) {
const { isValid, data } = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
if (!isValid) return false;
State.periodeStartDate = data.startDate.unix();
State.periodeEndDate = data.endDate.unix();
DTable.reload();
});
$('#filter-endDate').on('change', function(e) {
const { isValid, data } = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
if (!isValid) return false;
State.periodeStartDate = data.startDate.unix();
State.periodeEndDate = data.endDate.unix();
DTable.reload();
});
},
calcPeriodeDate: function(startDate, endDate) {
if (startDate.format('YYYY-MM-DD') === 'Invalid date') {
Helper.toast('Warning', 'just now', 'Tanggal mulai periode tidak valid');
return { isValid: false };
}
if (endDate.format('YYYY-MM-DD') === 'Invalid date') {
Helper.toast('Warning', 'just now', 'Tanggal akhir periode tidak valid');
return { isValid: false };
}
const duration = moment.duration(endDate.diff(startDate));
const diffDays = duration.days();
if (diffDays > 30) {
Helper.toast('Warning', 'just now', 'Maksimal periode 1 bulan');
return { isValid: false };
}
if (diffDays < 0) {
Helper.toast('Warning', 'just now', 'Rentang periode tidak valid');
return { isValid: false };
}
return { isValid: true, data: { startDate, endDate } };
},
}
const DTable = {
table: null,
activate: function() {
DTable.reload();
DTable.eventChildRow();
},
reload: function() {
// $('#tLedgerBl').DataTable();
// if (Driver.Table.firstInitDataTable == 1) { loadTableSkeletonLoading() } else { Driver.Table.firstInitDataTable = 1; }
DTable.setSummary({
total_bl: 0,
total_in: 0,
total_out: 0,
});
DTable.table = $('#tLedgerBl').DataTable({
processing: true,
serverSide: false,
bLengthChange: true,
deferRender: true,
destroy: true,
ajax: {
url: "{{ route('api_finance_list_ledger_balances') }}?start_date=" + State.periodeStartDate + "&end_date=" + State.periodeEndDate,
type: 'GET',
complete: function(jqXHR, textStatus, c) {
const {
total_bl,
total_in,
total_out,
} = jqXHR.responseJSON.summary;
DTable.setSummary({
total_bl,
total_in,
total_out,
});
// removeTableSkeletonLoading()
},
},
deferRender: true,
columns: [{
data: 'DT_RowIndex',
className: 'text-end',
visible: true,
orderable: true,
searchable: true,
},
// {
// data: 'action',
// className: 'text-center',
// visible: true,
// orderable: true,
// searchable: true,
// render: function(data, type, row, meta) {
// let action = `
// <a href="${State.url_view_detail}?code=${row.ord_code}" class="">
// <span class="icon ion-eye text-danger fz-16"></span>
// </a>
// `;
// return action;
// }
// },
{
"className": 'dt-control',
"orderable": false,
"data": null,
"defaultContent": '',
},
{
data: 'ord_code',
className: 'text-start text-nowrap',
visible: true,
orderable: true,
searchable: true,
createdCell: function(td, cellData, rowData, row, col) {
$(td).attr('data-ord_id', rowData.ord_id);
$(td).attr('data-ord_code', rowData.ord_code);
},
render: function(data, type, row, meta) {
return `#${data}`;
},
},
{
data: 'item_desc',
className: 'text-start',
visible: true,
orderable: true,
searchable: true,
},
{
data: 'total_in',
className: 'text-end text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
return '<span class="text-success">' + (new Intl.NumberFormat('id-ID')).format(data) + '</span>';
},
},
{
data: 'total_out',
className: 'text-end text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
return '<span class="text-danger">' + (new Intl.NumberFormat('id-ID')).format(data) + '</span>';
},
},
{
data: 'total_bl',
className: 'text-end text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
return (new Intl.NumberFormat('id-ID')).format(data);
// return (new Intl.NumberFormat('id-ID')).format(row.total_in - row.total_out);
},
},
],
});
},
setSummary: function({
total_bl,
total_in,
total_out,
}) {
$('#totAllBl').text((new Intl.NumberFormat('id-ID')).format(total_bl));
$('#totAllIn').text((new Intl.NumberFormat('id-ID')).format(total_in));
$('#totAllOut').text((new Intl.NumberFormat('id-ID')).format(total_out));
},
eventChildRow: function() {
$('#tLedgerBl tbody').on('click', 'td.dt-control', function () {
var tr = $(this).closest('tr');
var row = DTable.table.row( tr );
if ( row.child.isShown() ) {
// This row is already open - close it
row.child.hide();
tr.removeClass('shown');
}
else {
// Open this row
row.child( DTable.formatChildRow(row.data()) ).show();
tr.addClass('shown');
}
} );
},
formatChildRow: function(d) {
// `d` is the original data object for the row
// let template = `<table cellpadding="5" cellspacing="0" border="0" style="padding-left:50px;">
let template = `<table class="table table-bordered table-hover">
<thead style="border-style:none;">
<tr>
<th>Item</th>
<th class="text-end">Jumlah</th>
<th>Satuan</th>
<th class="text-center">Invoice (Rp)</th>
<th class="text-center">Pembayaran (Rp)</th>
<th class="text-center">Masuk (Rp)</th>
<th class="text-center">Keluar (Rp)</th>
<th class="text-center">Balance (Rp)</th>
</tr>
</thead>
<tbody>`
for (let item of d.a_items) {
// perlu diperbaiki cara if di query, jika kalkulasi ke vendor maka is_aprv = , jika ke client is_bill_aprv = 1
if (item.calc_to_vdr == State.calc_to_vdr.yes && item.is_aprv != State.is_aprv.yes) continue;
if (item.invc_to_client == State.invc_to_client.yes && item.is_bill_aprv != State.is_aprv.yes) continue;
let small_desc = '', amt_in = 0, amt_out = 0, amt_bl = 0;
if (item.is_bill_paid == State.is_a_item_paid.paid) {
amt_in = item.amt_in;
small_desc += `<br><small>waktu dibayarkan <span class="text-success">${moment.unix(item.paid_bill_at).format('DD MMM YYYY HH:mm:ss')}</span></small>`;
}
if (item.is_paid == State.is_a_item_paid.paid) {
amt_out = item.amt_out;
small_desc += `<br><small>waktu keluar <span class="text-danger">${moment.unix(item.paid_at).format('DD MMM YYYY HH:mm:ss')}</span></small>`;
}
if (amt_in != 0 || amt_out != 0) {
amt_bl = item.amt_bl;
}
template += `<tr>
<td>${item.item_desc}${small_desc}</td>
<td class="text-end">${item.unit_qty}</td>
<td>${item.unit_type_name}</td>
<td class="text-end">${(new Intl.NumberFormat('id-ID')).format(item.amt_in)}</td>
<td class="text-end">${(new Intl.NumberFormat('id-ID')).format(item.amt_out)}</td>
<td class="text-end text-success">${(new Intl.NumberFormat('id-ID')).format(amt_in)}</td>
<td class="text-end text-danger">${(new Intl.NumberFormat('id-ID')).format(amt_out)}</td>
<td class="text-end">${(new Intl.NumberFormat('id-ID')).format(amt_bl)}</td>
</tr>`;
}
template += `</tbody>
</table>`;
return template
},
};
Wrapper.activate();
</script>
@endsection

View File

@ -0,0 +1,413 @@
@extends('app.app')
@section('title')
Finance - Payment
@endsection
@section('content')
<div class="container-fluid">
<div class="content">
<div class="row">
<div class="col-12">
<label for="" class="form-label">Periode</label>
</div>
<div class="col-sm-12 col-md-6 col-lg-4">
<div class="mb-3 d-flex align-items-center">
<input class="form-control" type="date" id="filter-startDate">
<div class="mx-3">-</div>
<input class="form-control" type="date" id="filter-endDate">
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12 col-md-4 col-lg-3">
<div class="card">
<div class="card-body">
<h6 class="mb-3">Total</h6>
<h4 class="text-end mb-0">Rp<span id="totAllPayment">2.500.000</span></h4>
</div>
</div>
</div>
<div class="col-sm-12 col-md-4 col-lg-3">
<div class="card">
<div class="card-body">
<h6 class="mb-3">Uang Keluar</h6>
<h4 class="text-end mb-0">Rp<span id="totAllPaymentPayed">2.500.000</span></h4>
</div>
</div>
</div>
<div class="col-sm-12 col-md-4 col-lg-3">
<div class="card">
<div class="card-body">
<h6 class="mb-3">Belum Bayar</h6>
<h4 class="text-end mb-0">Rp<span id="totAllPaymentRemaining">2.500.000</span></h4>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12">
<div class="card">
<div class="card-header">
<div class="row d-flex align-items-center">
<div class="col">
<p class="card-title text-bold mb-0">Pembayaran</p>
<p class="card-subtitle text-muted">Daftar Pembayaran</p>
</div>
</div>
</div>
<div class="card-body">
<div class="table-responsive">
<table id="tPayments" class="table table-hover dataTable w-100">
<thead>
<tr class="">
<th class="">#</th>
<th class=""></th>
<th class="text-nowrap">Kode Transaksi</th>
<th class="text-nowrap">Nama Vendor</th>
<th class="w-25">item</th>
<th class="text-center">Total (Rp)</th>
<th class="text-center">Dibayar (Rp)</th>
<th class="text-center">Sisa (Rp)</th>
<th class="text-center">Status</th>
</tr>
</thead>
<tbody>
<tr class="">
<td class="">1</td>
<td class="">
<a href="{{ route('view_keuangan_payment_view') }}" class="">
<span class="icon ion-eye text-danger fz-16"></span>
</a>
</td>
<td class="text-nowrap">#89901280921890</td>
<td class="text-nowrap">Jangan Lupa Bahagia (JLB)</td>
<td class="text-nowrap">
<p class="mb-0">Pengantaran Logistik</p>
<p class="mb-0">Jakarta - yogyakarta</p>
<p class="mb-0">22 Apr 2022</p>
</td>
<td class="text-end">2.500.000</td>
<td class="text-end text-success">
<p class="mb-0">500 .000</p>
</td>
<td class="text-end text-danger">0</td>
<td class="text-center"><span class="text-success">sLunas</span></td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
@endsection
@section('customcss')
@endsection
@section('customjs')
<script>
// $('.dataTable').DataTable({
// "columnDefs": [ {
// "targets": 1,
// "orderable": false
// } ]
// });
</script>
<script>
'use strict';
const State = {
file_jimp_worker: "{{ asset('assets/js/worker/jimp.js') }}",
storage_lara: "{{ asset('storage') }}/",
periodeStartDate: '', // unix timestamps
periodeEndDate: '', // unix timestamps
stts_order: {
wait: "{{ App\Models\Orders::STTS_WAIT }}",
confirm: "{{ App\Models\Orders::STTS_CONFIRM }}",
have_get_vhc: "{{ App\Models\Orders::STTS_HAVE_GET_VHC }}",
pck: "{{ App\Models\Orders::STTS_PCK }}",
go: "{{ App\Models\Orders::STTS_GO }}",
arv: "{{ App\Models\Orders::STTS_ARV }}",
drop: "{{ App\Models\Orders::STTS_DROP }}",
client_pay: "{{ App\Models\Orders::STTS_CLIENT_PAY }}",
vendor_payed: "{{ App\Models\Orders::STTS_VENDOR_PAYED }}",
close: "{{ App\Models\Orders::STTS_CLOSE }}",
cancel: "{{ App\Models\Orders::STTS_CANCEL }}",
},
is_paid: {
yes: "{{ App\Models\Orders::IS_PAID_YES }}",
no: "{{ App\Models\Orders::IS_PAID_NO }}",
},
url_view_detail: "{{ route('view_keuangan_payment_view') }}",
delay_typing_front: 1000,
};
const Wrapper = {
activate: function() {
Filter.activate();
Wrapper.event();
DTable.activate();
},
event: function() {},
getHtmlSttsOrd: function(stts, row) {
if (row.total_payment === row.total_payed) {
return '<span class="text-success">Lunas</span>';
} else if (State.is_paid.yes == row.is_vdr_paid) {
if (row.total_payment !== row.total_payed) {
return '<span class="text-danger">Belum lunas</span>';
}
return '<span class="text-success">Lunas</span>';
} else if (State.stts_order.drop == stts) {
// return '<span class="text-dark">Selesai Melakukan Pengantaran</span>';
return '<span class="text-danger">Belum lunas</span>';
} else if (State.stts_order.client_pay == stts) {
// return '<span class="text-danger">Invoicing to Client</span>';
return '<span class="text-danger">Belum lunas</span>';
} else if (State.stts_order.vendor_payed == stts) {
// return '<span class="text-success">Payment to Vendor</span>';
return '<span class="text-danger">Belum lunas</span>';
} else if (State.stts_order.close == stts) {
return '<span class="text-success">Lunas</span>';
} else if (State.stts_order.cancel == stts) {
return '<span class="text-danger">Dibatalkan</span>';
} else {
// return '<span class="text-dark">-</span>';
return '<span class="text-danger">Belum lunas</span>';
}
},
};
const Filter = {
activate: function() {
const startDate = moment().startOf('month');
const endDate = moment().endOf('month');
$('#filter-startDate').val(startDate.format('YYYY-MM-DD')).trigger('change');
$('#filter-endDate').val(endDate.format('YYYY-MM-DD')).trigger('change');
State.periodeStartDate = startDate.unix();
State.periodeEndDate = endDate.unix();
Filter.evPeriodeDate();
},
evPeriodeDate: function() {
$('#filter-startDate').on('change', function(e) {
const { isValid, data } = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
if (!isValid) return false;
State.periodeStartDate = data.startDate.unix();
State.periodeEndDate = data.endDate.unix();
DTable.reload();
});
$('#filter-endDate').on('change', function(e) {
const { isValid, data } = Filter.calcPeriodeDate(moment($('#filter-startDate').val()), moment($('#filter-endDate').val()))
if (!isValid) return false;
State.periodeStartDate = data.startDate.unix();
State.periodeEndDate = data.endDate.unix();
DTable.reload();
});
},
calcPeriodeDate: function(startDate, endDate) {
if (startDate.format('YYYY-MM-DD') === 'Invalid date') {
Helper.toast('Warning', 'just now', 'Tanggal mulai periode tidak valid');
return { isValid: false };
}
if (endDate.format('YYYY-MM-DD') === 'Invalid date') {
Helper.toast('Warning', 'just now', 'Tanggal akhir periode tidak valid');
return { isValid: false };
}
const duration = moment.duration(endDate.diff(startDate));
const diffDays = duration.days();
if (diffDays > 30) {
Helper.toast('Warning', 'just now', 'Maksimal periode 1 bulan');
return { isValid: false };
}
if (diffDays < 0) {
Helper.toast('Warning', 'just now', 'Rentang periode tidak valid');
return { isValid: false };
}
return { isValid: true, data: { startDate, endDate } };
},
}
const DTable = {
activate: function() {
DTable.reload();
},
reload: function() {
// $('#tPayments').DataTable();
// if (Driver.Table.firstInitDataTable == 1) { loadTableSkeletonLoading() } else { Driver.Table.firstInitDataTable = 1; }
DTable.setSummary({
total_payment: 0,
total_payed: 0,
total_remaining: 0,
});
$('#tPayments').DataTable({
processing: true,
serverSide: false,
bLengthChange: true,
deferRender: true,
destroy: true,
ajax: {
url: "{{ route('api_finance_list_payments') }}?start_date=" + State.periodeStartDate + "&end_date=" + State.periodeEndDate,
type: 'GET',
complete: function(jqXHR, textStatus, c) {
const {
total_payment,
total_payed,
total_remaining,
} = jqXHR.responseJSON.summary;
DTable.setSummary({
total_payment,
total_payed,
total_remaining,
});
// removeTableSkeletonLoading()
},
},
deferRender: true,
columns: [{
data: 'DT_RowIndex',
className: 'text-end',
visible: true,
orderable: true,
searchable: true,
},
{
data: 'action',
className: 'text-center',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
let ord_codes = row.ord_code;
if (typeof row.childs != 'undefined' && row.childs.length > 0) {
for (const child of row.childs) {
ord_codes += ',' + child.ord_code;
}
}
let action = `
<a href="${State.url_view_detail}?code=${ord_codes}" class="">
<span class="icon ion-eye text-danger fz-16"></span>
</a>
`;
return action;
}
},
{
data: 'ord_code',
className: 'text-start text-nowrap',
visible: true,
orderable: true,
searchable: true,
createdCell: function(td, cellData, rowData, row, col) {
$(td).attr('data-ord_id', rowData.ord_id);
$(td).attr('data-ord_code', rowData.ord_code);
},
render: function(data, type, row, meta) {
let txt = '#' + data;
for (const child of row.childs) {
txt += '<br>#' + child.ord_code;
}
return txt;
},
},
{
data: 'vdr_name',
className: 'text-start text-nowrap',
visible: true,
orderable: true,
searchable: true,
},
{
data: 'main_item',
className: 'text-start',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
let txt = data;
for (const child of row.childs) {
txt += '<br><br>' + child.main_item;
}
return txt;
},
},
{
data: 'total_payment',
className: 'text-end text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
let txt = data;
for (const child of row.childs) {
txt += child.total_payment;
}
return (new Intl.NumberFormat('id-ID')).format(txt);
},
},
{
data: 'total_payed',
className: 'text-end text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
let txt = data;
for (const child of row.childs) {
txt += child.total_payed;
}
return '<span class="text-success">' + (new Intl.NumberFormat('id-ID')).format(txt) + '</span>';
},
},
{
data: 'total_remaining',
className: 'text-end text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
let txt = data;
for (const child of row.childs) {
txt += child.total_remaining;
}
return '<span class="text-danger">' + (new Intl.NumberFormat('id-ID')).format(txt) + '</span>';
},
},
{
data: 'ord_status',
className: 'text-end text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
let txt = Wrapper.getHtmlSttsOrd(data, row);
if (txt.indexOf('>Belum') > -1) {
return txt;
}
for (const child of row.childs) {
txt = Wrapper.getHtmlSttsOrd(child.ord_status, child);
if (txt.indexOf('>Belum') > -1) {
return txt;
}
}
return txt;
},
},
],
});
},
setSummary: function({
total_payment,
total_payed,
total_remaining,
}) {
$('#totAllPayment').text((new Intl.NumberFormat('id-ID')).format(total_payment));
$('#totAllPaymentPayed').text((new Intl.NumberFormat('id-ID')).format(total_payed));
$('#totAllPaymentRemaining').text((new Intl.NumberFormat('id-ID')).format(total_remaining));
},
};
Wrapper.activate();
</script>
@endsection

View File

@ -0,0 +1,401 @@
@extends('app.app')
@section('title')
Finance - Dana
@endsection
@section('content')
<div class="container-fluid">
<div class="content">
<div class="row">
<div class="col-12">
<div class="card">
<div class="card-header">
<p class="card-title text-bold mb-0">Riwayat Transfer Uang Saku</p>
<p class="card-subtitle text-muted">Daftar Transfer</p>
</div>
<div class="card-body">
<div class="table-responsive">
<table id="tTable" class="table table-hover dataTable w-100">
<thead>
<tr class="">
<th class="">#</th>
<th class=""></th>
<th class="text-nowrap">Kode Order</th>
{{-- <th class="text-nowrap">Kode Referensi</th> --}}
<th class="text-start">Lokasi Transfer</th>
<th class="text-nowrap">Bank</th>
<th class="text-nowrap">Pemlik Rekening</th>
<th class="text-nowrap text-end">No Rekening</th>
<th class="text-nowrap text-end">Total (Rp)</th>
<th class="text-center">Status</th>
<th class="text-start">Catatan</th>
</tr>
</thead>
<tbody>
<tr class="">
<td class="">1</td>
<td class="">
<a href="#" class="btnResend text-decoration-none me-1">
<span class="icon ion-undo text-danger fz-16"></span>
</a>
</td>
<td class="text-nowrap">#52314789</td>
{{-- <td class="text-nowrap">#89901280921890</td> --}}
<td class="text-start">Jangan Lupa Bahagia (JLB)</td>
<td class="text-nowrap">
<p class="mb-0">BCA (014)</p>
<p class="mb-0">Bank Central Asia</p>
</td>
<td class="text-start">Rafif</td>
<td class="text-center">0101010100101</td>
<td class="text-center">2.500.000</td>
<td class="text-center"><span class="text-danger">Fail</span></td>
<td class="text-start">-</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
{{-- modal resend pocket money tf --}}
<div class="modal fade" id="mdlResendPocket" data-bs-backdrop="static" data-bs-keyboard="false"
aria-labelledby="mdlResendPocketLabel" aria-hidden="true">
<div class="modal-dialog modal-md modal-dialog-centered modal-dialog-scrollable">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="mdlResendPocketLabel">Transfer Ulang</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
</div>
<div class="modal-body">
<form action="">
<div class="row">
<div class="col-sm-12">
<div class="mb-3">
<div class="form-check">
{{-- <input class="form-check-input" name="isResendPocket" type="checkbox" value="no" id="isResendPocket"> --}}
<label class="form-check-label text-dark" for="isResendPocket">
<p class="mb-1">Transfer ulang uang saku ?</p>
</label>
</div>
</div>
</div>
</div>
</form>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-sm btn-secondary" data-bs-dismiss="modal">Cancel</button>
<button type="button" id="btnSubmitResendPocket" class="btn btn-sm btn-primary">Transfer</button>
<div id="btnSubmitResendPocketSpinner" class="d-none">
<div class="spinner-border" role="status">
<span class="visually-hidden">Loading...</span>
</div>
</div>
</div>
</div>
</div>
</div>
{{-- modal resend pocket money tf --}}
@endsection
@section('customjs')
<script>
'use strict'
const State = {
stts: {
unpaid: "{{ \App\Models\OrdersLogsTf::STTS_UNPAID }}",
paid: "{{ \App\Models\OrdersLogsTf::STTS_PAID }}",
fail: "{{ \App\Models\OrdersLogsTf::STTS_FAIL }}",
pending: "{{ \App\Models\OrdersLogsTf::STTS_PENDING }}",
},
checkpoint_paid: {
unpaid: "{{ \App\Models\OrdersCheckpoints::IS_UNPAID }}",
paid: "{{ \App\Models\OrdersCheckpoints::IS_PAID }}",
fail: "{{ \App\Models\OrdersCheckpoints::IS_TF_FAIL }}",
},
delay_type_number: 1000,
storage_lara: "{{ asset('storage') }}/",
file_jimp_worker: "{{ asset('assets/js/worker/jimp.js') }}",
};
const Wrapper = {
activate: function() {
DTable.activate();
ResendPocket.activate();
},
};
const DTable = {
activate: function() {
DTable.reload();
},
reload: function() {
// $('#tTable').DataTable();
// if (Driver.Table.firstInitDataTable == 1) { loadTableSkeletonLoading() } else { Driver.Table.firstInitDataTable = 1; }
$('#tTable').DataTable({
processing: true,
serverSide: false,
bLengthChange: true,
deferRender: true,
destroy: true,
// fixedColumns: {
// left: 3,
// },
ajax: {
url: "{{ route('api_finance_list_pocket_tf_history') }}",
type: 'GET',
complete: function() {
// removeTableSkeletonLoading()
},
},
deferRender: true,
columns: [{
data: 'DT_RowIndex',
className: 'text-end',
visible: true,
orderable: true,
searchable: true,
},
{
data: 'action',
className: 'text-center',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
let action = '';
if (row.pocket_is_paid == State.checkpoint_paid.fail) {
action += `
<a href="#" class="btnResendPocket text-decoration-none me-1" data-bs-toggle="tooltip" data-bs-placement="top" title="Kirim Ulang">
<span class="icon ion-refresh text-danger fz-16"></span>
</a>
`;
}
// <a href="#" class="text-decoration-none text-danger btnDelDrv">
// <span class="icon ion-trash-b fz-16"></span>
// </a>
return action;
}
},
{
data: 'ord_code',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
createdCell: function(td, cellData, rowData, row, col) {
// $(td).attr('data-id', rowData.id);
$(td).attr('data-ord_id', rowData.ord_id);
$(td).attr('data-ord_code', rowData.ord_code);
$(td).attr('data-checkpoint_id', rowData.ord_checkpoint_id);
},
render: function(data, type, row, meta) {
return '#'+data;
},
},
// {
// data: 'ref_code',
// className: 'text-nowrap',
// visible: true,
// orderable: true,
// searchable: true,
// render: function(data, type, row, meta) {
// return '#'+data;
// },
// },
{
data: 'pck_name',
className: 'text-start',
visible: true,
orderable: true,
searchable: true,
},
{
data: 'bank_id',
className: 'text-start text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
return `
<p class="mb-0">${row.bank_short_name} (${row.bank_code})</p>
<p class="mb-0">${row.bank_name}</p>
`;
},
},
{
data: 'bank_acc_name',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
},
{
data: 'bank_acc_number',
className: 'text-center',
visible: true,
orderable: true,
searchable: true,
},
{
data: 'pocket_total',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
return (new Intl.NumberFormat('id-ID')).format(data);
},
},
// {
// data: 'stts', // log.stts
// className: 'text-center',
// visible: true,
// orderable: true,
// searchable: true,
// render: function(data, type, row, meta) {
// if (data == State.stts.unpaid) {
// return '<span class="text-dark">Unpaid</span>';
// } else if (data == State.stts.paid) {
// return '<span class="text-success">Success</span>';
// } else if (data == State.stts.fail) {
// return '<span class="text-danger">Fail</span>';
// } else if (data == State.stts.pending) {
// return '<span class="text-warning">Pending</span>';
// }
// return '<span class="text-danger">Fail</span>';
// },
// },
{
data: 'pocket_is_paid', // checkpoint.is_paid
className: 'text-center',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (data == State.checkpoint_paid.unpaid) {
return '<span class="text-dark">Unpaid</span>';
} else if (data == State.checkpoint_paid.paid) {
return '<span class="text-success">Success</span>';
} else if (data == State.checkpoint_paid.fail) {
return '<span class="text-danger">Fail</span>';
} else if (data == State.checkpoint_paid.pending) {
return '<span class="text-warning">Pending</span>';
}
return '<span class="text-danger">Fail</span>';
},
},
{
data: 'tf_note',
className: 'text-start',
visible: true,
orderable: true,
searchable: true,
},
],
});
},
};
const ResendPocket = {
activate: function () {
$('#tTable').on('click', '.btnResendPocket', async function(e) {
let checkpoint_id = $(e.target).closest('tr').find('td[data-checkpoint_id]').data('checkpoint_id');
console.log(checkpoint_id);
// let resp = await ResendPocket.reqData({
// checkpoint_id
// });
// if (resp.type != 'success') {
// Helper.toast('Riwayat tidak ditemukan', 'just now', 'please try again');
// return false;
// }
// ResendPocket.passDataToView(resp.data);
$('#mdlResendPocket').data('checkoint_id', checkpoint_id);
$('#mdlResendPocket').modal('show');
});
$('#btnSubmitResendPocket').on('click', async function() {
let data = ResendPocket.getData();
let isValid = ResendPocket.checkData(data, true);
if (!isValid) return false;
let submitItems = await ResendPocket.submitResendPocket(data);
});
},
getData: function() {
let data = {};
data.ord_checkpoint_id = $('#mdlResendPocket').data('checkoint_id');
return data;
},
checkData: function(data, isAlert = false) {
if (!data.ord_checkpoint_id) {
if (isAlert) Helper.toast('Warning', 'just now', 'Riwayat transfer tidak valid');
return false;
}
return true;
},
submitResendPocket: async function(data) {
return new Promise((resolve, reject) => {
if (typeof $('#btnSubmitResendPocket').attr('disabed') != 'undefined') {
resolve({
type: 'fail'
});
return false;
}
$('#btnSubmitResendPocket').attr('disabed', true);
$('#btnSubmitResendPocketSpinner').removeClass('d-none');
$.ajax({
url: "{{ route('api_finance_resend_pocket') }}",
method: 'POST',
crossDomain: true,
processData: true,
headers: {
'x-csrf-token': $('meta[name="csrf-token"]').attr('content'),
'x-api-key': Helper.getCookie('_trtk'),
},
data: data,
success: (data, textStatus, jqXHR) => {
$('#btnSubmitResendPocket').removeAttr('disabed');
$('#btnSubmitResendPocketSpinner').addClass('d-none');
if (data.meta.type != 'success') {
resolve({
type: 'fail'
});
Helper.toast('Warning', 'just now', data.meta.message);
return false;
}
Helper.toast('Success', 'just now', 'success transfer ulang');
$('#mdlResendPocket').modal('hide');
DTable.reload();
resolve({
type: 'success'
});
},
error: (jqXHR, textStatus, error) => {
$('#btnSubmitResendPocket').removeAttr('disabed');
$('#btnSubmitResendPocketSpinner').addClass('d-none');
if (jqXHR.status >= 500) {
Helper.toast('Error', 'just now', 'please try again');
} else {
Helper.toast('Error', 'just now', jqXHR.responseJSON.meta
.message);
}
resolve({
type: 'error'
});
}
})
});
},
}
Wrapper.activate();
</script>
@endsection