diff options
author | RaindropsSys <raindrops@equestria.dev> | 2024-06-29 20:59:16 +0200 |
---|---|---|
committer | RaindropsSys <raindrops@equestria.dev> | 2024-06-29 20:59:16 +0200 |
commit | 914bcbb474f6f186c212b2da0d9d864b5e75d8e4 (patch) | |
tree | b77a3e341f87e7a9c4ad9e1f9d4928f5b2495329 /src/FaunerieApp.ts | |
parent | 1c94bd658c2469f9ca9f465db82e71b6f7d2bfe8 (diff) | |
download | faunerie-914bcbb474f6f186c212b2da0d9d864b5e75d8e4.tar.gz faunerie-914bcbb474f6f186c212b2da0d9d864b5e75d8e4.tar.bz2 faunerie-914bcbb474f6f186c212b2da0d9d864b5e75d8e4.zip |
Rename to Faunerie
Diffstat (limited to 'src/FaunerieApp.ts')
-rwxr-xr-x | src/FaunerieApp.ts | 129 |
1 files changed, 129 insertions, 0 deletions
diff --git a/src/FaunerieApp.ts b/src/FaunerieApp.ts new file mode 100755 index 0000000..6614d07 --- /dev/null +++ b/src/FaunerieApp.ts @@ -0,0 +1,129 @@ +import {FaunerieDataStore} from "./FaunerieDataStore"; +import {FaunerieListType} from "libfaunerie"; +import {FaunerieAppDisplay} from "./FaunerieAppDisplay"; +import {FaunerieSettings} from "./FaunerieSettings"; +import {FaunerieSearch} from "./FaunerieSearch"; +import {FaunerieActions} from "./FaunerieActions"; +import {FaunerieAI} from "./FaunerieAI"; +import {FaunerieLoader} from "./FaunerieLoader"; +import {FauneriePropertyStore} from "libfaunerie/src/FauneriePropertyStore"; +import {FaunerieDerpibooru} from "./FaunerieDerpibooru"; + +export class FaunerieApp { + dataStore: FaunerieDataStore; + bootstrap: any; + display: FaunerieAppDisplay; + settings: FaunerieSettings; + search: FaunerieSearch; + actions: FaunerieActions; + ai: FaunerieAI; + loader: FaunerieLoader; + propertyStore: FauneriePropertyStore; + derpibooru: FaunerieDerpibooru; + + constructor(bootstrap: any) { + this.bootstrap = bootstrap; + this.dataStore = new FaunerieDataStore(this); + this.display = new FaunerieAppDisplay(this); + this.settings = new FaunerieSettings(this); + this.search = new FaunerieSearch(this); + this.actions = new FaunerieActions(this); + this.ai = new FaunerieAI(this); + this.loader = new FaunerieLoader(this); + this.derpibooru = new FaunerieDerpibooru(this); + + this.search.loadSearchModule(); + } + + createPropertyStore() { + this.propertyStore = this.dataStore.database.propertyStore; + } + + async finishLoading() { + document.getElementById("loading-btn").classList.add("disabled"); + + document.getElementById("load").innerText = "Loading interface..."; + document.getElementById("progress").classList.add("progress-bar-striped"); + document.getElementById("progress").style.width = "100%"; + + this.dataStore.loaded = true; + this.dataStore.page = 1; + this.dataStore.currentView = await this.dataStore.database.frontend.getAllImages(FaunerieListType.Array) as any[]; + this.display.updateDisplay(); + + this.dataStore.loader.hide(); + document.getElementById("app").classList.remove("disabled"); + } + + loadingError(msg: string) { + let li = document.createElement("li"); + li.classList.add("list-group-item"); + li.classList.add("list-group-item-warning"); + li.innerHTML = msg; + + document.getElementById("loader-errors-list").append(li); + document.getElementById("loader-errors").style.display = ""; + this.dataStore.hadErrorsLoading = true; + } + + async loadApp() { + if (this.dataStore.loaded) return; + + document.getElementById("load").innerText = "Waiting for application..."; + document.getElementById("progress").classList.remove("progress-bar-striped"); + document.getElementById("progress").style.width = "0%"; + + await this.loader.findDatabase(); + this.loader.checkBusyUpdating(); + await this.loader.initializeDatabase(); + await this.loader.updateCache(); + await this.loader.completeLoading(); + await this.derpibooru.initialize(); + } + + safeUnload() { + let modal = new this.bootstrap.Modal(document.getElementById("close-dialog")); + modal.show(); + + return new Promise<void>((res) => { + this.ai.unload(); + + if (!this.derpibooru.window?.isDestroyed()) { + this.derpibooru.window.destroy(); + } + + if (this.dataStore.database && !this.dataStore.unloaded) { + (async () => { + try { + await this.dataStore.database.close(); + } catch (e) { + console.error(e); + } + + this.dataStore.unloaded = true; + + res(); + })(); + } else { + res(); + } + }); + } + + async safeReload() { + await this.safeUnload(); + location.reload(); + } + + // noinspection JSUnusedGlobalSymbols + async safeClose() { + await this.safeUnload(); + window.close(); + } + + bootstrapTooltips() { + const tooltipTriggerList = document.querySelectorAll('[data-bs-toggle="tooltip"]'); + //@ts-ignore + [...tooltipTriggerList].map(tooltipTriggerEl => new bootstrap.Tooltip(tooltipTriggerEl)); + } +} |