42 lines
897 B
TypeScript
Raw Normal View History

2017-07-12 18:37:34 +00:00
import { delay } from "./Utils"
export class StatusMessage {
container: HTMLElement
text: HTMLElement
constructor(container: HTMLElement, text: HTMLElement) {
this.container = container
this.text = text
}
2017-07-21 08:10:48 +00:00
show(message: string, duration: number) {
2017-07-12 18:37:34 +00:00
let messageId = String(Date.now())
this.text.innerText = message
this.container.classList.remove("fade-out")
this.container.dataset.messageId = messageId
delay(duration || 4000).then(() => {
if(this.container.dataset.messageId !== messageId) {
return
}
this.close()
})
}
showError(message: string, duration?: number) {
2017-07-21 08:10:48 +00:00
this.show(message, duration || 4000)
2017-07-12 18:37:34 +00:00
this.container.classList.add("error-message")
}
2017-07-21 08:10:48 +00:00
showInfo(message: string, duration?: number) {
this.show(message, duration || 2000)
this.container.classList.add("info-message")
}
2017-07-12 18:37:34 +00:00
close() {
this.container.classList.add("fade-out")
}
}