2020-06-07 19:04:43 +03:00
|
|
|
Function.noop = () => {};
|
|
|
|
|
|
|
|
function MessageBox(title, body, buttons, callbacks) {
|
|
|
|
if(u(".ovk-diag-cont").length > 0) return false;
|
|
|
|
|
2023-09-17 19:19:25 +03:00
|
|
|
document.querySelector("html").style.overflowY = "hidden"
|
2020-06-07 19:04:43 +03:00
|
|
|
let dialog = u(
|
|
|
|
`<div class="ovk-diag-cont">
|
|
|
|
<div class="ovk-diag">
|
|
|
|
<div class="ovk-diag-head">${title}</div>
|
|
|
|
<div class="ovk-diag-body">${body}</div>
|
|
|
|
<div class="ovk-diag-action"></div>
|
|
|
|
</div>
|
|
|
|
</div>`);
|
|
|
|
u("body").addClass("dimmed").append(dialog);
|
|
|
|
|
|
|
|
buttons.forEach((text, callback) => {
|
|
|
|
u(".ovk-diag-action").append(u(`<button class="button">${text}</button>`));
|
|
|
|
let button = u(u(".ovk-diag-action > button.button").last());
|
|
|
|
|
|
|
|
button.on("click", function(e) {
|
|
|
|
let __closeDialog = () => {
|
|
|
|
u("body").removeClass("dimmed");
|
|
|
|
u(".ovk-diag-cont").remove();
|
2023-09-17 19:19:25 +03:00
|
|
|
document.querySelector("html").style.overflowY = "scroll"
|
2020-06-07 19:04:43 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
Reflect.apply(callbacks[callback], {
|
2021-10-13 20:50:16 +03:00
|
|
|
closeDialog: () => __closeDialog(),
|
|
|
|
$dialog: () => u(".ovk-diag-cont")
|
2020-06-07 19:04:43 +03:00
|
|
|
}, [e]);
|
|
|
|
|
|
|
|
__closeDialog();
|
|
|
|
});
|
|
|
|
});
|
2021-10-13 20:50:16 +03:00
|
|
|
|
|
|
|
return u(".ovk-diag-cont");
|
2020-07-17 19:25:55 +03:00
|
|
|
}
|