underbbs/ts/index.ts

52 lines
1.6 KiB
TypeScript
Raw Normal View History

import {AdapterState, AdapterData} from "./adapter";
import {Message, Attachment, Author} from "./message"
import util from "./util"
import { TabBarElement } from "./tabbar-element"
import { MessageElement } from "./message-element"
import { SettingsElement } from "./settings-element"
2024-04-22 00:02:44 +00:00
var $ = util.$
var _ = util._
2024-04-22 00:32:14 +00:00
function main() {
2024-04-27 22:39:53 +00:00
const settings = _("settings", JSON.parse(localStorage.getItem("settings") ?? "{}"));
2024-04-27 16:50:27 +00:00
customElements.define("underbbs-tabbar", TabBarElement);
customElements.define("underbbs-message", MessageElement);
customElements.define("underbbs-settings", SettingsElement);
tabbarInit(settings.adapters?.map((a:any)=>a.nickname) ?? []);
2024-05-13 00:26:44 +00:00
registerServiceWorker();
}
function tabbarInit(adapters: string[]) {
const nav = $("tabbar_injectparent");
if (nav) {
nav.innerHTML = `<underbbs-tabbar data-adapters="${adapters.join(",")}" data-currentadapter=""></underbbs-tabbar>`;
}
}
2024-04-22 00:02:44 +00:00
2024-05-13 00:26:44 +00:00
async function registerServiceWorker() {
if ("serviceWorker" in navigator) {
try {
const registration = await navigator.serviceWorker.register("/serviceWorker.js", {
scope: "/",
});
if (registration.installing) {
console.log("Service worker installing");
} else if (registration.waiting) {
console.log("Service worker installed");
} else if (registration.active) {
console.log("Service worker active");
}
} catch (error) {
console.error(`Registration failed with ${error}`);
}
const registration = await navigator.serviceWorker.ready;
(registration as any).sync.register("testdata").then((r:any)=>{console.log("but i will see this!")});
}
}
2024-04-27 16:50:27 +00:00
main();