Spaces:
Running
Running
| <html lang="en"> | |
| <head> | |
| <meta charset="UTF-8"> | |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> | |
| <title>PipeFlow Pro | Industrial Piping Project Controls</title> | |
| <script src="https://cdn.tailwindcss.com"></script> | |
| <script src="https://unpkg.com/feather-icons"></script> | |
| <script src="https://cdn.jsdelivr.net/npm/chart.js"></script> | |
| <script src="https://cdn.jsdelivr.net/npm/vanta@latest/dist/vanta.net.min.js"></script> | |
| <style> | |
| .sidebar { | |
| transition: all 0.3s ease; | |
| } | |
| .module-card: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 { | |
| animation: pulse 2s infinite; | |
| } | |
| @keyframes pulse { | |
| 0% { box-shadow: 0 0 0 0 rgba(74, 222, 128, 0.7); } | |
| 70% { box-shadow: 0 0 0 10px rgba(74, 222, 128, 0); } | |
| 100% { box-shadow: 0 0 0 0 rgba(74, 222, 128, 0); } | |
| } | |
| </style> | |
| </head> | |
| <body class="bg-gray-50 font-sans"> | |
| <!-- Vanta.js Background --> | |
| <div id="vanta-bg" class="fixed top-0 left-0 w-full h-full z-0"></div> | |
| <!-- Main Layout --> | |
| <div class="relative z-10 flex h-screen overflow-hidden"> | |
| <!-- Sidebar --> | |
| <div class="sidebar bg-gray-800 text-white w-64 flex-shrink-0 transform -translate-x-full md:translate-x-0 transition duration-300 ease-in-out"> | |
| <div class="p-4 border-b border-gray-700"> | |
| <div class="flex items-center space-x-2"> | |
| <img src="http://static.photos/green/100x100/133" alt="Greenberry Logo" class="w-8 h-8 rounded-full"> | |
| <h1 class="text-xl font-bold">PipeFlow Pro</h1> | |
| </div> | |
| <p class="text-gray-400 text-sm mt-1">Industrial Piping Command Center</p> | |
| </div> | |
| <nav class="p-4"> | |
| <div class="mb-6"> | |
| <h3 class="text-xs uppercase tracking-wider text-gray-400 mb-3">Modules</h3> | |
| <ul class="space-y-2"> | |
| <li> | |
| <a href="financial.html" class="flex items-center space-x-2 p-2 rounded-lg bg-gray-700 text-white"> | |
| <i data-feather="dollar-sign" class="w-5 h-5"></i> | |
| <span>Financial</span> | |
| </a> | |
| </li> | |
| <li> | |
| <a href="tracking.html" class="flex items-center space-x-2 p-2 rounded-lg hover:bg-gray-700"> | |
| <i data-feather="activity" class="w-5 h-5"></i> | |
| <span>Tracking</span> | |
| </a> | |
| </li> | |
| <li> | |
| <a href="earned-value.html" class="flex items-center space-x-2 p-2 rounded-lg hover:bg-gray-700"> | |
| <i data-feather="trending-up" class="w-5 h-5"></i> | |
| <span>Earned Value</span> | |
| </a> | |
| </li> | |
| <li> | |
| <a href="#plan-forecast" class="flex items-center space-x-2 p-2 rounded-lg hover:bg-gray-700"> | |
| <i data-feather="calendar" class="w-5 h-5"></i> | |
| <span>Plan & Forecast</span> | |
| </a> | |
| </li> | |
| </ul> | |
| </div> | |
| <div> | |
| <h3 class="text-xs uppercase tracking-wider text-gray-400 mb-3">Settings</h3> | |
| <ul class="space-y-2"> | |
| <li> | |
| <a href="#" class="flex items-center space-x-2 p-2 rounded-lg hover:bg-gray-700"> | |
| <i data-feather="user" class="w-5 h-5"></i> | |
| <span>Profile</span> | |
| </a> | |
| </li> | |
| <li> | |
| <a href="#" class="flex items-center space-x-2 p-2 rounded-lg hover:bg-gray-700"> | |
| <i data-feather="settings" class="w-5 h-5"></i> | |
| <span>Settings</span> | |
| </a> | |
| </li> | |
| <li> | |
| <a href="#" class="flex items-center space-x-2 p-2 rounded-lg hover:bg-gray-700"> | |
| <i data-feather="tool" class="w-5 h-5"></i> | |
| <span>Options</span> | |
| </a> | |
| </li> | |
| <li> | |
| <a href="#" class="flex items-center space-x-2 p-2 rounded-lg hover:bg-gray-700"> | |
| <i data-feather="folder" class="w-5 h-5"></i> | |
| <span>Project Management</span> | |
| </a> | |
| </li> | |
| </ul> | |
| </div> | |
| </nav> | |
| </div> | |
| <!-- Main Content --> | |
| <div class="flex-1 overflow-auto"> | |
| <!-- Top Navigation --> | |
| <header class="bg-white shadow-sm"> | |
| <div class="flex items-center justify-between px-6 py-4"> | |
| <div class="flex items-center space-x-4"> | |
| <button id="sidebar-toggle" class="md:hidden text-gray-500"> | |
| <i data-feather="menu"></i> | |
| </button> | |
| <h2 class="text-xl font-semibold text-gray-800">Dashboard</h2> | |
| </div> | |
| <div class="flex items-center space-x-4"> | |
| <div class="relative"> | |
| <i data-feather="bell" class="text-gray-500"></i> | |
| <span class="absolute top-0 right-0 w-2 h-2 bg-red-500 rounded-full"></span> | |
| </div> | |
| <div class="flex items-center space-x-2"> | |
| <img src="https://static.photos/people/40x40/1" alt="User" class="w-8 h-8 rounded-full"> | |
| <span class="text-sm font-medium">John Doe</span> | |
| </div> | |
| </div> | |
| </div> | |
| </header> | |
| <!-- Dashboard Content --> | |
| <main class="p-6"> | |
| <!-- Project Overview --> | |
| <div class="mb-8"> | |
| <div class="flex items-center justify-between mb-4"> | |
| <h3 class="text-lg font-semibold">Project Overview</h3> | |
| <div class="flex space-x-2"> | |
| <button class="px-3 py-1 text-sm bg-blue-500 text-white rounded-lg">Active Project</button> | |
| <button class="px-3 py-1 text-sm border border-gray-300 rounded-lg">All Projects</button> | |
| </div> | |
| </div> | |
| <div class="grid grid-cols-1 md:grid-cols-4 gap-4 mb-6"> | |
| <div class="bg-white p-4 rounded-lg shadow"> | |
| <div class="flex items-center justify-between"> | |
| <span class="text-gray-500">Budget</span> | |
| <i data-feather="dollar-sign" class="text-green-500"></i> | |
| </div> | |
| <h4 class="text-2xl font-bold mt-2">$4.2M</h4> | |
| <div class="mt-2 text-sm text-green-500 flex items-center"> | |
| <i data-feather="trending-up" class="w-4 h-4 mr-1"></i> | |
| <span>2.5% under</span> | |
| </div> | |
| </div> | |
| <div class="bg-white p-4 rounded-lg shadow"> | |
| <div class="flex items-center justify-between"> | |
| <span class="text-gray-500">Progress</span> | |
| <i data-feather="clock" class="text-blue-500"></i> | |
| </div> | |
| <h4 class="text-2xl font-bold mt-2">68%</h4> | |
| <div class="w-full bg-gray-200 rounded-full h-2 mt-2"> | |
| <div class="bg-blue-500 h-2 rounded-full" style="width: 68%"></div> | |
| </div> | |
| </div> | |
| <div class="bg-white p-4 rounded-lg shadow"> | |
| <div class="flex items-center justify-between"> | |
| <span class="text-gray-500">Materials Used</span> | |
| <i data-feather="package" class="text-purple-500"></i> | |
| </div> | |
| <h4 class="text-2xl font-bold mt-2">1,428 LF</h4> | |
| <div class="mt-2 text-sm text-red-500 flex items-center"> | |
| <i data-feather="alert-triangle" class="w-4 h-4 mr-1"></i> | |
| <span>5% over</span> | |
| </div> | |
| </div> | |
| <div class="bg-white p-4 rounded-lg shadow"> | |
| <div class="flex items-center justify-between"> | |
| <span class="text-gray-500">Labor Hours</span> | |
| <i data-feather="users" class="text-orange-500"></i> | |
| </div> | |
| <h4 class="text-2xl font-bold mt-2">3,428</h4> | |
| <div class="mt-2 text-sm text-green-500 flex items-center"> | |
| <i data-feather="trending-down" class="w-4 h-4 mr-1"></i> | |
| <span>8% under</span> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- Module Cards --> | |
| <div class="mb-8"> | |
| <h3 class="text-lg font-semibold mb-4">Project Modules</h3> | |
| <div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-4 gap-6"> | |
| <!-- Financial Module --> | |
| <div id="financial" class="module-card bg-white rounded-xl shadow-md overflow-hidden transition duration-300"> | |
| <div class="p-5"> | |
| <div class="flex items-center justify-between mb-4"> | |
| <div class="bg-blue-100 p-3 rounded-full"> | |
| <i data-feather="dollar-sign" class="text-blue-500 w-6 h-6"></i> | |
| </div> | |
| <span class="text-xs px-2 py-1 bg-blue-100 text-blue-800 rounded-full">Active</span> | |
| </div> | |
| <h4 class="text-xl font-bold mb-2">Financial Module</h4> | |
| <p class="text-gray-600 mb-4">Track budgets, expenditures, and generate detailed financial reports.</p> | |
| <div class="flex justify-between items-center"> | |
| <div> | |
| <span class="text-sm text-gray-500">Last updated</span> | |
| <span class="text-sm font-medium">2 hours ago</span> | |
| </div> | |
| <button class="text-blue-500 hover:text-blue-700"> | |
| <i data-feather="arrow-right"></i> | |
| </button> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- Tracking Module --> | |
| <div id="tracking" class="module-card bg-white rounded-xl shadow-md overflow-hidden transition duration-300"> | |
| <div class="p-5"> | |
| <div class="flex items-center justify-between mb-4"> | |
| <div class="bg-green-100 p-3 rounded-full"> | |
| <i data-feather="activity" class="text-green-500 w-6 h-6"></i> | |
| </div> | |
| <span class="text-xs px-2 py-1 bg-green-100 text-green-800 rounded-full">Active</span> | |
| </div> | |
| <h4 class="text-xl font-bold mb-2">Tracking Module</h4> | |
| <p class="text-gray-600 mb-4">Monitor installed quantities and progress against project milestones.</p> | |
| <div class="flex justify-between items-center"> | |
| <div> | |
| <span class="text-sm text-gray-500">Last updated</span> | |
| <span class="text-sm font-medium">15 min ago</span> | |
| </div> | |
| <button class="text-green-500 hover:text-green-700"> | |
| <i data-feather="arrow-right"></i> | |
| </button> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- Earned Value Module --> | |
| <div id="earned-value" class="module-card bg-white rounded-xl shadow-md overflow-hidden transition duration-300"> | |
| <div class="p-5"> | |
| <div class="flex items-center justify-between mb-4"> | |
| <div class="bg-purple-100 p-3 rounded-full"> | |
| <i data-feather="trending-up" class="text-purple-500 w-6 h-6"></i> | |
| </div> | |
| <span class="text-xs px-2 py-1 bg-purple-100 text-purple-800 rounded-full">Active</span> | |
| </div> | |
| <h4 class="text-xl font-bold mb-2">Earned Value</h4> | |
| <p class="text-gray-600 mb-4">Calculate CPI, SPI and compare planned vs. actual progress.</p> | |
| <div class="flex justify-between items-center"> | |
| <div> | |
| <span class="text-sm text-gray-500">Last updated</span> | |
| <span class="text-sm font-medium">1 hour ago</span> | |
| </div> | |
| <button class="text-purple-500 hover:text-purple-700"> | |
| <i data-feather="arrow-right"></i> | |
| </button> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- Plan & Forecast Module --> | |
| <div id="plan-forecast" class="module-card bg-white rounded-xl shadow-md overflow-hidden transition duration-300"> | |
| <div class="p-5"> | |
| <div class="flex items-center justify-between mb-4"> | |
| <div class="bg-orange-100 p-3 rounded-full"> | |
| <i data-feather="calendar" class="text-orange-500 w-6 h-6"></i> | |
| </div> | |
| <span class="text-xs px-2 py-1 bg-orange-100 text-orange-800 rounded-full">Active</span> | |
| </div> | |
| <h4 class="text-xl font-bold mb-2">Plan & Forecast</h4> | |
| <p class="text-gray-600 mb-4">Project schedules with Gantt charts and predictive analytics.</p> | |
| <div class="flex justify-between items-center"> | |
| <div> | |
| <span class="text-sm text-gray-500">Last updated</span> | |
| <span class="text-sm font-medium">4 hours ago</span> | |
| </div> | |
| <button class="text-orange-500 hover:text-orange-700"> | |
| <i data-feather="arrow-right"></i> | |
| </button> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- Charts Section --> | |
| <div class="grid grid-cols-1 lg:grid-cols-2 gap-6 mb-8"> | |
| <!-- Financial Performance --> | |
| <div class="bg-white p-6 rounded-lg shadow"> | |
| <div class="flex items-center justify-between mb-4"> | |
| <h3 class="text-lg font-semibold">Financial Performance</h3> | |
| <div class="flex space-x-2"> | |
| <button class="px-3 py-1 text-sm bg-blue-500 text-white rounded-lg">Monthly</button> | |
| <button class="px-3 py-1 text-sm border border-gray-300 rounded-lg">Quarterly</button> | |
| </div> | |
| </div> | |
| <canvas id="financialChart" height="250"></canvas> | |
| </div> | |
| <!-- Project Progress --> | |
| <div class="bg-white p-6 rounded-lg shadow"> | |
| <div class="flex items-center justify-between mb-4"> | |
| <h3 class="text-lg font-semibold">Project Progress</h3> | |
| <div class="flex items-center space-x-2"> | |
| <span class="text-sm text-gray-500">Last updated: 15 min ago</span> | |
| <button class="text-blue-500"> | |
| <i data-feather="refresh-cw" class="w-4 h-4"></i> | |
| </button> | |
| </div> | |
| </div> | |
| <canvas id="progressChart" height="250"></canvas> | |
| </div> | |
| </div> | |
| <!-- Milestones Summary --> | |
| <div class="bg-white p-6 rounded-lg shadow mb-8"> | |
| <div class="flex items-center justify-between mb-4"> | |
| <h3 class="text-lg font-semibold">Milestones Summary</h3> | |
| <button class="text-blue-500 hover:text-blue-700 text-sm">View All</button> | |
| </div> | |
| <div class="grid grid-cols-1 md:grid-cols-2 gap-4"> | |
| <!-- Upcoming Milestones --> | |
| <div class="border-l-4 border-blue-500 pl-4"> | |
| <h4 class="font-medium text-blue-700 mb-2">Upcoming</h4> | |
| <ul class="space-y-3"> | |
| <li> | |
| <div class="flex items-start"> | |
| <div class="bg-blue-100 p-1 rounded-full mr-3"> | |
| <i data-feather="calendar" class="text-blue-500 w-4 h-4"></i> | |
| </div> | |
| <div> | |
| <p class="font-medium">Zone 4 Piping Complete</p> | |
| <p class="text-sm text-gray-500">Due: May 15, 2023</p> | |
| </div> | |
| </div> | |
| </li> | |
| <li> | |
| <div class="flex items-start"> | |
| <div class="bg-blue-100 p-1 rounded-full mr-3"> | |
| <i data-feather="truck" class="text-blue-500 w-4 h-4"></i> | |
| </div> | |
| <div> | |
| <p class="font-medium">Material Delivery</p> | |
| <p class="text-sm text-gray-500">Due: May 8, 2023</p> | |
| </div> | |
| </div> | |
| </li> | |
| </ul> | |
| </div> | |
| <!-- Recent Milestones --> | |
| <div class="border-l-4 border-green-500 pl-4"> | |
| <h4 class="font-medium text-green-700 mb-2">Recently Completed</h4> | |
| <ul class="space-y-3"> | |
| <li> | |
| <div class="flex items-start"> | |
| <div class="bg-green-100 p-1 rounded-full mr-3"> | |
| <i data-feather="check" class="text-green-500 w-4 h-4"></i> | |
| </div> | |
| <div> | |
| <p class="font-medium">Zone 3 Hydro Test</p> | |
| <p class="text-sm text-gray-500">Completed: Apr 28, 2023</p> | |
| </div> | |
| </div> | |
| </li> | |
| <li> | |
| <div class="flex items-start"> | |
| <div class="bg-green-100 p-1 rounded-full mr-3"> | |
| <i data-feather="check" class="text-green-500 w-4 h-4"></i> | |
| </div> | |
| <div> | |
| <p class="font-medium">Pump Station Piping</p> | |
| <p class="text-sm text-gray-500">Completed: Apr 22, 2023</p> | |
| </div> | |
| </div> | |
| </li> | |
| </ul> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- Recent Activities --> | |
| <div class="bg-white p-6 rounded-lg shadow mb-8"> | |
| <div class="flex items-center justify-between mb-4"> | |
| <h3 class="text-lg font-semibold">Recent Activities</h3> | |
| <button class="text-blue-500 hover:text-blue-700 text-sm">View All</button> | |
| </div> | |
| <div class="space-y-4"> | |
| <div class="flex items-start space-x-4"> | |
| <div class="bg-green-100 p-2 rounded-full"> | |
| <i data-feather="check-circle" class="text-green-500 w-5 h-5"></i> | |
| </div> | |
| <div class="flex-1"> | |
| <p class="font-medium">Material delivery completed</p> | |
| <p class="text-sm text-gray-500">304 LF of 6" SCH40 pipe received at Site A</p> | |
| <p class="text-xs text-gray-400 mt-1">2 hours ago</p> | |
| </div> | |
| </div> | |
| <div class="flex items-start space-x-4"> | |
| <div class="bg-blue-100 p-2 rounded-full"> | |
| <i data-feather="dollar-sign" class="text-blue-500 w-5 h-5"></i> | |
| </div> | |
| <div class="flex-1"> | |
| <p class="font-medium">Invoice approved</p> | |
| <p class="text-sm text-gray-500">Invoice #INV-2023-045 for $24,850 approved</p> | |
| <p class="text-xs text-gray-400 mt-1">4 hours ago</p> | |
| </div> | |
| </div> | |
| <div class="flex items-start space-x-4"> | |
| <div class="bg-purple-100 p-2 rounded-full"> | |
| <i data-feather="trending-up" class="text-purple-500 w-5 h-5"></i> | |
| </div> | |
| <div class="flex-1"> | |
| <p class="font-medium">Earned value updated</p> | |
| <p class="text-sm text-gray-500">CPI: 1.02, SPI: 0.98 for Zone 3 piping</p> | |
| <p class="text-xs text-gray-400 mt-1">6 hours ago</p> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| </main> | |
| </div> | |
| </div> | |
| <script> | |
| // Initialize Feather Icons | |
| feather.replace(); | |
| // Initialize Vanta.js background | |
| VANTA.NET({ | |
| el: "#vanta-bg", | |
| color: 0x3b82f6, | |
| backgroundColor: 0xf8fafc, | |
| points: 12, | |
| maxDistance: 20, | |
| spacing: 15 | |
| }); | |
| // Toggle sidebar on mobile | |
| document.getElementById('sidebar-toggle').addEventListener('click', function() { | |
| document.querySelector('.sidebar').classList.toggle('translate-x-0'); | |
| }); | |
| // Initialize Financial Chart | |
| const financialCtx = document.getElementById('financialChart').getContext('2d'); | |
| const financialChart = new Chart(financialCtx, { | |
| type: 'bar', | |
| data: { | |
| labels: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun'], | |
| datasets: [ | |
| { | |
| label: 'Budget', | |
| data: [450000, 500000, 600000, 550000, 700000, 650000], | |
| backgroundColor: 'rgba(59, 130, 246, 0.7)', | |
| borderColor: 'rgba(59, 130, 246, 1)', | |
| borderWidth: 1 | |
| }, | |
| { | |
| label: 'Actual', | |
| data: [420000, 480000, 580000, 520000, 680000, 620000], | |
| backgroundColor: 'rgba(16, 185, 129, 0.7)', | |
| borderColor: 'rgba(16, 185, 129, 1)', | |
| borderWidth: 1 | |
| } | |
| ] | |
| }, | |
| options: { | |
| responsive: true, | |
| plugins: { | |
| legend: { | |
| position: 'top', | |
| }, | |
| tooltip: { | |
| callbacks: { | |
| label: function(context) { | |
| let label = context.dataset.label || ''; | |
| if (label) { | |
| label += ': '; | |
| } | |
| if (context.parsed.y !== null) { | |
| label += new Intl.NumberFormat('en-US', { style: 'currency', currency: 'USD' }).format(context.parsed.y); | |
| } | |
| return label; | |
| } | |
| } | |
| } | |
| }, | |
| scales: { | |
| y: { | |
| beginAtZero: true, | |
| ticks: { | |
| callback: function(value) { | |
| return '$' + (value / 1000) + 'K'; | |
| } | |
| } | |
| } | |
| } | |
| } | |
| }); | |
| // Initialize Progress Chart | |
| const progressCtx = document.getElementById('progressChart').getContext('2d'); | |
| const progressChart = new Chart(progressCtx, { | |
| type: 'line', | |
| data: { | |
| labels: ['Week 1', 'Week 2', 'Week 3', 'Week 4', 'Week 5', 'Week 6'], | |
| datasets: [ | |
| { | |
| label: 'Planned', | |
| data: [10, 20, 35, 45, 60, 75], | |
| borderColor: 'rgba(99, 102, 241, 1)', | |
| backgroundColor: 'rgba(99, 102, 241, 0.1)', | |
| borderWidth: 2, | |
| tension: 0.3, | |
| fill: true | |
| }, | |
| { | |
| label: 'Actual', | |
| data: [8, 18, 30, 42, 55, 68], | |
| borderColor: 'rgba(245, 158, 11, 1)', | |
| backgroundColor: 'rgba(245, 158, 11, 0.1)', | |
| borderWidth: 2, | |
| tension: 0.3, | |
| fill: true | |
| } | |
| ] | |
| }, | |
| options: { | |
| responsive: true, | |
| plugins: { | |
| legend: { | |
| position: 'top', | |
| }, | |
| tooltip: { | |
| callbacks: { | |
| label: function(context) { | |
| return context.dataset.label + ': ' + context.parsed.y + '%'; | |
| } | |
| } | |
| } | |
| }, | |
| scales: { | |
| y: { | |
| beginAtZero: true, | |
| max: 100, | |
| ticks: { | |
| callback: function(value) { | |
| return value + '%'; | |
| } | |
| } | |
| } | |
| } | |
| } | |
| }); | |
| </script> | |
| </body> | |
| </html> | |