HEX
Server: Microsoft-IIS/8.5
System: Windows NT YDAWBH120 6.3 build 9600 (Windows Server 2012 R2 Standard Edition) AMD64
User: tentjecom_web (0)
PHP: 7.4.14
Disabled: NONE
Upload Files
File: D:/HostingSpaces/BOoms/pro-oils.be/wwwroot/wp-content/themes/neve/assets/js/src/utils.js
/* jshint esversion: 6 */
/**
 * Check if we're on mobile resolution.
 *
 * @returns {boolean}
 */
export const isMobile = function() {
	return window.innerWidth <= 960;
};

/**
 * Http get request.
 *
 * @param theUrl
 * @param callback
 */
export const httpGetAsync = function(theUrl, callback, params) {
	let xmlHttp = new XMLHttpRequest();
	xmlHttp.onload = function() {
		if ( xmlHttp.readyState === 4 && xmlHttp.status === 200 )
			callback( xmlHttp.response );
	};
	xmlHttp.onerror = function(error) {
		console.error( error );
	};
	xmlHttp.open( 'POST', theUrl, true );
	xmlHttp.setRequestHeader( 'Content-Type', 'application/json; charset=UTF-8' );
	xmlHttp.send( params );
};

/**
 * Foreach wrapper.
 *
 * @param iterable
 * @param callback
 */
export const neveEach = function(iterable, callback) {
	for ( let i = 0; i < iterable.length; i++ ) {
		callback( iterable[i] );
	}
};

/**
 * Check if user is viewing on the best browser ever.
 */
export const isIe = function() {
	let ua = window.navigator.userAgent;
	let msie = ua.indexOf( 'MSIE ' ),
			edge = ua.indexOf( 'Edge/' ),
			trident = ua.indexOf( 'Trident/' );
	return ( msie > 0 || trident > 0 || edge > 0 );
};

/**
 * Unhash url.
 * @param url
 * @returns {string}
 */
export const unhashUrl = function(url) {

	if ( url.indexOf( '#' ) > -1 ) {
		url = url.substr( 0, url.lastIndexOf( '#' ) );
	}

	if ( url.substr( -1 ) === '/' ) {
		url = url.substring( 0, url.length - 1 );
	}

	return url;
};

/**
 * Add event handler to elements.
 *
 * @param element
 * @param event
 * @param callBack
 */
export const addEvent = function(element, event, callBack) {
	if ( element instanceof NodeList ) {
		for ( let i = 0; i < element.length; i++ ) {
			element[i].addEventListener( event, callBack );
		}
	} else if ( element instanceof Node || element instanceof Element ) {
		element.addEventListener( event, callBack );
	}
};

/**
 * Toggle Element class name.
 *
 * @param element
 * @param className
 */
export const toggleClass = function(element, className) {
	if ( element instanceof NodeList ) {
		for ( let i = 0; i < element.length; i++ ) {
			element[i].classList.toggle( className );
		}
	} else if ( element instanceof Node || element instanceof Element ) {
		element.classList.toggle( className );
	}
};

/**
 * Add class to element.
 *
 * @param element
 * @param className
 */
export const addClass = function(element, className) {
	if ( element instanceof NodeList ) {
		for ( let i = 0; i < element.length; i++ ) {
			element[i].classList.add( className );
		}
	} else if ( element instanceof Node || element instanceof Element ) {
		element.classList.add( className );
	}
};

/**
 * Remove class name from element.
 *
 * @param element
 * @param className
 */
export const removeClass = function(element, className) {
	// Split each class by space.
	let classes = className.split( ' ' );
	if ( element instanceof NodeList ) {
		for ( let i = 0; i < element.length; i++ ) {
			for ( let j = 0; j < classes.length; j++ ) {
				element[i].classList.remove( classes[j] );
			}
		}
	} else if ( element instanceof Node || element instanceof Element ) {
		for ( let j = 0; j < classes.length; j++ ) {
			element.classList.remove( classes[j] );
		}
	}
};

/**
 * Check if element is in view.
 * @param element
 * @param callback
 * @param intersectionRatio
 */
export const isInView = function(element, callback, intersectionRatio = 0.5) {
	let intersectionObserver = new IntersectionObserver( entries => {
		if ( entries[0].intersectionRatio <= intersectionRatio ) {
			return;
		}
		callback();
	} );
	intersectionObserver.observe( element );
};