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