Restructure fake packets layout

This commit is contained in:
dan
2025-12-06 19:43:42 +03:00
parent 096628b25f
commit f52d68300c

View File

@@ -413,9 +413,27 @@ public class FakeAdminResponder {
padding-right: 8px;
white-space: nowrap;
}
.services-nav {
display: flex;
align-items: center;
gap: 4px;
margin-left: 14px;
flex-wrap: wrap;
}
.services-nav .nav-link {
padding: 6px 10px;
border-radius: 10px;
margin: 2px 0;
background: rgba(122, 29, 255, 0.12);
border: 1px solid rgba(122, 29, 255, 0.28);
color: var(--text);
font-size: 10px;
letter-spacing: 0.3px;
white-space: nowrap;
}
.layout {
display: grid;
grid-template-columns: 280px 1fr;
grid-template-columns: 320px 1fr;
gap: 0;
min-height: calc(100vh - 72px);
}
@@ -432,30 +450,13 @@ public class FakeAdminResponder {
color: var(--muted);
margin-bottom: 10px;
}
.service {
margin: 8px 0;
border-radius: 14px;
border: 1px solid rgba(122, 29, 255, 0.25);
background: linear-gradient(125deg, rgba(122, 29, 255, 0.12), rgba(7, 4, 15, 0.9));
box-shadow: 0 12px 24px rgba(0, 0, 0, 0.3);
padding: 12px;
}
.service .name {
color: var(--text);
font-size: 10px;
}
.service .meta {
color: var(--muted);
font-size: 9px;
margin-top: 4px;
line-height: 1.5;
}
.content {
background: var(--panel);
border-left: 1px solid rgba(122, 29, 255, 0.15);
padding: 18px 22px 26px;
box-shadow: inset 0 0 30px rgba(0, 0, 0, 0.45), 0 0 38px rgba(122, 29, 255, 0.18);
position: relative;
min-height: calc(100vh - 120px);
}
.content-header {
display: flex;
@@ -467,15 +468,6 @@ public class FakeAdminResponder {
font-size: 12px;
color: var(--text);
}
.mode-pill {
background: rgba(122, 29, 255, 0.12);
border: 1px solid rgba(122, 29, 255, 0.35);
color: var(--accent);
padding: 6px 10px;
border-radius: 10px;
font-size: 9px;
letter-spacing: 0.5px;
}
.packet-board {
background: rgba(9, 7, 18, 0.9);
border: 1px solid rgba(122, 29, 255, 0.35);
@@ -514,11 +506,7 @@ public class FakeAdminResponder {
font-size: 10px;
}
.packet-line .bytes { color: #9ff8ff; }
.muted-bar {
color: rgba(230, 224, 255, 0.4);
font-size: 10px;
margin-top: 10px;
}
.empty-slot { background: transparent; border: none; box-shadow: none; }
</style>
</head>
<body>
@@ -538,27 +526,21 @@ public class FakeAdminResponder {
<div class="patterns-dropdown">
<button class="btn btn-dark btn-block" disabled>Patterns</button>
</div>
<div class="services-nav" id="nav-services"></div>
<span class="ml-auto text-monospace text-muted" style="font-size: 10px;">[Selected: none]</span>
</nav>
<div class="layout" style="margin-top: 64px;">
<aside class="sidebar">
<div class="sidebar-title">Services</div>
<div id="service-list"></div>
</aside>
<main class="content">
<div class="content-header">
<div class="title">Streams</div>
<div class="mode-pill">mode: fake</div>
</div>
<div class="sidebar-title">Packets</div>
<div class="packet-board">
<div class="packet-feed" id="packet-feed"></div>
<div class="muted-bar">Decoy feed only. Real capture stays sealed.</div>
</div>
</main>
</aside>
<main class="content empty-slot"></main>
</div>
</div>
<script>
const servicesEl = document.getElementById('service-list');
const navServicesEl = document.getElementById('nav-services');
const feedEl = document.getElementById('packet-feed');
const spmEl = document.getElementById('metric-spm');
const ppsEl = document.getElementById('metric-pps');
@@ -579,16 +561,13 @@ public class FakeAdminResponder {
});
function renderServices() {
servicesEl.innerHTML = '';
services.forEach((svc, idx) => {
const wrap = document.createElement('div');
wrap.className = 'service';
wrap.innerHTML = `
<div class="name">${svc.name} #${svc.port}</div>
<div class="meta">kind: ${(svc.packetKind || 'tcp').toUpperCase()}</div>
<div class="meta">streams per min: ${Math.floor(Math.random() * 80) + 4}</div>
`;
servicesEl.appendChild(wrap);
navServicesEl.innerHTML = '';
services.forEach((svc) => {
const link = document.createElement('a');
link.className = 'nav-link';
link.href = '#';
link.textContent = `${svc.name} #${svc.port}`;
navServicesEl.appendChild(link);
});
}