{% extends "base.html" %} {% block css %} {{ super() }} /* --- Map --- */ #map { width: 100%; height: 400px; margin-bottom: 20px; border-radius: 8px; display: block; } .leaflet-container { background: #1a1a1a; z-index: 1; } /* --- Node Info (3-column compact grid) --- */ .node-info { background-color: #1f2226; border: 1px solid #3a3f44; color: #ddd; font-size: 0.88rem; padding: 12px 14px; margin-bottom: 14px; border-radius: 8px; display: grid; grid-template-columns: repeat(3, minmax(120px, 1fr)); grid-column-gap: 14px; grid-row-gap: 6px; } .node-info div { padding: 2px 0; } .node-info strong { color: #9fd4ff; font-weight: 600; } /* --- Charts --- */ .chart-container { width: 100%; height: 320px; margin-bottom: 25px; border: 1px solid #3a3f44; border-radius: 8px; overflow: hidden; background-color: #16191d; } .chart-header { display: flex; justify-content: space-between; align-items: center; background: #1f2226; padding: 6px 12px; font-weight: bold; border-bottom: 1px solid #333; font-size: 1rem; letter-spacing: 0.5px; } .chart-actions button { background: rgba(255,255,255,0.05); border: 1px solid #555; border-radius: 4px; color: #ccc; font-size: 0.8rem; padding: 2px 6px; cursor: pointer; transition: background 0.2s; } .chart-actions button:hover { color: #fff; background: rgba(255,255,255,0.15); border-color: #888; } /* --- Packet Table --- */ .packet-table { width: 100%; border-collapse: collapse; font-size: 0.85rem; color: #e4e9ee; } .packet-table th, .packet-table td { border: 1px solid #3a3f44; padding: 6px 10px; text-align: left; } .packet-table th { background-color: #1f2226; font-weight: bold; } .packet-table tr:nth-of-type(odd) { background-color: #272b2f; } .packet-table tr:nth-of-type(even) { background-color: #212529; } .port-tag { padding: 2px 6px; border-radius: 6px; font-size: 0.75rem; color: #fff; } .port-1 { background-color: #007bff; } .port-3 { background-color: #28a745; } .port-4 { background-color: #ffc107; color:#000; } .port-5 { background-color: #dc3545; } .port-6 { background-color: #20c997; } .port-67 { background-color: #17a2b8; } .port-70 { background-color: #ff7043; } .port-71 { background-color: #ff66cc; } .port-0 { background-color: #6c757d; } .to-mqtt { font-style: italic; color: #aaa; } .payload-row { display: none; background-color: #1b1e22; } .payload-cell { padding: 8px 12px; font-family: monospace; white-space: pre-wrap; color: #b0bec5; border-top: none; } .packet-table tr.expanded + .payload-row { display: table-row; } .toggle-btn { cursor: pointer; color: #aaa; margin-right: 6px; } .toggle-btn:hover { color: #fff; } /* --- Chart Modal --- */ #chartModal { display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.9); z-index:9999; align-items:center; justify-content:center; } #chartModal > div { background:#1b1e22; border-radius:8px; width:90%; height:85%; padding:10px; } /* Link next to port tag */ .inline-link { margin-left: 6px; font-weight: bold; text-decoration: none; color: #9fd4ff; } .inline-link:hover { color: #c7e6ff; } {% endblock %} {% block body %}
| Time | Packet ID | From | To | Port |
|---|