|
|
<!DOCTYPE html> |
|
|
<html lang="en"> |
|
|
<head> |
|
|
<meta charset="UTF-8"> |
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0"> |
|
|
<title>Admin Dashboard | ShopSphere</title> |
|
|
<link rel="icon" type="image/x-icon" href="/static/favicon.ico"> |
|
|
<link rel="stylesheet" href="style.css"> |
|
|
<script src="https://cdn.tailwindcss.com"></script> |
|
|
<script src="https://cdn.jsdelivr.net/npm/feather-icons/dist/feather.min.js"></script> |
|
|
<script src="https://unpkg.com/feather-icons"></script> |
|
|
<script src="https://cdn.jsdelivr.net/npm/chart.js"></script> |
|
|
</head> |
|
|
<body class="bg-gray-100"> |
|
|
<admin-sidebar></admin-sidebar> |
|
|
|
|
|
<div class="ml-64 p-8"> |
|
|
<div class="flex justify-between items-center mb-8"> |
|
|
<h1 class="text-3xl font-bold">Admin Dashboard</h1> |
|
|
<div class="flex items-center gap-4"> |
|
|
<div class="relative"> |
|
|
<input type="text" placeholder="Search..." class="pl-10 pr-4 py-2 border rounded-lg"> |
|
|
<i data-feather="search" class="absolute left-3 top-2.5 text-gray-400"></i> |
|
|
</div> |
|
|
<button class="bg-indigo-600 hover:bg-indigo-700 text-white px-4 py-2 rounded-lg flex items-center"> |
|
|
<i data-feather="plus" class="mr-2"></i> |
|
|
Generate Report |
|
|
</button> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
|
|
|
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-4 gap-6 mb-8"> |
|
|
<div class="bg-white p-6 rounded-lg shadow"> |
|
|
<div class="flex justify-between"> |
|
|
<div> |
|
|
<p class="text-gray-500">Total Sales</p> |
|
|
<h3 class="text-2xl font-bold">$24,780</h3> |
|
|
<p class="text-green-500 text-sm mt-1">+12% from last month</p> |
|
|
</div> |
|
|
<div class="bg-indigo-100 text-indigo-600 p-3 rounded-full"> |
|
|
<i data-feather="dollar-sign"></i> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
<div class="bg-white p-6 rounded-lg shadow"> |
|
|
<div class="flex justify-between"> |
|
|
<div> |
|
|
<p class="text-gray-500">Total Orders</p> |
|
|
<h3 class="text-2xl font-bold">1,245</h3> |
|
|
<p class="text-green-500 text-sm mt-1">+8% from last month</p> |
|
|
</div> |
|
|
<div class="bg-green-100 text-green-600 p-3 rounded-full"> |
|
|
<i data-feather="shopping-cart"></i> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
<div class="bg-white p-6 rounded-lg shadow"> |
|
|
<div class="flex justify-between"> |
|
|
<div> |
|
|
<p class="text-gray-500">New Customers</p> |
|
|
<h3 class="text-2xl font-bold">142</h3> |
|
|
<p class="text-green-500 text-sm mt-1">+15% from last month</p> |
|
|
</div> |
|
|
<div class="bg-blue-100 text-blue-600 p-3 rounded-full"> |
|
|
<i data-feather="users"></i> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
<div class="bg-white p-6 rounded-lg shadow"> |
|
|
<div class="flex justify-between"> |
|
|
<div> |
|
|
<p class="text-gray-500">Avg. Order Value</p> |
|
|
<h3 class="text-2xl font-bold">$89.45</h3> |
|
|
<p class="text-green-500 text-sm mt-1">+5% from last month</p> |
|
|
</div> |
|
|
<div class="bg-purple-100 text-purple-600 p-3 rounded-full"> |
|
|
<i data-feather="trending-up"></i> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
|
|
|
<div class="grid grid-cols-1 lg:grid-cols-2 gap-6 mb-8"> |
|
|
<div class="bg-white p-6 rounded-lg shadow"> |
|
|
<h3 class="text-lg font-bold mb-4">Monthly Sales</h3> |
|
|
<canvas id="salesChart" height="300"></canvas> |
|
|
</div> |
|
|
<div class="bg-white p-6 rounded-lg shadow"> |
|
|
<h3 class="text-lg font-bold mb-4">Revenue by Category</h3> |
|
|
<canvas id="categoryChart" height="300"></canvas> |
|
|
</div> |
|
|
<div class="bg-white p-6 rounded-lg shadow"> |
|
|
<h3 class="text-lg font-bold mb-4">Traffic Sources</h3> |
|
|
<canvas id="trafficChart" height="300"></canvas> |
|
|
</div> |
|
|
<div class="bg-white p-6 rounded-lg shadow"> |
|
|
<h3 class="text-lg font-bold mb-4">Yearly Performance</h3> |
|
|
<canvas id="yearlyChart" height="300"></canvas> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
|
|
|
<div class="bg-white rounded-lg shadow overflow-hidden"> |
|
|
<div class="px-6 py-4 border-b flex justify-between items-center"> |
|
|
<h3 class="text-lg font-bold">Recent Orders</h3> |
|
|
<a href="/admin-orders.html" class="text-indigo-600 hover:text-indigo-800 text-sm font-medium">View All</a> |
|
|
</div> |
|
|
<div class="overflow-x-auto"> |
|
|
<table class="min-w-full divide-y divide-gray-200"> |
|
|
<thead class="bg-gray-50"> |
|
|
<tr> |
|
|
<th class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">Order ID</th> |
|
|
<th class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">Customer</th> |
|
|
<th class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">Date</th> |
|
|
<th class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">Amount</th> |
|
|
<th class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">Status</th> |
|
|
<th class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">Actions</th> |
|
|
</tr> |
|
|
</thead> |
|
|
<tbody class="bg-white divide-y divide-gray-200"> |
|
|
<tr> |
|
|
<td class="px-6 py-4 whitespace-nowrap text-sm font-medium text-gray-900">#ORD-7842</td> |
|
|
<td class="px-6 py-4 whitespace-nowrap text-sm text-gray-500">Sarah Johnson</td> |
|
|
<td class="px-6 py-4 whitespace-nowrap text-sm text-gray-500">June 15, 2023</td> |
|
|
<td class="px-6 py-4 whitespace-nowrap text-sm text-gray-500">$187.99</td> |
|
|
<td class="px-6 py-4 whitespace-nowrap"> |
|
|
<span class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-green-100 text-green-800">Delivered</span> |
|
|
</td> |
|
|
<td class="px-6 py-4 whitespace-nowrap text-sm font-medium"> |
|
|
<a href="#" class="text-indigo-600 hover:text-indigo-900 mr-3">View</a> |
|
|
<a href="#" class="text-red-600 hover:text-red-900">Delete</a> |
|
|
</td> |
|
|
</tr> |
|
|
<tr> |
|
|
<td class="px-6 py-4 whitespace-nowrap text-sm font-medium text-gray-900">#ORD-7841</td> |
|
|
<td class="px-6 py-4 whitespace-nowrap text-sm text-gray-500">Michael Chen</td> |
|
|
<td class="px-6 py-4 whitespace-nowrap text-sm text-gray-500">June 14, 2023</td> |
|
|
<td class="px-6 py-4 whitespace-nowrap text-sm text-gray-500">$245.50</td> |
|
|
<td class="px-6 py-4 whitespace-nowrap"> |
|
|
<span class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-yellow-100 text-yellow-800">Processing</span> |
|
|
</td> |
|
|
<td class="px-6 py-4 whitespace-nowrap text-sm font-medium"> |
|
|
<a href="#" class="text-indigo-600 hover:text-indigo-900 mr-3">View</a> |
|
|
<a href="#" class="text-red-600 hover:text-red-900">Delete</a> |
|
|
</td> |
|
|
</tr> |
|
|
<tr> |
|
|
<td class="px-6 py-4 whitespace-nowrap text-sm font-medium text-gray-900">#ORD-7840</td> |
|
|
<td class="px-6 py-4 whitespace-nowrap text-sm text-gray-500">David Rodriguez</td> |
|
|
<td class="px-6 py-4 whitespace-nowrap text-sm text-gray-500">June 13, 2023</td> |
|
|
<td class="px-6 py-4 whitespace-nowrap text-sm text-gray-500">$98.75</td> |
|
|
<td class="px-6 py-4 whitespace-nowrap"> |
|
|
<span class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-blue-100 text-blue-800">Shipped</span> |
|
|
</td> |
|
|
<td class="px-6 py-4 whitespace-nowrap text-sm font-medium"> |
|
|
<a href="#" class="text-indigo-600 hover:text-indigo-900 mr-3">View</a> |
|
|
<a href="#" class="text-red-600 hover:text-red-900">Delete</a> |
|
|
</td> |
|
|
</tr> |
|
|
</tbody> |
|
|
</table> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
<script src="components/admin-sidebar.js"></script> |
|
|
<script src="script.js"></script> |
|
|
<script> |
|
|
feather.replace(); |
|
|
|
|
|
|
|
|
const salesCtx = document.getElementById('salesChart').getContext('2d'); |
|
|
const salesChart = new Chart(salesCtx, { |
|
|
type: 'line', |
|
|
data: { |
|
|
labels: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'], |
|
|
datasets: [{ |
|
|
label: 'Sales ($)', |
|
|
data: [8500, 10200, 9800, 12500, 14300, 16700, 15200, 18100, 17500, 19300, 21000, 24780], |
|
|
backgroundColor: 'rgba(99, 102, 241, 0.1)', |
|
|
borderColor: 'rgba(99, 102, 241, 1)', |
|
|
borderWidth: 2, |
|
|
tension: 0.3, |
|
|
fill: true |
|
|
}] |
|
|
}, |
|
|
options: { |
|
|
responsive: true, |
|
|
plugins: { |
|
|
legend: { |
|
|
display: false |
|
|
} |
|
|
}, |
|
|
scales: { |
|
|
y: { |
|
|
beginAtZero: true |
|
|
} |
|
|
} |
|
|
} |
|
|
}); |
|
|
|
|
|
|
|
|
const categoryCtx = document.getElementById('categoryChart').getContext('2d'); |
|
|
const categoryChart = new Chart(categoryCtx, { |
|
|
type: 'doughnut', |
|
|
data: { |
|
|
labels: ['Electronics', 'Fashion', 'Home & Living', 'Beauty', 'Other'], |
|
|
datasets: [{ |
|
|
data: [35, 25, 20, 15, 5], |
|
|
backgroundColor: [ |
|
|
'rgba(99, 102, 241, 0.8)', |
|
|
'rgba(79, 70, 229, 0.8)', |
|
|
'rgba(109, 40, 217, 0.8)', |
|
|
'rgba(139, 92, 246, 0.8)', |
|
|
'rgba(168, 85, 247, 0.8)' |
|
|
], |
|
|
borderWidth: 0 |
|
|
}] |
|
|
}, |
|
|
options: { |
|
|
responsive: true, |
|
|
plugins: { |
|
|
legend: { |
|
|
position: 'right' |
|
|
} |
|
|
} |
|
|
} |
|
|
}); |
|
|
|
|
|
|
|
|
const trafficCtx = document.getElementById('trafficChart').getContext('2d'); |
|
|
const trafficChart = new Chart(trafficCtx, { |
|
|
type: 'bar', |
|
|
data: { |
|
|
labels: ['Direct', 'Organic', 'Social', 'Referral', 'Paid'], |
|
|
datasets: [{ |
|
|
label: 'Traffic Sources', |
|
|
data: [35, 40, 15, 7, 3], |
|
|
backgroundColor: [ |
|
|
'rgba(99, 102, 241, 0.7)', |
|
|
'rgba(79, 70, 229, 0.7)', |
|
|
'rgba(109, 40, 217, 0.7)', |
|
|
'rgba(139, 92, 246, 0.7)', |
|
|
'rgba(168, 85, 247, 0.7)' |
|
|
], |
|
|
borderWidth: 0 |
|
|
}] |
|
|
}, |
|
|
options: { |
|
|
responsive: true, |
|
|
plugins: { |
|
|
legend: { |
|
|
display: false |
|
|
} |
|
|
}, |
|
|
scales: { |
|
|
y: { |
|
|
beginAtZero: true |
|
|
} |
|
|
} |
|
|
} |
|
|
}); |
|
|
|
|
|
|
|
|
const yearlyCtx = document.getElementById('yearlyChart').getContext('2d'); |
|
|
const yearlyChart = new Chart(yearlyCtx, { |
|
|
type: 'line', |
|
|
data: { |
|
|
labels: ['2020', '2021', '2022', '2023'], |
|
|
datasets: [{ |
|
|
label: 'Yearly Revenue', |
|
|
data: [85000, 125000, 178000, 220000], |
|
|
backgroundColor: 'rgba(99, 102, 241, 0.1)', |
|
|
borderColor: 'rgba(99, 102, 241, 1)', |
|
|
borderWidth: 2, |
|
|
tension: 0.3, |
|
|
fill: true |
|
|
}] |
|
|
}, |
|
|
options: { |
|
|
responsive: true, |
|
|
plugins: { |
|
|
legend: { |
|
|
display: false |
|
|
} |
|
|
}, |
|
|
scales: { |
|
|
y: { |
|
|
beginAtZero: true |
|
|
} |
|
|
} |
|
|
} |
|
|
}); |
|
|
</script> |
|
|
</body> |
|
|
</html> |