Files
gps-frontend/resources/views/menu_v2/Finance/billing.blade.php
meusinfirmary b9891d2f81 Initial commit
2025-04-22 14:33:37 +07:00

383 lines
18 KiB
PHP
Executable File

@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