feat: wire new widget renderers in app.js

This commit is contained in:
2026-04-06 07:33:46 +00:00
parent 36e82a78f0
commit 5c0c99ed75
+23 -31
View File
@@ -1,13 +1,15 @@
import { fetchDashboardData } from "./api.js"; import { fetchDashboardData } from "./api.js";
import { getState, setError, subscribe, updateData } from "./state.js"; import { getState, subscribe, updateData } from "./state.js";
import { renderHeader } from "./renderers/header.js"; import { renderHeader } from "./renderers/header.js";
import { renderNetworkHealth } from "./renderers/network-health.js";
import { renderQuickAccess } from "./renderers/quick-access.js";
import { renderServices } from "./renderers/services.js";
import { renderStats } from "./renderers/stats.js"; import { renderStats } from "./renderers/stats.js";
import { renderStorage } from "./renderers/storage.js"; import { renderStorage } from "./renderers/storage.js";
import { renderServices } from "./renderers/services.js";
let pollTimer = null; import { renderNetworkHealth } from "./renderers/network-health.js";
import { renderQuickAccess } from "./renderers/quick-access.js";
import { renderHomeAssistant } from "./renderers/home-assistant.js";
import { renderUptimeKuma } from "./renderers/uptime-kuma.js";
import { renderImmich } from "./renderers/immich.js";
import { renderBackrest } from "./renderers/backrest.js";
function render(state) { function render(state) {
renderHeader(state); renderHeader(state);
@@ -15,34 +17,24 @@ function render(state) {
renderStorage(state); renderStorage(state);
renderServices(state); renderServices(state);
renderNetworkHealth(state); renderNetworkHealth(state);
renderHomeAssistant(state);
renderUptimeKuma(state);
renderImmich(state);
renderBackrest(state);
renderQuickAccess();
} }
async function refreshData() { subscribe(render);
async function refresh() {
try { try {
const payload = await fetchDashboardData(); const data = await fetchDashboardData();
updateData(payload); updateData(data);
} catch (error) { } catch (err) {
console.error("Dashboard refresh failed", error); console.error("Dashboard fetch error:", err);
setError(error instanceof Error ? error : new Error("Unknown dashboard refresh error"));
} finally {
restartPolling();
} }
} }
function restartPolling() { render(getState());
if (pollTimer) { refresh();
window.clearInterval(pollTimer); setInterval(refresh, (getState().overview?.refresh_hint_seconds ?? 20) * 1000);
}
const state = window.__dashboardState?.() ?? null;
const interval = state?.refreshIntervalMs ?? 20000;
pollTimer = window.setInterval(refreshData, interval);
}
subscribe((state) => {
window.__dashboardState = () => state;
render(state);
});
renderQuickAccess();
refreshData();
window.setInterval(() => renderHeader(getState()), 1000);