mirror of
https://github.com/bitburner-official/bitburner-src.git
synced 2024-12-24 23:22:29 +01:00
83 lines
2.3 KiB
JavaScript
83 lines
2.3 KiB
JavaScript
import { KEY } from "./helpers/keyCodes";
|
|
|
|
/**
|
|
* Create and display a pop-up dialog box.
|
|
* This dialog box does not allow for any interaction and should close when clicking
|
|
* outside of it
|
|
*/
|
|
let dialogBoxes = [];
|
|
|
|
// Close dialog box when clicking outside
|
|
$(document).click(function(event) {
|
|
if (dialogBoxOpened && dialogBoxes.length >= 1) {
|
|
if (!$(event.target).closest(dialogBoxes[0]).length){
|
|
closeTopmostDialogBox();
|
|
}
|
|
}
|
|
});
|
|
|
|
function closeTopmostDialogBox() {
|
|
if (!dialogBoxOpened || dialogBoxes.length === 0) return;
|
|
dialogBoxes[0].remove();
|
|
dialogBoxes.shift();
|
|
if (dialogBoxes.length == 0) {
|
|
dialogBoxOpened = false;
|
|
} else {
|
|
dialogBoxes[0].style.visibility = "visible";
|
|
}
|
|
}
|
|
|
|
// Dialog box close buttons
|
|
$(document).on('click', '.dialog-box-close-button', function( event ) {
|
|
closeTopmostDialogBox();
|
|
});
|
|
|
|
document.addEventListener("keydown", function (event) {
|
|
if (event.keyCode == KEY.ESC && dialogBoxOpened) {
|
|
closeTopmostDialogBox();
|
|
event.preventDefault();
|
|
}
|
|
});
|
|
|
|
let dialogBoxOpened = false;
|
|
|
|
function dialogBoxCreate(txt, preformatted=false) {
|
|
console.log(`dialogBoxCreate() called`)
|
|
var container = document.createElement("div");
|
|
container.setAttribute("class", "dialog-box-container");
|
|
|
|
var content = document.createElement("div");
|
|
content.setAttribute("class", "dialog-box-content");
|
|
|
|
var closeButton = document.createElement("span");
|
|
closeButton.setAttribute("class", "dialog-box-close-button");
|
|
closeButton.innerHTML = "×"
|
|
|
|
var textE;
|
|
if (preformatted) {
|
|
// For text files as they are often computed data that
|
|
// shouldn't be wrapped and should retain tabstops.
|
|
textE = document.createElement("pre");
|
|
textE.innerHTML = txt;
|
|
} else {
|
|
textE = document.createElement("p");
|
|
textE.innerHTML = txt.replace(/(?:\r\n|\r|\n)/g, '<br>');
|
|
}
|
|
|
|
content.appendChild(closeButton);
|
|
content.appendChild(textE);
|
|
container.appendChild(content);
|
|
|
|
document.body.appendChild(container);
|
|
if (dialogBoxes.length >= 1) {
|
|
container.style.visibility = "hidden";
|
|
}
|
|
dialogBoxes.push(container);
|
|
|
|
setTimeout(function() {
|
|
dialogBoxOpened = true;
|
|
}, 400);
|
|
}
|
|
|
|
export {dialogBoxCreate, dialogBoxOpened};
|