Spaces:
Running
Running
| <html lang="en"> | |
| <head> | |
| <meta charset="UTF-8"> | |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> | |
| <title>StockSync Pro | Modern Inventory Dashboard</title> | |
| <script src="https://cdn.tailwindcss.com"></script> | |
| <script src="https://unpkg.com/feather-icons"></script> | |
| <script src="https://cdn.jsdelivr.net/npm/feather-icons/dist/feather.min.js"></script> | |
| <script src="https://cdn.jsdelivr.net/npm/vanta@latest/dist/vanta.globe.min.js"></script> | |
| <script src="https://cdn.jsdelivr.net/npm/chart.js"></script> | |
| <style> | |
| .vanta-bg { | |
| position: absolute; | |
| top: 0; | |
| left: 0; | |
| width: 100%; | |
| height: 100%; | |
| z-index: -1; | |
| opacity: 0.1; | |
| } | |
| .sidebar { | |
| transition: all 0.3s ease; | |
| } | |
| .card-hover:hover { | |
| transform: translateY(-5px); | |
| box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04); | |
| } | |
| .kpi-badge { | |
| transition: all 0.2s ease; | |
| } | |
| .kpi-badge:hover { | |
| transform: scale(1.05); | |
| } | |
| </style> | |
| </head> | |
| <body class="bg-gray-50 font-sans text-gray-800"> | |
| <div class="vanta-bg" id="vanta-bg"></div> | |
| <div class="flex h-screen overflow-hidden"> | |
| <!-- Sidebar --> | |
| <div class="sidebar bg-indigo-800 text-white w-64 flex-shrink-0 hidden md:block"> | |
| <div class="p-4 border-b border-indigo-700"> | |
| <h1 class="text-2xl font-bold flex items-center"> | |
| <i data-feather="package" class="mr-2"></i> StockSync Pro | |
| </h1> | |
| </div> | |
| <nav class="p-4"> | |
| <div class="mb-6"> | |
| <p class="text-xs uppercase text-indigo-300 mb-2">Dashboard</p> | |
| <a href="index.html" class="flex items-center py-2 px-3 bg-indigo-700 rounded-lg text-white"> | |
| <i data-feather="home" class="mr-3"></i> Overview | |
| </a> | |
| </div> | |
| <div class="mb-6"> | |
| <p class="text-xs uppercase text-indigo-300 mb-2">Inventory</p> | |
| <a href="products.html" class="flex items-center py-2 px-3 bg-indigo-700 rounded-lg text-white"> | |
| <i data-feather="box" class="mr-3"></i> Products | |
| </a> | |
| <a href="locations.html" class="flex items-center py-2 px-3 text-indigo-200 hover:bg-indigo-700 hover:text-white rounded-lg mb-2"> | |
| <i data-feather="map-pin" class="mr-3"></i> Locations | |
| </a> | |
| <a href="transfers.html" class="flex items-center py-2 px-3 text-indigo-200 hover:bg-indigo-700 hover:text-white rounded-lg"> | |
| <i data-feather="move" class="mr-3"></i> Transfers | |
| </a> | |
| </div> | |
| <div class="mb-6"> | |
| <p class="text-xs uppercase text-indigo-300 mb-2">Manufacturing</p> | |
| <a href="#" class="flex items-center py-2 px-3 text-indigo-200 hover:bg-indigo-700 hover:text-white rounded-lg mb-2"> | |
| <i data-feather="layers" class="mr-3"></i> BOMs | |
| </a> | |
| <a href="#" class="flex items-center py-2 px-3 text-indigo-200 hover:bg-indigo-700 hover:text-white rounded-lg"> | |
| <i data-feather="clipboard" class="mr-3"></i> Work Orders | |
| </a> | |
| </div> | |
| <div class="mb-6"> | |
| <p class="text-xs uppercase text-indigo-300 mb-2">Reports</p> | |
| <a href="#" class="flex items-center py-2 px-3 text-indigo-200 hover:bg-indigo-700 hover:text-white rounded-lg mb-2"> | |
| <i data-feather="bar-chart-2" class="mr-3"></i> Analytics | |
| </a> | |
| <a href="#" class="flex items-center py-2 px-3 text-indigo-200 hover:bg-indigo-700 hover:text-white rounded-lg"> | |
| <i data-feather="file-text" class="mr-3"></i> Inventory Report | |
| </a> | |
| </div> | |
| </nav> | |
| </div> | |
| <!-- Main Content --> | |
| <div class="flex-1 flex flex-col overflow-hidden"> | |
| <!-- Top Navigation --> | |
| <header class="bg-white border-b border-gray-200 flex items-center justify-between px-6 py-4"> | |
| <button class="md:hidden text-gray-500"> | |
| <i data-feather="menu"></i> | |
| </button> | |
| <div class="flex-1 mx-4"> | |
| <div class="relative max-w-md"> | |
| <input type="text" placeholder="Search products, orders..." | |
| class="w-full pl-10 pr-4 py-2 border rounded-lg focus:outline-none focus:ring-2 focus:ring-indigo-500"> | |
| <i data-feather="search" class="absolute left-3 top-2.5 text-gray-400"></i> | |
| </div> | |
| </div> | |
| <div class="flex items-center space-x-4"> | |
| <button class="relative p-2 text-gray-500 hover:text-gray-700"> | |
| <i data-feather="bell"></i> | |
| <span class="absolute top-0 right-0 h-2 w-2 rounded-full bg-red-500"></span> | |
| </button> | |
| <div class="flex items-center"> | |
| <img src="http://static.photos/people/200x200/1" alt="User" class="h-8 w-8 rounded-full"> | |
| <span class="ml-2 text-sm font-medium hidden md:inline">Admin User</span> | |
| </div> | |
| </div> | |
| </header> | |
| <!-- Main Content Area --> | |
| <main class="flex-1 overflow-y-auto p-6"> | |
| <div class="mb-6 flex justify-between items-center"> | |
| <h2 class="text-2xl font-bold text-gray-800">Inventory Dashboard</h2> | |
| <div class="flex space-x-2"> | |
| <a href="products.html" class="px-4 py-2 bg-indigo-600 text-white rounded-lg hover:bg-indigo-700 flex items-center"> | |
| <i data-feather="plus" class="mr-2"></i> New Product | |
| </a> | |
| <button class="px-4 py-2 border border-gray-300 rounded-lg hover:bg-gray-50 flex items-center"> | |
| <i data-feather="refresh-cw" class="mr-2"></i> Refresh | |
| </button> | |
| </div> | |
| </div> | |
| <!-- KPIs --> | |
| <div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-4 gap-6 mb-6"> | |
| <div class="bg-white rounded-xl shadow-sm p-6 card-hover"> | |
| <div class="flex items-center justify-between"> | |
| <div> | |
| <p class="text-sm text-gray-500">Total Products</p> | |
| <h3 class="text-2xl font-bold mt-1">1,248</h3> | |
| <p class="text-sm text-green-500 mt-1 flex items-center"> | |
| <i data-feather="trending-up" class="mr-1"></i> 12% from last month | |
| </p> | |
| </div> | |
| <div class="bg-indigo-100 p-3 rounded-full"> | |
| <i data-feather="box" class="text-indigo-600"></i> | |
| </div> | |
| </div> | |
| </div> | |
| <div class="bg-white rounded-xl shadow-sm p-6 card-hover"> | |
| <div class="flex items-center justify-between"> | |
| <div> | |
| <p class="text-sm text-gray-500">Low Stock Items</p> | |
| <h3 class="text-2xl font-bold mt-1">87</h3> | |
| <p class="text-sm text-red-500 mt-1 flex items-center"> | |
| <i data-feather="alert-triangle" class="mr-1"></i> Needs attention | |
| </p> | |
| </div> | |
| <div class="bg-red-100 p-3 rounded-full"> | |
| <i data-feather="alert-circle" class="text-red-600"></i> | |
| </div> | |
| </div> | |
| </div> | |
| <div class="bg-white rounded-xl shadow-sm p-6 card-hover"> | |
| <div class="flex items-center justify-between"> | |
| <div> | |
| <p class="text-sm text-gray-500">Inventory Value</p> | |
| <h3 class="text-2xl font-bold mt-1">$524,789</h3> | |
| <p class="text-sm text-blue-500 mt-1 flex items-center"> | |
| <i data-feather="dollar-sign" class="mr-1"></i> 8% from last month | |
| </p> | |
| </div> | |
| <div class="bg-blue-100 p-3 rounded-full"> | |
| <i data-feather="dollar-sign" class="text-blue-600"></i> | |
| </div> | |
| </div> | |
| </div> | |
| <div class="bg-white rounded-xl shadow-sm p-6 card-hover"> | |
| <div class="flex items-center justify-between"> | |
| <div> | |
| <p class="text-sm text-gray-500">Pending Orders</p> | |
| <h3 class="text-2xl font-bold mt-1">42</h3> | |
| <p class="text-sm text-yellow-500 mt-1 flex items-center"> | |
| <i data-feather="clock" class="mr-1"></i> Processing | |
| </p> | |
| </div> | |
| <div class="bg-yellow-100 p-3 rounded-full"> | |
| <i data-feather="shopping-cart" class="text-yellow-600"></i> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- Charts --> | |
| <div class="grid grid-cols-1 lg:grid-cols-3 gap-6 mb-6"> | |
| <div class="bg-white rounded-xl shadow-sm p-6 lg:col-span-2 card-hover"> | |
| <div class="flex justify-between items-center mb-4"> | |
| <h3 class="font-medium text-lg">Inventory Movement (Last 30 Days)</h3> | |
| <select class="border rounded-lg px-3 py-1 text-sm focus:outline-none focus:ring-2 focus:ring-indigo-500"> | |
| <option>Last 30 Days</option> | |
| <option>Last 60 Days</option> | |
| <option>Last 90 Days</option> | |
| </select> | |
| </div> | |
| <div class="h-80"> | |
| <canvas id="inventoryChart"></canvas> | |
| </div> | |
| </div> | |
| <div class="bg-white rounded-xl shadow-sm p-6 card-hover"> | |
| <h3 class="font-medium text-lg mb-4">Inventory Distribution</h3> | |
| <div class="h-80"> | |
| <canvas id="inventoryPieChart"></canvas> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- Recent Activity & Low Stock --> | |
| <div class="grid grid-cols-1 lg:grid-cols-3 gap-6"> | |
| <div class="bg-white rounded-xl shadow-sm p-6 lg:col-span-2 card-hover"> | |
| <h3 class="font-medium text-lg mb-4">Recent Activity</h3> | |
| <div class="space-y-4"> | |
| <div class="flex items-start"> | |
| <div class="bg-green-100 p-2 rounded-full mr-3"> | |
| <i data-feather="arrow-up" class="text-green-600"></i> | |
| </div> | |
| <div> | |
| <p class="text-sm font-medium">Received 250 units of "Premium Widgets"</p> | |
| <p class="text-xs text-gray-500">Today, 09:24 AM • Warehouse A</p> | |
| </div> | |
| </div> | |
| <div class="flex items-start"> | |
| <div class="bg-blue-100 p-2 rounded-full mr-3"> | |
| <i data-feather="truck" class="text-blue-600"></i> | |
| </div> | |
| <div> | |
| <p class="text-sm font-medium">Transfer initiated to Warehouse B</p> | |
| <p class="text-xs text-gray-500">Today, 08:15 AM • 50 units of "Basic Components"</p> | |
| </div> | |
| </div> | |
| <div class="flex items-start"> | |
| <div class="bg-red-100 p-2 rounded-full mr-3"> | |
| <i data-feather="alert-circle" class="text-red-600"></i> | |
| </div> | |
| <div> | |
| <p class="text-sm font-medium">Low stock alert for "Fasteners M3"</p> | |
| <p class="text-xs text-gray-500">Yesterday, 04:30 PM • Only 12 units remaining</p> | |
| </div> | |
| </div> | |
| <div class="flex items-start"> | |
| <div class="bg-purple-100 p-2 rounded-full mr-3"> | |
| <i data-feather="clipboard" class="text-purple-600"></i> | |
| </div> | |
| <div> | |
| <p class="text-sm font-medium">New production order created</p> | |
| <p class="text-xs text-gray-500">Yesterday, 02:45 PM • Product "Deluxe Model 2024"</p> | |
| </div> | |
| </div> | |
| </div> | |
| <button class="mt-4 text-indigo-600 text-sm font-medium flex items-center"> | |
| View all activity <i data-feather="chevron-right" class="ml-1 h-4 w-4"></i> | |
| </button> | |
| </div> | |
| <div class="bg-white rounded-xl shadow-sm p-6 card-hover"> | |
| <div class="flex justify-between items-center mb-4"> | |
| <h3 class="font-medium text-lg">Low Stock Items</h3> | |
| <button class="text-indigo-600 text-sm font-medium">View All</button> | |
| </div> | |
| <div class="space-y-4"> | |
| <div class="flex items-center justify-between p-3 bg-red-50 rounded-lg kpi-badge"> | |
| <div class="flex items-center"> | |
| <div class="bg-white p-2 rounded-lg mr-3"> | |
| <i data-feather="box" class="text-red-500"></i> | |
| </div> | |
| <div> | |
| <p class="text-sm font-medium">Fasteners M3</p> | |
| <p class="text-xs text-gray-500">SKU: FST-M3-BL</p> | |
| </div> | |
| </div> | |
| <div class="text-right"> | |
| <p class="text-sm font-bold text-red-500">12/50</p> | |
| <p class="text-xs text-gray-500">units left</p> | |
| </div> | |
| </div> | |
| <div class="flex items-center justify-between p-3 bg-orange-50 rounded-lg kpi-badge"> | |
| <div class="flex items-center"> | |
| <div class="bg-white p-2 rounded-lg mr-3"> | |
| <i data-feather="box" class="text-orange-500"></i> | |
| </div> | |
| <div> | |
| <p class="text-sm font-medium">Power Adapter 12V</p> | |
| <p class="text-xs text-gray-500">SKU: PWR-ADP-12</p> | |
| </div> | |
| </div> | |
| <div class="text-right"> | |
| <p class="text-sm font-bold text-orange-500">8/30</p> | |
| <p class="text-xs text-gray-500">units left</p> | |
| </div> | |
| </div> | |
| <div class="flex items-center justify-between p-3 bg-yellow-50 rounded-lg kpi-badge"> | |
| <div class="flex items-center"> | |
| <div class="bg-white p-2 rounded-lg mr-3"> | |
| <i data-feather="box" class="text-yellow-500"></i> | |
| </div> | |
| <div> | |
| <p class="text-sm font-medium">LCD Display 7"</p> | |
| <p class="text-xs text-gray-500">SKU: LCD-7-IN</p> | |
| </div> | |
| </div> | |
| <div class="text-right"> | |
| <p class="text-sm font-bold text-yellow-500">15/40</p> | |
| <p class="text-xs text-gray-500">units left</p> | |
| </div> | |
| </div> | |
| <div class="flex items-center justify-between p-3 bg-yellow-50 rounded-lg kpi-badge"> | |
| <div class="flex items-center"> | |
| <div class="bg-white p-2 rounded-lg mr-3"> | |
| <i data-feather="box" class="text-yellow-500"></i> | |
| </div> | |
| <div> | |
| <p class="text-sm font-medium">Rubber Feet (4-pack)</p> | |
| <p class="text-xs text-gray-500">SKU: RB-FT-4PK</p> | |
| </div> | |
| </div> | |
| <div class="text-right"> | |
| <p class="text-sm font-bold text-yellow-500">22/100</p> | |
| <p class="text-xs text-gray-500">units left</p> | |
| </div> | |
| </div> | |
| </div> | |
| <button class="mt-4 w-full py-2 border border-indigo-600 text-indigo-600 rounded-lg hover:bg-indigo-50 flex items-center justify-center"> | |
| <i data-feather="plus" class="mr-2"></i> Create Purchase Order | |
| </button> | |
| </div> | |
| </div> | |
| </main> | |
| </div> | |
| </div> | |
| <script> | |
| // Vanta.js background | |
| VANTA.GLOBE({ | |
| el: "#vanta-bg", | |
| mouseControls: true, | |
| touchControls: true, | |
| gyroControls: false, | |
| minHeight: 200.00, | |
| minWidth: 200.00, | |
| scale: 1.00, | |
| scaleMobile: 1.00, | |
| color: 0x5b6ee1, | |
| backgroundColor: 0xf8fafc, | |
| size: 1.00 | |
| }); | |
| // Charts | |
| document.addEventListener('DOMContentLoaded', function() { | |
| // Inventory Movement Chart | |
| const inventoryCtx = document.getElementById('inventoryChart').getContext('2d'); | |
| const inventoryChart = new Chart(inventoryCtx, { | |
| type: 'line', | |
| data: { | |
| labels: ['Jan 1', 'Jan 5', 'Jan 10', 'Jan 15', 'Jan 20', 'Jan 25', 'Jan 30'], | |
| datasets: [ | |
| { | |
| label: 'Received', | |
| data: [120, 190, 130, 170, 150, 200, 180], | |
| borderColor: '#4CAF50', | |
| backgroundColor: 'rgba(76, 175, 80, 0.1)', | |
| tension: 0.3, | |
| fill: true | |
| }, | |
| { | |
| label: 'Shipped', | |
| data: [80, 120, 105, 110, 95, 150, 130], | |
| borderColor: '#F44336', | |
| backgroundColor: 'rgba(244, 67, 54, 0.1)', | |
| tension: 0.3, | |
| fill: true | |
| }, | |
| { | |
| label: 'Transferred', | |
| data: [40, 70, 55, 60, 75, 50, 65], | |
| borderColor: '#2196F3', | |
| backgroundColor: 'rgba(33, 150, 243, 0.1)', | |
| tension: 0.3, | |
| fill: true | |
| } | |
| ] | |
| }, | |
| options: { | |
| responsive: true, | |
| maintainAspectRatio: false, | |
| plugins: { | |
| legend: { | |
| position: 'top', | |
| }, | |
| tooltip: { | |
| mode: 'index', | |
| intersect: false, | |
| } | |
| }, | |
| scales: { | |
| y: { | |
| beginAtZero: true | |
| } | |
| } | |
| } | |
| }); | |
| // Inventory Distribution Pie Chart | |
| const pieCtx = document.getElementById('inventoryPieChart').getContext('2d'); | |
| const pieChart = new Chart(pieCtx, { | |
| type: 'doughnut', | |
| data: { | |
| labels: ['Electronics', 'Mechanical', 'Packaging', 'Raw Materials', 'Finished Goods'], | |
| datasets: [{ | |
| data: [25, 15, 10, 30, 20], | |
| backgroundColor: [ | |
| '#4CAF50', | |
| '#2196F3', | |
| '#FFC107', | |
| '#9C27B0', | |
| '#F44336' | |
| ], | |
| borderWidth: 0 | |
| }] | |
| }, | |
| options: { | |
| responsive: true, | |
| maintainAspectRatio: false, | |
| plugins: { | |
| legend: { | |
| position: 'right', | |
| } | |
| }, | |
| cutout: '70%' | |
| } | |
| }); | |
| }); | |
| // Feather Icons | |
| feather.replace(); | |
| </script> | |
| </body> | |
| </html> | |