30 lines
994 B
JavaScript
30 lines
994 B
JavaScript
let escCallback = () => {};
|
|
document.onkeydown = (e) => {
|
|
const isEsc = e.key === "Escape" || e.key === "Esc";
|
|
if (isEsc) escCallback();
|
|
};
|
|
|
|
const messages = document.querySelectorAll(".vanishing-message");
|
|
messages.forEach((message) => {
|
|
message.addEventListener("click", () => {
|
|
const overlay = message.parentElement.querySelector(".overlay");
|
|
const modal = message.parentElement.querySelector(".modal");
|
|
const closeButton = message.parentElement.querySelector(".modal-close");
|
|
|
|
overlay.style.display = "block";
|
|
modal.style.display = "block";
|
|
|
|
const onClose = () => {
|
|
const parent = modal.parentElement;
|
|
parent.parentElement.removeChild(parent);
|
|
if (document.querySelectorAll(".vanishing-message").length == 0) {
|
|
document.querySelector(".vanishing-messages").style.display = "none";
|
|
}
|
|
};
|
|
|
|
overlay.addEventListener("click", onClose);
|
|
closeButton.addEventListener("click", onClose);
|
|
escCallback = onClose;
|
|
});
|
|
});
|