mirror of
https://github.com/alextselegidis/easyappointments.git
synced 2025-01-23 06:00:01 +03:00
126 lines
4.2 KiB
JavaScript
126 lines
4.2 KiB
JavaScript
/* ----------------------------------------------------------------------------
|
|
* Easy!Appointments - Online Appointment Scheduler
|
|
*
|
|
* @package EasyAppointments
|
|
* @author A.Tselegidis <alextselegidis@gmail.com>
|
|
* @copyright Copyright (c) Alex Tselegidis
|
|
* @license https://opensource.org/licenses/GPL-3.0 - GPLv3
|
|
* @link https://easyappointments.org
|
|
* @since v1.5.0
|
|
* ---------------------------------------------------------------------------- */
|
|
|
|
/**
|
|
* Messages utility.
|
|
*
|
|
* This module implements the functionality of messages.
|
|
*/
|
|
window.App.Utils.Message = (function () {
|
|
let messageModal = null;
|
|
|
|
/**
|
|
* Show a message box to the user.
|
|
*
|
|
* This functions displays a message box in the admin array. It is useful when user
|
|
* decisions or verifications are needed.
|
|
*
|
|
* @param {String} title The title of the message box.
|
|
* @param {String} message The message of the dialog.
|
|
* @param {Array} [buttons] Contains the dialog buttons along with their functions.
|
|
* @param {Boolean} [isDismissible] If true, the button will show the close X in the header and close with the press of the Escape button.
|
|
*
|
|
* @return {jQuery|null} Return the #message-modal selector or null if the arguments are invalid.
|
|
*/
|
|
function show(title, message, buttons = null, isDismissible = true) {
|
|
if (!title || !message) {
|
|
return null;
|
|
}
|
|
|
|
if (!buttons) {
|
|
buttons = [
|
|
{
|
|
text: lang('close'),
|
|
className: 'btn btn-outline-primary',
|
|
click: function (event, messageModal) {
|
|
messageModal.hide();
|
|
},
|
|
},
|
|
];
|
|
}
|
|
|
|
if (messageModal?.dispose && messageModal?.hide && messageModal?._element) {
|
|
messageModal.hide();
|
|
messageModal.dispose();
|
|
messageModal = undefined;
|
|
}
|
|
|
|
$('#message-modal').remove();
|
|
|
|
const $messageModal = $(`
|
|
<div class="modal" id="message-modal" tabindex="-1">
|
|
<div class="modal-dialog modal-dialog-centered modal-dialog-scrollable">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<h5 class="modal-title">
|
|
${title}
|
|
</h5>
|
|
${
|
|
isDismissible
|
|
? '<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>'
|
|
: ''
|
|
}
|
|
</div>
|
|
<div class="modal-body">
|
|
${message}
|
|
</div>
|
|
<div class="modal-footer">
|
|
<!-- * -->
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
`).appendTo('body');
|
|
|
|
buttons.forEach((button) => {
|
|
if (!button) {
|
|
return;
|
|
}
|
|
|
|
if (!button.className) {
|
|
button.className = 'btn btn-outline-primary';
|
|
}
|
|
|
|
const $button = $(`
|
|
<button type="button" class="${button.className}">
|
|
${button.text}
|
|
</button>
|
|
`).appendTo($messageModal.find('.modal-footer'));
|
|
|
|
if (button.click) {
|
|
$button.on('click', (event) => button.click(event, messageModal));
|
|
}
|
|
});
|
|
|
|
messageModal = new bootstrap.Modal('#message-modal', {
|
|
keyboard: isDismissible,
|
|
backdrop: 'static',
|
|
});
|
|
|
|
$messageModal.on('shown.bs.modal', () => {
|
|
$messageModal
|
|
.find('.modal-footer button:last')
|
|
.removeClass('btn-outline-primary')
|
|
.addClass('btn-primary')
|
|
.focus();
|
|
});
|
|
|
|
messageModal.show();
|
|
|
|
$messageModal.css('z-index', '99999').next().css('z-index', '9999');
|
|
|
|
return $messageModal;
|
|
}
|
|
|
|
return {
|
|
show,
|
|
};
|
|
})();
|