oont-contents/plugins/jetpack/modules/subscriptions/subscribe-overlay/subscribe-overlay.js
2025-02-08 15:10:23 +01:00

73 lines
2.2 KiB
JavaScript

const { domReady } = wp;
domReady( function () {
const overlay = document.querySelector( '.jetpack-subscribe-overlay' );
const overlayDismissedCookie = 'jetpack_post_subscribe_overlay_dismissed';
const skipUrlParam = 'jetpack_skip_subscription_popup';
const hasOverlayDismissedCookie =
document.cookie && document.cookie.indexOf( overlayDismissedCookie ) > -1;
// Subscriber ended up here e.g. from emails:
// we won't show the overlay to them in future since they most likely are already a subscriber.
function skipOverlay() {
const url = new URL( window.location.href );
if ( url.searchParams.has( skipUrlParam ) ) {
url.searchParams.delete( skipUrlParam );
window.history.replaceState( {}, '', url );
setOverlayDismissedCookie();
return true;
}
return false;
}
if ( ! overlay || hasOverlayDismissedCookie || skipOverlay() ) {
return;
}
const close = overlay.querySelector( '.jetpack-subscribe-overlay__close' );
close.onclick = function ( event ) {
event.preventDefault();
closeOverlay();
};
const toContent = overlay.querySelector( '.jetpack-subscribe-overlay__to-content' );
// User can edit overlay, and could remove to content link.
if ( toContent ) {
toContent.onclick = function ( event ) {
event.preventDefault();
closeOverlay();
};
}
// When the form is submitted, and next modal loads, it'll fire "subscription-modal-loaded" signalling that this form can be hidden.
const form = overlay.querySelector( 'form' );
if ( form ) {
form.addEventListener( 'subscription-modal-loaded', closeOverlay );
}
function closeOverlayOnEscapeKeydown( event ) {
if ( event.key === 'Escape' ) {
closeOverlay();
}
}
function openOverlay() {
overlay.classList.add( 'open' );
document.body.classList.add( 'jetpack-subscribe-overlay-open' );
setOverlayDismissedCookie();
window.addEventListener( 'keydown', closeOverlayOnEscapeKeydown );
}
function closeOverlay() {
overlay.classList.remove( 'open' );
document.body.classList.remove( 'jetpack-subscribe-overlay-open' );
window.removeEventListener( 'keydown', closeOverlayOnEscapeKeydown );
}
function setOverlayDismissedCookie() {
document.cookie = `${ overlayDismissedCookie }=true; path=/;`;
}
openOverlay();
} );