upskill-event-manager/assets/js/spectra-pro-popup-builder-admin.js
Ben Reed cdc5ea85f4 feat: Add comprehensive CSS, JavaScript and theme asset infrastructure
Add massive collection of CSS, JavaScript and theme assets that were previously excluded:

**CSS Files (681 total):**
- HVAC plugin-specific styles (hvac-*.css): 34 files including dashboard, certificates, registration, mobile nav, accessibility fixes, animations, and welcome popup
- Theme framework files (Astra, builder systems, layouts): 200+ files
- Plugin compatibility styles (WooCommerce, WPForms, Elementor, Contact Form 7): 150+ files
- WordPress core and editor styles: 50+ files
- Responsive and RTL language support: 200+ files

**JavaScript Files (400+ total):**
- HVAC plugin functionality (hvac-*.js): 27 files including menu systems, dashboard enhancements, profile sharing, mobile responsive features, accessibility, and animations
- Framework and library files: jQuery plugins, GSAP, AOS, Swiper, Chart.js, Lottie, Isotope
- Plugin compatibility scripts: WPForms, WooCommerce, Elementor, Contact Form 7, LifterLMS
- WordPress core functionality: customizer, admin, block editor compatibility
- Third-party integrations: Stripe, SMTP, analytics, search functionality

**Assets:**
- Certificate background images and logos
- Comprehensive theme styling infrastructure
- Mobile-responsive design systems
- Cross-browser compatibility assets
- Performance-optimized minified versions

**Updated .gitignore:**
- Fixed asset directory whitelisting patterns to properly include CSS/JS/images
- Added proper directory structure recognition (!/assets/css/, !/assets/js/, etc.)
- Maintains security by excluding sensitive files while including essential assets

This commit provides the complete frontend infrastructure needed for:
- Full theme functionality and styling
- Plugin feature implementations
- Mobile responsiveness and accessibility
- Cross-browser compatibility
- Performance optimization
- Developer workflow support
2025-08-11 16:20:31 -03:00

154 lines
5.5 KiB
JavaScript

// Spectra Pro Popup JS Actions Needed in the Admin CPT Page.
const UAGBQuickviewModal = ( event ) => {
event.preventDefault();
const element = event.target;
const dashiconElement = element.querySelector( '.dashicons' );
// Add the Loading Dashicon.
dashiconElement.classList.remove( 'dashicons-visibility' );
dashiconElement.classList.add( 'dashicons-ellipsis' );
const popupData = new FormData();
popupData.append( 'action', 'uag_trigger_popup_quickview' );
popupData.append( 'nonce', spectra_pro_popup_builder_admin.spectra_pro_popup_builder_admin_nonce );
popupData.append( 'popup_id', element.dataset.popup_id );
fetch( spectra_pro_popup_builder_admin.ajax_url, {
method: 'POST',
credentials: 'same-origin',
body: popupData,
} )
.then( ( resp ) => resp.json() )
.then( ( jsonResp ) => {
if ( false === jsonResp.success ) {
return;
}
// Return early if the modal overlay isn't found.
const modalOverlay = document.querySelector( '.spectra-popup-builder__modal--overlay' );
if ( ! modalOverlay ) {
return;
}
const modal = modalOverlay.querySelector( '.spectra-popup-builder__modal' );
if ( ! modal ) {
return;
}
const body = document.querySelector( 'body' );
// Show the Modal.
modalOverlay.style.display = 'flex';
setTimeout( () => {
body.classList.add( 'spectra-popup-builder__modal--scroll-lock' );
modalOverlay.style.opacity = 1;
modal.style.opacity = 1;
}, 50 );
// Set the required constants.
const {
name,
type,
inclusions,
exclusions,
status,
date,
edit,
editLabel,
} = jsonResp.data;
const title = modal.querySelector( '.spectra-popup-builder__modal--title' );
const typeBadge = modal.querySelector( '.spectra-popup-builder__modal--type' );
const inclusionCell = modal.querySelector( '.spectra-popup-builder__modal--body-inclusions' );
const exclusionCell = modal.querySelector( '.spectra-popup-builder__modal--body-exclusions' );
const closeButton = modal.querySelector( '.spectra-popup-builder__modal--close' );
const statusSpan = modal.querySelector( '.spectra-popup-builder__modal--status' );
const dateSpan = modal.querySelector( '.spectra-popup-builder__modal--date' );
const editLink = modal.querySelector( '.spectra-popup-builder__modal--edit' );
// Add all the text content.
title.textContent = name;
typeBadge.textContent = 'banner' === type ? 'info bar' : type;
statusSpan.textContent = 'publish' === status ? 'published' : status;
dateSpan.textContent = date;
editLink.textContent = editLabel;
// Add the Inclusions list if it exists, else add 'Entire Website'.
if ( inclusionCell && inclusions?.length ) {
const inclusionMarkup = document.createElement( 'ul' );
inclusions.forEach( inclusionRule => {
const inclusionRuleMarkup = document.createElement( 'li' );
inclusionRuleMarkup.textContent = inclusionRule;
inclusionMarkup.appendChild( inclusionRuleMarkup );
} );
inclusionCell.appendChild( inclusionMarkup );
} else {
const noInclusion = document.createElement( 'div' );
noInclusion.textContent = 'Entire Website';
inclusionCell.appendChild( noInclusion );
}
// Add the exclusion list if it exists, else add 'None'.
if ( exclusionCell && exclusions?.length ) {
const exclusionMarkup = document.createElement( 'ul' );
exclusions.forEach( exclusionRule => {
const exclusionRuleMarkup = document.createElement( 'li' );
exclusionRuleMarkup.textContent = exclusionRule;
exclusionMarkup.appendChild( exclusionRuleMarkup );
} );
exclusionCell.appendChild( exclusionMarkup );
} else {
const noExclusion = document.createElement( 'div' );
noExclusion.textContent = 'Not Set';
exclusionCell.appendChild( noExclusion );
}
// Add the Edit Button Link.
editLink?.setAttribute( 'href', edit.replace( '&', '&' ) );
// Cleanup when the Modal is Closed.
const closeQuickview = ( e ) => {
e.preventDefault();
modal.style.opacity = 0;
body.classList.remove( 'spectra-popup-builder__modal--scroll-lock' );
setTimeout( () => {
modalOverlay.style.opacity = 0;
}, 50 );
setTimeout( () => {
modalOverlay.style.display = 'none';
title.textContent = '';
typeBadge.textContent = '';
statusSpan.textContent = '';
dateSpan.textContent = '';
inclusionCell.innerHTML = '';
exclusionCell.innerHTML = '';
editLink?.setAttribute( 'href', 'javascript:void(0)' );
editLink.textContent = wp.i18n.__( 'Edit', 'spectra-pro' );
closeButton.removeEventListener( 'click', closeQuickview );
}, 200 );
}
// Close the Modal when the Close Button is clicked.
closeButton.addEventListener( 'click', closeQuickview );
// Add the Quick View Dashicon back once the modal loads.
setTimeout( () => {
dashiconElement.classList.remove( 'dashicons-ellipsis' );
dashiconElement.classList.add( 'dashicons-visibility' );
}, 150 );
} )
.catch( () => {
// Add the Quick View Dashicon back.
dashiconElement.classList.remove( 'dashicons-ellipsis' );
dashiconElement.classList.add( 'dashicons-visibility' );
} );
}
// Bind Related Click Events on Load.
document.addEventListener( 'DOMContentLoaded', () => {
// Bind all the Quick-view Buttons.
const spectraQuickButtons = document.querySelectorAll( '.spectra-popup-builder__button' );
for ( let spectraQuickButtonCount = 0; spectraQuickButtonCount < spectraQuickButtons.length; spectraQuickButtonCount++ ) {
spectraQuickButtons[ spectraQuickButtonCount ].addEventListener( 'click', ( event ) => UAGBQuickviewModal( event ) );
}
} );