Your IP : 3.16.50.1


Current Path : /home/ncdcgo/public_html/wp-content/plugins/Ultimate_VC_Addons/assets/js/
Upload File :
Current File : /home/ncdcgo/public_html/wp-content/plugins/Ultimate_VC_Addons/assets/js/jparallax.js

jQuery( document ).ready( function () {
	/* vc hack by amit */
	jQuery( '.upb_row_bg' ).each( function ( index, urow ) {
		const row = jQuery( urow ).parent();
		row[ 0 ].style.setProperty( 'background-image', 'none', 'important' );
	} );
	/* end */
	if ( jQuery( '.vcpb-fs-jquery' ).length > 0 ) {
		if ( ! jQuery.event.special.frame ) {
			// jquery.events.frame.js
			// 1.1 - lite
			// Stephen Band
			//
			// Project home:
			// webdev.stephband.info/events/frame/
			//
			// Source:
			// http://github.com/stephband/jquery.event.frame
			( function ( d, h ) {
				function i( a, b ) {
					function e() {
						f.frameCount++;
						a.call( f );
					}
					var f = this,
						g;
					this.frameDuration = b || 25;
					this.frameCount = -1;
					this.start = function () {
						e();
						g = setInterval( e, this.frameDuration );
					};
					this.stop = function () {
						clearInterval( g );
						g = null;
					};
				}
				function j() {
					let a = d.event.special.frame.handler,
						b = d.Event( 'frame' ),
						e = this.array,
						f = e.length;
					for ( b.frameCount = this.frameCount; f--;  )
						a.call( e[ f ], b );
				}
				let c;
				if ( ! d.event.special.frame )
					d.event.special.frame = {
						setup( a ) {
							if ( c ) c.array.push( this );
							else {
								c = new i( j, a && a.frameDuration );
								c.array = [ this ];
								var b = setTimeout( function () {
									c.start();
									clearTimeout( b );
									b = null;
								}, 0 );
							}
						},
						teardown() {
							for ( var a = c.array, b = a.length; b--;  )
								if ( a[ b ] === this ) {
									a.splice( b, 1 );
									break;
								}
							if ( a.length === 0 ) {
								c.stop();
								c = h;
							}
						},
						handler() {
							if ( d.event.handle ) {
								d.event.handle.apply( this, arguments );
							} else {
								d.event.dispatch.apply( this, arguments );
							}
						},
					};
			} )( jQuery );
		}
		// jquery.jparallax.js
		// 1.0
		// Stephen Band
		//
		// Project and documentation site:
		// webdev.stephband.info/jparallax/
		//
		// Repository:
		// github.com/stephband/jparallax
		//
		// Dependencies:
		// jquery.event.frame
		( function ( l, t ) {
			function y( i ) {
				return this.lib[ i ];
			}
			function q( i ) {
				return typeof i === 'boolean' ? i : !! parseFloat( i );
			}
			function r( i, b ) {
				const k = [ q( i.xparallax ), q( i.yparallax ) ];
				this.ontarget = false;
				this.decay = i.decay;
				this.pointer = b || [ 0.5, 0.5 ];
				this.update = function ( e, a ) {
					if ( this.ontarget ) this.pointer = e;
					else if (
						( ! k[ 0 ] ||
							u( e[ 0 ] - this.pointer[ 0 ] ) < a[ 0 ] ) &&
						( ! k[ 1 ] || u( e[ 1 ] - this.pointer[ 1 ] ) < a[ 1 ] )
					) {
						this.ontarget = true;
						this.pointer = e;
					} else {
						a = [];
						for ( let g = 2; g--;  )
							if ( k[ g ] )
								a[ g ] =
									e[ g ] +
									this.decay * ( this.pointer[ g ] - e[ g ] );
						this.pointer = a;
					}
				};
			}
			function z( i, b ) {
				let k = this,
					e = i instanceof l ? i : l( i ),
					a = [ q( b.xparallax ), q( b.yparallax ) ],
					g = 0,
					d;
				this.pointer = [ 0, 0 ];
				this.active = false;
				this.activeOutside = ( b && b.activeOutside ) || false;
				this.update = function ( h ) {
					let j = this.pos,
						c = this.size,
						f = [],
						m = 2;
					if ( g > 0 ) {
						if ( g === 2 ) {
							g = 0;
							if ( d ) h = d;
						}
						for ( ; m--;  )
							if ( a[ m ] ) {
								f[ m ] = ( h[ m ] - j[ m ] ) / c[ m ];
								f[ m ] =
									f[ m ] < 0 ? 0 : f[ m ] > 1 ? 1 : f[ m ];
							}
						this.active = true;
						this.pointer = f;
					} else this.active = false;
				};
				this.updateSize = function () {
					const h = e.width(),
						j = e.height();
					k.size = [ h, j ];
					k.threshold = [ 1 / h, 1 / j ];
				};
				this.updatePos = function () {
					const h = e.offset() || { left: 0, top: 0 },
						j =
							parseInt( e.css( 'borderLeftWidth' ) ) +
							parseInt( e.css( 'paddingLeft' ) ),
						c =
							parseInt( e.css( 'borderTopWidth' ) ) +
							parseInt( e.css( 'paddingTop' ) );
					k.pos = [ h.left + j, h.top + c ];
				};
				l( window )
					.bind( 'resize', k.updateSize )
					.bind( 'resize', k.updatePos );
				e.bind( 'mouseenter', function () {
					g = 1;
				} ).bind( 'mouseleave', function ( h ) {
					g = 2;
					d = [ h.pageX, h.pageY ];
				} );
				this.updateSize();
				this.updatePos();
			}
			function A( i, b ) {
				const k = [],
					e = [],
					a = [],
					g = [];
				this.update = function ( d ) {
					for ( var h = [], j, c, f = 2, m = {}; f--;  )
						if ( e[ f ] ) {
							h[ f ] = e[ f ] * d[ f ] + a[ f ];
							if ( k[ f ] ) {
								j = g[ f ];
								c = h[ f ] * -1;
							} else {
								j = h[ f ] * 100 + '%';
								c = h[ f ] * this.size[ f ] * -1;
							}
							if ( f === 0 ) {
								m.left = j;
								m.marginLeft = c;
							} else {
								m.top = j;
								m.marginTop = c;
							}
						}
					i.css( m );
				};
				this.setParallax = function ( d, h, j, c ) {
					d = [ d || b.xparallax, h || b.yparallax ];
					j = [ j || b.xorigin, c || b.yorigin ];
					for ( c = 2; c--;  ) {
						k[ c ] = o.px.test( d[ c ] );
						if ( typeof j[ c ] === 'string' )
							j[ c ] = o.percent.test( j[ c ] )
								? parseFloat( j[ c ] ) / 100
								: v[ j[ c ] ] || 1;
						if ( k[ c ] ) {
							e[ c ] = parseInt( d[ c ] );
							a[ c ] = j[ c ] * ( this.size[ c ] - e[ c ] );
							g[ c ] = j[ c ] * 100 + '%';
						} else {
							e[ c ] =
								d[ c ] === true
									? 1
									: o.percent.test( d[ c ] )
									? parseFloat( d[ c ] ) / 100
									: d[ c ];
							a[ c ] = e[ c ] ? j[ c ] * ( 1 - e[ c ] ) : 0;
						}
					}
				};
				this.getPointer = function () {
					for (
						var d = i.offsetParent(),
							h = i.position(),
							j = [],
							c = [],
							f = 2;
						f--;

					) {
						j[ f ] = k[ f ]
							? 0
							: h[ f === 0 ? 'left' : 'top' ] /
							  ( d[ f === 0 ? 'outerWidth' : 'outerHeight' ]() -
									this.size[ f ] );
						c[ f ] = ( j[ f ] - a[ f ] ) / e[ f ];
					}
					return c;
				};
				this.setSize = function ( d, h ) {
					this.size = [ d || i.outerWidth(), h || i.outerHeight() ];
				};
				this.setSize( b.width, b.height );
				this.setParallax(
					b.xparallax,
					b.yparallax,
					b.xorigin,
					b.yorigin
				);
			}
			function s( i ) {
				let b = l( this ),
					k = i.data,
					e = b.data( n ),
					a = k.port,
					g = k.mouse,
					d = e.mouse;
				if ( k.timeStamp !== i.timeStamp ) {
					k.timeStamp = i.timeStamp;
					a.update( w );
					if ( a.active || ! g.ontarget )
						g.update( a.pointer, a.threshold );
				}
				if ( d ) {
					d.update(
						e.freeze ? e.freeze.pointer : a.pointer,
						a.threshold
					);
					if ( d.ontarget ) {
						delete e.mouse;
						e.freeze && b.unbind( p ).addClass( k.freezeClass );
					}
					g = d;
				} else g.ontarget && ! a.active && b.unbind( p );
				e.layer.update( g.pointer );
			}
			var n = 'parallax',
				x = {
					mouseport: 'body',
					xparallax: true,
					yparallax: true,
					xorigin: 0.5,
					yorigin: 0.5,
					decay: 0.66,
					frameDuration: 30,
					freezeClass: 'freeze',
				},
				v = {
					left: 0,
					top: 0,
					middle: 0.5,
					center: 0.5,
					right: 1,
					bottom: 1,
				},
				o = { px: /^\d+\s?px$/, percent: /^\d+\s?%$/ },
				p = 'frame.' + n,
				u = Math.abs,
				w = [ 0, 0 ];
			y.lib = v;
			l.fn[ n ] = function ( i ) {
				const b = l.extend( {}, l.fn[ n ].options, i ),
					k = arguments,
					e = this;
				if ( ! ( b.mouseport instanceof l ) )
					b.mouseport = l( b.mouseport );
				b.port = new z( b.mouseport, b );
				b.mouse = new r( b );
				b.mouseport.bind( 'mouseenter', function () {
					b.mouse.ontarget = false;
					e.each( function () {
						const a = l( this );
						a.data( n ).freeze || a.bind( p, b, s );
					} );
				} );
				return e
					.bind( 'freeze', function ( a ) {
						const g = l( this ),
							d = g.data( n ),
							h = d.mouse || d.freeze || b.mouse,
							j = o.percent.exec( a.x )
								? parseFloat( a.x.replace( /%$/, '' ) ) / 100
								: a.x || h.pointer[ 0 ],
							c = o.percent.exec( a.y )
								? parseFloat( a.y.replace( /%$/, '' ) ) / 100
								: a.y || h.pointer[ 1 ];
						a = a.decay;
						d.freeze = { pointer: [ j, c ] };
						d.mouse = new r( b, h.pointer );
						if ( a !== t ) d.mouse.decay = a;
						g.bind( p, b, s );
					} )
					.bind( 'unfreeze', function ( a ) {
						const g = l( this ),
							d = g.data( n );
						a = a.decay;
						let h;
						if ( d.freeze ) {
							h = d.mouse ? d.mouse.pointer : d.freeze.pointer;
							d.mouse = new r( b );
							d.mouse.pointer = h;
							if ( a !== t ) d.mouse.decay = a;
							delete d.freeze;
							g.removeClass( x.freezeClass ).bind( p, b, s );
						}
					} )
					.each( function ( a ) {
						const g = l( this );
						a = k[ a + 1 ] ? l.extend( {}, b, k[ a + 1 ] ) : b;
						const d = new A( g, a );
						g.data( n, {
							layer: d,
							mouse: new r( a, d.getPointer() ),
						} );
					} );
			};
			l.fn[ n ].options = x;
			l( document ).ready( function () {
				l( document ).mousemove( function ( i ) {
					w = [ i.pageX, i.pageY ];
				} );
			} );
		} )( jQuery );
		//if(! jQuery.browser.mobile){
		jQuery( '.vcpb-fs-jquery' ).each( function () {
			const selector = jQuery( this );
			const sense = selector.data( 'parallax_sense' );
			const incr = selector.outerWidth() * ( sense / 100 );
			let img_list = selector.data( 'img-array' );
			img_list = img_list.split( ',' );
			const img_list_len = img_list.length;
			for ( let i = 0; i < img_list_len; i++ ) {
				jQuery( selector ).prepend(
					'<img class="ultimate_h_parallax" src="' +
						img_list[ i ] +
						'"></div>'
				);
			}
			const hp = jQuery( selector ).find( '.ultimate_h_parallax' );
			hp.css( { 'max-width': 'none', position: 'absolute' } );
			hp.css( 'min-width', hp.parent().outerWidth() + incr + 'px' );
		} );
		const resiz = function () {
			jQuery( '.vcpb-fs-jquery' ).each( function () {
				const selector = jQuery( this );
				const sense = selector.data( 'parallax_sense' );
				const incr = selector.outerWidth() * ( sense / 100 );
				const hp = jQuery( selector ).find( '.ultimate_h_parallax' );
				if ( hp.parent().outerHeight() > hp.outerHeight() ) {
					hp.css(
						'min-height',
						hp.parent().outerHeight() + incr + 'px'
					);
				}
				if ( hp.outerHeight() > hp.outerWidth() ) {
					hp.css( 'width', 'auto' );
				}
				jQuery( selector ).css( 'background-image', '' );
			} );
		};
		resiz();
		jQuery( window ).resize( function () {
			resiz();
		} );
		jQuery( window ).on( 'load', function () {
			jQuery( '.vcpb-fs-jquery' ).each( function () {
				let layer_count = jQuery( this ).find( '.ultimate_h_parallax' )
					.length;
				layer_count = 1 / layer_count;
				let lay_opt = new Array();
				jQuery( this )
					.find( '.ultimate_h_parallax' )
					.each( function ( index ) {
						lay_opt.push(
							"{'xparallax':" +
								layer_count * ( index + 1 ) +
								" , 'yparallax':" +
								layer_count * ( index + 1 ) +
								'}'
						);
					} );
				lay_opt = lay_opt.join( ',' );

				if (
					! /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(
						navigator.userAgent
					)
				)
					var is_mobile = 'false';
				else var is_mobile = 'true';

				const is_img_parallax_disable_on_mobile = jQuery( this )
					.parent()
					.data( 'img-parallax-mobile-disable' )
					.toString();
				if (
					is_mobile == 'true' &&
					is_img_parallax_disable_on_mobile == 'true'
				)
					var disable_row_effect = 'true';
				else var disable_row_effect = 'false';

				if ( disable_row_effect == 'false' )
					eval(
						"jQuery(this).find('.ultimate_h_parallax').parallax({mouseport: jQuery(this).parent()}," +
							lay_opt +
							"); var mouse = {x: 0, y: 0}; document.addEventListener('mousemove', function(e){  mouse.x = e.clientX || e.pageX; mouse.y = e.clientY || e.pageY; jQuery(this).parent().trigger({type: 'mousemove', pageX: mouse.x, pageY: mouse.y }); }, true); jQuery(this).parent().trigger({type: 'mouseenter', pageX: 0, pageY: 0}); var x = 1; document.onmousemove = document.onmouseover = function (e) { if(x > 1) return false; mouse.x = e.clientX || e.pageX;  mouse.y = e.clientY || e.pageY; x++; if(x == 2) jQuery(this).parent().trigger({type: 'mousemove', pageX: mouse.x, pageY: mouse.y }); }"
					);
			} );
		} );
		//}
	}
} );