|
|
<!doctype html>
|
|
|
<html lang="ru">
|
|
|
<head>
|
|
|
<meta charset="UTF-8" />
|
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
|
<title>Панель Триангуляции</title>
|
|
|
<link rel="stylesheet" href="/static/styles.css" />
|
|
|
</head>
|
|
|
<body>
|
|
|
<div class="bg-glow bg-glow-a"></div>
|
|
|
<div class="bg-glow bg-glow-b"></div>
|
|
|
|
|
|
<main class="app-shell">
|
|
|
<aside class="side-nav card">
|
|
|
<p class="kicker">Триангуляция</p>
|
|
|
<h1 class="side-title">Пульт</h1>
|
|
|
|
|
|
<div class="menu-wrap">
|
|
|
<button id="menu-toggle" class="btn btn-primary menu-toggle">Разделы</button>
|
|
|
<div id="menu-list" class="menu-list">
|
|
|
<button class="menu-item menu-item-active" data-section="overview">Обзор</button>
|
|
|
<button class="menu-item" data-section="frequencies">Частоты</button>
|
|
|
<button class="menu-item" data-section="receivers">Ресиверы</button>
|
|
|
<button class="menu-item" data-section="delivery">Доставка</button>
|
|
|
<button class="menu-item" data-section="servers">Серверы</button>
|
|
|
<button class="menu-item" data-section="json">Конфигурация</button>
|
|
|
</div>
|
|
|
</div>
|
|
|
|
|
|
<div class="side-meta">
|
|
|
<span id="updated-date" class="badge badge-meta">дата: н/д</span>
|
|
|
<span id="updated-time" class="badge badge-meta">время: н/д</span>
|
|
|
<span id="health-status" class="badge">состояние: н/д</span>
|
|
|
<span id="delivery-status" class="badge">доставка: н/д</span>
|
|
|
</div>
|
|
|
</aside>
|
|
|
|
|
|
<section class="content-area">
|
|
|
<section id="section-overview" class="panel panel-active">
|
|
|
<header class="hero card">
|
|
|
<h2>Панель Радиопозиционирования</h2>
|
|
|
<p class="muted">Мониторинг и управление расчётом 3D триангуляции.</p>
|
|
|
<div class="hero-actions">
|
|
|
<button id="refresh-now" class="btn btn-primary">Обновить</button>
|
|
|
</div>
|
|
|
</header>
|
|
|
|
|
|
<article class="card">
|
|
|
<h2>Итоговая Позиция</h2>
|
|
|
<div class="result-box">
|
|
|
<div><span class="muted">Выбранная частота:</span> <b id="selected-freq">-</b></div>
|
|
|
<div><span class="muted">X:</span> <b id="pos-x">-</b></div>
|
|
|
<div><span class="muted">Y:</span> <b id="pos-y">-</b></div>
|
|
|
<div><span class="muted">Z:</span> <b id="pos-z">-</b></div>
|
|
|
<div><span class="muted">СКО (RMSE):</span> <b id="rmse">-</b></div>
|
|
|
</div>
|
|
|
</article>
|
|
|
</section>
|
|
|
|
|
|
<section id="section-frequencies" class="panel">
|
|
|
<article class="card">
|
|
|
<h2>Таблица По Частотам</h2>
|
|
|
<div class="table-wrap">
|
|
|
<table id="freq-table">
|
|
|
<thead>
|
|
|
<tr>
|
|
|
<th>Частота (МГц)</th>
|
|
|
<th>X</th>
|
|
|
<th>Y</th>
|
|
|
<th>Z</th>
|
|
|
<th>СКО (RMSE)</th>
|
|
|
<th>Точно</th>
|
|
|
</tr>
|
|
|
</thead>
|
|
|
<tbody></tbody>
|
|
|
</table>
|
|
|
</div>
|
|
|
</article>
|
|
|
</section>
|
|
|
|
|
|
<section id="section-receivers" class="panel">
|
|
|
<article class="card">
|
|
|
<h2>Ресиверы</h2>
|
|
|
<div id="receivers-list" class="mono small"></div>
|
|
|
</article>
|
|
|
</section>
|
|
|
|
|
|
<section id="section-delivery" class="panel">
|
|
|
<article class="card">
|
|
|
<h2>Доставка На Выходы</h2>
|
|
|
<div id="delivery-details" class="mono small"></div>
|
|
|
</article>
|
|
|
</section>
|
|
|
|
|
|
<section id="section-servers" class="panel">
|
|
|
<article class="card">
|
|
|
<h2>Настройка Серверов</h2>
|
|
|
<p class="muted">Доступы входа и выхода задаются отдельно. Общий фильтр входа автоматически применяется ко всем входным серверам.</p>
|
|
|
|
|
|
<h3 class="servers-title">Доступ К Входным Серверам</h3>
|
|
|
<div class="server-grid">
|
|
|
<label>Выбранный сервер
|
|
|
<select id="receiver-select"></select>
|
|
|
</label>
|
|
|
<div class="server-actions-row">
|
|
|
<button id="add-receiver" class="btn" type="button">Добавить вход</button>
|
|
|
<button id="remove-receiver" class="btn" type="button">Удалить вход</button>
|
|
|
<span id="receiver-count" class="badge">входов: 0</span>
|
|
|
</div>
|
|
|
<label>Имя ресивера<input id="rx-id" type="text" /></label>
|
|
|
<label>Адрес сервера (URL)<input id="rx-url" type="text" /></label>
|
|
|
<label>Частоты ресивера, МГц (через запятую)<input id="rx-frequencies" type="text" placeholder="433.92, 868.1" /></label>
|
|
|
<label>Координата X<input id="rx-center-x" type="number" step="0.001" /></label>
|
|
|
<label>Координата Y<input id="rx-center-y" type="number" step="0.001" /></label>
|
|
|
<label>Координата Z<input id="rx-center-z" type="number" step="0.001" /></label>
|
|
|
</div>
|
|
|
|
|
|
<h3 class="servers-title">Общий Фильтр Входа (Авто Для Всех)</h3>
|
|
|
<div class="server-grid">
|
|
|
<label>Фильтр включен
|
|
|
<select id="shared-filter-enabled">
|
|
|
<option value="true">да</option>
|
|
|
<option value="false">нет</option>
|
|
|
</select>
|
|
|
</label>
|
|
|
<label>Мин. частота, МГц<input id="shared-min-freq" type="number" step="0.001" min="0" /></label>
|
|
|
<label>Макс. частота, МГц<input id="shared-max-freq" type="number" step="0.001" min="0" /></label>
|
|
|
<label>Мин. RSSI, дБм<input id="shared-min-rssi" type="number" step="0.1" /></label>
|
|
|
<label>Макс. RSSI, дБм<input id="shared-max-rssi" type="number" step="0.1" /></label>
|
|
|
</div>
|
|
|
|
|
|
<h3 class="servers-title">Выходные Серверы</h3>
|
|
|
<div class="server-grid">
|
|
|
<label>Выбранный выход
|
|
|
<select id="output-select"></select>
|
|
|
</label>
|
|
|
<div class="server-actions-row">
|
|
|
<button id="add-output-server" class="btn" type="button">Добавить выход</button>
|
|
|
<button id="remove-output-server" class="btn" type="button">Удалить выход</button>
|
|
|
<span id="output-count" class="badge">выходов: 0</span>
|
|
|
</div>
|
|
|
<label>Имя выхода<input id="out-name" type="text" /></label>
|
|
|
<label>Токен записи (API, только сессия)<input id="write-token" type="password" /></label>
|
|
|
<label>IP/хост выхода<input id="out-ip" type="text" /></label>
|
|
|
</div>
|
|
|
|
|
|
<div class="editor-actions">
|
|
|
<button id="load-servers" class="btn">Загрузить</button>
|
|
|
<button id="save-servers" class="btn btn-primary">Сохранить серверы</button>
|
|
|
<span id="servers-state" class="badge">серверы: н/д</span>
|
|
|
</div>
|
|
|
</article>
|
|
|
</section>
|
|
|
|
|
|
<section id="section-json" class="panel">
|
|
|
<article class="card">
|
|
|
<h2>Конфигурация</h2>
|
|
|
<div class="editor-actions">
|
|
|
<button id="load-config" class="btn">Загрузить</button>
|
|
|
<button id="save-config" class="btn btn-primary">Сохранить конфиг</button>
|
|
|
<span id="config-state" class="badge">конфиг: н/д</span>
|
|
|
</div>
|
|
|
<textarea id="config-editor" class="editor" spellcheck="false"></textarea>
|
|
|
</article>
|
|
|
</section>
|
|
|
</section>
|
|
|
</main>
|
|
|
|
|
|
<script src="/static/app.js"></script>
|
|
|
</body>
|
|
|
</html>
|