117 lines
5.4 KiB
HTML
117 lines
5.4 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="de" data-bs-theme="dark">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
<title>MeshDD-Bot Dashboard</title>
|
|
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/css/bootstrap.min.css" rel="stylesheet">
|
|
<link href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.3/font/bootstrap-icons.min.css" rel="stylesheet">
|
|
<link rel="stylesheet" href="/static/css/style.css">
|
|
</head>
|
|
<body>
|
|
<!-- Navbar -->
|
|
<nav class="navbar navbar-expand-sm bg-body-tertiary border-bottom">
|
|
<div class="container-fluid">
|
|
<a class="navbar-brand" href="/">
|
|
<i class="bi bi-broadcast-pin text-info me-2"></i>MeshDD-Bot <small class="text-body-secondary" id="versionLabel"></small>
|
|
</a>
|
|
<div class="d-flex align-items-center gap-3">
|
|
<a href="/map" target="_blank" class="btn btn-outline-info btn-sm">
|
|
<i class="bi bi-map me-1"></i>Karte
|
|
</a>
|
|
<button class="btn btn-outline-secondary btn-sm" id="themeToggle" title="Theme wechseln">
|
|
<i class="bi bi-sun-fill" id="themeIcon"></i>
|
|
</button>
|
|
<span class="badge d-flex align-items-center gap-2" id="statusBadge">
|
|
<span class="status-dot" id="statusDot"></span>
|
|
<span id="statusText">Verbinde...</span>
|
|
</span>
|
|
</div>
|
|
</div>
|
|
</nav>
|
|
|
|
<div class="container-fluid py-3">
|
|
<!-- Stats Cards -->
|
|
<div class="row g-2 mb-3">
|
|
<div class="col-6 col-md-3">
|
|
<div class="card text-center border-info border-opacity-25">
|
|
<div class="card-body py-2">
|
|
<div class="fs-4 fw-bold text-info" id="statNodes">0</div>
|
|
<div class="text-body-secondary small">Nodes</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="col-6 col-md-3">
|
|
<div class="card text-center border-success border-opacity-25">
|
|
<div class="card-body py-2">
|
|
<div class="fs-4 fw-bold text-success" id="statPositions">0</div>
|
|
<div class="text-body-secondary small">Mit Position</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="col-6 col-md-3">
|
|
<div class="card text-center border-warning border-opacity-25">
|
|
<div class="card-body py-2">
|
|
<div class="fs-4 fw-bold text-warning" id="statMessages">0</div>
|
|
<div class="text-body-secondary small">Nachrichten</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="col-6 col-md-3">
|
|
<div class="card text-center border-primary border-opacity-25">
|
|
<div class="card-body py-2">
|
|
<div class="fs-4 fw-bold text-primary" id="statTextMessages">0</div>
|
|
<div class="text-body-secondary small">Textnachrichten</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Panels -->
|
|
<div class="row g-3">
|
|
<!-- Nodes Table -->
|
|
<div class="col-lg-7">
|
|
<div class="card">
|
|
<div class="card-header d-flex align-items-center">
|
|
<i class="bi bi-router me-2 text-info"></i>
|
|
<span class="fw-semibold">Nodes</span>
|
|
<span class="badge bg-info ms-auto" id="nodeCountBadge">0</span>
|
|
</div>
|
|
<div class="card-body p-0 table-responsive" style="max-height: 500px; overflow-y: auto;">
|
|
<table class="table table-hover table-sm mb-0 align-middle">
|
|
<thead class="table-dark sticky-top">
|
|
<tr>
|
|
<th>Name</th>
|
|
<th>Hardware</th>
|
|
<th class="text-end px-1">SNR</th>
|
|
<th class="px-1">Batterie</th>
|
|
<th class="text-center px-1">Hops</th>
|
|
<th class="text-end px-1">Zuletzt</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody id="nodesTable"></tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Messages -->
|
|
<div class="col-lg-5">
|
|
<div class="card">
|
|
<div class="card-header d-flex align-items-center">
|
|
<i class="bi bi-chat-dots me-2 text-warning"></i>
|
|
<span class="fw-semibold">Nachrichten</span>
|
|
</div>
|
|
<div class="card-body p-0" style="max-height: 500px; overflow-y: auto;">
|
|
<div class="list-group list-group-flush" id="messagesList"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/js/bootstrap.bundle.min.js"></script>
|
|
<script src="/static/js/dashboard.js"></script>
|
|
</body>
|
|
</html>
|