| | <!DOCTYPE html> |
| | <html lang="en" class="light"> |
| | <head> |
| | <meta charset="UTF-8"> |
| | <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| | <title>NodeNest | Node.js Hosting Panel</title> |
| | <link rel="icon" type="image/x-icon" href="/static/favicon.ico"> |
| | <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> |
| | <link rel="stylesheet" href="style.css"> |
| | <script> |
| | tailwind.config = { |
| | darkMode: 'class', |
| | theme: { |
| | extend: { |
| | colors: { |
| | primary: { |
| | 50: '#f0f9ff', |
| | 100: '#e0f2fe', |
| | 200: '#bae6fd', |
| | 300: '#7dd3fc', |
| | 400: '#38bdf8', |
| | 500: '#0ea5e9', |
| | 600: '#0284c7', |
| | 700: '#0369a1', |
| | 800: '#075985', |
| | 900: '#0c4a6e', |
| | }, |
| | secondary: { |
| | 50: '#f5f3ff', |
| | 100: '#ede9fe', |
| | 200: '#ddd6fe', |
| | 300: '#c4b5fd', |
| | 400: '#a78bfa', |
| | 500: '#8b5cf6', |
| | 600: '#7c3aed', |
| | 700: '#6d28d9', |
| | 800: '#5b21b6', |
| | 900: '#4c1d95', |
| | } |
| | } |
| | } |
| | } |
| | } |
| | </script> |
| | </head> |
| | <body class="bg-gray-50 dark:bg-gray-900 min-h-screen transition-colors duration-200"> |
| | <custom-navbar></custom-navbar> |
| | <script src="components/navbar.js"></script> |
| | <main class="container mx-auto px-4 py-8"> |
| | <div class="flex flex-col md:flex-row gap-6"> |
| | |
| | <custom-sidebar></custom-sidebar> |
| | |
| | |
| | <div class="flex-1"> |
| | <div class="bg-white dark:bg-gray-800 rounded-lg shadow-md p-6 mb-6"> |
| | <div class="flex justify-between items-center mb-6"> |
| | <h2 class="text-2xl font-semibold text-gray-800 dark:text-white">Your Node.js Projects</h2> |
| | <button class="bg-primary-500 hover:bg-primary-600 text-white px-4 py-2 rounded-md flex items-center gap-2 transition-colors"> |
| | <i data-feather="plus"></i> |
| | New Project |
| | </button> |
| | </div> |
| |
|
| | |
| | <div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6"> |
| | |
| | <div class="border border-gray-200 dark:border-gray-700 rounded-lg overflow-hidden hover:shadow-lg transition-shadow"> |
| | <div class="bg-primary-500 p-4 text-white"> |
| | <div class="flex justify-between items-center"> |
| | <h3 class="font-medium">E-commerce API</h3> |
| | <span class="bg-primary-700 text-xs px-2 py-1 rounded">Running</span> |
| | </div> |
| | </div> |
| | <div class="p-4 bg-white dark:bg-gray-800"> |
| | <div class="flex items-center gap-2 text-gray-600 dark:text-gray-300 mb-3"> |
| | <i data-feather="cpu" class="w-4 h-4"></i> |
| | <span class="text-sm">2 vCPU / 4GB RAM</span> |
| | </div> |
| | <div class="flex items-center gap-2 text-gray-600 dark:text-gray-300 mb-3"> |
| | <i data-feather="clock" class="w-4 h-4"></i> |
| | <span class="text-sm">Uptime: 12 days</span> |
| | </div> |
| | <div class="flex items-center gap-2 text-gray-600 dark:text-gray-300 mb-4"> |
| | <i data-feather="activity" class="w-4 h-4"></i> |
| | <span class="text-sm">Port: 3000</span> |
| | </div> |
| | <div class="flex gap-2"> |
| | <button class="flex-1 bg-gray-100 dark:bg-gray-700 hover:bg-gray-200 dark:hover:bg-gray-600 text-gray-800 dark:text-white py-2 px-3 rounded text-sm flex items-center justify-center gap-1"> |
| | <i data-feather="terminal" class="w-4 h-4"></i> Console |
| | </button> |
| | <button class="flex-1 bg-gray-100 dark:bg-gray-700 hover:bg-gray-200 dark:hover:bg-gray-600 text-gray-800 dark:text-white py-2 px-3 rounded text-sm flex items-center justify-center gap-1"> |
| | <i data-feather="settings" class="w-4 h-4"></i> Settings |
| | </button> |
| | </div> |
| | </div> |
| | </div> |
| |
|
| | |
| | <div class="border border-gray-200 dark:border-gray-700 rounded-lg overflow-hidden hover:shadow-lg transition-shadow"> |
| | <div class="bg-secondary-500 p-4 text-white"> |
| | <div class="flex justify-between items-center"> |
| | <h3 class="font-medium">Blog Platform</h3> |
| | <span class="bg-secondary-700 text-xs px-2 py-1 rounded">Stopped</span> |
| | </div> |
| | </div> |
| | <div class="p-4 bg-white dark:bg-gray-800"> |
| | <div class="flex items-center gap-2 text-gray-600 dark:text-gray-300 mb-3"> |
| | <i data-feather="cpu" class="w-4 h-4"></i> |
| | <span class="text-sm">1 vCPU / 2GB RAM</span> |
| | </div> |
| | <div class="flex items-center gap-2 text-gray-600 dark:text-gray-300 mb-3"> |
| | <i data-feather="clock" class="w-4 h-4"></i> |
| | <span class="text-sm">Uptime: 0 days</span> |
| | </div> |
| | <div class="flex items-center gap-2 text-gray-600 dark:text-gray-300 mb-4"> |
| | <i data-feather="activity" class="w-4 h-4"></i> |
| | <span class="text-sm">Port: 4000</span> |
| | </div> |
| | <div class="flex gap-2"> |
| | <button class="flex-1 bg-gray-100 dark:bg-gray-700 hover:bg-gray-200 dark:hover:bg-gray-600 text-gray-800 dark:text-white py-2 px-3 rounded text-sm flex items-center justify-center gap-1"> |
| | <i data-feather="play" class="w-4 h-4"></i> Start |
| | </button> |
| | <button class="flex-1 bg-gray-100 dark:bg-gray-700 hover:bg-gray-200 dark:hover:bg-gray-600 text-gray-800 dark:text-white py-2 px-3 rounded text-sm flex items-center justify-center gap-1"> |
| | <i data-feather="settings" class="w-4 h-4"></i> Settings |
| | </button> |
| | </div> |
| | </div> |
| | </div> |
| |
|
| | |
| | <div class="border-2 border-dashed border-gray-300 dark:border-gray-600 rounded-lg hover:border-primary-500 dark:hover:border-primary-500 transition-colors flex items-center justify-center min-h-[200px] cursor-pointer"> |
| | <div class="text-center p-4"> |
| | <i data-feather="plus" class="w-8 h-8 mx-auto text-gray-400 dark:text-gray-500 mb-2"></i> |
| | <p class="text-gray-500 dark:text-gray-400">Create new project</p> |
| | </div> |
| | </div> |
| | </div> |
| | </div> |
| |
|
| | |
| | <div class="bg-white dark:bg-gray-800 rounded-lg shadow-md p-6"> |
| | <h2 class="text-2xl font-semibold text-gray-800 dark:text-white mb-6">Resources Usage</h2> |
| | <div class="grid grid-cols-1 md:grid-cols-3 gap-6"> |
| | |
| | <div class="bg-gray-50 dark:bg-gray-700 p-4 rounded-lg"> |
| | <div class="flex justify-between items-center mb-2"> |
| | <h3 class="font-medium text-gray-800 dark:text-white">CPU</h3> |
| | <span class="text-sm font-medium text-primary-500">35%</span> |
| | </div> |
| | <div class="w-full bg-gray-200 dark:bg-gray-600 rounded-full h-2.5"> |
| | <div class="bg-primary-500 h-2.5 rounded-full" style="width: 35%"></div> |
| | </div> |
| | <p class="text-xs text-gray-500 dark:text-gray-400 mt-2">2 vCPU / 4 used</p> |
| | </div> |
| |
|
| | |
| | <div class="bg-gray-50 dark:bg-gray-700 p-4 rounded-lg"> |
| | <div class="flex justify-between items-center mb-2"> |
| | <h3 class="font-medium text-gray-800 dark:text-white">Memory</h3> |
| | <span class="text-sm font-medium text-secondary-500">68%</span> |
| | </div> |
| | <div class="w-full bg-gray-200 dark:bg-gray-600 rounded-full h-2.5"> |
| | <div class="bg-secondary-500 h-2.5 rounded-full" style="width: 68%"></div> |
| | </div> |
| | <p class="text-xs text-gray-500 dark:text-gray-400 mt-2">4 GB / 2.7 GB used</p> |
| | </div> |
| |
|
| | |
| | <div class="bg-gray-50 dark:bg-gray-700 p-4 rounded-lg"> |
| | <div class="flex justify-between items-center mb-2"> |
| | <h3 class="font-medium text-gray-800 dark:text-white">Storage</h3> |
| | <span class="text-sm font-medium text-yellow-500">42%</span> |
| | </div> |
| | <div class="w-full bg-gray-200 dark:bg-gray-600 rounded-full h-2.5"> |
| | <div class="bg-yellow-500 h-2.5 rounded-full" style="width: 42%"></div> |
| | </div> |
| | <p class="text-xs text-gray-500 dark:text-gray-400 mt-2">50 GB / 21 GB used</p> |
| | </div> |
| | </div> |
| | </div> |
| | </div> |
| | </div> |
| | </main> |
| | <custom-footer></custom-footer> |
| | <script src="components/footer.js"></script> |
| | <script src="components/sidebar.js"></script> |
| | <script src="script.js"></script> |
| | <script> |
| | feather.replace(); |
| | </script> |
| | <script src="https://huggingface.co/deepsite/deepsite-badge.js"></script> |
| | </body> |
| | </html> |
| |
|