Spaces:
Running
Running
| <html lang="en"> | |
| <head> | |
| <meta charset="UTF-8"> | |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> | |
| <title>NetOrganizer Pro</title> | |
| <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="components/navbar.js"></script> | |
| <script src="components/footer.js"></script> | |
| </head> | |
| <body class="bg-gray-100"> | |
| <custom-navbar></custom-navbar> | |
| <main class="container mx-auto px-4 py-8"> | |
| <div class="max-w-4xl mx-auto bg-white rounded-xl shadow-md overflow-hidden p-6"> | |
| <h1 class="text-3xl font-bold text-gray-800 mb-6">Network Service Organizer</h1> | |
| <div class="mb-8"> | |
| <label class="block text-gray-700 font-medium mb-2">Service Type</label> | |
| <div class="flex space-x-4"> | |
| <button id="internetBtn" class="service-type-btn bg-blue-600 text-white px-6 py-3 rounded-lg font-medium hover:bg-blue-700 transition duration-200">Internet</button> | |
| <button id="l2lBtn" class="service-type-btn bg-gray-200 text-gray-800 px-6 py-3 rounded-lg font-medium hover:bg-gray-300 transition duration-200">LAN to LAN</button> | |
| </div> | |
| </div> | |
| <!-- Internet Service Form --> | |
| <div id="internetForm" class="space-y-6"> | |
| <div class="grid md:grid-cols-2 gap-6"> | |
| <div> | |
| <label for="client" class="block text-gray-700 font-medium mb-2">Client</label> | |
| <input type="text" id="client" class="w-full px-4 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500"> | |
| </div> | |
| <div> | |
| <label for="serviceNumber" class="block text-gray-700 font-medium mb-2">Service Number</label> | |
| <input type="text" id="serviceNumber" class="w-full px-4 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500"> | |
| </div> | |
| </div> | |
| <div> | |
| <label for="address" class="block text-gray-700 font-medium mb-2">Address</label> | |
| <input type="text" id="address" class="w-full px-4 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500"> | |
| </div> | |
| <div> | |
| <label for="bandwidth" class="block text-gray-700 font-medium mb-2">Bandwidth</label> | |
| <input type="text" id="bandwidth" class="w-full px-4 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500"> | |
| </div> | |
| <div> | |
| <label for="ipRange" class="block text-gray-700 font-medium mb-2">IP Range (e.g., 190.220.1.216/29)</label> | |
| <input type="text" id="ipRange" class="w-full px-4 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500"> | |
| <button id="calculateBtn" class="mt-2 bg-blue-600 text-white px-4 py-2 rounded-lg hover:bg-blue-700 transition duration-200">Calculate IPs</button> | |
| </div> | |
| <div id="ipTableContainer" class="hidden mt-6 overflow-x-auto"> | |
| <table class="min-w-full bg-white border border-gray-200"> | |
| <thead class="bg-gray-50"> | |
| <tr> | |
| <th class="px-4 py-2 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">Type</th> | |
| <th class="px-4 py-2 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">IP Address</th> | |
| <th class="px-4 py-2 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">Subnet Mask</th> | |
| </tr> | |
| </thead> | |
| <tbody id="ipTableBody" class="divide-y divide-gray-200"> | |
| <!-- IP Table rows will be generated here --> | |
| </tbody> | |
| </table> | |
| <div class="mt-4 flex space-x-4"> | |
| <button id="copyTableBtn" class="bg-gray-600 text-white px-4 py-2 rounded-lg hover:bg-gray-700 transition duration-200"> | |
| <i data-feather="copy" class="mr-2"></i> Copy Table | |
| </button> | |
| </div> | |
| <div class="mt-4 grid md:grid-cols-2 gap-4"> | |
| <div> | |
| <label class="block text-gray-700 font-medium mb-1">Primary DNS</label> | |
| <p class="text-gray-800">186.12.238.16</p> | |
| </div> | |
| <div> | |
| <label class="block text-gray-700 font-medium mb-1">Secondary DNS</label> | |
| <p class="text-gray-800">186.12.238.15</p> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- L2L Service Form --> | |
| <div id="l2lForm" class="hidden space-y-6"> | |
| <div class="grid md:grid-cols-2 gap-6"> | |
| <div> | |
| <label for="l2lClient" class="block text-gray-700 font-medium mb-2">Client</label> | |
| <input type="text" id="l2lClient" class="w-full px-4 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500"> | |
| </div> | |
| <div> | |
| <label for="l2lServiceNumber" class="block text-gray-700 font-medium mb-2">Service Number</label> | |
| <input type="text" id="l2lServiceNumber" class="w-full px-4 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500"> | |
| </div> | |
| </div> | |
| <div> | |
| <label for="l2lBandwidth" class="block text-gray-700 font-medium mb-2">Bandwidth</label> | |
| <input type="text" id="l2lBandwidth" class="w-full px-4 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500"> | |
| </div> | |
| <div class="grid md:grid-cols-2 gap-6"> | |
| <div class="border border-gray-200 p-4 rounded-lg"> | |
| <h3 class="text-lg font-medium text-gray-800 mb-3">Site A</h3> | |
| <div class="space-y-4"> | |
| <div> | |
| <label for="siteAAddress" class="block text-gray-700 font-medium mb-1">Address</label> | |
| <input type="text" id="siteAAddress" class="w-full px-3 py-2 border border-gray-300 rounded-md"> | |
| </div> | |
| <div> | |
| <label for="siteADevice" class="block text-gray-700 font-medium mb-1">Device Info</label> | |
| <textarea id="siteADevice" rows="3" class="w-full px-3 py-2 border border-gray-300 rounded-md"></textarea> | |
| </div> | |
| <div> | |
| <label for="siteAPort" class="block text-gray-700 font-medium mb-1">Service Port</label> | |
| <input type="text" id="siteAPort" class="w-full px-3 py-2 border border-gray-300 rounded-md"> | |
| </div> | |
| </div> | |
| </div> | |
| <div class="border border-gray-200 p-4 rounded-lg"> | |
| <h3 class="text-lg font-medium text-gray-800 mb-3">Site B</h3> | |
| <div class="space-y-4"> | |
| <div> | |
| <label for="siteBAddress" class="block text-gray-700 font-medium mb-1">Address</label> | |
| <input type="text" id="siteBAddress" class="w-full px-3 py-2 border border-gray-300 rounded-md"> | |
| </div> | |
| <div> | |
| <label for="siteBDevice" class="block text-gray-700 font-medium mb-1">Device Info</label> | |
| <textarea id="siteBDevice" rows="3" class="w-full px-3 py-2 border border-gray-300 rounded-md"></textarea> | |
| </div> | |
| <div> | |
| <label for="siteBPort" class="block text-gray-700 font-medium mb-1">Service Port</label> | |
| <input type="text" id="siteBPort" class="w-full px-3 py-2 border border-gray-300 rounded-md"> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <div class="mt-8"> | |
| <button id="generateBtn" class="bg-green-600 text-white px-6 py-3 rounded-lg font-medium hover:bg-green-700 transition duration-200 flex items-center"> | |
| <i data-feather="mail" class="mr-2"></i> Generate Email Template | |
| </button> | |
| </div> | |
| <div id="outputContainer" class="hidden mt-8 p-6 bg-gray-50 rounded-lg border border-gray-200"> | |
| <h2 class="text-xl font-bold text-gray-800 mb-4">Email Template</h2> | |
| <div id="emailOutput" class="whitespace-pre-wrap text-gray-700"></div> | |
| <button id="copyBtn" class="mt-4 bg-blue-600 text-white px-4 py-2 rounded-lg hover:bg-blue-700 transition duration-200"> | |
| <i data-feather="copy" class="mr-2"></i> Copy to Clipboard | |
| </button> | |
| </div> | |
| </div> | |
| </main> | |
| <custom-footer></custom-footer> | |
| <script src="script.js"></script> | |
| <script> | |
| feather.replace(); | |
| </script> | |
| <script src="https://huggingface.co/deepsite/deepsite-badge.js"></script> | |
| </body> | |
| </html> |