swup
Version:
Versatile and extensible page transition library for server-rendered websites
33 lines (26 loc) • 782 B
text/typescript
import type Swup from '../Swup.js';
import { nextTick } from '../utils.js';
import type { Visit } from './Visit.js';
/**
* Perform the in/enter animation of the next page.
* @returns Promise<void>
*/
export const animatePageIn = async function (this: Swup, visit: Visit) {
// Check if failed/aborted in the meantime
if (visit.done) return;
const animation = this.hooks.call(
'animation:in:await',
visit,
{ skip: false },
(visit, { skip }) => {
if (skip) return;
return this.awaitAnimations({ selector: visit.animation.selector });
}
);
await nextTick();
await this.hooks.call('animation:in:start', visit, undefined, () => {
this.classes.remove('is-animating');
});
await animation;
await this.hooks.call('animation:in:end', visit, undefined);
};