Files
fnx_web/res/include/script/file_viewer/IntroPopup.js

35 lines
1.1 KiB
JavaScript
Raw Normal View History

2021-06-22 00:32:05 +02:00
function IntroPopup() {
if (localStorage.getItem("viewer_intro_popup_dismissed") === "🍆") {
return
}
let btnHome = document.getElementById("button_home")
this.popup = document.createElement("div")
this.popup.classList = "intro_popup"
this.moveToElement(btnHome)
let clone = document.getElementById("intro_popup").content.cloneNode(true)
clone.querySelector(".intro_popup_close").addEventListener("click", () => { this.close() })
this.popup.append(clone)
document.getElementById("file_viewer").append(this.popup)
// Sometimes the layout is not correctly calculated yet when this script
// runs. We adjust the values later
2021-09-03 17:41:32 +02:00
setTimeout(() => { this.moveToElement(btnHome) }, 400)
2021-06-22 00:32:05 +02:00
}
IntroPopup.prototype.moveToElement = function (el) {
let rect = el.getBoundingClientRect()
this.popup.style.top = (rect.top + el.offsetHeight + 20) + "px"
2021-09-10 21:27:07 +02:00
this.popup.style.left = (rect.left + (el.clientWidth / 2) - 40) + "px"
2021-06-22 00:32:05 +02:00
}
IntroPopup.prototype.close = function () {
localStorage.setItem("viewer_intro_popup_dismissed", "🍆")
this.popup.style.opacity = 0
setTimeout(() => { this.popup.remove() }, 500)
}