[feat](trx-frontend-http): overlay map controls

Co-authored-by: OpenAI Codex <codex@openai.com>
Signed-off-by: Stan Grams <sjg@haxx.space>
This commit is contained in:
2026-03-13 14:18:18 +01:00
parent 60697bb26a
commit a82a7ab668
2 changed files with 68 additions and 28 deletions
@@ -671,29 +671,29 @@
</div> </div>
</div> </div>
<div id="tab-map" class="tab-panel" style="display:none;"> <div id="tab-map" class="tab-panel" style="display:none;">
<div class="map-locator-filters"> <div id="map-stage">
<div class="map-locator-filter-group"> <div class="map-overlay-panel">
<span class="map-locator-filter-label">Filter by</span> <div class="map-locator-filter-group">
<div id="map-locator-phase" class="map-locator-phase-row"></div> <span class="map-locator-filter-label">Filter by</span>
</div> <div id="map-locator-phase" class="map-locator-phase-row"></div>
<div class="map-locator-filter-group"> </div>
<span class="map-locator-filter-label" id="map-locator-choice-label">Show</span> <div class="map-locator-filter-group">
<div id="map-locator-choice-filter" class="map-locator-chip-row"></div> <span class="map-locator-filter-label" id="map-locator-choice-label">Show</span>
</div> <div id="map-locator-choice-filter" class="map-locator-chip-row"></div>
<div class="map-locator-filter-group"> </div>
<span class="map-locator-filter-label">Search</span> <div class="map-locator-filter-group">
<input type="text" id="map-search-filter" class="map-search-input" placeholder="Callsign, MMSI, locator, message..." /> <span class="map-locator-filter-label">Search</span>
</div> <input type="text" id="map-search-filter" class="map-search-input" placeholder="Callsign, MMSI, locator, message..." />
<div class="map-locator-filter-group"> </div>
<span class="map-locator-filter-label">Paths</span> <div class="map-locator-filter-group">
<div class="map-locator-phase-row"> <span class="map-locator-filter-label">Paths</span>
<button type="button" id="map-p2p-paths-toggle" class="map-locator-phase-btn">TRX Paths On</button> <div class="map-locator-phase-row">
<button type="button" id="map-contact-paths-toggle" class="map-locator-phase-btn">Contact Paths On</button> <button type="button" id="map-p2p-paths-toggle" class="map-locator-phase-btn">TRX Paths On</button>
<span class="map-locator-empty">TRX paths on popup, directed contact paths when both locators are known</span> <button type="button" id="map-contact-paths-toggle" class="map-locator-phase-btn">Contact Paths On</button>
<span class="map-locator-empty">TRX paths on popup, directed contact paths when both locators are known</span>
</div>
</div> </div>
</div> </div>
</div>
<div id="map-stage">
<button type="button" id="map-fullscreen-btn" class="map-fullscreen-btn">Fullscreen</button> <button type="button" id="map-fullscreen-btn" class="map-fullscreen-btn">Fullscreen</button>
<div id="aprs-map"></div> <div id="aprs-map"></div>
</div> </div>
@@ -1218,18 +1218,42 @@ small { color: var(--text-muted); }
#tab-map { #tab-map {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: 0.75rem;
min-height: 0; min-height: 0;
} }
#map-stage { #map-stage {
position: relative; position: relative;
flex: 0 1 auto; flex: 0 1 auto;
min-height: 0; min-height: 0;
overflow: hidden;
border-radius: 6px;
border: 1px solid color-mix(in srgb, var(--border-light) 78%, transparent);
background:
linear-gradient(180deg, color-mix(in srgb, var(--card-bg) 86%, transparent), color-mix(in srgb, var(--card-bg) 64%, transparent)),
color-mix(in srgb, var(--input-bg) 88%, transparent);
} }
#aprs-map { #aprs-map {
width: 100%; width: 100%;
min-height: 0; min-height: 0;
border-radius: 6px; border-radius: 0;
}
.map-overlay-panel {
position: absolute;
top: 0.7rem;
left: 0.7rem;
z-index: 410;
display: flex;
flex-direction: column;
gap: 0.45rem;
width: min(30rem, calc(100% - 4.9rem));
max-height: calc(100% - 1.4rem);
padding: 0.7rem 0.75rem;
border-radius: 0.8rem;
border: 1px solid color-mix(in srgb, var(--border-light) 74%, transparent);
background: color-mix(in srgb, var(--card-bg) 82%, transparent);
box-shadow: 0 16px 30px rgba(0, 0, 0, 0.24);
backdrop-filter: blur(14px);
-webkit-backdrop-filter: blur(14px);
overflow: auto;
} }
.map-fullscreen-btn { .map-fullscreen-btn {
position: absolute; position: absolute;
@@ -1782,13 +1806,14 @@ body.map-fake-fullscreen-active {
} }
.map-locator-filter-group { .map-locator-filter-group {
display: flex; display: flex;
align-items: center; align-items: flex-start;
gap: 0.5rem; gap: 0.5rem;
flex-wrap: wrap; flex-wrap: wrap;
} }
.map-locator-filter-label { .map-locator-filter-label {
flex: 0 0 auto; flex: 0 0 auto;
min-width: 4.8rem; min-width: 4.4rem;
padding-top: 0.35rem;
font-size: 0.72rem; font-size: 0.72rem;
font-weight: 700; font-weight: 700;
letter-spacing: 0.03em; letter-spacing: 0.03em;
@@ -1837,7 +1862,8 @@ body.map-fake-fullscreen-active {
font-size: 0.74rem; font-size: 0.74rem;
color: var(--text-muted); color: var(--text-muted);
opacity: 0.8; opacity: 0.8;
align-self: center; align-self: flex-start;
padding-top: 0.2rem;
} }
.map-locator-chip { .map-locator-chip {
--chip-color: var(--filter-border); --chip-color: var(--filter-border);
@@ -1871,13 +1897,14 @@ body.map-fake-fullscreen-active {
font-weight: 600; font-weight: 600;
} }
.map-search-input { .map-search-input {
flex: 1 1 15rem;
width: 100%; width: 100%;
max-width: 22rem; max-width: none;
min-height: 1.95rem; min-height: 1.95rem;
padding: 0.3rem 0.55rem; padding: 0.3rem 0.55rem;
border-radius: 7px; border-radius: 7px;
border: 1px solid color-mix(in srgb, var(--border-light) 76%, transparent); border: 1px solid color-mix(in srgb, var(--border-light) 76%, transparent);
background: color-mix(in srgb, var(--card-bg) 78%, transparent); background: color-mix(in srgb, var(--card-bg) 72%, transparent);
color: var(--text); color: var(--text);
font-size: 0.82rem; font-size: 0.82rem;
} }
@@ -2248,11 +2275,24 @@ button:focus-visible, input:focus-visible, select:focus-visible {
width: 100%; width: 100%;
flex-basis: 100%; flex-basis: 100%;
} }
.map-overlay-panel {
top: 0.55rem;
left: 0.55rem;
width: calc(100% - 1.1rem);
max-height: min(16.5rem, calc(100% - 1.1rem));
padding: 0.6rem 0.65rem;
border-radius: 0.7rem;
}
.map-locator-filter-group { .map-locator-filter-group {
align-items: stretch; align-items: stretch;
} }
.map-locator-filter-label { .map-locator-filter-label {
width: 100%; width: 100%;
min-width: 0;
padding-top: 0;
}
.map-locator-empty {
padding-top: 0;
} }
.rds-grid { .rds-grid {
grid-template-columns: minmax(0, 1fr); grid-template-columns: minmax(0, 1fr);