63 lines
1.2 KiB
TypeScript
Raw Normal View History

2017-06-19 14:49:24 +00:00
import { Application } from "./Application"
2017-06-20 10:41:26 +00:00
import { findAll } from "./utils"
import * as actions from "./actions"
2017-06-19 14:49:24 +00:00
export class AnimeNotifier {
app: Application
constructor(app: Application) {
this.app = app
}
2017-06-19 15:45:27 +00:00
onReadyStateChange() {
if(document.readyState !== "interactive") {
return
}
this.run()
}
2017-06-19 14:49:24 +00:00
run() {
this.app.content = this.app.find("content")
this.app.loading = this.app.find("loading")
this.app.run()
}
2017-06-19 15:45:27 +00:00
2017-06-20 10:41:26 +00:00
loading(isLoading: boolean) {
if(isLoading) {
this.app.loading.classList.remove(this.app.fadeOutClass)
} else {
this.app.loading.classList.add(this.app.fadeOutClass)
}
}
2017-06-19 15:45:27 +00:00
onContentLoaded() {
this.updateAvatars()
2017-06-20 10:41:26 +00:00
for(let element of findAll(".action")) {
let actionName = element.dataset.action
element.onclick = () => {
actions[actionName](this, element)
}
}
2017-06-19 15:45:27 +00:00
}
updateAvatars() {
2017-06-20 10:41:26 +00:00
for(let element of findAll(".user-image")) {
let img = element as HTMLImageElement
2017-06-19 15:45:27 +00:00
if(img.naturalWidth === 0) {
img.onload = function() {
this.classList.add("user-image-found")
}
img.onerror = function() {
this.classList.add("user-image-not-found")
}
} else {
img.classList.add("user-image-found")
}
}
}
2017-06-19 14:49:24 +00:00
}