Merge pull request #61 from lklynet/fix/version-display-and-notification-bug

Add version to diagnostics and fix update notification bug
This commit is contained in:
LKLY
2026-01-12 15:12:14 -05:00
committed by GitHub
3 changed files with 71 additions and 54 deletions
+1 -1
View File
@@ -1,6 +1,6 @@
{
"name": "hypermind",
"version": "0.12.2",
"version": "0.13.0",
"description": "A decentralized P2P counter of active deployments",
"main": "server.js",
"scripts": {
+4
View File
@@ -104,6 +104,10 @@
>{{FULL_ID}}</span
>
</div>
<div class="stat-row">
<span class="stat-label">Version</span>
<span class="stat-value" id="diag-version">{{VERSION}}</span>
</div>
<div class="stat-row">
<span class="stat-label">Heartbeats Received</span>
<span class="stat-value" id="diag-heartbeats-rx">0</span>
+66 -53
View File
@@ -2,78 +2,91 @@ const CACHE_KEY = "hypermind-version-check";
const CACHE_DURATION = 86400000;
const getCurrentVersion = () => {
return document.body.dataset.version || "no-version";
return document.body.dataset.version || "no-version";
};
const isNewer = (latest, current) => {
if (current === "no-version") return true;
const l = latest.split(".").map(Number);
const c = current.split(".").map(Number);
for (let i = 0; i < 3; i++) {
if (l[i] > (c[i] || 0)) return true;
if (l[i] < (c[i] || 0)) return false;
}
return false;
};
const checkForNewVersion = async () => {
try {
const cached = localStorage.getItem(CACHE_KEY);
if (cached) {
try {
const parsedCache = JSON.parse(cached);
const now = Date.now();
try {
const cached = localStorage.getItem(CACHE_KEY);
if (cached) {
try {
const parsedCache = JSON.parse(cached);
const now = Date.now();
if (now - parsedCache.timestamp < CACHE_DURATION) {
if (parsedCache.data) {
showVersionNotification(parsedCache.data);
}
return;
}
} catch (e) {
localStorage.removeItem(CACHE_KEY);
}
if (now - parsedCache.timestamp < CACHE_DURATION) {
if (parsedCache.data) {
showVersionNotification(parsedCache.data);
}
return;
}
const response = await fetch("/api/github/latest-release");
if (!response.ok) return;
const release = await response.json();
const cacheData = {
data: release,
timestamp: Date.now(),
};
localStorage.setItem(CACHE_KEY, JSON.stringify(cacheData));
showVersionNotification(release);
} catch (error) {
console.error("Error checking for new version:", error);
} catch (e) {
localStorage.removeItem(CACHE_KEY);
}
}
const response = await fetch("/api/github/latest-release");
if (!response.ok) return;
const release = await response.json();
const cacheData = {
data: release,
timestamp: Date.now(),
};
localStorage.setItem(CACHE_KEY, JSON.stringify(cacheData));
showVersionNotification(release);
} catch (error) {
console.error("Error checking for new version:", error);
}
};
const showVersionNotification = (release) => {
if (!release || !release.tag_name) return;
if (!release || !release.tag_name) return;
const latestVersion = release.tag_name.replace(/^v/, "");
const currentVersion = getCurrentVersion();
const latestVersion = release.tag_name.replace(/^v/, "");
const currentVersion = getCurrentVersion();
if (latestVersion === currentVersion) return;
if (!isNewer(latestVersion, currentVersion)) return;
const dismissedKey = `hypermind-version-dismissed-${release.tag_name}`;
if (localStorage.getItem(dismissedKey) === "true") return;
const dismissedKey = `hypermind-version-dismissed-${release.tag_name}`;
if (localStorage.getItem(dismissedKey) === "true") return;
const banner = document.getElementById("version-notification");
if (!banner) return;
const banner = document.getElementById("version-notification");
if (!banner) return;
const versionText = banner.querySelector(".version-text");
const updateLink = banner.querySelector(".update-link");
const dismissBtn = banner.querySelector(".dismiss-btn");
const versionText = banner.querySelector(".version-text");
const updateLink = banner.querySelector(".update-link");
const dismissBtn = banner.querySelector(".dismiss-btn");
versionText.textContent = `New version ${release.tag_name} available!`;
updateLink.href = release.html_url;
versionText.textContent = `New version ${release.tag_name} available!`;
updateLink.href = release.html_url;
dismissBtn.onclick = () => {
banner.classList.remove("active");
localStorage.setItem(dismissedKey, "true");
};
dismissBtn.onclick = () => {
banner.classList.remove("active");
localStorage.setItem(dismissedKey, "true");
};
setTimeout(() => {
banner.classList.add("active");
}, 1000);
setTimeout(() => {
banner.classList.add("active");
}, 1000);
};
if (document.readyState === "loading") {
document.addEventListener("DOMContentLoaded", checkForNewVersion);
document.addEventListener("DOMContentLoaded", checkForNewVersion);
} else {
checkForNewVersion();
checkForNewVersion();
}