[feat](trx-frontend-http): add frequency layers display for virtual channels
Render virtual channels as absolutely-positioned layer strips inside a shared relative container (#vchan-freq-layers). Layers are sorted by frequency ascending so higher-frequency channels receive a higher z-index and sit on top by default. Hovering any layer temporarily assigns it the maximum z-index to bring it to the front; leaving restores the original stacking order. Each layer is offset by 11 px vertically so all channels remain visible as a staggered card stack. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com> Signed-off-by: Stan Grams <sjg@haxx.space>
This commit is contained in:
@@ -392,6 +392,44 @@ input.status-input, select.status-input { width: 100%; padding: 0.45rem 0.5rem;
|
||||
border-color: var(--vchan-color);
|
||||
box-shadow: inset 3px 0 0 var(--vchan-color);
|
||||
}
|
||||
/* Frequency layers: absolutely-positioned channel strips stacked by frequency */
|
||||
.vchan-freq-layers {
|
||||
position: relative;
|
||||
margin-top: 0.5rem;
|
||||
/* height is set dynamically by vchanRenderLayers() */
|
||||
}
|
||||
.vchan-freq-layer {
|
||||
position: absolute;
|
||||
left: 0;
|
||||
right: 0;
|
||||
height: 2rem;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
padding: 0 0.6rem;
|
||||
border-radius: 6px;
|
||||
background: var(--input-bg);
|
||||
border: 1px solid var(--border-light);
|
||||
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
|
||||
font-size: 0.82rem;
|
||||
color: var(--text-muted);
|
||||
cursor: pointer;
|
||||
white-space: nowrap;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
transition: border-color 0.12s, box-shadow 0.12s;
|
||||
}
|
||||
.vchan-freq-layer:hover {
|
||||
border-color: var(--vchan-color);
|
||||
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
|
||||
color: var(--text);
|
||||
}
|
||||
.vchan-freq-layer.active {
|
||||
background: var(--btn-bg);
|
||||
color: var(--text);
|
||||
font-weight: 600;
|
||||
border-color: var(--vchan-color);
|
||||
box-shadow: inset 3px 0 0 var(--vchan-color);
|
||||
}
|
||||
/* Applied to #freq and #spectrum-bw-input when on a virtual channel */
|
||||
.vchan-ch-active {
|
||||
border-color: var(--vchan-color) !important;
|
||||
|
||||
Reference in New Issue
Block a user