|
import { api } from "../../../scripts/api.js";
|
|
import { app } from "../../../scripts/app.js";
|
|
|
|
|
|
|
|
|
|
app.registerExtension({
|
|
name: "pysssss.FaviconStatus",
|
|
async setup() {
|
|
let link = document.querySelector("link[rel~='icon']");
|
|
if (!link) {
|
|
link = document.createElement("link");
|
|
link.rel = "icon";
|
|
document.head.appendChild(link);
|
|
}
|
|
|
|
const getUrl = (active, user) => new URL(`assets/favicon${active ? "-active" : ""}${user ? ".user" : ""}.ico`, import.meta.url);
|
|
const testUrl = async (active) => {
|
|
const url = getUrl(active, true);
|
|
const r = await fetch(url, {
|
|
method: "HEAD",
|
|
});
|
|
if (r.status === 200) {
|
|
return url;
|
|
}
|
|
return getUrl(active, false);
|
|
};
|
|
const activeUrl = await testUrl(true);
|
|
const idleUrl = await testUrl(false);
|
|
|
|
let executing = false;
|
|
const update = () => (link.href = executing ? activeUrl : idleUrl);
|
|
|
|
for (const e of ["execution_start", "progress"]) {
|
|
api.addEventListener(e, () => {
|
|
executing = true;
|
|
update();
|
|
});
|
|
}
|
|
|
|
api.addEventListener("executing", ({ detail }) => {
|
|
|
|
executing = !!detail;
|
|
update();
|
|
});
|
|
|
|
api.addEventListener("status", ({ detail }) => {
|
|
let title = "ComfyUI";
|
|
if (detail && detail.exec_info.queue_remaining) {
|
|
title = `(${detail.exec_info.queue_remaining}) ${title}`;
|
|
}
|
|
document.title = title;
|
|
update();
|
|
executing = false;
|
|
});
|
|
update();
|
|
},
|
|
});
|
|
|