2024-06-30 19:45:42 +02:00
|
|
|
import { POPUP_RESULT, POPUP_TYPE, Popup } from './popup.js';
|
|
|
|
|
|
|
|
/** @type {Popup} */
|
|
|
|
let loaderPopup;
|
|
|
|
|
2024-06-30 22:03:38 +02:00
|
|
|
let preloaderYoinked = false;
|
|
|
|
|
2023-10-31 22:16:33 +02:00
|
|
|
export function showLoader() {
|
2024-06-30 20:44:29 +02:00
|
|
|
// Two loaders don't make sense. Don't await, we can overlay the old loader while it closes
|
2024-06-30 19:45:42 +02:00
|
|
|
if (loaderPopup) loaderPopup.complete(POPUP_RESULT.CANCELLED);
|
|
|
|
|
|
|
|
loaderPopup = new Popup(`
|
|
|
|
<div id="loader">
|
|
|
|
<div id="load-spinner" class="fa-solid fa-gear fa-spin fa-3x"></div>
|
2024-06-30 23:27:49 +03:00
|
|
|
</div>`, POPUP_TYPE.DISPLAY, null, { transparent: true, animation: 'none' });
|
2024-06-30 19:45:42 +02:00
|
|
|
|
|
|
|
// No close button, loaders are not closable
|
|
|
|
loaderPopup.closeButton.style.display = 'none';
|
|
|
|
|
|
|
|
loaderPopup.show();
|
2024-04-08 00:18:21 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
export async function hideLoader() {
|
2024-06-30 19:45:42 +02:00
|
|
|
if (!loaderPopup) {
|
|
|
|
console.warn('There is no loader showing to hide');
|
2024-06-30 20:44:29 +02:00
|
|
|
return Promise.resolve();
|
2024-06-30 19:45:42 +02:00
|
|
|
}
|
|
|
|
|
2024-06-30 20:44:29 +02:00
|
|
|
return new Promise((resolve) => {
|
2025-01-30 21:59:59 +02:00
|
|
|
const spinner = $('#load-spinner');
|
|
|
|
if (!spinner.length) {
|
|
|
|
console.warn('Spinner element not found, skipping animation');
|
|
|
|
cleanup();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check if transitions are enabled
|
|
|
|
const transitionDuration = spinner[0] ? getComputedStyle(spinner[0]).transitionDuration : '0s';
|
|
|
|
const hasTransitions = parseFloat(transitionDuration) > 0;
|
|
|
|
|
|
|
|
if (hasTransitions) {
|
|
|
|
Promise.race([
|
|
|
|
new Promise((r) => setTimeout(r, 500)), // Fallback timeout
|
|
|
|
new Promise((r) => spinner.one('transitionend webkitTransitionEnd oTransitionEnd MSTransitionEnd', r)),
|
|
|
|
]).finally(cleanup);
|
|
|
|
} else {
|
|
|
|
cleanup();
|
|
|
|
}
|
|
|
|
|
|
|
|
function cleanup() {
|
2024-07-04 01:41:21 +03:00
|
|
|
$('#loader').remove();
|
2024-06-30 23:27:49 +03:00
|
|
|
// Yoink preloader entirely; it only exists to cover up unstyled content while loading JS
|
|
|
|
// If it's present, we remove it once and then it's gone.
|
|
|
|
yoinkPreloader();
|
|
|
|
|
2025-01-30 21:59:59 +02:00
|
|
|
loaderPopup.complete(POPUP_RESULT.AFFIRMATIVE)
|
|
|
|
.catch((err) => console.error('Error completing loaderPopup:', err))
|
|
|
|
.finally(() => {
|
|
|
|
loaderPopup = null;
|
|
|
|
resolve();
|
|
|
|
});
|
|
|
|
}
|
2024-06-30 19:45:42 +02:00
|
|
|
|
2025-01-30 21:59:59 +02:00
|
|
|
// Apply the styles
|
|
|
|
spinner.css({
|
|
|
|
'filter': 'blur(15px)',
|
|
|
|
'opacity': '0',
|
|
|
|
});
|
2024-06-30 20:44:29 +02:00
|
|
|
});
|
2023-12-03 14:23:20 +02:00
|
|
|
}
|
2024-06-30 20:44:29 +02:00
|
|
|
|
2024-06-30 22:03:38 +02:00
|
|
|
function yoinkPreloader() {
|
|
|
|
if (preloaderYoinked) return;
|
|
|
|
document.getElementById('preloader').remove();
|
|
|
|
preloaderYoinked = true;
|
|
|
|
}
|