Uname: Linux p3plzcpnl499967.prod.phx3.secureserver.net 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
Software: Apache
PHP version: 8.2.30 [ PHP INFO ] PHP os: Linux
Server Ip: 208.109.40.231
Your Ip: 216.73.216.173
User: nayff91c5tsx (10005085) | Group: nayff91c5tsx (10005085)
Safe Mode: OFF
Disable Function:
NONE

name : site-general.js
import { animateScrollTop, hideElAfterDelay } from "../utils/anim-util";
import {
	forEachEl,
	getBreakpoints,
	listenDocumentEvent,
} from "../utils/dom-util";

/**
 * This module is intended to handle the site wide JS functionality.
 * Except for the desktop menu and mobile menu functionality.
 *
 * Along with the desktop-menu.js and mobile-menu.js, this file will be combined to site-min.js file.
 */
export default function setupSite() {
	const breakpoints = getBreakpoints();

	/**
	 * Initialize the module, call the main functions.
	 *
	 * This function is the only function that should be called on top level scope.
	 * Other functions are called / hooked from this function.
	 */
	function init() {
		setupBodyClasses();
		setupScrollToTop();
		wpcf7support();
		setupBoxedLayoutSupport();

		// Add identifier in body class telling if we're using the vanilla JS version.
		document.body.classList.add("wpbf-vanilla");

		// On window resize, re-run the body class setup - so that it has the updated breakpoint class name.
		window.addEventListener("resize", function (e) {
			setupBodyClasses();
		});

		// Executing various triggers on window load.
		window.addEventListener("load", function () {
			window.setTimeout(function () {
				forEachEl(".opacity", function (el) {
					el.classList.add("is-visible");
				});
			}, 200);

			forEachEl(".display-none", function (el) {
				el.style.display = "block";
			});

			window.dispatchEvent(new Event("resize"));
			window.dispatchEvent(new Event("scroll"));
		});
	}

	/**
	 * Setup body classes based on breakpoint.
	 *
	 * This function will add "wpbf-is-{device}" class to the body tag.
	 */
	function setupBodyClasses() {
		const windowWidth = document.documentElement.clientWidth;
		let bodyClass = "";

		if (windowWidth > breakpoints.desktop) {
			bodyClass = "wpbf-is-desktop";
		} else {
			if (windowWidth > breakpoints.tablet) {
				bodyClass = "wpbf-is-tablet";
			} else {
				bodyClass = "wpbf-is-mobile";
			}
		}

		document.body.classList.remove("wpbf-is-desktop");
		document.body.classList.remove("wpbf-is-tablet");
		document.body.classList.remove("wpbf-is-mobile");

		document.body.classList.add(bodyClass);
	}

	/**
	 * Setup scroll to top functionality.
	 */
	function setupScrollToTop() {
		const scrolltopEl = document.querySelector(".scrolltop");
		if (!scrolltopEl || !(scrolltopEl instanceof HTMLElement)) return;

		const dataScrolltop = scrolltopEl.dataset.scrolltopValue;
		const scrollTopSetting = dataScrolltop ? parseFloat(dataScrolltop) : 0;

		// Show or hide scroll-to-top button on window scroll event.
		window.addEventListener("scroll", function (e) {
			if (window.scrollY > scrollTopSetting) {
				scrolltopEl.classList.add("is-visible");
			} else {
				scrolltopEl.classList.remove("is-visible");
			}
		});

		// Scroll to top functionality.
		listenDocumentEvent(
			"click",
			".scrolltop",
			/**
			 * @param {MouseEvent} e - The scroll event.
			 * @this {HTMLElement}
			 */
			function (e) {
				document.body.tabIndex = -1;
				document.body.focus();
				this.blur();
				animateScrollTop(0, 500);
			},
		);
	}

	/**
	 * Support for Contact Form 7.
	 */
	function wpcf7support() {
		forEachEl(".wpcf7-form-control-wrap", function (el) {
			el.addEventListener("mouseenter", function () {
				const tooltips = el.querySelectorAll(".wpcf7-not-valid-tip");

				tooltips.forEach(function (tooltip) {
					tooltip.classList.add("wpbf-fading");
					tooltip.classList.add("wpbf-fade-out");

					if (tooltip instanceof HTMLElement) {
						hideElAfterDelay(tooltip, 400);
					}
				});
			});
		});
	}

	/**
	 * Setup support for boxed layout mode.
	 */
	function setupBoxedLayoutSupport() {
		const page = document.querySelector(".wpbf-page");
		if (!page || !(page instanceof HTMLElement)) return;

		const pageMarginTop = window.getComputedStyle(page).marginTop;

		window.addEventListener("resize", function () {
			const pageWidth = page.offsetWidth;

			// If page width is >= window width, then remove margin top & margin bottom.
			if (pageWidth >= document.documentElement.clientWidth) {
				page.style.marginTop = "0";
				page.style.marginBottom = "0";
			} else {
				// Otherwise, add the margin top & margin bottom.
				page.style.marginTop = pageMarginTop;
				page.style.marginBottom = pageMarginTop;
			}
		});
	}

	// Run the module.
	init();
}
© 2026 GrazzMean