let logMonitorEl = null; let logMonitorStatus = true; async function logMonitor() { if (logMonitorStatus) setTimeout(logMonitor, opts.logmonitor_refresh_period); if (!opts.logmonitor_show) return; logMonitorStatus = false; let res; try { res = await fetch('/sdapi/v1/log?clear=True'); } catch {} if (res?.ok) { logMonitorStatus = true; if (!logMonitorEl) logMonitorEl = document.getElementById('logMonitorData'); if (!logMonitorEl) return; const lines = await res.json(); if (logMonitorEl && lines?.length > 0) logMonitorEl.parentElement.parentElement.style.display = opts.logmonitor_show ? 'block' : 'none'; for (const line of lines) { try { const l = JSON.parse(line); const row = document.createElement('tr'); row.style = 'padding: 10px; margin: 0;'; row.innerHTML = `${new Date(1000 * l.created).toISOString()}${l.level}${l.facility}${l.module}${l.msg}`; logMonitorEl.appendChild(row); } catch {} } while (logMonitorEl.childElementCount > 100) logMonitorEl.removeChild(logMonitorEl.firstChild); logMonitorEl.scrollTop = logMonitorEl.scrollHeight; } } let logMonitorInitialized = false; async function initLogMonitor() { if (logMonitorInitialized) return; const el = document.getElementsByTagName('footer')[0]; if (!el) return; logMonitorInitialized = true; el.classList.add('log-monitor'); el.innerHTML = `
Time Level Facility Module Message
`; el.style.display = 'none'; logMonitor(); log('initLogMonitor'); } onAfterUiUpdate(initLogMonitor);