HEX
Server: Apache
System: Linux b5.s-host.com.ua 4.18.0-305.10.2.el7.x86_64 #1 SMP Fri Jul 23 21:00:55 UTC 2021 x86_64
User: unelbhzm (1470)
PHP: 8.0.18
Disabled: NONE
Upload Files
File: /sites/nuofama.com/wp-content/themes/blocksy/static/js/frontend/parallax/ios-inner-height.js
'use strict'

function isIpad() {
	const ua = window.navigator.userAgent

	if (ua.indexOf('iPad') > -1) {
		return true
	}

	if (ua.indexOf('Macintosh') > -1) {
		try {
			document.createEvent('TouchEvent')
			return true
		} catch (e) {}
	}

	return false
}

/**
 * @module ios-inner-height
 *
 * @description Get proper window.innerHeight from iOS devices,
 * excluding URL control and menu bar.
 *
 * @return {function} Callable function to retrieve the
 * cached `window.innerHeight` measurement, specific to the
 * device's current orientation.
 */
module.exports = (function () {
	// Avoid errors when globals are undefined (CI, etc)
	// https://github.com/tylerjpeterson/ios-inner-height/pull/7
	if (typeof window === 'undefined' || typeof navigator === 'undefined') {
		return function () {
			return 0
		}
	}

	// Non-iOS browsers return window.innerHeight per usual.
	// No caching here since browsers can be resized, and setting
	// up resize-triggered cache invalidation is not in scope.
	/* istanbul ignore if  */
	if (!navigator.userAgent.match(/iphone|ipod|ipad/i) && !isIpad()) {
		/**
		 * Avoids conditional logic in the implementation
		 * @return {number} - window's innerHeight measurement in pixels
		 */
		return function () {
			return window.innerHeight
		}
	}

	// Store initial orientation
	var axis = Math.abs(window.orientation)
	// And hoist cached dimensions
	var dims = { w: 0, h: 0 }

	/**
	 * Creates an element with a height of 100vh since iOS accurately
	 * reports vp height (but not window.innerHeight). Then destroy it.
	 */
	var createRuler = function () {
		var ruler = document.createElement('div')

		ruler.style.position = 'fixed'
		ruler.style.height = '100vh'
		ruler.style.width = 0
		ruler.style.top = 0

		document.documentElement.appendChild(ruler)

		// Set cache conscientious of device orientation
		dims.w = axis === 90 ? ruler.offsetHeight : window.innerWidth
		dims.h = axis === 90 ? window.innerWidth : ruler.offsetHeight

		// Clean up after ourselves
		document.documentElement.removeChild(ruler)
		ruler = null
	}

	// Measure once
	createRuler()

	/**
	 * Returns window's cached innerHeight measurement
	 * based on viewport height and device orientation
	 * @return {number} - window's innerHeight measurement in pixels
	 */
	return function () {
		if (Math.abs(window.orientation) !== 90) {
			return dims.h
		}

		return dims.w
	}
})()