index.html 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>ArduPilot Overlay Manager</title>
  6. <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css" rel="stylesheet">
  7. <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.10.5/font/bootstrap-icons.css">
  8. <style>
  9. .btn-custom { background-color: #0B61A4; color: white; transition: all 0.2s; }
  10. .btn-custom:hover { background-color: #084b82; color: white; transform: translateY(-1px); }
  11. </style>
  12. </head>
  13. <body class="bg-light">
  14. <nav class="navbar navbar-dark shadow-sm py-3" style="background-color: #0B61A4;">
  15. <div class="container d-flex align-items-center">
  16. <img src="/patch-manager/static/logo.png" alt="ArduPilot Logo" class="me-3 bg-white p-2 rounded shadow-sm">
  17. <span class="navbar-brand mb-0 h3 fw-bold">Overlay Manager</span>
  18. </div>
  19. </nav>
  20. <div class="container mt-4">
  21. <div class="card shadow border-0 rounded-3 mb-4">
  22. <div class="card-body p-4">
  23. <h5 class="card-title fw-bold text-secondary mb-3"><i class="bi bi-cloud-arrow-up-fill me-2 text-primary"></i>Inject Custom Source</h5>
  24. <form action="/patch-manager/upload" method="post" enctype="multipart/form-data" class="row g-3">
  25. <div class="col-md-5"><input class="form-control border-primary" type="file" name="file" required></div>
  26. <div class="col-md-5"><input type="text" class="form-control border-primary" name="target_path" placeholder="Path (e.g., libraries/AP_HAL)"></div>
  27. <div class="col-md-2"><button type="submit" class="btn btn-custom w-100 fw-bold">Upload</button></div>
  28. </form>
  29. </div>
  30. </div>
  31. <div class="card shadow border-0 rounded-3">
  32. <div class="card-body p-0">
  33. <table class="table table-hover align-middle mb-0">
  34. <thead class="table-light"><tr><th class="ps-4 py-3">Source Path</th><th class="text-end pe-4 py-3">Actions</th></tr></thead>
  35. <tbody>
  36. {% for file in files %}
  37. <tr>
  38. <td class="ps-4 font-monospace">{{ file }}</td>
  39. <td class="text-end pe-4">
  40. <a href="/patch-manager/edit?filepath={{ file }}" class="btn btn-sm btn-outline-primary me-2"><i class="bi bi-pencil"></i> Edit</a>
  41. <form action="/patch-manager/delete" method="post" class="d-inline" onsubmit="return confirm('Delete this file?');">
  42. <input type="hidden" name="filepath" value="{{ file }}">
  43. <button type="submit" class="btn btn-sm btn-outline-danger"><i class="bi bi-trash"></i> Delete</button>
  44. </form>
  45. </td>
  46. </tr>
  47. {% endfor %}
  48. </tbody>
  49. </table>
  50. </div>
  51. </div>
  52. </div>
  53. </body>
  54. </html>