| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>ArduPilot Overlay Manager</title>
- <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css" rel="stylesheet">
- <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.10.5/font/bootstrap-icons.css">
- <style>
- .btn-custom { background-color: #0B61A4; color: white; transition: all 0.2s; }
- .btn-custom:hover { background-color: #084b82; color: white; transform: translateY(-1px); }
- </style>
- </head>
- <body class="bg-light">
- <nav class="navbar navbar-dark shadow-sm py-2" style="background-color: #0B61A4;">
- <div class="container d-flex align-items-center">
- <div class="d-flex align-items-center">
- <img src="/patch-manager/static/logo.png" alt="ArduPilot Logo" height="35" class="d-inline-block align-text-top me-3">
- <span class="navbar-brand mb-0 h4 fw-bold">Overlay Manager</span>
- </div>
- <div class="ms-auto">
- <a href="javascript:void(0);" onclick="window.location.href = window.location.protocol + '//' + window.location.hostname;" class="btn btn-outline-light btn-sm">
- <i class="bi bi-arrow-left me-1"></i>Back to Main App
- </a>
- </div>
- </div>
- </nav>
- <div class="container mt-4">
-
- <div class="row mb-4 g-4">
- <div class="col-md-7">
- <div class="card shadow border-0 rounded-3 h-100">
- <div class="card-body p-4">
- <h5 class="card-title fw-bold text-secondary mb-3"><i class="bi bi-cloud-arrow-up-fill me-2 text-primary"></i>Upload to Folder</h5>
- <form action="/patch-manager/upload" method="post" enctype="multipart/form-data" class="d-flex flex-column gap-3">
- <input class="form-control border-primary" type="file" name="file" required>
-
- <div class="input-group">
- <span class="input-group-text bg-light border-primary text-secondary"><i class="bi bi-folder2-open"></i></span>
- <select class="form-select border-primary" name="target_path">
- {% for d in dirs %}
- <option value="{{ d }}">{% if d == "" %}/ (Root Directory){% else %}{{ d }}{% endif %}</option>
- {% endfor %}
- </select>
- </div>
- <button type="submit" class="btn btn-custom fw-bold mt-auto">Upload File</button>
- </form>
- </div>
- </div>
- </div>
- <div class="col-md-5">
- <div class="card shadow border-0 rounded-3 h-100">
- <div class="card-body p-4">
- <h5 class="card-title fw-bold text-secondary mb-3"><i class="bi bi-folder-plus me-2 text-success"></i>Create New Folder</h5>
- <form action="/patch-manager/create_folder" method="post" class="d-flex flex-column gap-3">
- <input type="text" class="form-control border-primary" name="folder_path" placeholder="Path (e.g., libraries/AP_HAL)" required>
- <button type="submit" class="btn btn-success fw-bold mt-auto">Create Folder</button>
- </form>
- </div>
- </div>
- </div>
- </div>
- <div class="card shadow border-0 rounded-3">
- <div class="card-body p-0">
- <table class="table table-hover align-middle mb-0">
- <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>
- <tbody>
- {% for file in files %}
- <tr>
- <td class="ps-4 font-monospace">{{ file }}</td>
- <td class="text-end pe-4">
- <a href="/patch-manager/edit?filepath={{ file }}" class="btn btn-sm btn-outline-primary me-2"><i class="bi bi-pencil"></i> Edit</a>
- <form action="/patch-manager/delete" method="post" class="d-inline" onsubmit="return confirm('Delete this file?');">
- <input type="hidden" name="filepath" value="{{ file }}">
- <button type="submit" class="btn btn-sm btn-outline-danger"><i class="bi bi-trash"></i> Delete</button>
- </form>
- </td>
- </tr>
- {% endfor %}
- </tbody>
- </table>
- </div>
- </div>
- </div>
- </body>
- </html>
|