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

221 lines
11 KiB
PHP
Executable File

@extends('app.app')
@section('title')
User Client
@endsection
@section('customcss')
@endsection
@section('content')
<div class="container-fluid">
<div class="content">
<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">Transaksi</p>
<p class="card-subtitle text-muted">Daftar Transaksi</p>
</div>
<div class="col text-end">
<a href="{{ route('view_user_client_transaction_add') }}" class="btn btn-sm btn-danger">Tambah Transaksi</a>
</div>
</div>
</div>
<div class="card-body">
<div class="table-responsive">
<table id="tOrders" class="table table-hover dataTable">
<thead>
<tr class="">
<th class="text-nowrap">#</th>
<th class="text-nowrap text-center">Tindakan</th>
<th class="text-nowrap">Nomor Pesanan</th>
<th class="text-nowrap text-center">Waktu Pesanan</th>
<th class="text-nowrap">Lokasi Penjemputan</th>
<th class="text-nowrap">Lokasi Pengantaran</th>
<th class="text-nowrap">Status Pesanan</th>
</tr>
</thead>
<tbody>
<tr class="">
<td class="text-nowrap">#</td>
<td class="text-nowrap">#BKS00928887210001</td>
<td class="text-nowrap text-center">Feb 20, 2022 17:29:50</td>
<td class="text-nowrap">Kantor Pusat SiCepat (yogyakarta)</td>
<td class="text-nowrap">Kantor Pusat SiCepat (yogyakarta)</td>
<td class="text-nowrap"><span class="badge bg-warning text-dark">Waiting For
Confirmation</span></td>
<td class="text-nowrap text-center">
<a href="{{ route('view_user_client_transaction_view') }}" class="text-danger"><span class="icon ion-eye fz-16"></span></a>
</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
@endsection
@section('customjs')
<script>
'use strict';
const State = {
file_jimp_worker: "{{ asset('assets/js/worker/jimp.js') }}",
storage_lara: "{{ asset('storage') }}/",
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 }}",
},
url_view_order: "{{ route('view_user_client_transaction_view') }}",
};
const Wrapper = {
activate: function() {
Wrapper.event();
OrdTable.activate();
},
event: function() {},
};
const OrdTable = {
activate: function() {
OrdTable.reload();
},
reload: function() {
// $('#tOrders').DataTable();
// if (User.Table.firstInitDataTable == 1) { loadTableSkeletonLoading() } else { User.Table.firstInitDataTable = 1; }
$('#tOrders').DataTable({
processing: true,
serverSide: false,
bLengthChange: true,
deferRender: true,
destroy: true,
ajax: {
url: "{{ route('api_user_client_list_orders') }}",
type: 'GET',
complete: function(jqXHR, textStatus, c) {
let count = jqXHR.responseJSON.count;
if (typeof count != 'undefined') {
$('#count_orders').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="${State.url_view_order}?code=${row.ord_code}" class="text-danger"><span class="icon ion-eye fz-16"></span></a>
`;
return action;
}
},
{
data: 'ord_code',
className: 'text-start',
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-phone', rowData.phone);
$(td).attr('data-phone_code', rowData.phone_code);
$(td).attr('data-client_group_name', rowData.client_group_name);
},
render: function(data, type, row, meta) {
return '#' + data;
},
},
{
data: 'crt',
className: 'text-center',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
return moment.unix(data).format('DD MMM YYYY HH:mm:ss');
},
},
{
data: 'pck_name',
className: 'text-start text-nowrap',
visible: true,
orderable: true,
searchable: true,
},
{
data: 'drop_name',
className: 'text-start text-nowrap',
visible: true,
orderable: true,
searchable: true,
},
{
data: 'status',
className: 'text-center',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (State.stts_order.wait == data) {
return '<span class="badge bg-warning text-dark">Menunggu Konfirmasi</span>';
} else if (State.stts_order.confirm == data) {
return '<span class="badge bg-warning text-dark">Mencari Kendaraan</span>';
} else if (State.stts_order.have_get_vhc == data) {
return '<span class="badge bg-warning text-dark">Kendaraan Menuju Lokasi Penjemputan</span>';
} else if (State.stts_order.pck == data) {
return '<span class="badge bg-warning text-dark">Berhasil Mengambil Pesanan</span>';
} else if (State.stts_order.go == data) {
return '<span class="badge bg-info text-dark">Menuju Lokasi Pengantaran</span>';
} else if (State.stts_order.arv == data) {
return '<span class="badge bg-info text-dark">Tiba Dilokasi Pengantaran</span>';
} else if (State.stts_order.drop == data) {
return '<span class="badge bg-warning text-dark">Selesai Melakukan Pengantaran</span>';
} else if (State.stts_order.client_pay == data) {
return '<span class="badge bg-danger text-light">Selesai</span>';
} else if (State.stts_order.vendor_payed == data) {
return '<span class="badge bg-danger text-light">Selesai</span>';
} else if (State.stts_order.close == data) {
return '<span class="badge bg-danger text-light">Selesai</span>';
} else if (State.stts_order.cancel == data) {
return '<span class="badge bg-danger text-light">Dibatalkan</span>';
} else {
return '<span class="badge bg-secondary text-white">-</span>';
}
},
},
],
});
},
};
Wrapper.activate();
</script>
@endsection