feat: wire new widget renderers in app.js
This commit is contained in:
@@ -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);
|
|
||||||
Reference in New Issue
Block a user