Restructure fake packets layout
This commit is contained in:
@@ -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);
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user