vevet
Version:
Vevet is a JavaScript library for creative development that simplifies crafting rich interactions like split text animations, carousels, marquees, preloading, and more.
51 lines (37 loc) • 1.18 kB
text/typescript
import { Callbacks } from '@/base/Callbacks';
import { IPageLoadCallbacksMap } from './types';
import { addEventListener } from '@/utils/listeners';
interface IProps {
prefix: string;
applyClassNames: boolean;
}
export function createPageLoad({ prefix, applyClassNames }: IProps) {
const callbacks = new Callbacks<IPageLoadCallbacksMap>();
let isLoaded = false;
if (document.readyState === 'complete') {
setTimeout(() => handleLoaded(), 0);
} else {
addEventListener(window, 'load', () => handleLoaded());
}
/** Callback on page loaded */
function handleLoaded() {
const html = document.documentElement;
const { body } = document;
isLoaded = true;
if (applyClassNames) {
html.classList.remove(`${prefix}loading`);
body.classList.remove(`${prefix}loading`);
html.classList.add(`${prefix}loaded`);
}
callbacks.emit('loaded', undefined);
}
/** Add a callback on page load */
function onLoad(callback: () => void) {
if (isLoaded) {
callback();
return () => {};
}
return callbacks.on('loaded', () => callback());
}
return { onLoad, getIsLoaded: () => isLoaded };
}