From ebef585c9c5d5f2c9aab01f1a2526046055e24ae Mon Sep 17 00:00:00 2001 From: Magnus Hoff Date: Fri, 1 Dec 2017 16:44:07 +0100 Subject: [PATCH] Replace use of `confirm()`, for #47 --- assets/script.js | 44 ++++++++++++++++++++++++++++++++++++++++---- 1 file changed, 40 insertions(+), 4 deletions(-) diff --git a/assets/script.js b/assets/script.js index f4457f1..d9992da 100644 --- a/assets/script.js +++ b/assets/script.js @@ -79,6 +79,39 @@ function alertAsync(message) { }); } +function confirmAsync(message) { + const dialogHtml = ""; + + const dialog = document.createElement("div"); + dialog.className = "modal-block"; + dialog.innerHTML = dialogHtml; + + const messageNode = dialog.querySelector(".message"); + const btnNo = dialog.querySelector('button[name="no"]'); + const btnYes = dialog.querySelector('button[name="yes"]'); + + messageNode.textContent = message; + + document.body.appendChild(dialog); + btnNo.focus(); + + function remove() { + document.body.removeChild(dialog); + } + + return new Promise((resolve, reject) => { + btnNo.addEventListener("click", () => { + remove(); + resolve(false); + }); + + btnYes.addEventListener("click", () => { + remove(); + resolve(true); + }); + }); +} + let hasBeenOpen = false; function openEditor() { const container = document.querySelector(".container"); @@ -182,10 +215,13 @@ function openEditor() { ev.preventDefault(); ev.stopPropagation(); - if (!isEdited(form) || confirm("Discard changes?")) { - container.classList.remove('edit'); - form.reset(); - } + Promise.resolve(!isEdited(form) || confirmAsync("Discard changes?")) + .then(doReset => { + if (doReset) { + container.classList.remove('edit'); + form.reset(); + } + }); }); window.addEventListener("beforeunload", function (ev) {