MIF_E31210104/app/Views/home/transaksi/historyTransaksi.php

133 lines
5.8 KiB
PHP

<?= $this->extend('layout/home') ?>
<?= $this->section('content') ?>
<div class="py-32">
<div class="font-semibold text-4xl text-center mb-10"><?= $title ?></div>
<div class="flex justify-between items-center">
<div class="py-5">
<div class="bg-white rounded-lg flex p-2 text-gray-800">
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor" class="w-5 h-5 mr-3">
<path stroke-linecap="round" stroke-linejoin="round" d="m21 21-5.197-5.197m0 0A7.5 7.5 0 1 0 5.196 5.196a7.5 7.5 0 0 0 10.607 10.607Z" />
</svg>
<input type="text" id="searchInput" placeholder="Cari data.." class="bg-white focus:outline-none">
</div>
</div>
</div>
<div class="bg-white text-gray-800 rounded-lg p-5 px-10 shadow-xl">
<div id="tableContainer">
<table class="w-full">
<thead>
<tr class="text-left">
<th class="py-3">#</th>
<th class="py-3">Nama</th>
<th class="py-3">Nomor WhatsApp</th>
<th class="py-3">Total</th>
<th class="py-3">Kategori Pembarayan</th>
<th class="py-3">Tipe Pembayaran</th>
<th class="py-3">Status</th>
<th class="py-3">Keterangan</th>
<th class="py-3">Tanggal</th>
<th class="py-3">Aksi</th>
</tr>
</thead>
<tbody id="tableBody">
</tbody>
</table>
</div>
<div id="pagination" class="mt-5"></div>
</div>
</div>
<?= $this->endSection() ?>
<?= $this->section('script') ?>
<script>
const itemsPerPage = 5;
let currentPage = 1;
let originalData = <?= json_encode($data) ?>;
let data = originalData.slice();
function formatRupiah(angka) {
var reverse = angka.toString().split('').reverse().join(''),
ribuan = reverse.match(/\d{1,3}/g);
ribuan = ribuan.join('.').split('').reverse().join('');
return 'Rp ' + ribuan;
}
function displayData() {
const startIndex = (currentPage - 1) * itemsPerPage;
const endIndex = startIndex + itemsPerPage;
const displayData = data.slice(startIndex, endIndex);
const tableBody = document.getElementById('tableBody');
let tableContent = '';
displayData.forEach((item, index) => {
tableContent += `
<tr>
<td class="font-bold">${startIndex + index + 1}</td>
<td>${item['name']}</td>
<td>${item['nomor']}</td>
<td>${formatRupiah(item['total'])}</td>
<td>${item['kategori_pembayaran'] === 'bulanan' ? 'Bulanan' : 'Instalasi Baru' }</td>
<td>${item['type_pembayaran'] === '1' ? 'Online' : 'COD (Cash On Delivery)'}</td>
<td><span class="py-1 px-3 rounded-lg text-white ${item['status'] === '0' ? 'bg-red-500': 'bg-green-500'}">${item['status'] === '0' ? 'Belum Bayar' : 'Berhasil'}</span></td>
<td>${item['kategori_pembayaran'] === 'bulanan' ? 'Pembayaran tagihan bulanan a/n' : 'Pembayaran tagihan pemasangan a/n' } <span class="font-bold">${item['name']}</span> sebesar ${formatRupiah(item['total'])}</td>
<td>${item['created_at']}</td>
<td class="text-white flex gap-2">
<a href="<?= base_url('home/transaksi/saya/detail/') ?>${item['id']}" class="bg-sky-500 p-2 rounded-lg">
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor" class="w-4 h-4">
<path stroke-linecap="round" stroke-linejoin="round" d="M2.036 12.322a1.012 1.012 0 0 1 0-.639C3.423 7.51 7.36 4.5 12 4.5c4.638 0 8.573 3.007 9.963 7.178.07.207.07.431 0 .639C20.577 16.49 16.64 19.5 12 19.5c-4.638 0-8.573-3.007-9.963-7.178Z" />
<path stroke-linecap="round" stroke-linejoin="round" d="M15 12a3 3 0 1 1-6 0 3 3 0 0 1 6 0Z" />
</svg>
</a>
</td>
</tr>
`;
});
tableBody.innerHTML = tableContent;
}
function generatePagination() {
const totalPages = Math.ceil(data.length / itemsPerPage);
let paginationHTML = '';
for (let i = 1; i <= totalPages; i++) {
paginationHTML += `
<a href="#" onclick="changePage(${i})" class="${currentPage === i ? 'font-bold text-white bg-sky-500 mr-2 p-2 px-4 rounded-lg' : ''}">${i}</a>
`;
}
document.getElementById('pagination').innerHTML = paginationHTML;
}
function changePage(pageNumber) {
currentPage = pageNumber;
displayData();
generatePagination();
}
function handleSearch() {
const searchInput = document.getElementById('searchInput').value.trim().toLowerCase();
if (searchInput === '') {
data = originalData.slice();
} else {
data = originalData.filter(item => {
return item['total'].toLowerCase().includes(searchInput) ||
item['status'].toLowerCase().includes(searchInput);
});
}
currentPage = 1;
displayData();
generatePagination();
}
document.getElementById('searchInput').addEventListener('input', handleSearch);
displayData();
generatePagination();
</script>
<?= $this->endSection() ?>