277 lines
14 KiB
PHP
277 lines
14 KiB
PHP
<?php
|
|
declare(strict_types=1);
|
|
require_once 'db/config.php';
|
|
|
|
$current_branch_id = (int)($_GET['branch_id'] ?? 1);
|
|
$db = db();
|
|
|
|
// Fetch branches for the switcher
|
|
$branches = $db->query("SELECT * FROM branches")->fetchAll();
|
|
$current_branch = array_filter($branches, fn($b) => $b['id'] == $current_branch_id);
|
|
$current_branch = reset($current_branch);
|
|
|
|
// Mock data for dashboard stats (to be replaced with real queries later)
|
|
$stats = [
|
|
'total_sales' => 'Rp 12.450.000',
|
|
'total_orders' => 128,
|
|
'total_products' => 45,
|
|
'total_members' => 12
|
|
];
|
|
?>
|
|
<!DOCTYPE html>
|
|
<html lang="id">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
<title>POS Pro - Dashboard Modern</title>
|
|
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css" rel="stylesheet">
|
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.0/font/bootstrap-icons.css">
|
|
<link href="assets/css/custom.css?v=<?php echo time(); ?>" rel="stylesheet">
|
|
<!-- ApexCharts -->
|
|
<script src="https://cdn.jsdelivr.net/npm/apexcharts"></script>
|
|
</head>
|
|
<body>
|
|
<div class="wrapper">
|
|
<!-- Sidebar -->
|
|
<nav id="sidebar" class="bg-dark text-white">
|
|
<div class="sidebar-header p-3">
|
|
<h4 class="mb-0">POS<span class="text-success">PRO</span></h4>
|
|
<small class="text-muted">Sistem Multi-Cabang</small>
|
|
</div>
|
|
<ul class="list-unstyled components p-2">
|
|
<li class="active">
|
|
<a href="index.php?branch_id=<?php echo $current_branch_id; ?>" class="nav-link text-white p-2 d-block rounded">
|
|
<i class="bi bi-speedometer2 me-2"></i> Dashboard
|
|
</a>
|
|
</li>
|
|
<li>
|
|
<a href="pos.php?branch_id=<?php echo $current_branch_id; ?>" class="nav-link text-white p-2 d-block rounded">
|
|
<i class="bi bi-cart3 me-2"></i> Kasir (POS)
|
|
</a>
|
|
</li>
|
|
<li>
|
|
<a href="products.php?branch_id=<?php echo $current_branch_id; ?>" class="nav-link text-white p-2 d-block rounded">
|
|
<i class="bi bi-box-seam me-2"></i> Produk
|
|
</a>
|
|
</li>
|
|
<li>
|
|
<a href="members.php?branch_id=<?php echo $current_branch_id; ?>" class="nav-link text-white p-2 d-block rounded">
|
|
<i class="bi bi-people me-2"></i> Member
|
|
</a>
|
|
</li>
|
|
<li>
|
|
<a href="vouchers.php?branch_id=<?php echo $current_branch_id; ?>" class="nav-link text-white p-2 d-block rounded">
|
|
<i class="bi bi-ticket-perforated me-2"></i> Voucher
|
|
</a>
|
|
</li>
|
|
<li>
|
|
<a href="#" class="nav-link text-white p-2 d-block rounded">
|
|
<i class="bi bi-graph-up me-2"></i> Laporan
|
|
</a>
|
|
</li>
|
|
<li>
|
|
<a href="#" class="nav-link text-white p-2 d-block rounded">
|
|
<i class="bi bi-gear me-2"></i> Pengaturan
|
|
</a>
|
|
</li>
|
|
</ul>
|
|
</nav>
|
|
|
|
<!-- Page Content -->
|
|
<div id="content">
|
|
<nav class="navbar navbar-expand-lg navbar-light bg-white border-bottom p-3">
|
|
<div class="container-fluid">
|
|
<button type="button" id="sidebarCollapse" class="btn btn-outline-dark me-3">
|
|
<i class="bi bi-list"></i>
|
|
</button>
|
|
<div class="ms-auto d-flex align-items-center">
|
|
<div class="dropdown me-3">
|
|
<button class="btn btn-light dropdown-toggle" type="button" data-bs-toggle="dropdown">
|
|
<i class="bi bi-geo-alt me-1"></i> <?php echo htmlspecialchars($current_branch['name']); ?>
|
|
</button>
|
|
<ul class="dropdown-menu shadow border-0">
|
|
<?php foreach ($branches as $branch): ?>
|
|
<li><a class="dropdown-item" href="?branch_id=<?php echo $branch['id']; ?>"><?php echo htmlspecialchars($branch['name']); ?></a></li>
|
|
<?php endforeach; ?>
|
|
</ul>
|
|
</div>
|
|
<div class="dropdown">
|
|
<button class="btn btn-light rounded-circle p-2" type="button" data-bs-toggle="dropdown">
|
|
<i class="bi bi-person-circle fs-5"></i>
|
|
</button>
|
|
<ul class="dropdown-menu dropdown-menu-end shadow border-0">
|
|
<li><a class="dropdown-item" href="#">Profil</a></li>
|
|
<li><hr class="dropdown-divider"></li>
|
|
<li><a class="dropdown-item text-danger" href="#">Keluar</a></li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</nav>
|
|
|
|
<div class="container-fluid p-4">
|
|
<div class="d-flex justify-content-between align-items-center mb-4">
|
|
<h2 class="mb-0">Ringkasan Dashboard</h2>
|
|
<div class="text-muted small"><?php
|
|
setlocale(LC_TIME, 'id_ID.utf8', 'id_ID', 'id');
|
|
echo date('l, d F Y');
|
|
?></div>
|
|
</div>
|
|
|
|
<!-- Stats Cards -->
|
|
<div class="row g-4 mb-4">
|
|
<div class="col-md-3">
|
|
<div class="card border-0 shadow-sm rounded-4">
|
|
<div class="card-body p-4">
|
|
<div class="d-flex justify-content-between mb-3">
|
|
<div class="bg-soft-primary p-3 rounded-4">
|
|
<i class="bi bi-currency-dollar text-primary fs-4"></i>
|
|
</div>
|
|
<span class="text-success small fw-bold">+12% <i class="bi bi-arrow-up"></i></span>
|
|
</div>
|
|
<h4 class="mb-1"><?php echo $stats['total_sales']; ?></h4>
|
|
<div class="text-muted small">Total Pendapatan</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="col-md-3">
|
|
<div class="card border-0 shadow-sm rounded-4">
|
|
<div class="card-body p-4">
|
|
<div class="d-flex justify-content-between mb-3">
|
|
<div class="bg-soft-success p-3 rounded-4">
|
|
<i class="bi bi-bag-check text-success fs-4"></i>
|
|
</div>
|
|
<span class="text-success small fw-bold">+8% <i class="bi bi-arrow-up"></i></span>
|
|
</div>
|
|
<h4 class="mb-1"><?php echo $stats['total_orders']; ?></h4>
|
|
<div class="text-muted small">Total Pesanan</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="col-md-3">
|
|
<div class="card border-0 shadow-sm rounded-4">
|
|
<div class="card-body p-4">
|
|
<div class="d-flex justify-content-between mb-3">
|
|
<div class="bg-soft-warning p-3 rounded-4">
|
|
<i class="bi bi-box-seam text-warning fs-4"></i>
|
|
</div>
|
|
<span class="text-muted small fw-bold">Aktif</span>
|
|
</div>
|
|
<h4 class="mb-1"><?php echo $stats['total_products']; ?></h4>
|
|
<div class="text-muted small">Stok Produk</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="col-md-3">
|
|
<div class="card border-0 shadow-sm rounded-4">
|
|
<div class="card-body p-4">
|
|
<div class="d-flex justify-content-between mb-3">
|
|
<div class="bg-soft-info p-3 rounded-4">
|
|
<i class="bi bi-people text-info fs-4"></i>
|
|
</div>
|
|
<span class="text-info small fw-bold">+5 <i class="bi bi-plus"></i></span>
|
|
</div>
|
|
<h4 class="mb-1"><?php echo $stats['total_members']; ?></h4>
|
|
<div class="text-muted small">Member Loyal</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Charts Row -->
|
|
<div class="row g-4 mb-4">
|
|
<div class="col-md-8">
|
|
<div class="card border-0 shadow-sm rounded-4 h-100">
|
|
<div class="card-header bg-white border-0 p-4 pb-0">
|
|
<h5 class="mb-0">Analisis Penjualan</h5>
|
|
<small class="text-muted">Tren performa mingguan</small>
|
|
</div>
|
|
<div class="card-body p-4">
|
|
<div id="salesChart"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="col-md-4">
|
|
<div class="card border-0 shadow-sm rounded-4 h-100">
|
|
<div class="card-header bg-white border-0 p-4 pb-0">
|
|
<h5 class="mb-0">Penjualan per Kategori</h5>
|
|
<small class="text-muted">Distribusi produk</small>
|
|
</div>
|
|
<div class="card-body p-4">
|
|
<div id="categoryChart"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="row g-4">
|
|
<div class="col-md-6">
|
|
<div class="card border-0 shadow-sm rounded-4">
|
|
<div class="card-header bg-white border-0 p-4 pb-0">
|
|
<h5 class="mb-0">Transaksi Terakhir</h5>
|
|
</div>
|
|
<div class="card-body p-4">
|
|
<div class="table-responsive">
|
|
<table class="table table-borderless align-middle">
|
|
<thead>
|
|
<tr class="text-muted small">
|
|
<th>NO. INV</th>
|
|
<th>PELANGGAN</th>
|
|
<th>TOTAL</th>
|
|
<th>STATUS</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<tr>
|
|
<td class="fw-bold">#INV-1024</td>
|
|
<td>Pelanggan Umum</td>
|
|
<td>Rp 45.000</td>
|
|
<td><span class="badge bg-soft-success text-success">Lunas</span></td>
|
|
</tr>
|
|
<tr>
|
|
<td class="fw-bold">#INV-1023</td>
|
|
<td>John Doe</td>
|
|
<td>Rp 120.000</td>
|
|
<td><span class="badge bg-soft-success text-success">Lunas</span></td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="col-md-6">
|
|
<div class="card border-0 shadow-sm rounded-4">
|
|
<div class="card-header bg-white border-0 p-4 pb-0">
|
|
<h5 class="mb-0">Produk Terlaris</h5>
|
|
</div>
|
|
<div class="card-body p-4">
|
|
<div class="d-flex align-items-center mb-3">
|
|
<div class="bg-light p-2 rounded-3 me-3"><i class="bi bi-cup-hot text-primary"></i></div>
|
|
<div class="flex-grow-1">
|
|
<div class="fw-bold">Kopi Susu Gula Aren</div>
|
|
<small class="text-muted">Minuman</small>
|
|
</div>
|
|
<div class="fw-bold text-success">156 terjual</div>
|
|
</div>
|
|
<div class="d-flex align-items-center">
|
|
<div class="bg-light p-2 rounded-3 me-3"><i class="bi bi-egg-fried text-primary"></i></div>
|
|
<div class="flex-grow-1">
|
|
<div class="fw-bold">Nasi Goreng Spesial</div>
|
|
<small class="text-muted">Makanan</small>
|
|
</div>
|
|
<div class="fw-bold text-success">92 terjual</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.bundle.min.js"></script>
|
|
<script src="assets/js/main.js?v=<?php echo time(); ?>"></script>
|
|
</body>
|
|
</html>
|