/**
* Porto theme's main JavaScript file
*/
/* Alternatives for old browsers */
if ( !String.prototype.endsWith ) {
String.prototype.endsWith = function( search, this_len ) {
if ( this_len === undefined || this_len > this.length ) {
this_len = this.length;
}
return this.substring( this_len - search.length, this_len ) === search;
};
}
if ( window.NodeList && !NodeList.prototype.forEach ) {
NodeList.prototype.forEach = Array.prototype.forEach;
}
if ( !String.prototype.trim ) {
String.prototype.trim = function() {
return this.replace( /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g, '' );
};
}
/* Smart Resize */
( function( $, sr ) {
'use strict';
// debouncing function from John Hann
// http://unscriptable.com/index.php/2009/03/20/debouncing-javascript-methods/
var debounce = function( func, threshold, execAsap ) {
var timeout;
return function debounced() {
var obj = this, args = arguments;
function delayed() {
if ( !execAsap )
func.apply( obj, args );
timeout = null;
}
if ( timeout && timeout.val )
theme.deleteTimeout( timeout );
else if ( execAsap )
func.apply( obj, args );
timeout = theme.requestTimeout( delayed, threshold || 100 );
};
};
// smartresize
jQuery.fn[sr] = function( fn ) { return fn ? this.on( 'resize', debounce( fn ) ) : this.trigger( sr ); };
} )( jQuery, 'smartresize' );
/* easing */
jQuery.extend( jQuery.easing, {
def: 'easeOutQuad',
swing: function( x, t, b, c, d ) {
return jQuery.easing[jQuery.easing.def]( x, t, b, c, d );
},
easeOutQuad: function( x, t, b, c, d ) {
return -c * ( t /= d ) * ( t - 2 ) + b;
},
easeInOutQuart: function( x, t, b, c, d ) {
if ( ( t /= d / 2 ) < 1 ) return c / 2 * t * t * t * t + b;
return -c / 2 * ( ( t -= 2 ) * t * t * t - 2 ) + b;
},
easeOutQuint: function( x, t, b, c, d ) {
return c * ( ( t = t / d - 1 ) * t * t * t * t + 1 ) + b;
}
} );
( function( $ ) {
/**
* Copyright 2012, Digital Fusion
* Licensed under the MIT license.
* http://teamdf.com/jquery-plugins/license/
*
* @author Sam Sehnert
* @desc A small plugin that checks whether elements are within
* the user visible viewport of a web browser.
* only accounts for vertical position, not horizontal.
*/
$.fn.visible = function( partial, hidden, direction, container ) {
if ( this.length < 1 )
return;
var $t = this.length > 1 ? this.eq( 0 ) : this,
isContained = typeof container !== 'undefined' && container !== null,
$w = isContained ? $( container ) : $( window ),
wPosition = isContained ? $w.position() : 0,
t = $t.get( 0 ),
vpWidth = $w.outerWidth(),
vpHeight = $w.outerHeight(),
direction = ( direction ) ? direction : 'both',
clientSize = hidden === true ? t.offsetWidth * t.offsetHeight : true;
if ( typeof t.getBoundingClientRect === 'function' ) {
// Use this native browser method, if available.
var rec = t.getBoundingClientRect(),
tViz = isContained ?
rec.top - wPosition.top >= 0 && rec.top < vpHeight + wPosition.top :
rec.top >= 0 && rec.top < vpHeight,
bViz = isContained ?
rec.bottom - wPosition.top > 0 && rec.bottom <= vpHeight + wPosition.top :
rec.bottom > 0 && rec.bottom <= vpHeight,
lViz = isContained ?
rec.left - wPosition.left >= 0 && rec.left < vpWidth + wPosition.left :
rec.left >= 0 && rec.left < vpWidth,
rViz = isContained ?
rec.right - wPosition.left > 0 && rec.right < vpWidth + wPosition.left :
rec.right > 0 && rec.right <= vpWidth,
vVisible = partial ? tViz || bViz : tViz && bViz,
hVisible = partial ? lViz || rViz : lViz && rViz;
if ( direction === 'both' )
return clientSize && vVisible && hVisible;
else if ( direction === 'vertical' )
return clientSize && vVisible;
else if ( direction === 'horizontal' )
return clientSize && hVisible;
} else {
var viewTop = isContained ? 0 : wPosition,
viewBottom = viewTop + vpHeight,
viewLeft = $w.scrollLeft(),
viewRight = viewLeft + vpWidth,
position = $t.position(),
_top = position.top,
_bottom = _top + $t.height(),
_left = position.left,
_right = _left + $t.width(),
compareTop = partial === true ? _bottom : _top,
compareBottom = partial === true ? _top : _bottom,
compareLeft = partial === true ? _right : _left,
compareRight = partial === true ? _left : _right;
if ( direction === 'both' )
return !!clientSize && ( ( compareBottom <= viewBottom ) && ( compareTop >= viewTop ) ) && ( ( compareRight <= viewRight ) && ( compareLeft >= viewLeft ) );
else if ( direction === 'vertical' )
return !!clientSize && ( ( compareBottom <= viewBottom ) && ( compareTop >= viewTop ) );
else if ( direction === 'horizontal' )
return !!clientSize && ( ( compareRight <= viewRight ) && ( compareLeft >= viewLeft ) );
}
};
} )( jQuery );
/*
Name: Porto Theme Javascript
Writtern By: P-THEMES
Javascript Version: 1.2
*/
// Theme
window.theme || (window.theme = {});
// Configuration
( function( theme, $ ) {
'use strict';
theme = theme || {};
$.extend( theme, {
rtl: js_porto_vars.rtl == '1' ? true : false,
rtl_browser: $( 'html' ).hasClass( 'browser-rtl' ),
ajax_url: js_porto_vars.ajax_url,
request_error: js_porto_vars.request_error,
change_logo: js_porto_vars.change_logo == '1' ? true : false,
show_sticky_header: js_porto_vars.show_sticky_header == '1' ? true : false,
show_sticky_header_tablet: js_porto_vars.show_sticky_header_tablet == '1' ? true : false,
show_sticky_header_mobile: js_porto_vars.show_sticky_header_mobile == '1' ? true : false,
category_ajax: js_porto_vars.category_ajax == '1' ? true : false,
prdctfltr_ajax: js_porto_vars.prdctfltr_ajax == '1' ? true : false,
container_width: parseInt( js_porto_vars.container_width ),
grid_gutter_width: parseInt( js_porto_vars.grid_gutter_width ),
screen_xl: parseInt( js_porto_vars.screen_xl ),
screen_xxl: parseInt( js_porto_vars.screen_xxl ),
slider_loop: js_porto_vars.slider_loop == '1' ? true : false,
slider_autoplay: js_porto_vars.slider_autoplay == '1' ? true : false,
slider_autoheight: js_porto_vars.slider_autoheight == '1' ? true : false,
slider_speed: js_porto_vars.slider_speed ? js_porto_vars.slider_speed : 5000,
slider_nav: js_porto_vars.slider_nav == '1' ? true : false,
slider_nav_hover: js_porto_vars.slider_nav_hover == '1' ? true : false,
slider_margin: js_porto_vars.slider_margin == '1' ? 40 : 0,
slider_dots: js_porto_vars.slider_dots == '1' ? true : false,
slider_animatein: js_porto_vars.slider_animatein ? js_porto_vars.slider_animatein : '',
slider_animateout: js_porto_vars.slider_animateout ? js_porto_vars.slider_animateout : '',
product_thumbs_count: js_porto_vars.product_thumbs_count ? parseInt( js_porto_vars.product_thumbs_count, 10 ) : 4,
product_zoom: js_porto_vars.product_zoom == '1' ? true : false,
product_zoom_mobile: js_porto_vars.product_zoom_mobile == '1' ? true : false,
product_image_popup: js_porto_vars.product_image_popup == '1' ? 'fadeOut' : false,
innerHeight: window.innerHeight,
animation_support: !$( 'html' ).hasClass( 'no-csstransitions' ),
owlConfig: {
rtl: js_porto_vars.rtl == '1' ? true : false,
loop: js_porto_vars.slider_loop == '1' ? true : false,
autoplay: js_porto_vars.slider_autoplay == '1' ? true : false,
autoHeight: js_porto_vars.slider_autoheight == '1' ? true : false,
autoplayTimeout: js_porto_vars.slider_speed ? js_porto_vars.slider_speed : 7000,
autoplayHoverPause: true,
lazyLoad: true,
nav: js_porto_vars.slider_nav == '1' ? true : false,
navText: ["", ""],
dots: js_porto_vars.slider_dots == '1' ? true : false,
stagePadding: ( js_porto_vars.slider_nav_hover != '1' && js_porto_vars.slider_margin == '1' ) ? 40 : 0,
animateOut: js_porto_vars.slider_animateout ? js_porto_vars.slider_animateout : '',
animateIn: js_porto_vars.slider_animatein ? js_porto_vars.slider_animatein : ''
},
sticky_nav_height: 0,
is_device_mobile: /(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino/i.test( navigator.userAgent || navigator.vendor || window.opera ) || /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test( ( navigator.userAgent || navigator.vendor || window.opera ).substr( 0, 4 ) ),
getScrollbarWidth: function() {
if ( this.scrollbarSize === undefined ) {
this.scrollbarSize = window.innerWidth - document.documentElement.clientWidth;
}
return this.scrollbarSize;
},
isTablet: function() {
if ( window.innerWidth < 992 )
return true;
return false;
},
isMobile: function() {
if ( window.innerWidth <= 480 )
return true;
return false;
},
isIOS: function () {
return [
'iPad Simulator',
'iPhone Simulator',
'iPod Simulator',
'iPad',
'iPhone',
'iPod'
].includes(navigator.platform)
// iPad on iOS 13 detection
|| (navigator.userAgent.includes("Mac") && "ontouchend" in document);
},
refreshVCContent: function( $elements ) {
if ( $elements || $( document.body ).hasClass( 'elementor-page' ) ) {
$( window ).trigger( 'resize' );
}
theme.refreshStickySidebar( true );
if ( typeof window.vc_js == 'function' )
window.vc_js();
$( document.body ).trigger( 'porto_refresh_vc_content', [$elements] );
},
adminBarHeight: function() {
if ( theme.adminBarHeightNum || 0 === theme.adminBarHeightNum ) {
return theme.adminBarHeightNum;
}
var obj = document.getElementById( 'wpadminbar' ),
fixed_top = $( '.porto-scroll-progress.fixed-top:not(.fixed-under-header)' );
if ( fixed_top.length && '0px' == fixed_top.css( 'margin-top' ) ) {
theme.adminBarHeightNum = fixed_top.height();
} else {
theme.adminBarHeightNum = 0;
}
if ( obj && obj.offsetHeight && window.innerWidth > 600 ) {
theme.adminBarHeightNum += obj.offsetHeight;
}
return theme.adminBarHeightNum;
},
refreshStickySidebar: function( timeout, $sticky_sidebar ) {
if ( typeof $sticky_sidebar == 'undefined' ) {
$sticky_sidebar = $( '.sidebar [data-plugin-sticky]' );
}
if ( $sticky_sidebar.get( 0 ) ) {
if ( timeout ) {
theme.requestTimeout( function() {
$sticky_sidebar.trigger( 'recalc.pin' );
}, 400 );
} else {
$sticky_sidebar.trigger( 'recalc.pin' );
}
}
},
scrolltoContainer: function( $container, timeout ) {
if ( $container.get( 0 ) ) {
if ( window.innerWidth < 992 ) {
$( '.sidebar-overlay' ).trigger( 'click' );
}
if ( !timeout ) {
timeout = 600;
}
$( 'html, body' ).stop().animate( {
scrollTop: $container.offset().top - theme.StickyHeader.sticky_height - theme.adminBarHeight() - theme.sticky_nav_height - 18
}, timeout, 'easeOutQuad' );
}
},
requestFrame: function( fn ) {
var handler = window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame;
if ( !handler ) {
return setTimeout( fn, 1000 / 60 );
}
var rt = new Object()
rt.val = handler( fn );
return rt;
},
requestTimeout: function( fn, delay ) {
var handler = window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame;
if ( !handler ) {
return setTimeout( fn, delay );
}
var start, rt = new Object();
function loop( timestamp ) {
if ( !start ) {
start = timestamp;
}
var progress = timestamp - start;
progress >= delay ? fn.call() : rt.val = handler( loop );
};
rt.val = handler( loop );
return rt;
},
deleteTimeout: function( timeoutID ) {
if ( !timeoutID ) {
return;
}
var handler = window.cancelAnimationFrame || window.webkitCancelAnimationFrame || window.mozCancelAnimationFrame;
if ( !handler ) {
return clearTimeout( timeoutID );
}
if ( timeoutID.val ) {
return handler( timeoutID.val );
}
},
execPluginFunction: function( functionName, context ) {
var args = Array.prototype.slice.call( arguments, 2 );
var namespaces = functionName.split( "." );
var func = namespaces.pop();
for ( var i = 0; i < namespaces.length; i++ ) {
context = context[namespaces[i]];
}
return context[func].apply( context, args );
},
getOptions: function( opts ) {
if ( typeof ( opts ) == 'object' ) {
return opts;
} else if ( typeof ( opts ) == 'string' ) {
try {
return JSON.parse( opts.replace( /'/g, '"' ).replace( ';', '' ) );
} catch ( e ) {
return {};
}
} else {
return {};
}
},
mergeOptions: function( obj1, obj2 ) {
var obj3 = {};
for ( var attrname in obj1 ) { obj3[attrname] = obj1[attrname]; }
for ( var attrname in obj2 ) { obj3[attrname] = obj2[attrname]; }
return obj3;
},
intObs: function( selector, functionName, accY ) {
var $el;
if ( typeof selector == 'string' ) {
$el = document.querySelectorAll( selector );
} else {
$el = selector;
}
var intersectionObserverOptions = {
rootMargin: '200px'
}
if ( typeof accY != 'undefined' ) {
intersectionObserverOptions.rootMargin = '0px 0px ' + Number( accY ) + 'px 0px';
}
var observer = new IntersectionObserver( function( entries ) {
for ( var i = 0; i < entries.length; i++ ) {
var entry = entries[i];
if ( entry.intersectionRatio > 0 ) {
var $this = $( entry.target ),
opts;
if ( typeof functionName == 'string' ) {
var pluginOptions = theme.getOptions( $this.data( 'plugin-options' ) );
if ( pluginOptions )
opts = pluginOptions;
theme.execPluginFunction( functionName, $this, opts );
} else {
var callback = functionName;
callback.call( $this );
}
// Unobserve
observer.unobserve( entry.target );
}
}
}, intersectionObserverOptions );
Array.prototype.forEach.call( $el, function( obj ) {
observer.observe( obj );
} );
},
dynIntObsInit: function( selector, functionName, pluginDefaults ) {
var $el;
if ( typeof selector == 'string' ) {
$el = document.querySelectorAll( selector );
} else {
$el = selector;
}
Array.prototype.forEach.call( $el, function( obj ) {
var $this = $( obj ),
opts;
if ( $this.data( 'observer-init' ) ) {
return;
}
var pluginOptions = theme.getOptions( $this.data( 'plugin-options' ) );
if ( pluginOptions )
opts = pluginOptions;
var mergedPluginDefaults = theme.mergeOptions( pluginDefaults, opts )
var intersectionObserverOptions = {
rootMargin: '0px 0px 200px 0px',
thresholds: 0
}
if ( mergedPluginDefaults.accY ) {
intersectionObserverOptions.rootMargin = '0px 0px ' + Number( mergedPluginDefaults.accY ) + 'px 0px';
}
var observer = new IntersectionObserver( function( entries ) {
for ( var i = 0; i < entries.length; i++ ) {
var entry = entries[i];
if ( entry.intersectionRatio > 0 ) {
theme.execPluginFunction( functionName, $this, mergedPluginDefaults );
// Unobserve
observer.unobserve( entry.target );
}
}
}, intersectionObserverOptions );
observer.observe( obj );
$this.data( 'observer-init', true );
} );
}
} );
if ( theme.isIOS() ) {
document.body.classList.add( 'ios' );
}
$.extend( theme, {
add_query_arg: function( key, value ) {
key = escape( key ); value = escape( value );
var s = document.location.search;
var kvp = key + "=" + value;
var r = new RegExp( "(&|\\?)" + key + "=[^\&]*" );
s = s.replace( r, "$1" + kvp );
if ( !RegExp.$1 ) { s += ( s.length > 0 ? '&' : '?' ) + kvp; };
//again, do what you will here
return s;
},
addUrlParam: function (href, name, value) {
var url = document.createElement('a'), s, r;
href = decodeURIComponent(decodeURI(href));
url.href = href;
s = url.search;
if (0 <= s.indexOf(name + '=')) {
r = s.replace(new RegExp(name + '=[^&]*'), name + '=' + value);
} else {
r = (s.length && 0 <= s.indexOf('?')) ? s : '?';
r.endsWith('?') || (r += '&');
r += name + '=' + value;
}
return encodeURI(href.replace(s, '') + r.replace(/&+/, '&'));
},
removeUrlParam: function (href, name) {
var url = document.createElement('a'), s, r;
href = decodeURIComponent(decodeURI(href));
url.href = href;
s = url.search;
if (0 <= s.indexOf(name + '=')) {
r = s.replace(new RegExp(name + '=[^&]*'), '').replace(/&+/, '&').replace('?&', '?');
r.endsWith('&') && (r = r.substr(0, r.length - 1));
r.endsWith('?') && (r = r.substr(0, r.length - 1));
r = r.replace('&&', '&');
} else {
r = s;
}
return encodeURI(href.replace(s, '') + r);
}
} );
} ).apply( this, [window.theme, jQuery] );
( function( theme, $ ) {
'use strict';
theme = theme || {};
var disableMobileAnimations = function () {
if ( $( document.body ).hasClass( 'porto-dm-animate' ) && window.innerWidth < 768 ) {
theme.animation_support = false;
$( '[data-appear-animation]' ).removeAttr( 'data-appear-animation' );
$( '.elementor-invisible' ).removeAttr( 'data-settings' ).removeData( 'settings' ).removeClass( 'elementor-invisible' )
.add( $( '.appear-animation' ).removeClass( 'appear-animation' ) );
}
}
// expose to scope
$.extend( theme, {
disableMobileAnimations: disableMobileAnimations
} );
theme.disableMobileAnimations();
} ).apply( this, [window.theme, jQuery] );
/**
* Copyright 2016 Google Inc. All Rights Reserved.
*
* Licensed under the W3C SOFTWARE AND DOCUMENT NOTICE AND LICENSE.
*
* https://www.w3.org/Consortium/Legal/2015/copyright-software-and-document
*
*/
!function() { "use strict"; if ( "object" == typeof window ) if ( "IntersectionObserver" in window && "IntersectionObserverEntry" in window && "intersectionRatio" in window.IntersectionObserverEntry.prototype ) "isIntersecting" in window.IntersectionObserverEntry.prototype || Object.defineProperty( window.IntersectionObserverEntry.prototype, "isIntersecting", { get: function() { return this.intersectionRatio > 0 } } ); else { var t = function( t ) { for ( var e = window.document, o = i( e ); o; )o = i( e = o.ownerDocument ); return e }(), e = [], o = null, n = null; s.prototype.THROTTLE_TIMEOUT = 100, s.prototype.POLL_INTERVAL = null, s.prototype.USE_MUTATION_OBSERVER = !0, s._setupCrossOriginUpdater = function() { return o || ( o = function( t, o ) { n = t && o ? l( t, o ) : { top: 0, bottom: 0, left: 0, right: 0, width: 0, height: 0 }, e.forEach( function( t ) { t._checkForIntersections() } ) } ), o }, s._resetCrossOriginUpdater = function() { o = null, n = null }, s.prototype.observe = function( t ) { if ( !this._observationTargets.some( function( e ) { return e.element == t } ) ) { if ( !t || 1 != t.nodeType ) throw new Error( "target must be an Element" ); this._registerInstance(), this._observationTargets.push( { element: t, entry: null } ), this._monitorIntersections( t.ownerDocument ), this._checkForIntersections() } }, s.prototype.unobserve = function( t ) { this._observationTargets = this._observationTargets.filter( function( e ) { return e.element != t } ), this._unmonitorIntersections( t.ownerDocument ), 0 == this._observationTargets.length && this._unregisterInstance() }, s.prototype.disconnect = function() { this._observationTargets = [], this._unmonitorAllIntersections(), this._unregisterInstance() }, s.prototype.takeRecords = function() { var t = this._queuedEntries.slice(); return this._queuedEntries = [], t }, s.prototype._initThresholds = function( t ) { var e = t || [0]; return Array.isArray( e ) || ( e = [e] ), e.sort().filter( function( t, e, o ) { if ( "number" != typeof t || isNaN( t ) || t < 0 || t > 1 ) throw new Error( "threshold must be a number between 0 and 1 inclusively" ); return t !== o[e - 1] } ) }, s.prototype._parseRootMargin = function( t ) { var e = ( t || "0px" ).split( /\s+/ ).map( function( t ) { var e = /^(-?\d*\.?\d+)(px|%)$/.exec( t ); if ( !e ) throw new Error( "rootMargin must be specified in pixels or percent" ); return { value: parseFloat( e[1] ), unit: e[2] } } ); return e[1] = e[1] || e[0], e[2] = e[2] || e[0], e[3] = e[3] || e[1], e }, s.prototype._monitorIntersections = function( e ) { var o = e.defaultView; if ( o && -1 == this._monitoringDocuments.indexOf( e ) ) { var n = this._checkForIntersections, r = null, s = null; this.POLL_INTERVAL ? r = o.setInterval( n, this.POLL_INTERVAL ) : ( h( o, "resize", n, !0 ), h( e, "scroll", n, !0 ), this.USE_MUTATION_OBSERVER && "MutationObserver" in o && ( s = new o.MutationObserver( n ) ).observe( e, { attributes: !0, childList: !0, characterData: !0, subtree: !0 } ) ), this._monitoringDocuments.push( e ), this._monitoringUnsubscribes.push( function() { var t = e.defaultView; t && ( r && t.clearInterval( r ), c( t, "resize", n, !0 ) ), c( e, "scroll", n, !0 ), s && s.disconnect() } ); var u = this.root && ( this.root.ownerDocument || this.root ) || t; if ( e != u ) { var a = i( e ); a && this._monitorIntersections( a.ownerDocument ) } } }, s.prototype._unmonitorIntersections = function( e ) { var o = this._monitoringDocuments.indexOf( e ); if ( -1 != o ) { var n = this.root && ( this.root.ownerDocument || this.root ) || t; if ( !this._observationTargets.some( function( t ) { var o = t.element.ownerDocument; if ( o == e ) return !0; for ( ; o && o != n; ) { var r = i( o ); if ( ( o = r && r.ownerDocument ) == e ) return !0 } return !1 } ) ) { var r = this._monitoringUnsubscribes[o]; if ( this._monitoringDocuments.splice( o, 1 ), this._monitoringUnsubscribes.splice( o, 1 ), r(), e != n ) { var s = i( e ); s && this._unmonitorIntersections( s.ownerDocument ) } } } }, s.prototype._unmonitorAllIntersections = function() { var t = this._monitoringUnsubscribes.slice( 0 ); this._monitoringDocuments.length = 0, this._monitoringUnsubscribes.length = 0; for ( var e = 0; e < t.length; e++ )t[e]() }, s.prototype._checkForIntersections = function() { if ( this.root || !o || n ) { var t = this._rootIsInDom(), e = t ? this._getRootRect() : { top: 0, bottom: 0, left: 0, right: 0, width: 0, height: 0 }; this._observationTargets.forEach( function( n ) { var i = n.element, s = u( i ), h = this._rootContainsTarget( i ), c = n.entry, a = t && h && this._computeTargetAndRootIntersection( i, s, e ), l = null; this._rootContainsTarget( i ) ? o && !this.root || ( l = e ) : l = { top: 0, bottom: 0, left: 0, right: 0, width: 0, height: 0 }; var f = n.entry = new r( { time: window.performance && performance.now && performance.now(), target: i, boundingClientRect: s, rootBounds: l, intersectionRect: a } ); c ? t && h ? this._hasCrossedThreshold( c, f ) && this._queuedEntries.push( f ) : c && c.isIntersecting && this._queuedEntries.push( f ) : this._queuedEntries.push( f ) }, this ), this._queuedEntries.length && this._callback( this.takeRecords(), this ) } }, s.prototype._computeTargetAndRootIntersection = function( e, i, r ) { if ( "none" != window.getComputedStyle( e ).display ) { for ( var s, h, c, a, f, d, g, m, v = i, _ = p( e ), b = !1; !b && _; ) { var w = null, y = 1 == _.nodeType ? window.getComputedStyle( _ ) : {}; if ( "none" == y.display ) return null; if ( _ == this.root || 9 == _.nodeType ) if ( b = !0, _ == this.root || _ == t ) o && !this.root ? !n || 0 == n.width && 0 == n.height ? ( _ = null, w = null, v = null ) : w = n : w = r; else { var I = p( _ ), E = I && u( I ), T = I && this._computeTargetAndRootIntersection( I, E, r ); E && T ? ( _ = I, w = l( E, T ) ) : ( _ = null, v = null ) } else { var R = _.ownerDocument; _ != R.body && _ != R.documentElement && "visible" != y.overflow && ( w = u( _ ) ) } if ( w && ( s = w, h = v, c = void 0, a = void 0, f = void 0, d = void 0, g = void 0, m = void 0, c = Math.max( s.top, h.top ), a = Math.min( s.bottom, h.bottom ), f = Math.max( s.left, h.left ), d = Math.min( s.right, h.right ), m = a - c, v = ( g = d - f ) >= 0 && m >= 0 && { top: c, bottom: a, left: f, right: d, width: g, height: m } || null ), !v ) break; _ = _ && p( _ ) } return v } }, s.prototype._getRootRect = function() { var e; if ( this.root && !d( this.root ) ) e = u( this.root ); else { var o = d( this.root ) ? this.root : t, n = o.documentElement, i = o.body; e = { top: 0, left: 0, right: n.clientWidth || i.clientWidth, width: n.clientWidth || i.clientWidth, bottom: n.clientHeight || i.clientHeight, height: n.clientHeight || i.clientHeight } } return this._expandRectByRootMargin( e ) }, s.prototype._expandRectByRootMargin = function( t ) { var e = this._rootMarginValues.map( function( e, o ) { return "px" == e.unit ? e.value : e.value * ( o % 2 ? t.width : t.height ) / 100 } ), o = { top: t.top - e[0], right: t.right + e[1], bottom: t.bottom + e[2], left: t.left - e[3] }; return o.width = o.right - o.left, o.height = o.bottom - o.top, o }, s.prototype._hasCrossedThreshold = function( t, e ) { var o = t && t.isIntersecting ? t.intersectionRatio || 0 : -1, n = e.isIntersecting ? e.intersectionRatio || 0 : -1; if ( o !== n ) for ( var i = 0; i < this.thresholds.length; i++ ) { var r = this.thresholds[i]; if ( r == o || r == n || r < o != r < n ) return !0 } }, s.prototype._rootIsInDom = function() { return !this.root || f( t, this.root ) }, s.prototype._rootContainsTarget = function( e ) { var o = this.root && ( this.root.ownerDocument || this.root ) || t; return f( o, e ) && ( !this.root || o == e.ownerDocument ) }, s.prototype._registerInstance = function() { e.indexOf( this ) < 0 && e.push( this ) }, s.prototype._unregisterInstance = function() { var t = e.indexOf( this ); -1 != t && e.splice( t, 1 ) }, window.IntersectionObserver = s, window.IntersectionObserverEntry = r } function i( t ) { try { return t.defaultView && t.defaultView.frameElement || null } catch ( t ) { return null } } function r( t ) { this.time = t.time, this.target = t.target, this.rootBounds = a( t.rootBounds ), this.boundingClientRect = a( t.boundingClientRect ), this.intersectionRect = a( t.intersectionRect || { top: 0, bottom: 0, left: 0, right: 0, width: 0, height: 0 } ), this.isIntersecting = !!t.intersectionRect; var e = this.boundingClientRect, o = e.width * e.height, n = this.intersectionRect, i = n.width * n.height; this.intersectionRatio = o ? Number( ( i / o ).toFixed( 4 ) ) : this.isIntersecting ? 1 : 0 } function s( t, e ) { var o, n, i, r = e || {}; if ( "function" != typeof t ) throw new Error( "callback must be a function" ); if ( r.root && 1 != r.root.nodeType && 9 != r.root.nodeType ) throw new Error( "root must be a Document or Element" ); this._checkForIntersections = ( o = this._checkForIntersections.bind( this ), n = this.THROTTLE_TIMEOUT, i = null, function() { i || ( i = setTimeout( function() { o(), i = null }, n ) ) } ), this._callback = t, this._observationTargets = [], this._queuedEntries = [], this._rootMarginValues = this._parseRootMargin( r.rootMargin ), this.thresholds = this._initThresholds( r.threshold ), this.root = r.root || null, this.rootMargin = this._rootMarginValues.map( function( t ) { return t.value + t.unit } ).join( " " ), this._monitoringDocuments = [], this._monitoringUnsubscribes = [] } function h( t, e, o, n ) { "function" == typeof t.addEventListener ? t.addEventListener( e, o, n || !1 ) : "function" == typeof t.attachEvent && t.attachEvent( "on" + e, o ) } function c( t, e, o, n ) { "function" == typeof t.removeEventListener ? t.removeEventListener( e, o, n || !1 ) : "function" == typeof t.detatchEvent && t.detatchEvent( "on" + e, o ) } function u( t ) { var e; try { e = t.getBoundingClientRect() } catch ( t ) { } return e ? ( e.width && e.height || ( e = { top: e.top, right: e.right, bottom: e.bottom, left: e.left, width: e.right - e.left, height: e.bottom - e.top } ), e ) : { top: 0, bottom: 0, left: 0, right: 0, width: 0, height: 0 } } function a( t ) { return !t || "x" in t ? t : { top: t.top, y: t.top, bottom: t.bottom, left: t.left, x: t.left, right: t.right, width: t.width, height: t.height } } function l( t, e ) { var o = e.top - t.top, n = e.left - t.left; return { top: o, left: n, height: e.height, width: e.width, bottom: o + e.height, right: n + e.width } } function f( t, e ) { for ( var o = e; o; ) { if ( o == t ) return !0; o = p( o ) } return !1 } function p( e ) { var o = e.parentNode; return 9 == e.nodeType && e != t ? i( e ) : ( o && o.assignedSlot && ( o = o.assignedSlot.parentNode ), o && 11 == o.nodeType && o.host ? o.host : o ) } function d( t ) { return t && 9 === t.nodeType } }();
/* browser select */
( function( $ ) {
'use strict';
$.extend( {
browserSelector: function() {
// Touch
var hasTouch = 'ontouchstart' in window || navigator.msMaxTouchPoints;
var u = navigator.userAgent,
ua = u.toLowerCase(),
is = function( t ) {
return ua.indexOf( t ) > -1;
},
g = 'gecko',
w = 'webkit',
s = 'safari',
o = 'opera',
h = document.documentElement,
b = [( !( /opera|webtv/i.test( ua ) ) && /msie\s(\d)/.test( ua ) ) ? ( 'ie ie' + parseFloat( navigator.appVersion.split( "MSIE" )[1] ) ) : is( 'firefox/2' ) ? g + ' ff2' : is( 'firefox/3.5' ) ? g + ' ff3 ff3_5' : is( 'firefox/3' ) ? g + ' ff3' : is( 'gecko/' ) ? g : is( 'opera' ) ? o + ( /version\/(\d+)/.test( ua ) ? ' ' + o + RegExp.jQuery1 : ( /opera(\s|\/)(\d+)/.test( ua ) ? ' ' + o + RegExp.jQuery2 : '' ) ) : is( 'konqueror' ) ? 'konqueror' : is( 'chrome' ) ? w + ' chrome' : is( 'iron' ) ? w + ' iron' : is( 'applewebkit/' ) ? w + ' ' + s + ( /version\/(\d+)/.test( ua ) ? ' ' + s + RegExp.jQuery1 : '' ) : is( 'mozilla/' ) ? g : '', is( 'j2me' ) ? 'mobile' : is( 'iphone' ) ? 'iphone' : is( 'ipod' ) ? 'ipod' : is( 'mac' ) ? 'mac' : is( 'darwin' ) ? 'mac' : is( 'webtv' ) ? 'webtv' : is( 'win' ) ? 'win' : is( 'freebsd' ) ? 'freebsd' : ( is( 'x11' ) || is( 'linux' ) ) ? 'linux' : '', 'js'];
var c = b.join( ' ' );
if ( theme.is_device_mobile ) {
c += ' mobile';
}
if ( hasTouch ) {
c += ' touch';
}
h.className += ' ' + c;
// IE11 Detect
var isIE11 = !( window.ActiveXObject ) && "ActiveXObject" in window;
if ( isIE11 ) {
$( 'html' ).removeClass( 'gecko' ).addClass( 'ie ie11' );
return;
}
}
} );
$.browserSelector();
} )( jQuery );
// Accordion
( function( theme, $ ) {
'use strict';
theme = theme || {};
var instanceName = '__accordion';
var Accordion = function( $el, opts ) {
return this.initialize( $el, opts );
};
Accordion.defaults = {
};
Accordion.prototype = {
initialize: function( $el, opts ) {
if ( $el.data( instanceName ) ) {
return this;
}
this.$el = $el;
this
.setData()
.setOptions( opts )
.build();
return this;
},
setData: function() {
this.$el.data( instanceName, this );
return this;
},
setOptions: function( opts ) {
this.options = $.extend( true, {}, Accordion.defaults, opts, {
wrapper: this.$el
} );
return this;
},
build: function() {
if ( !$.fn.collapse ) {
return this;
}
var $el = this.options.wrapper,
$collapse = $el.find( '.collapse' ),
collapsible = $el.data( 'collapsible' ),
active_num = $el.data( 'active-tab' );
if ( $collapse.length > 0 ) {
if ( $el.data( 'use-accordion' ) && 'yes' == $el.data( 'use-accordion' ) ) {
$el.find( '.collapse' ).attr( 'data-parent', '#' + $el.attr( 'id' ) );
}
if ( collapsible == 'yes' ) {
$collapse.collapse( { toggle: false, parent: '#' + $el.attr( 'id' ) } );
} else if ( !isNaN( active_num ) && active_num == parseInt( active_num ) && $el.find( '.collapse' ).length > active_num ) {
$el.find( '.collapse' ).collapse( { toggle: false, parent: '#' + $el.attr( 'id' ) } );
$el.find( '.collapse' ).eq( active_num - 1 ).collapse( 'toggle' );
} else {
$el.find( '.collapse' ).collapse( { parent: '#' + $el.attr( 'id' ) } );
}
}
return this;
}
};
// expose to scope
$.extend( theme, {
Accordion: Accordion
} );
// jquery plugin
$.fn.themeAccordion = function( opts ) {
return this.map( function() {
var $this = $( this );
if ( $this.data( instanceName ) ) {
return $this.data( instanceName );
} else {
return new theme.Accordion( $this, opts );
}
} );
};
} ).apply( this, [window.theme, jQuery] );
// Accordion Menu
( function( theme, $ ) {
'use strict';
theme = theme || {};
var instanceName = '__accordionMenu';
var AccordionMenu = function( $el, opts ) {
return this.initialize( $el, opts );
};
AccordionMenu.defaults = {
};
AccordionMenu.prototype = {
initialize: function( $el, opts ) {
if ( $el.data( instanceName ) ) {
return this;
}
this.$el = $el;
this
.setData()
.setOptions( opts )
.build();
return this;
},
setData: function() {
this.$el.data( instanceName, this );
return this;
},
setOptions: function( opts ) {
this.options = $.extend( true, {}, AccordionMenu.defaults, opts, {
wrapper: this.$el
} );
return this;
},
build: function() {
var self = this,
$el = this.options.wrapper;
$el.find( 'li.menu-item.active' ).each( function() {
var $this = $( this );
if ( $this.find( '> .arrow' ).get( 0 ) )
$this.find( '> .arrow' ).trigger( 'click' );
} );
$el.on( 'click', '.arrow', function( e ) {
e.preventDefault();
e.stopPropagation();
var $this = $( this ),
$parent = $this.closest( 'li' );
if ( typeof self.options.open_one != 'undefined' ) {
$parent.siblings( '.open' ).children( '.arrow' ).next().hide();
$parent.siblings( '.open' ).removeClass( 'open' );
$this.next().stop().toggle();
} else {
$this.next().stop().slideToggle();
}
if ( $parent.hasClass( 'open' ) ) {
$parent.removeClass( 'open' );
} else {
$parent.addClass( 'open' );
}
if ( $this.closest( '.header-side-nav .sidebar-menu' ).length ) { // for side header
$( '.header-side-nav [data-plugin-sticky]' ).trigger( 'recalc.pin' );
}
return false;
} );
$el.find( '.menu-item-has-children' ).each( function () {
var $this = $(this);
if ( $this.find( '>.sub-menu > li:not(.hidden-item)' ).length == 0 ) {
$this.addClass( 'hidden-item' );
}
} );
return this;
}
};
// expose to scope
$.extend( theme, {
AccordionMenu: AccordionMenu
} );
// jquery plugin
$.fn.themeAccordionMenu = function( opts ) {
return this.map( function() {
var $this = $( this );
if ( $this.data( instanceName ) ) {
return $this.data( instanceName );
} else {
return new theme.AccordionMenu( $this, opts );
}
} );
};
} ).apply( this, [window.theme, jQuery] );
// Fit Video
( function( theme, $ ) {
'use strict';
theme = theme || {};
var instanceName = '__fitVideo';
var FitVideo = function( $el, opts ) {
return this.initialize( $el, opts );
};
FitVideo.defaults = {
};
FitVideo.prototype = {
initialize: function( $el, opts ) {
if ( $el.data( instanceName ) ) {
return this;
}
this.$el = $el;
this
.setData()
.setOptions( opts )
.build();
return this;
},
setData: function() {
this.$el.data( instanceName, this );
return this;
},
setOptions: function( opts ) {
this.options = $.extend( true, {}, FitVideo.defaults, opts, {
wrapper: this.$el
} );
return this;
},
build: function() {
if ( !$.fn.fitVids ) {
return this;
}
var $el = this.options.wrapper;
$el.fitVids();
$( window ).on( 'resize', function() {
$el.fitVids();
} );
return this;
}
};
// expose to scope
$.extend( theme, {
FitVideo: FitVideo
} );
// jquery plugin
$.fn.themeFitVideo = function( opts ) {
return this.map( function() {
var $this = $( this );
if ( $this.data( instanceName ) ) {
return $this.data( instanceName );
} else {
return new theme.FitVideo( $this, opts );
}
} );
};
} ).apply( this, [window.theme, jQuery] );
/* Porto Video Background */
( function( theme, $ ) {
'use strict';
theme = theme || {};
var instanceName = '__videobackground';
var PluginVideoBackground = function( $el, opts ) {
return this.initialize( $el, opts );
};
PluginVideoBackground.defaults = {
overlay: true,
volume: 1,
playbackRate: 1,
muted: true,
loop: true,
autoplay: true,
position: '50% 50%',
posterType: 'detect'
};
PluginVideoBackground.prototype = {
initialize: function( $el, opts ) {
this.$el = $el;
this
.setData()
.setOptions( opts )
.build();
return this;
},
setData: function() {
this.$el.data( instanceName, this );
return this;
},
setOptions: function( opts ) {
this.options = $.extend( true, {}, PluginVideoBackground.defaults, opts, {
path: this.$el.data( 'video-path' ),
wrapper: this.$el
} );
return this;
},
build: function() {
if ( !$.fn.vide || !this.options.path ) {
return this;
}
if ( this.options.overlay ) {
this.options.wrapper.prepend(
$( '
' ).addClass( 'video-overlay' )
);
}
this.options.wrapper.vide( this.options.path, this.options );
return this;
}
};
// expose to scope
$.extend( theme, {
PluginVideoBackground: PluginVideoBackground
} );
// jquery plugin
$.fn.themePluginVideoBackground = function( opts ) {
return this.map( function() {
var $this = $( this );
if ( $this.data( instanceName ) ) {
return $this.data( instanceName );
} else {
return new PluginVideoBackground( $this, opts );
}
} );
};
} ).apply( this, [window.theme, jQuery] );
// Flickr Zoom
( function( theme, $ ) {
'use strict';
theme = theme || {};
var instanceName = '__flickrZoom';
var FlickrZoom = function( $el, opts ) {
return this.initialize( $el, opts );
};
FlickrZoom.defaults = {
};
FlickrZoom.prototype = {
initialize: function( $el, opts ) {
if ( $el.data( instanceName ) ) {
return this;
}
this.$el = $el;
this
.setData()
.setOptions( opts )
.build();
return this;
},
setData: function() {
this.$el.data( instanceName, this );
return this;
},
setOptions: function( opts ) {
this.options = $.extend( true, {}, FlickrZoom.defaults, opts, {
wrapper: this.$el
} );
return this;
},
build: function() {
var $el = this.options.wrapper,
links = [],
i = 0,
$flickr_links = $el.find( '.flickr_badge_image > a' );
$flickr_links.each( function() {
var slide = {},
$image = $( this ).find( '> img' );
slide.src = $image.attr( 'src' ).replace( '_s.', '_b.' );
slide.title = $image.attr( 'title' );
links[i] = slide;
i++;
} );
$flickr_links.on( 'click', function( e ) {
e.preventDefault();
if ( $.fn.magnificPopup ) {
$.magnificPopup.close();
$.magnificPopup.open( $.extend( true, {}, theme.mfpConfig, {
items: links,
gallery: {
enabled: true
},
type: 'image'
} ), $flickr_links.index( $( this ) ) );
}
} );
return this;
}
};
// expose to scope
$.extend( theme, {
FlickrZoom: FlickrZoom
} );
// jquery plugin
$.fn.themeFlickrZoom = function( opts ) {
return this.map( function() {
var $this = $( this );
if ( $this.data( instanceName ) ) {
return $this.data( instanceName );
} else {
return new theme.FlickrZoom( $this, opts );
}
} );
}
} ).apply( this, [window.theme, jQuery] );
// Lazy Load
( function( theme, $ ) {
'use strict';
theme = theme || {};
var instanceName = '__lazyload';
var PluginLazyLoad = function( $el, opts ) {
return this.initialize( $el, opts );
};
PluginLazyLoad.defaults = {
effect: 'show',
appearEffect: '',
appear: function( elements_left, settings ) {
},
load: function( elements_left, settings ) {
$( this ).addClass( 'lazy-load-loaded' );
}
};
PluginLazyLoad.prototype = {
initialize: function( $el, opts ) {
if ( !$el.length ) {
return this;
}
if ( !$.fn.lazyload ) {
return this;
}
var options = $.extend( true, {}, PluginLazyLoad.defaults, opts, {} );
return lazyload( $el, options );
}
};
// expose to scope
$.extend( theme, {
PluginLazyLoad: PluginLazyLoad
} );
// jquery plugin
$.fn.themePluginLazyLoad = function( opts ) {
var $this = $( this );
if ( $this.data( instanceName ) ) {
return this;
} else {
var ins = new PluginLazyLoad( $.makeArray( this ), opts );
$this.data( instanceName, ins );
}
return this;
}
} ).apply( this, [window.theme, jQuery] );
// Masonry
( function( theme, $ ) {
'use strict';
theme = theme || {};
var instanceName = '__masonry';
var Masonry = function( $el, opts ) {
return this.initialize( $el, opts );
};
Masonry.defaults = {
itemSelector: 'li',
isOriginLeft: !theme.rtl
};
Masonry.prototype = {
initialize: function( $el, opts ) {
if ( $el.data( instanceName ) ) {
return this;
}
this.$el = $el;
this
.setData()
.setOptions( opts )
.build();
return this;
},
setData: function() {
this.$el.data( instanceName, this );
return this;
},
setOptions: function( opts ) {
this.options = $.extend( true, {}, Masonry.defaults, opts, {
wrapper: this.$el
} );
return this;
},
build: function() {
if ( !$.fn.isotope ) {
return this;
}
var self = this,
$el = this.options.wrapper,
trigger_timer = null;
$el.isotope( this.options );
$el.isotope( 'on', 'layoutComplete', function() {
if ( typeof this.options.callback == 'function' ) {
this.options.callback.call();
}
if ( $el.find( '.porto-lazyload:not(.lazy-load-loaded):visible' ).length ) {
$( window ).trigger( 'scroll' );
}
} );
$el.isotope( 'layout' );
self.resize();
$( window ).smartresize( function() {
self.resize()
} );
return this;
},
resize: function() {
var self = this,
$el = this.options.wrapper;
if ( self.resizeTimer ) {
theme.deleteTimeout( self.resizeTimer );
}
self.resizeTimer = theme.requestTimeout( function() {
if ( $el.data( 'isotope' ) ) {
$el.isotope( 'layout' );
}
delete self.resizeTimer;
}, 600 );
}
};
// expose to scope
$.extend( theme, {
Masonry: Masonry
} );
// jquery plugin
$.fn.themeMasonry = function( opts ) {
return this.map( function() {
var $this = $( this );
imagesLoaded( this, function() {
if ( $this.data( instanceName ) ) {
return $this.data( instanceName );
} else {
return new theme.Masonry( $this, opts );
}
} );
} );
}
} ).apply( this, [window.theme, jQuery] );
// Toggle
( function( theme, $ ) {
'use strict';
theme = theme || {};
var instanceName = '__toggle';
var Toggle = function( $el, opts ) {
return this.initialize( $el, opts );
};
Toggle.defaults = {
};
Toggle.prototype = {
initialize: function( $el, opts ) {
if ( $el.data( instanceName ) ) {
return this;
}
this.$el = $el;
this
.setData()
.setOptions( opts )
.build();
return this;
},
setData: function() {
this.$el.data( instanceName, this );
return this;
},
setOptions: function( opts ) {
this.options = $.extend( true, {}, Toggle.defaults, opts, {
wrapper: this.$el
} );
return this;
},
build: function() {
var $el = this.options.wrapper;
if ( $el.hasClass( 'active' ) )
$el.find( "> div.toggle-content" ).stop().slideDown( 350, function() {
$( this ).attr( 'style', '' ).show();
} );
$el.on( 'click', "> label", function( e ) {
var parentSection = $( this ).parent(),
parentWrapper = $( this ).closest( "div.toogle" ),
parentToggles = $( this ).closest( ".porto-toggles" ),
isAccordion = parentWrapper.hasClass( "toogle-accordion" ),
toggleContent = parentSection.find( "> div.toggle-content" );
if ( isAccordion && typeof ( e.originalEvent ) != "undefined" ) {
parentWrapper.find( "section.toggle.active > label" ).trigger( "click" );
}
// Preview Paragraph
if ( !parentSection.hasClass( "active" ) ) {
if ( parentToggles.length ) {
if ( parentToggles.data( 'view' ) == 'one-toggle' ) {
parentToggles.find( '.toggle' ).each( function() {
$( this ).removeClass( 'active' );
$( this ).find( "> div.toggle-content" ).stop().slideUp( 350, function() {
$( this ).attr( 'style', '' ).hide();
} );
} );
}
}
toggleContent.stop().slideDown( 350, function() {
$( this ).attr( 'style', '' ).show();
theme.refreshVCContent( toggleContent );
} );
parentSection.addClass( "active" );
} else {
if ( !parentToggles.length || parentToggles.data( 'view' ) != 'one-toggle' ) {
toggleContent.stop().slideUp( 350, function() {
$( this ).attr( 'style', '' ).hide();
} );
parentSection.removeClass( "active" );
}
}
} );
return this;
}
};
// expose to scope
$.extend( theme, {
Toggle: Toggle
} );
// jquery plugin
$.fn.themeToggle = function( opts ) {
return this.map( function() {
var $this = $( this );
if ( $this.data( instanceName ) ) {
return $this.data( instanceName );
} else {
return new theme.Toggle( $this, opts );
}
} );
}
} ).apply( this, [window.theme, jQuery] );
// Parallax
( function( theme, $ ) {
'use strict';
theme = theme || {};
var instanceName = '__parallax';
var Parallax = function( $el, opts ) {
return this.initialize( $el, opts );
};
Parallax.defaults = {
speed: 1.5,
horizontalPosition: '50%',
offset: 0,
scale: false,
startOffset: 7,
scaleInvert: false,
};
Parallax.prototype = {
initialize: function( $el, opts ) {
if ( $el.data( instanceName ) ) {
return this;
}
this.$el = $el;
this
.setData()
.setOptions( opts )
.build();
return this;
},
setData: function() {
this.$el.data( instanceName, this );
return this;
},
setOptions: function( opts ) {
this.options = $.extend( true, {}, Parallax.defaults, opts, {
wrapper: this.$el
} );
return this;
},
build: function() {
var self = this,
$window = $( window ),
offset,
yPos,
bgpos,
background;
// Create Parallax Element
background = $( '' );
// Set Style for Parallax Element
var bg = self.options.wrapper.data( 'image-src' ) ? 'url(' + self.options.wrapper.data( 'image-src' ) + ')' : self.options.wrapper.css( 'background-image' );
background.css( {
'background-image': bg,
'background-size': 'cover',
'background-position': '50% 0%',
'position': 'absolute',
'top': 0,
'left': 0,
'width': '100%',
'height': self.options.speed * 100 + '%'
} );
// Add Parallax Element on DOM
self.options.wrapper.prepend( background );
// Set Overlfow Hidden and Position Relative to Parallax Wrapper
self.options.wrapper.css( {
'position': 'relative',
'overflow': 'hidden'
} );
if ( self.options.wrapper.attr( 'data-parallax-type' ) ) { // horizontal
self.options.parallaxType = 'horizontal';
background.css( {
'background-position': '0% 50%',
'width': self.options.speed * 100 + '%',
'height': '100%',
} );
}
// Scroll Scale
if ( self.options.scale ) {
background.wrap( '' );
background.css( {
'transition': 'transform 500ms ease-out'
} );
this.scaleParallaxFunc = this.scaleParallax.bind( this );
this.scaleParallaxFunc();
window.addEventListener( 'scroll', this.scaleParallaxFunc );
window.addEventListener( 'resize', this.scaleParallaxFunc );
}
// Parallax Effect on Scroll & Resize
var parallaxEffectOnScrolResize = function() {
var skrollr_size = 100 * self.options.speed,
skrollr_start = -( skrollr_size - 100 );
if ( !self.options.parallaxType ) {
background.attr( "data-bottom-top", "top: " + skrollr_start + "%;" ).attr( "data-top-bottom", "top: 0%;" );
} else {
skrollr_start /= 9.8;
background.attr( "data-bottom-top", "left: " + skrollr_start + "%;" ).attr( "data-top-bottom", "left: 0%;" );
}
}
if ( !theme.is_device_mobile ) {
parallaxEffectOnScrolResize();
} else {
if ( self.options.enableOnMobile == true ) {
parallaxEffectOnScrolResize();
} else {
self.options.wrapper.addClass( 'parallax-disabled' );
}
}
return this;
},
scaleParallax: function() {
var self = this,
$window = $( window ),
scrollTop = $window.scrollTop(),
$background = self.options.wrapper.find( '.parallax-background' ),
elementOffset = self.options.wrapper.offset().top,
currentElementOffset = ( elementOffset - scrollTop ),
scrollPercent = Math.abs( +( currentElementOffset - $window.height() ) / ( self.options.startOffset ? self.options.startOffset : 7 ) );
scrollPercent = parseInt( ( scrollPercent >= 100 ) ? 100 : scrollPercent );
var currentScale = ( scrollPercent / 100 ) * 50;
if ( !self.options.scaleInvert ) {
$background.css( {
'transform': 'scale(1.' + String( currentScale ).padStart( 2, '0' ) + ', 1.' + String( currentScale ).padStart( 2, '0' ) + ')'
} );
} else {
$background.css( {
'transform': 'scale(1.' + String( 50 - currentScale ).padStart( 2, '0' ) + ', 1.' + String( 50 - currentScale ).padStart( 2, '0' ) + ')'
} );
}
},
disable: function() {
var self = this;
if ( self.options.scale ) {
window.removeEventListener( 'scroll', this.scaleParallaxFunc );
window.removeEventListener( 'resize', this.scaleParallaxFunc );
}
}
};
// expose to scope
$.extend( theme, {
Parallax: Parallax
} );
// jquery plugin
$.fn.themeParallax = function( opts ) {
if ( typeof skrollr == 'undefined' ) {
return this;
}
var obj = this.map( function() {
var $this = $( this );
if ( $this.data( instanceName ) ) {
return $this.data( instanceName );
} else {
return new theme.Parallax( $this, opts );
}
} );
if ( theme.portoSkrollr ) {
theme.portoSkrollr.refresh();
} else if ( !theme.is_device_mobile ) {
theme.portoSkrollr = skrollr.init( { forceHeight: false, smoothScrolling: false, mobileCheck: function() { return theme.is_device_mobile } } );
}
return obj;
}
} ).apply( this, [window.theme, jQuery] );
// In Viewport Style
!function( o, e ) { "object" == typeof exports && "undefined" != typeof module ? e( exports ) : "function" == typeof define && define.amd ? define( ["exports"], e ) : e( o.observeElementInViewport = {} ) }( this, function( o ) { function e( o, e, t, r ) { if ( void 0 === t && ( t = function() { } ), void 0 === r && ( r = {} ), !o ) throw new Error( "Target element to observe should be a valid DOM Node" ); var n = Object.assign( {}, { viewport: null, modTop: "0px", modRight: "0px", modBottom: "0px", modLeft: "0px", threshold: [0] }, r ), i = n.viewport, f = n.modTop, s = n.modLeft, u = n.modBottom, a = n.modRight, d = n.threshold; if ( !Array.isArray( d ) && "number" != typeof d ) throw new Error( "threshold should be a number or an array of numbers" ); var p = Array.isArray( d ) ? d.map( function( o ) { return Math.floor( o % 101 ) / 100 } ) : [Math.floor( d ? d % 101 : 0 ) / 100], c = Math.min.apply( Math, p ), m = { root: i instanceof Node ? i : null, rootMargin: f + " " + a + " " + u + " " + s, threshold: p }, h = new IntersectionObserver( function( r, n ) { var i = r.filter( function( e ) { return e.target === o } )[0], f = function() { return n.unobserve( o ) }; i && ( i.isInViewport = i.isIntersecting && i.intersectionRatio >= c, i.isInViewport ? e( i, f, o ) : t( i, f, o ) ) }, m ); return h.observe( o ), function() { return h.unobserve( o ) } } o.observeElementInViewport = e, o.isInViewport = function( o, t ) { return void 0 === t && ( t = {} ), new Promise( function( r, n ) { try { e( o, function( o, e ) { e(), r( !0 ) }, function( o, e ) { e(), r( !1 ) }, t ) } catch ( o ) { n( o ) } } ) } } );
//# sourceMappingURL=index.umd.js.map
( function( theme, $ ) {
theme = theme || {};
var instanceName = '__inviewportstyle';
var PluginInViewportStyle = function( $el, opts ) {
return this.initialize( $el, opts );
};
PluginInViewportStyle.defaults = {
viewport: window,
scroll_bg_scale: false,
scale_extra_class: '',
set_round: '',
scale_bg: '#08c',
threshold: [0],
modTop: '-200px',
modBottom: '-200px',
style: { 'transition': 'all 1s ease-in-out' },
styleIn: { 'background-color': '#08c' },
styleOut: { 'background-color': '#fff' },
};
PluginInViewportStyle.prototype = {
initialize: function( $el, opts ) {
if ( $el.data( instanceName ) ) {
return this;
}
this.$el = $el;
this
.setData()
.setOptions( opts )
.build();
return this;
},
setData: function() {
this.$el.data( instanceName, this );
return this;
},
setOptions: function( opts ) {
this.options = $.extend( true, {}, PluginInViewportStyle.defaults, opts, {} );
return this;
},
build: function() {
var self = this,
el = self.$el.get( 0 );
if ( self.options.scroll_bg_scale && 'undefined' != typeof gsap ) {
self.$scaleObject = $( '' ).addClass( self.options.scale_extra_class );
self.$el.addClass( 'view-scale-wrapper' ).append( self.$scaleObject );
self.$scaleObject.css( 'background-color', self.options.scale_bg );
self.scale = true;
self.scaleEventFunc = self.scaleEvent.bind( this );
self.scaleEventFunc();
$( window ).on( 'scroll', self.scaleEventFunc );
} else {
self.$el.css( self.options.style );
if ( typeof window.IntersectionObserver === 'function' ) {
self.viewPort = observeElementInViewport.observeElementInViewport(
el, function() {
self.$el.css( self.options.styleIn );
}, function() {
self.$el.css( self.options.styleOut );
}, {
viewport: self.options.viewport,
threshold: self.options.threshold,
modTop: self.options.modTop,
modBottom: self.options.modBottom
}
)
};
}
return this;
},
scaleEvent: function() {
var self = this,
position = self.$el[0].getBoundingClientRect();
if ( self.scale && position.top < window.innerHeight && position.bottom >= 0 ) {
gsap.set( self.$scaleObject[0], {
width: "150vmax",
height: "150vmax",
xPercent: -50,
yPercent: -50,
top: "50%",
left: "50%"
} );
let _start = "-50%";
if ( self.$el.height() < 600 ) {
_start = "-600px";
}
var scaleGsap = gsap.timeline( {
scrollTrigger: {
trigger: self.$el[0],
start: _start,
end: "0%",
scrub: 2,
invalidateOnRefresh: true,
},
defaults: {
ease: "none"
}
} );
scaleGsap.fromTo( self.$scaleObject[0], {
scale: 0
}, {
x: 0,
y: 0,
ease: "power3.in",
scale: 1
} );
self.scale = false;
}
},
disable: function() {
var self = this;
if ( self.options.scroll_bg_scale ) {
self.$el.find( '.scale-expand' ).remove();
self.$el.removeClass( 'view-scale-wrapper' )
} else {
self.$el.css( { 'background-color': '', 'transition': '' } );
self.viewPort();
}
}
};
// expose to scope
$.extend( theme, {
PluginInViewportStyle: PluginInViewportStyle
} );
// jquery plugin
$.fn.themePluginInViewportStyle = function( opts ) {
return this.map( function() {
var $this = $( this );
if ( $this.data( instanceName ) ) {
return $this.data( instanceName );
} else {
return new PluginInViewportStyle( $this, opts );
}
} );
}
} ).apply( this, [window.theme, jQuery] );
// Sticky
( function( theme, $ ) {
'use strict';
// jQuery Pin plugin
$.fn.themePin = function( options ) {
var scrollY = 0, lastScrollY = 0, elements = [], disabled = false, $window = $( window ), fixedSideTop = [], fixedSideBottom = [], prevDataTo = [];
options = options || {};
var recalculateLimits = function() {
for ( var i = 0, len = elements.length; i < len; i++ ) {
var $this = elements[i];
if ( options.minWidth && window.innerWidth < options.minWidth ) {
if ( $this.parent().hasClass( "pin-wrapper" ) ) {
if ( options.hasWrap ) {
// $this.parent().removeClass( "pin-wrapper" );
$this.parent().css( 'height', '' );
} else {
$this.unwrap();
}
}
$this.css( { width: "", left: "", top: "", position: "" } );
if ( options.activeClass ) { $this.removeClass( options.activeClass ); }
$this.removeClass( 'sticky-transition' );
$this.removeClass( 'sticky-absolute' );
disabled = true;
continue;
} else {
disabled = false;
}
var $container = options.containerSelector ? ( $this.closest( options.containerSelector ).length ? $this.closest( options.containerSelector ) : $( options.containerSelector ) ) : $( document.body ),
offset = $this.offset();
if ( options.hasWrap && $container.height() < $this.closest( '.pin-wrapper' ).outerHeight() ) { // for sticky side header
$container = $this.closest( '.pin-wrapper' );
}
var containerOffset = $container.offset();
if ( typeof containerOffset == 'undefined' ) {
continue;
}
var parentOffset = $this.parent().offset();
if ( !$this.parent().hasClass( "pin-wrapper" ) ) {
$this.wrap( "" );
if ( $this.hasClass( 'elementor-element-populated' ) ) {
var $el_cont = $this.closest( '.elementor-container' );
if ( $el_cont.length ) {
var matches = $el_cont.attr( 'class' ).match( /elementor-column-gap-([a-z]*)/g );
if ( matches && matches.length ) {
var gap = matches[0].replace( 'elementor-column-gap-', '' );
$this.addClass( 'porto-gap-' + gap );
}
}
}
}
var pad = $.extend( {
top: 0,
bottom: 0
}, options.padding || {} );
var $pin = $this.parent(),
pt = parseInt( $pin.parent().css( 'padding-top' ) ), pb = parseInt( $pin.parent().css( 'padding-bottom' ) );
if ( options.autoInit ) {
if ( $( '#header' ).hasClass( 'header-side' ) ) {
pad.top = theme.adminBarHeight();
/*if ($('.page-top.fixed-pos').length) {
pad.top += $('.page-top.fixed-pos').height();
}*/
} else {
pad.top = theme.adminBarHeight();
if ( $( '#header > .main-menu-wrap' ).length || !$( '#header' ).hasClass( 'sticky-menu-header' ) ) {
pad.top += theme.StickyHeader.sticky_height;
}
}
if ( typeof options.paddingOffsetTop != 'undefined' ) {
pad.top += parseInt( options.paddingOffsetTop, 10 );
} else {
pad.top += 18;
}
if ( typeof options.paddingOffsetBottom != 'undefined' ) {
pad.bottom = parseInt( options.paddingOffsetBottom, 10 );
} else {
pad.bottom = 0;
}
}
var bb = $this.css( 'border-bottom' ), h = $this.outerHeight();
$this.css( 'border-bottom', '1px solid transparent' );
var o_h = $this.outerHeight() - h - 1;
$this.css( 'border-bottom', bb );
$this.css( { width: $this.outerWidth() <= $pin.width() ? $this.outerWidth() : $pin.width() } );
$pin.css( "height", $this.outerHeight() + o_h );
if ( ( !options.autoFit && !options.fitToBottom ) || $this.outerHeight() <= $window.height() ) {
$this.data( "themePin", {
pad: pad,
from: ( options.containerSelector ? containerOffset.top : offset.top ) - pad.top + pt,
pb: pb,
parentTop: parentOffset.top - pt,
offset: o_h,
stickyOffset: options.stickyOffset ? options.stickyOffset : 0
} );
} else {
$this.data( "themePin", {
pad: pad,
fromFitTop: ( options.containerSelector ? containerOffset.top : offset.top ) - pad.top + pt,
from: ( options.containerSelector ? containerOffset.top : offset.top ) + $this.outerHeight() - window.innerHeight + pt,
pb: pb,
parentTop: parentOffset.top - pt,
offset: o_h,
stickyOffset: options.stickyOffset ? options.stickyOffset : 0
} );
}
}
};
var onScroll = function() {
if ( disabled ) { return; }
scrollY = $window.scrollTop();
var window_height = window.innerHeight || $window.height();
for ( var i = 0, len = elements.length; i < len; i++ ) {
var $this = $( elements[i] ),
data = $this.data( "themePin" ),
sidebarTop;
let contentWrap = $this.closest( '.porto-products-filter-body' );
let sidebarWrap = $this.closest( '.sidebar' );
if ( contentWrap.length && sidebarWrap.length ) {
if ( $.contains( contentWrap[0], sidebarWrap[0] ) && !contentWrap.hasClass( 'opened' ) ) {
continue;
}
}
if ( !data || typeof data.pad == 'undefined' ) { // Removed element
continue;
}
var $container = options.containerSelector ? ( $this.closest( options.containerSelector ).length ? $this.closest( options.containerSelector ) : $( options.containerSelector ) ) : $( document.body ),
isFitToTop = ( !options.autoFit && !options.fitToBottom ) || ( $this.outerHeight() + data.pad.top ) <= window_height;
if ( options.hasWrap && $container.height() < $this.closest( '.pin-wrapper' ).outerHeight() ) { // for sticky side header
$container = $this.closest( '.pin-wrapper' );
}
data.end = $container.offset().top + $container.height();
if ( isFitToTop ) {
data.to = $container.offset().top + $container.height() - $this.outerHeight() - data.pad.bottom - data.pb;
} else {
data.to = $container.offset().top + $container.height() - window_height - data.pb;
data.to2 = $container.height() - $this.outerHeight() - data.pad.bottom - data.pb;
}
if ( prevDataTo[i] === 0 ) {
prevDataTo[i] = data.to;
}
if ( isFitToTop ) {
var from = data.from - data.pad.bottom,
to = data.to - data.pad.top - data.offset,
$parent = $this.closest( '.sticky-nav-wrapper' ),
widgetTop;
// Sticky Navigation
if ( $parent.length ) {
widgetTop = $parent.offset().top - data.pad.top;
if ( widgetTop > from ) {
from = widgetTop;
}
}
if ( typeof data.fromFitTop != 'undefined' && data.fromFitTop ) {
from = data.fromFitTop - data.pad.bottom;
}
if ( from + $this.outerHeight() > data.end || from >= to ) {
$this.css( { position: "", top: "", left: "" } );
if ( options.activeClass ) { $this.removeClass( options.activeClass ); }
$this.removeClass( 'sticky-transition' );
$this.removeClass( 'sticky-absolute' );
continue;
}
if ( scrollY > from + data.stickyOffset && scrollY < to ) {
!( $this.css( "position" ) == "fixed" ) && $this.css( {
left: $this.offset().left,
top: data.pad.top
} ).css( "position", "fixed" );
if ( options.activeClass ) { $this.addClass( options.activeClass ); }
$this.removeClass( 'sticky-transition' );
$this.removeClass( 'sticky-absolute' );
} else if ( scrollY >= to ) {
$this.css( {
left: "",
top: to - data.parentTop + data.pad.top
} ).css( "position", "absolute" );
if ( options.activeClass ) { $this.addClass( options.activeClass ); }
if ( $this.hasClass( 'sticky-absolute' ) ) $this.addClass( 'sticky-transition' );
$this.addClass( 'sticky-absolute' );
} else {
$this.css( { position: "", top: "", left: "" } );
if ( options.activeClass ) { $this.removeClass( options.activeClass ); }
$this.removeClass( 'sticky-transition' );
$this.removeClass( 'sticky-absolute' );
}
} else if ( options.fitToBottom ) {
var from = data.from,
to = data.to;
if ( data.from + window_height > data.end || data.from >= to ) {
$this.css( { position: "", top: "", bottom: "", left: "" } );
if ( options.activeClass ) { $this.removeClass( options.activeClass ); }
$this.removeClass( 'sticky-transition' );
$this.removeClass( 'sticky-absolute' );
continue;
}
if ( scrollY > from && scrollY < to ) {
!( $this.css( "position" ) == "fixed" ) && $this.css( {
left: $this.offset().left,
bottom: data.pad.bottom,
top: ""
} ).css( "position", "fixed" );
if ( options.activeClass ) { $this.addClass( options.activeClass ); }
$this.removeClass( 'sticky-transition' );
$this.removeClass( 'sticky-absolute' );
} else if ( scrollY >= to ) {
$this.css( {
left: "",
top: data.to2,
bottom: ""
} ).css( "position", "absolute" );
if ( options.activeClass ) { $this.addClass( options.activeClass ); }
if ( $this.hasClass( 'sticky-absolute' ) ) $this.addClass( 'sticky-transition' );
$this.addClass( 'sticky-absolute' );
} else {
$this.css( { position: "", top: "", bottom: "", left: "" } );
if ( options.activeClass ) { $this.removeClass( options.activeClass ); }
$this.removeClass( 'sticky-transition' );
$this.removeClass( 'sticky-absolute' );
}
} else { // auto fit
var this_height = $this.outerHeight()
if ( prevDataTo[i] != data.to ) {
if ( fixedSideBottom[i] && this_height + $this.offset().top + data.pad.bottom < scrollY + window_height ) {
fixedSideBottom[i] = false;
}
}
if ( ( this_height + data.pad.top + data.pad.bottom ) > window_height || fixedSideTop[i] || fixedSideBottom[i] ) {
var padTop = parseInt( $this.parent().parent().css( 'padding-top' ) );
// Reset the sideSortables style when scrolling to the top.
if ( scrollY + data.pad.top - padTop <= data.parentTop ) {
$this.css( { position: "", top: "", bottom: "", left: "" } );
fixedSideTop[i] = fixedSideBottom[i] = false;
if ( options.activeClass ) { $this.removeClass( options.activeClass ); }
} else if ( scrollY >= data.to ) {
$this.css( {
left: "",
top: data.to2,
bottom: ""
} ).css( "position", "absolute" );
if ( options.activeClass ) { $this.addClass( options.activeClass ); }
} else {
// When scrolling down.
if ( scrollY >= lastScrollY ) {
if ( fixedSideTop[i] ) {
// Let it scroll.
fixedSideTop[i] = false;
sidebarTop = $this.offset().top - data.parentTop;
$this.css( {
left: "",
top: sidebarTop,
bottom: ""
} ).css( "position", "absolute" );
if ( options.activeClass ) { $this.addClass( options.activeClass ); }
} else if ( !fixedSideBottom[i] && this_height + $this.offset().top + data.pad.bottom < scrollY + window_height ) {
// Pin the bottom.
fixedSideBottom[i] = true;
!( $this.css( "position" ) == "fixed" ) && $this.css( {
left: $this.offset().left,
bottom: data.pad.bottom,
top: ""
} ).css( "position", "fixed" );
if ( options.activeClass ) { $this.addClass( options.activeClass ); }
}
// When scrolling up.
} else if ( scrollY < lastScrollY ) {
if ( fixedSideBottom[i] ) {
// Let it scroll.
fixedSideBottom[i] = false;
sidebarTop = $this.offset().top - data.parentTop;
/*if ($this.css('position') == 'absolute' && sidebarTop > data.to2) {
sidebarTop = data.to2;
}*/
$this.css( {
left: "",
top: sidebarTop,
bottom: ""
} ).css( "position", "absolute" );
if ( options.activeClass ) { $this.addClass( options.activeClass ); }
} else if ( !fixedSideTop[i] && $this.offset().top >= scrollY + data.pad.top ) {
// Pin the top.
fixedSideTop[i] = true;
!( $this.css( "position" ) == "fixed" ) && $this.css( {
left: $this.offset().left,
top: data.pad.top,
bottom: ''
} ).css( "position", "fixed" );
if ( options.activeClass ) { $this.addClass( options.activeClass ); }
} else if ( !fixedSideBottom[i] && fixedSideTop[i] && $this.css( 'position' ) == 'absolute' && $this.offset().top >= scrollY + data.pad.top ) {
fixedSideTop[i] = false;
}
}
}
} else {
// If the sidebar container is smaller than the viewport, then pin/unpin the top when scrolling.
if ( scrollY >= ( data.parentTop - data.pad.top ) ) {
$this.css( {
position: 'fixed',
top: data.pad.top
} );
} else {
$this.css( { position: "", top: "", bottom: "", left: "" } );
if ( options.activeClass ) { $this.removeClass( options.activeClass ); }
}
fixedSideTop[i] = fixedSideBottom[i] = false;
}
}
prevDataTo[i] = data.to;
}
lastScrollY = scrollY;
};
var update = function() { recalculateLimits(); onScroll(); },
r_timer = null;
this.each( function() {
var $this = $( this ),
data = $this.data( 'themePin' ) || {};
if ( data && data.update ) { return; }
elements.push( $this );
$( "img", this ).one( "load", function() {
if ( r_timer ) {
theme.deleteTimeout( r_timer );
}
r_timer = theme.requestFrame( recalculateLimits );
} );
data.update = update;
$this.data( 'themePin', data );
fixedSideTop.push( false );
fixedSideBottom.push( false );
prevDataTo.push( 0 );
} );
//$window.on( 'touchmove', onScroll );
window.addEventListener( 'touchmove', onScroll, { passive: true } );
window.addEventListener( 'scroll', onScroll, { passive: true } );
recalculateLimits();
if ( !theme.isLoaded ) {
$window.on( 'load', update );
} else {
update();
}
$( this ).on( 'recalc.pin', function() {
recalculateLimits();
onScroll();
} );
return this;
};
theme = theme || {};
var instanceName = '__sticky';
var Sticky = function( $el, opts ) {
return this.initialize( $el, opts );
};
Sticky.defaults = {
autoInit: false,
minWidth: 767,
activeClass: 'sticky-active',
padding: {
top: 0,
bottom: 0
},
offsetTop: 0,
offsetBottom: 0,
autoFit: false,
fitToBottom: false,
stickyOffset: 0
};
Sticky.prototype = {
initialize: function( $el, opts ) {
if ( $el.data( instanceName ) ) {
return this;
}
this.$el = $el;
this
.setData()
.setOptions( opts )
.build();
return this;
},
setData: function() {
this.$el.data( instanceName, this );
return this;
},
setOptions: function( opts ) {
this.options = $.extend( true, {}, Sticky.defaults, opts, {
wrapper: this.$el
} );
return this;
},
build: function() {
if ( !$.fn.themePin ) {
return this;
}
var self = this,
$el = this.options.wrapper,
stickyResizeTrigger;
if ( $el.hasClass( 'porto-sticky-nav' ) ) {
this.options.padding.top = theme.StickyHeader.sticky_height + theme.adminBarHeight();
this.options.activeClass = 'sticky-active';
this.options.containerSelector = '.main-content-wrap';
theme.sticky_nav_height = $el.outerHeight();
if ( this.options.minWidth > window.innerWidth )
theme.sticky_nav_height = 0;
var porto_progress_obj = $( '.porto-scroll-progress.fixed-top:not(.fixed-under-header)' );
if ( porto_progress_obj.length ) {
var flag = false;
if ( porto_progress_obj.is( ':hidden' ) ) {
porto_progress_obj.show();
flag = true;
}
if ( flag ) {
porto_progress_obj.hide();
}
}
var offset = theme.adminBarHeight() + theme.StickyHeader.sticky_height - 1,
$transitionOffset = ( offset > 100 ) ? offset : 100;
this.options.stickyOffset = theme.sticky_nav_height + $transitionOffset;
var init_filter_widget_sticky = function() {
var prevScrollPos = $el.data('prev-pos') ? $el.data('prev-pos') : 0,
scrollUpOffset = 0,
objHeight = $el.outerHeight() + parseInt( $el.css( 'margin-bottom' ) ),
scrollTop = $( window ).scrollTop();
if ( $( '.page-wrapper' ).hasClass( 'sticky-scroll-up' ) ) {
if ( scrollTop >= prevScrollPos ) {
$el.addClass('scroll-down');
} else {
$el.removeClass('scroll-down');
}
// Header is scroll-up Sticky Type
scrollUpOffset = - theme.StickyHeader.sticky_height;
if ( 'undefined' == typeof ( theme.StickyHeader.sticky_height ) ) {
$el.data( 'prev-pos', 0 );
} else {
// The transition of Sticky isn't working in this area
if ( $el.parent().offset().top + objHeight + $transitionOffset < scrollTop + offset + scrollUpOffset ) {
$el.addClass( 'sticky-ready' );
} else {
$el.removeClass( 'sticky-ready' );
}
$el.data( 'prev-pos', scrollTop );
}
}
}
if ( this.options.minWidth <= window.innerWidth ) {
window.removeEventListener( 'scroll', init_filter_widget_sticky );
window.addEventListener( 'scroll', init_filter_widget_sticky, { passive: true } );
init_filter_widget_sticky();
}
}
$el.themePin( this.options );
$( window ).smartresize( function() {
if ( stickyResizeTrigger ) {
clearTimeout( stickyResizeTrigger );
}
stickyResizeTrigger = setTimeout( function() {
$el.trigger( 'recalc.pin' );
}, 800 );
var $parent = $el.parent();
$el.outerWidth( $parent.width() );
if ( $el.css( 'position' ) == 'fixed' ) {
$el.css( 'left', $parent.offset().left );
}
if ( $el.hasClass( 'porto-sticky-nav' ) ) {
theme.sticky_nav_height = $el.outerHeight();
if ( self.options.minWidth > window.innerWidth )
theme.sticky_nav_height = 0;
}
} );
return this;
}
};
// expose to scope
$.extend( theme, {
Sticky: Sticky
} );
// jquery plugin
$.fn.themeSticky = function( opts ) {
return this.map( function() {
var $this = $( this );
if ( $this.data( instanceName ) ) {
$this.trigger( 'recalc.pin' );
setTimeout( function() {
$this.trigger( 'recalc.pin' );
}, 800 );
return $this.data( instanceName );
} else {
return new theme.Sticky( $this, opts );
}
} );
}
} ).apply( this, [window.theme, jQuery] );
// Mobile Panel
( function( theme, $ ) {
'use strict';
$( function() {
$( document.body ).on( 'click', '.mobile-toggle', function( e ) {
var $nav_panel = $( '#nav-panel' );
if ( $nav_panel.length > 0 ) {
if ( $( this ).closest( '.header-main' ).length && $nav_panel.closest( '.header-builder-p' ).length && !$nav_panel.parent( '.header-main' ).length ) {
$nav_panel.appendTo( $( this ).closest( '.header-main' ) );
} else if ( $( this ).closest( '.header-main' ).length && $nav_panel.closest( '.wp-block-template-part' ).length ) {
$nav_panel.insertAfter( $( this ).closest( '.header-main' ) );
}
if ( $nav_panel.is( ':visible' ) && $( '#header' ).hasClass( 'sticky-header' ) ) {
var h_h = $( '#header' ).height(), p_h = $nav_panel.outerHeight();
if ( h_h > p_h + 30 ) {
$( '#header' ).css( 'height', h_h - p_h );
}
}
$nav_panel.stop().slideToggle();
} else if ( $( '#side-nav-panel' ).length > 0 ) {
$( 'html' ).toggleClass( 'panel-opened' );
$( '.panel-overlay' ).toggleClass( 'active' );
if ( $( '#side-nav-panel' ).hasClass( 'panel-right' ) ) {
$( 'html' ).addClass( 'panel-right-opened' );
}
}
if ( $( '#nav-panel .skeleton-body, #side-nav-panel .skeleton-body' ).length ) {
theme.lazyload_menu( 1, 'mobile_menu' );
}
e.preventDefault();
} );
$( document.body ).on( 'click', '.panel-overlay', function() {
$( 'html' ).css( 'transition', 'margin .3s' ).removeClass( 'panel-opened' ).removeClass( 'panel-right-opened' );
theme.requestTimeout( function() {
$( 'html' ).css( 'transition', '' );
}, 260 );
$( this ).removeClass( 'active' );
} );
$( document.body ).on( 'click', '.side-nav-panel-close', function( e ) {
e.preventDefault();
$( '.panel-overlay' ).trigger( 'click' );
} );
$( document.body ).on( 'click', '#side-nav-panel .mobile-tab-items .nav-item', function( e ) {
e.preventDefault();
var $this = $( this ),
$id = $this.attr('pane-id'),
$parent = $this.closest('.mobile-tabs');
if ( $id ) {
$parent.find('.active').removeClass( 'active' );
$this.addClass('active');
$parent.find('.mobile-tab-content [tab-id="' + $id + '"]').addClass( 'active' );
}
} );
$( window ).on( 'resize', function() {
if ( window.innerWidth > 991 ) {
$( '#nav-panel' ).hide();
if ( $( 'html' ).hasClass( 'panel-opened' ) ) {
$( '.panel-overlay' ).trigger( 'click' );
}
}
} );
} );
} ).apply( this, [window.theme, jQuery] );
// Blog / Portfolio Like
( function( theme, $ ) {
'use strict';
$( function() {
$( document ).on( 'click', '.blog-like, .portfolio-like', function( e ) {
e.preventDefault();
var $this = $( this ),
parentObj = this.parentNode,
item_id = $this.attr( 'data-id' ),
is_blog = $this.hasClass( 'blog-like' ),
sendData = { nonce: js_porto_vars.porto_nonce };
if ( is_blog ) {
if ( $this.hasClass( 'updating' ) ) {
return false;
}
$this.addClass( 'updating' ).text( '...' );
sendData.blog_id = item_id;
sendData.action = 'porto_blog-like';
} else {
sendData.portfolio_id = item_id;
sendData.action = 'porto_portfolio-like';
}
$.post(
theme.ajax_url,
sendData,
function( data ) {
if ( data ) {
$this.remove();
parentObj.innerHTML = data;
if ( typeof bootstrap != 'undefined' ) {
var tooltipTriggerList = [].slice.call( parentObj.querySelectorAll( '[data-bs-tooltip]' ) );
tooltipTriggerList.map( function( tooltipTriggerEl ) {
return new bootstrap.Tooltip( tooltipTriggerEl )
} );
}
}
}
);
return false;
} );
} );
} ).apply( this, [window.theme, jQuery] );
// Scroll to Top
//** jQuery Scroll to Top Control script- (c) Dynamic Drive DHTML code library: http://www.dynamicdrive.com.
//** Available/ usage terms at http://www.dynamicdrive.com (March 30th, 09')
//** v1.1 (April 7th, 09'):
//** 1) Adds ability to scroll to an absolute position (from top of page) or specific element on the page instead.
//** 2) Fixes scroll animation not working in Opera.
var scrolltotop = {
//startline: Integer. Number of pixels from top of doc scrollbar is scrolled before showing control
//scrollto: Keyword (Integer, or "Scroll_to_Element_ID"). How far to scroll document up when control is clicked on (0=top).
setting: { startline: 100, scrollto: 0, scrollduration: 1000, fadeduration: [500, 100] },
controlHTML: '

', //HTML for control, which is auto wrapped in DIV w/ ID="topcontrol"
controlattrs: { offsetx: 10, offsety: 10 }, //offset of control relative to right/ bottom of window corner
anchorkeyword: '#top', //Enter href value of HTML anchors on the page that should also act as "Scroll Up" links
state: { isvisible: false, shouldvisible: false },
scrollup: function() {
if ( !this.cssfixedsupport ) //if control is positioned using JavaScript
this.$control.css( { opacity: 0 } ); //hide control immediately after clicking it
var dest = isNaN( this.setting.scrollto ) ? this.setting.scrollto : parseInt( this.setting.scrollto );
if ( typeof dest == "string" && jQuery( '#' + dest ).length == 1 ) //check element set by string exists
dest = jQuery( '#' + dest ).offset().top;
else
dest = 0;
this.$body.stop().animate( { scrollTop: dest }, this.setting.scrollduration );
},
keepfixed: function() {
var $window = jQuery( window );
var controlx = $window.scrollLeft() + $window.width() - this.$control.width() - this.controlattrs.offsetx;
var controly = $window.scrollTop() + $window.height() - this.$control.height() - this.controlattrs.offsety;
this.$control.css( { left: controlx + 'px', top: controly + 'px' } );
},
togglecontrol: function() {
var scrolltop = jQuery( window ).scrollTop();
if ( !this.cssfixedsupport )
this.keepfixed();
this.state.shouldvisible = ( scrolltop >= this.setting.startline ) ? true : false;
if ( this.state.shouldvisible && !this.state.isvisible ) {
this.$control.stop().animate( { opacity: 1 }, this.setting.fadeduration[0] );
this.state.isvisible = true;
}
else if ( this.state.shouldvisible == false && this.state.isvisible ) {
this.$control.stop().animate( { opacity: 0 }, this.setting.fadeduration[1] );
this.state.isvisible = false;
}
},
init: function() {
jQuery( document ).ready( function( $ ) {
var mainobj = scrolltotop;
var iebrws = document.all;
mainobj.cssfixedsupport = !iebrws || iebrws && document.compatMode == "CSS1Compat" && window.XMLHttpRequest //not IE or IE7+ browsers in standards mode
mainobj.$body = ( window.opera ) ? ( document.compatMode == "CSS1Compat" ? $( 'html' ) : $( 'body' ) ) : $( 'html,body' );
mainobj.$control = $( '
' + mainobj.controlHTML + '
' )
.css( { position: mainobj.cssfixedsupport ? 'fixed' : 'absolute', bottom: mainobj.controlattrs.offsety, opacity: 0, cursor: 'pointer' } )
.attr( { title: '' } )
.on( 'click', function() { mainobj.scrollup(); return false; } )
.appendTo( 'body' );
if ( document.all && !window.XMLHttpRequest && mainobj.$control.text() != '' ) //loose check for IE6 and below, plus whether control contains any text
mainobj.$control.css( { width: mainobj.$control.width() } ); //IE6- seems to require an explicit width on a DIV containing text
mainobj.togglecontrol();
$( 'a[href="' + mainobj.anchorkeyword + '"]' ).on( 'click', function() {
mainobj.scrollup();
return false;
} );
$( window ).on( 'scroll resize', function( e ) {
mainobj.togglecontrol();
} );
} );
}
};
//scrolltotop.init()
( function( theme, $ ) {
'use strict';
theme = theme || {};
$.extend( theme, {
ScrollToTop: {
defaults: {
html: '
',
offsetx: 10,
offsety: 0
},
initialize: function( html, offsetx, offsety ) {
if ( $( '#topcontrol' ).length ) {
return this;
}
this.html = ( html || this.defaults.html );
this.offsetx = ( offsetx || this.defaults.offsetx );
this.offsety = ( offsety || this.defaults.offsety );
this.build();
return this;
},
build: function() {
var self = this;
if ( typeof scrolltotop !== 'undefined' ) {
// scroll top control
scrolltotop.controlHTML = self.html;
scrolltotop.controlattrs = { offsetx: self.offsetx, offsety: self.offsety };
scrolltotop.init();
}
return self;
}
}
} );
} ).apply( this, [window.theme, jQuery] );
// Mega Menu
( function( theme, $ ) {
'use strict';
theme = theme || {};
$.extend( theme, {
MegaMenu: {
defaults: {
menu: $( '.mega-menu' )
},
initialize: function( $menu ) {
this.$menu = ( $menu || this.defaults.menu );
this.events(); // Include the build function
return this;
},
popupWidth: function() {
var winWidth = window.innerWidth,
popupWidth = theme.bodyWidth - theme.grid_gutter_width * 2;
if ( !$( 'body' ).hasClass( 'wide' ) ) {
if ( winWidth >= 1140 + theme.grid_gutter_width && winWidth <= theme.container_width + 2 * theme.grid_gutter_width - 1 && theme.container_width >= 1360 )
popupWidth = 1140 - theme.grid_gutter_width;
else if ( winWidth >= theme.container_width + theme.grid_gutter_width - 1 )
popupWidth = theme.container_width - theme.grid_gutter_width;
else if ( winWidth >= 992 )
popupWidth = 960 - theme.grid_gutter_width;
else if ( winWidth >= 768 )
popupWidth = 720 - theme.grid_gutter_width;
}
return popupWidth;
},
calcMenuPosition: function( menu_obj, is_left ) {
var menu = menu_obj,
$menuWrap;
if ( $( menu ).closest( '.elementor-top-section' ).length ) {
// Elementor Section
$menuWrap = $( menu ).closest( '.elementor-top-section' );
} else if ( $( menu ).closest( '.e-con.e-parent' ).length ) {
// Elementor Container
$menuWrap = $( menu ).closest( '.e-con.e-parent' );
} else if ( $( menu ).closest( '.e-con' ).length ) {
// Elementor Container
$menuWrap = $( menu ).closest( '.e-con' );
} else if ( $( menu ).closest( '.header-main' ).length ) {
// Header Type
$menuWrap = $( menu ).closest( '.header-main' );
} else if ( $( menu ).closest( '.main-menu-wrap' ).length ) {
// Customize header builder & header type
$menuWrap = $( menu ).closest( '.main-menu-wrap' );
} else if ( $( menu ).closest( '.header-top' ).length ) {
// Customize header builder
$menuWrap = $( menu ).closest( '.header-top' );
} else if ( $( menu ).closest( '.header-bottom' ).length ) {
// Customize header builder
$menuWrap = $( menu ).closest( '.header-bottom' );
} else {
// Built with WPBakery
$menuWrap = $( menu ).closest( '.top-row' );
}
var $headerContainer = $menuWrap;
if ( $menuWrap.children( '.elementor-container' ).length ) {
$headerContainer = $menuWrap.children( '.elementor-container' );
} else if ( $menuWrap.find( '.container-fluid' ).length ) {
$headerContainer = $menuWrap.find( '.container-fluid' );
} else if ( $menuWrap.find( '.container' ).length ) {
$headerContainer = $menuWrap.find( '.container' );
} else if ( $menuWrap.find( '.e-con-inner' ).length ) {
$headerContainer = $menuWrap.find( '.e-con-inner' );
} else if ( $menuWrap.find( '.vc_column_container' ).length ) {
$headerContainer = $menuWrap.find( '.vc_column_container' );
}
if ( $headerContainer.length >= 1 ) {
var isParent = false;
$headerContainer.each( function () {
var $this = $(this);
if ( $this.find( menu ).length && ! isParent ) {
$headerContainer = $this;
isParent = true;
}
} );
if ( ! isParent ) {
$headerContainer = $menuWrap;
}
}
if ( ! $headerContainer.length ) {
return;
}
var menuContainerWidth = $headerContainer.outerWidth() - parseInt( $headerContainer.css( 'padding-left' ) ) - parseInt( $headerContainer.css( 'padding-right' ) );
if ( menuContainerWidth < 900 ) return;
if ( menu.parent().hasClass( 'pos-fullwidth' ) ) {
menu.get( 0 ).style.width = menuContainerWidth + 'px';
}
var browserWidth = document.body.offsetWidth,
menuLeftPos = menu.offset().left - ( ( browserWidth - menuContainerWidth ) / 2 ),
l = false;
if ( 'center' == is_left ) {
var remainWidth = menuContainerWidth - ( menuLeftPos + menu.width() );
if ( remainWidth <= 0 ) {
l = remainWidth;
} else if ( menuLeftPos <= 0 ) {
l = -menuLeftPos;
}
} else if ( 'justify' == is_left ) {
if ( window.theme.rtl ) {
menuLeftPos = browserWidth - ( menu.offset().left + menu.outerWidth() ) - ( browserWidth - menuContainerWidth ) / 2;
}
var menuWidth = menu.width(),
remainWidth = menuContainerWidth - ( menuLeftPos + menuWidth );
if ( menuLeftPos > remainWidth && menuLeftPos < menuWidth ) {
l = ( menuLeftPos + remainWidth ) / 3;
}
if ( remainWidth <= 0 ) {
l = -remainWidth;
}
} else if ( false !== is_left ) {
var remainWidth = menuContainerWidth - ( menuLeftPos + menu.width() );
if ( remainWidth <= 0 ) {
l = -remainWidth;
}
} else if ( menuLeftPos <= 0 ) {
l = -menuLeftPos;
}
return l;
},
build: function( $menu ) {
var self = this;
if ( !$menu ) {
$menu = self.$menu;
}
$menu.each( function() {
var $menu = $( this ),
$menu_container = $menu.closest( '.container' ),
container_width = self.popupWidth();
if ( $menu.closest( '.porto-popup-menu' ).length ) {
return false;
}
var $menu_items = $menu.children( 'li.has-sub' );
$menu_items.each( function() {
var $menu_item = $( this ),
$popup = $menu_item.children( '.popup' );
if ( $popup.length ) {
var popup_obj = $popup.get( 0 );
popup_obj.style.display = 'block';
if ( $menu_item.hasClass( 'wide' ) ) {
popup_obj.style.left = 0;
var padding = parseInt( $popup.css( 'padding-left' ) ) + parseInt( $popup.css( 'padding-right' ) ) +
parseInt( $popup.find( '> .inner' ).css( 'padding-left' ) ) + parseInt( $popup.find( '> .inner' ).css( 'padding-right' ) );
var row_number = 4;
if ( $menu_item.hasClass( 'col-1' ) ) row_number = 1;
if ( $menu_item.hasClass( 'col-2' ) ) row_number = 2;
if ( $menu_item.hasClass( 'col-3' ) ) row_number = 3;
if ( $menu_item.hasClass( 'col-4' ) ) row_number = 4;
if ( $menu_item.hasClass( 'col-5' ) ) row_number = 5;
if ( $menu_item.hasClass( 'col-6' ) ) row_number = 6;
if ( window.innerWidth < 992 )
row_number = 1;
var col_length = 0;
$popup.find( '> .inner > ul > li' ).each( function() {
var cols = parseFloat( $( this ).attr( 'data-cols' ) );
if ( cols <= 0 || !cols )
cols = 1;
if ( cols > row_number )
cols = row_number;
col_length += cols;
} );
if ( col_length > row_number ) col_length = row_number;
var popup_max_width = $popup.data( 'popup-mw' ) ? $popup.data( 'popup-mw' ) : $popup.find( '.inner' ).css( 'max-width' ),
col_width = container_width / row_number;
if ( 'none' !== popup_max_width && parseInt( popup_max_width ) < container_width ) {
col_width = parseInt( popup_max_width ) / row_number;
}
$popup.find( '> .inner > ul > li' ).each( function() {
var cols = parseFloat( $( this ).data( 'cols' ) );
if ( cols <= 0 )
cols = 1;
if ( cols > row_number )
cols = row_number;
if ( $menu_item.hasClass( 'pos-center' ) || $menu_item.hasClass( 'pos-left' ) || $menu_item.hasClass( 'pos-right' ) )
this.style.width = ( 100 / col_length * cols ) + '%';
else
this.style.width = ( 100 / row_number * cols ) + '%';
} );
if ( $menu_item.hasClass( 'pos-center' ) ) { // position center
var width = col_width * col_length - padding;
$popup.find( '> .inner > ul' ).get( 0 ).style.width = width + 'px';
var left_position = ( $menu_item.outerWidth() - width ) / 2;
popup_obj.style.left = left_position + 'px';
popup_obj.style.right = 'auto';
self.SetMenuPosition( popup_obj, $popup, 'center', left_position );
} else if ( $menu_item.hasClass( 'pos-left' ) ) { // position left
$popup.find( '> .inner > ul' ).get( 0 ).style.width = ( col_width * col_length - padding ) + 'px';
popup_obj.style.left = '0';
popup_obj.style.right = 'auto';
self.SetMenuPosition( popup_obj, $popup );
} else if ( $menu_item.hasClass( 'pos-right' ) ) { // position right
$popup.find( '> .inner > ul' ).get( 0 ).style.width = ( col_width * col_length - padding ) + 'px';
popup_obj.style.right = '0';
popup_obj.style.left = 'auto';
self.SetMenuPosition( popup_obj, $popup, false );
} else if ( $menu_item.hasClass( 'pos-fullwidth' ) ) {
popup_obj.style.right = 'auto';
popup_obj.style.left = '0';
self.SetMenuPosition( popup_obj, $popup );
} else {
$popup.find( '> .inner > ul' ).get( 0 ).style.width = ( container_width - padding ) + 'px';
if ( theme.rtl ) {
popup_obj.style.right = '0';
popup_obj.style.left = 'auto';
} else {
popup_obj.style.left = '0';
popup_obj.style.right = 'auto';
}
self.SetMenuPosition( popup_obj, $popup, 'justify' );
}
} else { // auto position
if ( $menu_item.hasClass( 'pos-left' ) ) { // position left
if ( $popup.offset().left + $popup.width() > window.innerWidth ) {
$menu_item.removeClass( 'pos-left' ).addClass( 'pos-right' );
}
} else if ( $menu_item.hasClass( 'pos-right' ) ) { // position right
if ( $popup.offset().left < 0 ) {
$menu_item.removeClass( 'pos-right' ).addClass( 'pos-left' );
}
} else { // position justify
if ( $popup.offset().left + $popup.width() > window.innerWidth ) {
$menu_item.addClass( 'pos-right' );
} else if ( $popup.find( '> .inner > ul' ).length ) {
var $sub_menu = $popup.find( '> .inner > ul' ).eq( 0 );
if ( $sub_menu.offset().left + $sub_menu.width() + 200 > window.innerWidth ) {
$sub_menu.addClass( 'pos-left' );
}
}
}
}
$menu_item.addClass( 'sub-ready' );
}
} );
} );
return self;
},
SetMenuPosition: function ( popup_obj, $popup, is_left = true, offsetWidth = 0 ) {
setTimeout( () => {
var self = this,
left_position = self.calcMenuPosition( $popup, is_left );
if ( 0 !== left_position ) {
if ( 'center' == is_left ) {
// Center
if ( false !== left_position ) {
popup_obj.style.left = ( offsetWidth + left_position ) + 'px';
popup_obj.style.right = 'auto';
}
} else if ( 'justify' == is_left ) {
if ( theme.rtl ) {
popup_obj.style.left = 'auto';
if ( left_position ) {
popup_obj.style.right = '-' + left_position + 'px';
} else {
if ( ! $( 'body' ).hasClass( 'wide' ) ) {
popup_obj.style.right = '-15px';
} else {
popup_obj.style.right = '0';
}
}
} else {
popup_obj.style.right = 'auto';
if ( left_position ) {
popup_obj.style.left = '-' + left_position + 'px';
} else {
if ( ! $( 'body' ).hasClass( 'wide' ) ) {
popup_obj.style.left = '-15px';
} else {
popup_obj.style.left = '0';
}
}
}
} else {
if ( is_left ) {
popup_obj.style.right = 'auto';
if ( false !== left_position ) {
popup_obj.style.left = '-' + left_position + 'px';
} else {
if ( ! $( 'body' ).hasClass( 'wide' ) ) {
popup_obj.style.left = '-15px';
} else {
popup_obj.style.left = '0';
}
}
} else {
popup_obj.style.left = 'auto';
if ( false !== left_position ) {
popup_obj.style.right = '-' + left_position + 'px';
} else {
if ( ! $( 'body' ).hasClass( 'wide' ) ) {
popup_obj.style.right = '-15px';
} else {
popup_obj.style.right = '0';
}
}
}
}
}
} );
},
events: function() {
var self = this;
$( window ).smartresize( function( e ) {
if ( e.originalEvent ) {
self.build();
}
} );
if ( theme.isLoaded ) {
theme.requestFrame( function() {
self.build();
} );
} else {
$( window ).on( 'load', function() {
theme.requestFrame( function() {
self.build();
} );
} );
}
return self;
}
}
} );
} ).apply( this, [window.theme, jQuery] );
// Sidebar Menu
( function( theme, $ ) {
'use strict';
theme = theme || {};
$.extend( theme, {
SidebarMenu: {
defaults: {
menu: $( '.sidebar-menu:not(.side-menu-accordion)' ),
toggle: $( '.widget_sidebar_menu .widget-title .toggle' ),
menu_toggle: $( '#main-toggle-menu .menu-title' )
},
rtl: theme.rtl,
initialize: function( $menu, $toggle, $menu_toggle ) {
if ( this.$menu && this.$menu.length && $menu && $menu.length ) {
this.$menu = $.uniqueSort( $.merge( this.$menu, $menu ) );
this.build();
return this;
}
this.$menu = ( $menu || this.defaults.menu );
if ( !this.$menu.length ) {
return this;
}
this.$toggle = ( $toggle || this.defaults.toggle );
this.$menu_toggle = ( $menu_toggle || this.defaults.menu_toggle );
this.events();
return this;
},
isRightSidebar: function( $menu ) {
var flag = false;
if ( this.rtl ) {
flag = !( $( '#main' ).hasClass( 'column2-right-sidebar' ) || $( '#main' ).hasClass( 'column2-wide-right-sidebar' ) );
} else {
flag = $( '#main' ).hasClass( 'column2-right-sidebar' ) || $( '#main' ).hasClass( 'column2-wide-right-sidebar' );
}
if ( $menu.closest( '#main-toggle-menu' ).length ) {
if ( this.rtl ) {
flag = true;
} else {
flag = false;
}
}
var $header_wrapper = $menu.closest( '.header-wrapper' );
if ( $header_wrapper.length && $header_wrapper.hasClass( 'header-side-nav' ) ) {
if ( this.rtl ) {
flag = true;
} else {
flag = false;
}
if ( $( '.page-wrapper' ).hasClass( 'side-nav-right' ) ) {
if ( this.rtl ) {
flag = false;
} else {
flag = true;
}
}
}
return flag;
},
popupWidth: function() {
var winWidth = window.innerWidth,
popupWidth = theme.bodyWidth - theme.grid_gutter_width * 2;
if ( !$( 'body' ).hasClass( 'wide' ) ) {
if ( winWidth >= 1140 + theme.grid_gutter_width && winWidth <= theme.container_width + 2 * theme.grid_gutter_width - 1 && theme.container_width >= 1360 )
popupWidth = 1140 - theme.grid_gutter_width;
else if ( winWidth >= theme.container_width + theme.grid_gutter_width - 1 )
popupWidth = theme.container_width - theme.grid_gutter_width;
else if ( winWidth >= 992 )
popupWidth = 960 - theme.grid_gutter_width;
else if ( winWidth >= 768 )
popupWidth = 720 - theme.grid_gutter_width;
}
return popupWidth;
},
build: function( $menus ) {
var self = this;
if ( !$menus ) {
$menus = self.$menu;
}
if ( !$menus.length ) {
return;
}
$menus.find( '.menu-item-has-children' ).each( function () {
var $this = $(this);
if ( $this.find( '>.popup' ).length > 0 && $this.find( '>.popup>.inner>.sub-menu > li:not(.hidden-item)' ).length == 0 ) {
$this.addClass( 'hidden-item' );
}
} );
var $parent_toggle_wrap = $menus.parent( '.toggle-menu-wrap' ),
parent_toogle_wrap = null;
if ( $parent_toggle_wrap.length && $parent_toggle_wrap.is( ':hidden' ) ) {
parent_toogle_wrap = $parent_toggle_wrap.get( 0 );
parent_toogle_wrap.style.display = 'block';
parent_toogle_wrap.style.visibility = 'hidden';
}
$menus.each( function() {
var menuobj = this, $menu = $( this ), container_width;
if ( menuobj.classList.contains( 'side-menu-slide' ) ) {
return;
}
if ( window.innerWidth < 992 )
container_width = self.popupWidth();
else {
var menu_width = this.offsetWidth ? this.offsetWidth : $menu.width();
container_width = self.popupWidth() - menu_width - 45;
}
var is_right_sidebar = self.isRightSidebar( $menu ),
$menu_items = $menu.children( 'li' );
$menu_items.each( function() {
var $menu_item = $( this ),
$popup = $menu_item.children( '.popup' );
if ( $popup.length ) {
var popup_obj = $popup.get( 0 ),
is_opened = false;
if ( $popup.is( ':visible' ) ) {
is_opened = true;
} else {
popup_obj.style.display = 'block';
}
if ( $menu_item.hasClass( 'wide' ) ) {
if ( !$menu.hasClass( 'side-menu-columns' ) ) {
popup_obj.style.left = 0;
}
var row_number = 4;
if ( $menu_item.hasClass( 'col-1' ) ) row_number = 1;
if ( $menu_item.hasClass( 'col-2' ) ) row_number = 2;
if ( $menu_item.hasClass( 'col-3' ) ) row_number = 3;
if ( $menu_item.hasClass( 'col-4' ) ) row_number = 4;
if ( $menu_item.hasClass( 'col-5' ) ) row_number = 5;
if ( $menu_item.hasClass( 'col-6' ) ) row_number = 6;
if ( window.innerWidth < 992 )
row_number = 1;
var col_length = 0;
$popup.find( '> .inner > ul > li' ).each( function() {
var cols = parseFloat( $( this ).data( 'cols' ) );
if ( !cols || cols <= 0 )
cols = 1;
if ( cols > row_number )
cols = row_number;
col_length += cols;
} );
if ( col_length > row_number ) col_length = row_number;
var popup_max_width = $popup.data( 'popup-mw' ) ? $popup.data( 'popup-mw' ) : $popup.find( '.inner' ).css( 'max-width' ),
col_width = container_width / row_number;
if ( 'none' !== popup_max_width && parseInt( popup_max_width ) < container_width ) {
col_width = parseInt( popup_max_width ) / row_number;
}
$popup.find( '> .inner > ul > li' ).each( function() {
var cols = parseFloat( $( this ).data( 'cols' ) );
if ( cols <= 0 )
cols = 1;
if ( cols > row_number )
cols = row_number;
if ( $menu_item.hasClass( 'pos-center' ) || $menu_item.hasClass( 'pos-left' ) || $menu_item.hasClass( 'pos-right' ) )
this.style.width = ( 100 / col_length * cols ) + '%';
else
this.style.width = ( 100 / row_number * cols ) + '%';
} );
popup_obj.children[0].children[0].style.width = col_width * col_length + 1 + 'px';
if ( !$menu.hasClass( 'side-menu-columns' ) ) {
if ( is_right_sidebar ) {
popup_obj.style.left = 'auto';
popup_obj.style.right = ( this.offsetWidth ? this.offsetWidth : $( this ).width() ) + 'px';
} else {
popup_obj.style.left = ( this.offsetWidth ? this.offsetWidth : $( this ).width() ) + 'px';
popup_obj.style.right = 'auto';
}
}
}
if ( !is_opened ) {
popup_obj.style.display = 'none';
}
if ( menuobj.classList.contains( 'side-menu-accordion' ) ) {
} else if ( menuobj.classList.contains( 'side-menu-slide' ) ) {
} else if ( !$menu_item.hasClass( 'sub-ready' ) ) {
if ( !( 'ontouchstart' in document ) && window.innerWidth > 991 ) {
$menu_item.on( 'mouseenter', function() {
$menu_items.find( '.popup' ).hide();
$popup.show();
$popup.parent().addClass( 'open' );
//$( document.body ).trigger( 'appear_refresh' );
if ( !$menu.hasClass( 'side-menu-columns' ) && 'static' !== $popup.parent().css('position') ) {
let _thisTop = this.getBoundingClientRect().top;
if ( this.offsetParent && ( _thisTop + popup_obj.offsetHeight > theme.innerHeight ) ) {
// let _top = ( popup_obj.offsetHeight - this.offsetHeight ) / 2;
let _top = _thisTop + popup_obj.offsetHeight - theme.innerHeight;
let _top1 = _thisTop - this.parentNode.getBoundingClientRect().top;
if ( _top1 < _top ) {
_top = _top1;
}
popup_obj.style.top = -1 * ( _top ) + 'px';
popup_obj.style.setProperty( '--porto-sd-menu-popup-top', -1 * ( _top ) + 'px' );
} else {
popup_obj.style.top = '';
popup_obj.style.setProperty( '--porto-sd-menu-popup-top', '' );
}
}
if ( $popup.find( '.owl-carousel' ).length ) {
$popup.find( '.owl-carousel' ).each( function() {
var $this = $( this ),
opts;
if ( ! $this.hasClass( 'owl-loaded' ) ) {
var pluginOptions = $this.data( 'plugin-options' );
if ( pluginOptions )
opts = pluginOptions;
$this.themeCarousel( opts );
}
} );
}
} ).on( 'mouseleave', function() {
$popup.hide();
$popup.parent().removeClass( 'open' );
} );
} else {
$menu_item.on( 'click', '.arrow', function() {
if ( ! $menu.hasClass( 'side-menu-columns' ) && ! $popup.parent().hasClass( 'open' ) && window.innerWidth > 991 ) {
$menus.children( 'li.has-sub' ).removeClass( 'open' ).children( '.popup' ).hide();
}
$popup.slideToggle();
$popup.parent().toggleClass( 'open' );
//$( document.body ).trigger( 'appear_refresh' );
} );
}
$menu_item.addClass( 'sub-ready' );
}
}
} );
} );
// slide menu
if ( $menus.hasClass( 'side-menu-slide' ) ) {
var slideNavigation = {
$mainNav: $menus,
$mainNavItem: $menus.find( 'li' ),
build: function() {
var self = this;
self.menuNav();
},
initSub: function( $obj ) {
var currentMenu = $obj.closest( 'ul' ),
nextMenu = $obj.parent().find( 'ul' ).first();
if ( nextMenu.children( '.menu-item' ).children( '.go-back' ).length < 1 ) {
nextMenu.prepend( '' );
}
currentMenu.addClass( 'next-menu' );
nextMenu.addClass( 'visible' );
currentMenu.css( {
overflow: 'visible',
'overflow-y': 'visible'
} );
//for (i = 0; i < nextMenu.find('> li').length; i++) {
if ( nextMenu.outerHeight() < ( nextMenu.closest( '.header-main' ).outerHeight() - 100 ) ) {
nextMenu.css( {
height: nextMenu.outerHeight() + nextMenu.find( '> li' ).outerHeight()
} );
}
// }
var nextMenuHeightDiff = nextMenu.find( '> li' ).length * nextMenu.find( '> li' ).outerHeight() - nextMenu.outerHeight();
if ( nextMenuHeightDiff > 0 ) {
nextMenu.css( {
overflow: 'hidden',
'overflow-y': 'scroll'
} );
}
nextMenu.css( {
'padding-top': nextMenuHeightDiff + 'px'
} );
},
menuNav: function() {
var self = this;
self.$mainNav.find( '.menu-item-has-children > a.nolink' ).removeClass( 'nolink' ).attr( 'href', '' );
self.$mainNav.find( '.menu-item-has-children > a:not(.go-back)' ).off( 'click' ).on( 'click', function( e ) {
e.stopImmediatePropagation();
e.preventDefault();
var $this = $( this );
if ( js_porto_vars.lazyload_menu && !self.$mainNav.hasClass( 'sub-ready' ) ) {
self.initSub( $this );
self.$mainNav.on( 'sub-loaded', function() {
self.initSub( $this );
} );
} else {
self.initSub( $this );
}
} );
}
};
slideNavigation.build();
}
if ( parent_toogle_wrap ) {
parent_toogle_wrap.style.display = '';
parent_toogle_wrap.style.visibility = '';
}
return self;
},
events: function() {
var self = this;
self.$toggle.on( 'click', function() {
var $widget = $( this ).parent().parent();
var $this = $( this );
if ( $this.hasClass( 'closed' ) ) {
$this.removeClass( 'closed' );
$widget.removeClass( 'closed' );
$widget.find( '.sidebar-menu-wrap' ).stop().slideDown( 400, function() {
$( this ).attr( 'style', '' ).show();
self.build();
} );
} else {
$this.addClass( 'closed' );
$widget.addClass( 'closed' );
$widget.find( '.sidebar-menu-wrap' ).stop().slideUp( 400, function() {
$( this ).attr( 'style', '' ).hide();
} );
}
} );
this.$menu_toggle.on( 'click', function() {
var $toggle_menu = $( this ).parent();
if ( $toggle_menu.hasClass( 'show-always' ) || $toggle_menu.hasClass( 'show-hover' ) ) {
return;
}
var $this = $( this );
if ( $this.hasClass( 'closed' ) ) {
$this.removeClass( 'closed' );
$toggle_menu.removeClass( 'closed' );
$toggle_menu.find( '.toggle-menu-wrap' ).stop().slideDown( 400, function() {
$( this ).attr( 'style', '' ).show();
} );
self.build();
} else {
$this.addClass( 'closed' );
$toggle_menu.addClass( 'closed' );
$toggle_menu.find( '.toggle-menu-wrap' ).stop().slideUp( 400, function() {
$( this ).attr( 'style', '' ).hide();
} );
}
} );
if ( self.$menu.hasClass( 'side-menu-slide' ) ) {
self.$menu.on( 'click', '.go-back', function( e ) {
e.preventDefault();
var prevMenu = $( this ).closest( '.next-menu' ),
prevMenuHeightDiff = 0;
if ( prevMenu.length && prevMenu.find( '> li' ).length ) {
prevMenuHeightDiff = prevMenu.find( '> li' ).length * prevMenu.find( '> li' ).outerHeight() - prevMenu.outerHeight();
}
prevMenu.removeClass( 'next-menu' );
$( this ).closest( 'ul' ).removeClass( 'visible' );
if ( prevMenuHeightDiff > 0 ) {
prevMenu.css( {
overflow: 'hidden',
'overflow-y': 'scroll'
} );
}
} );
}
if ( $( '.sidebar-menu:not(.side-menu-accordion)' ).closest( '[data-plugin-sticky]' ).length ) {
var sidebarRefreshTimer;
$( window ).smartresize( function() {
if ( sidebarRefreshTimer ) {
clearTimeout( sidebarRefreshTimer );
}
sidebarRefreshTimer = setTimeout( function() {
self.build();
}, 800 );
} );
} else {
$( window ).smartresize( function( e ) {
if ( e.originalEvent ) {
self.build();
}
} );
}
setTimeout( function() {
self.build();
}, 400 );
if ( 'ontouchstart' in document ) {
$( document.body ).on( 'click', function(e) {
if ( window.innerWidth > 991 ) {
if ( ! $( e.target ).closest( 'li.has-sub.open' ).length ) {
self.$menu.each( function() {
var $this = $(this);
if ( $this.hasClass( 'side-menu-accordion' ) || $this.hasClass( 'side-menu-slide' ) || $this.hasClass( 'side-menu-columns' ) ) {
return;
}
$this.children( 'li.has-sub' ).removeClass( 'open' ).children( '.popup' ).hide();
} );
}
}
} );
}
return self;
}
}
} );
} ).apply( this, [window.theme, jQuery] );
// Sticky Header
( function( theme, $ ) {
'use strict';
theme = theme || {};
$.extend( theme, {
StickyHeader: {
defaults: {
header: $( '#header' )
},
initialize: function( $header ) {
this.$header = ( $header || this.defaults.header );
this.sticky_height = 0;
this.sticky_pos = 0;
this.change_logo = theme.change_logo;
if ( !theme.show_sticky_header || !this.$header.length || $( '.side-header-narrow-bar' ).length )
return this;
var self = this;
var $menu_wrap = self.$header.find( '> .main-menu-wrap' );
if ( $menu_wrap.length ) {
self.$menu_wrap = $menu_wrap;
self.menu_height = $menu_wrap.height();
} else {
self.$menu_wrap = false;
}
self.$header_main = self.$header.find( '.header-main' );
if ( self.$header_main.length > 1 ) {
self.$header_main = $( self.$header_main[0] );
}
// fix compatibility issue with Elementor pro header builder
if ( !self.$header_main.length && self.$header.children( '.elementor-location-header' ).length ) {
self.$header_main = self.$header.children( '.elementor-location-header' ).last().addClass( 'header-main' );
}
if ( !self.$header_main.length ) {
return this;
}
self.reveal = self.$header.parents( '.header-wrapper' ).hasClass( 'header-reveal' );
self.is_sticky = false;
self.reset()
.build()
.events();
return self;
},
build: function() {
var self = this;
if ( !self.is_sticky && ( window.innerHeight + self.header_height + theme.adminBarHeight() + parseInt( self.$header.css( 'border-top-width' ) ) >= $( document ).height() ) ) {
return self;
}
if ( window.innerHeight > $( document.body ).height() )
window.scrollTo( 0, 0 );
var scroll_top = $( window ).scrollTop(),
$pageWrapper = $( '.page-wrapper' );
if ( self.$menu_wrap && !theme.isTablet() ) {
self.$header_main.stop().css( 'top', 0 );
if ( self.$header.parent().hasClass( 'fixed-header' ) )
self.$header.parent().attr( 'style', '' );
// Scroll Up - Header Type
if ( $( '.page-wrapper' ).hasClass( 'sticky-scroll-up' ) ) {
scroll_top -= self.sticky_height;
if ( scroll_top > self.sticky_pos + 100 ) {
self.$header.addClass( 'sticky-ready' );
} else {
self.$header.removeClass( 'sticky-ready' );
}
}
if ( scroll_top > self.sticky_pos ) {
if ( !self.$header.hasClass( 'sticky-header' ) && ( ! $pageWrapper.hasClass( 'sticky-scroll-up' ) || ( $pageWrapper.hasClass( 'sticky-scroll-up' ) && 'undefined' !== typeof ( $pageWrapper.data( 'prev-scrollpos' ) ) ) ) ) {
var header_height = self.$header.outerHeight();
self.$header.addClass( 'sticky-header' ).css( 'height', header_height );
self.$menu_wrap.stop().css( 'top', theme.adminBarHeight() );
var selectric = self.$header.find( '.header-main .searchform select' ).data( 'selectric' );
if ( selectric && typeof selectric.close != 'undefined' )
selectric.close();
if ( self.$header.parent().hasClass( 'fixed-header' ) ) {
self.$header_main.hide();
self.$header.css( 'height', '' );
}
if ( !self.init_toggle_menu ) {
self.init_toggle_menu = true;
theme.MegaMenu.build();
if ( $( '#main-toggle-menu' ).length ) {
if ( $( '#main-toggle-menu' ).hasClass( 'show-always' ) ) {
$( '#main-toggle-menu' ).data( 'show-always', true );
$( '#main-toggle-menu' ).removeClass( 'show-always' );
}
$( '#main-toggle-menu' ).addClass( 'closed' );
$( '#main-toggle-menu .menu-title' ).addClass( 'closed' );
$( '#main-toggle-menu .toggle-menu-wrap' ).attr( 'style', '' );
}
}
self.is_sticky = true;
}
} else {
if ( self.$header.hasClass( 'sticky-header' ) ) {
self.$header.removeClass( 'sticky-header' );
self.$header.css( 'height', '' );
self.$menu_wrap.stop().css( 'top', 0 );
self.$header_main.show();
var selectric = self.$header.find( '.main-menu-wrap .searchform select' ).data( 'selectric' );
if ( selectric && typeof selectric.close != 'undefined' )
selectric.close();
if ( self.init_toggle_menu ) {
self.init_toggle_menu = false;
theme.MegaMenu.build();
if ( $( '#main-toggle-menu' ).length ) {
if ( $( '#main-toggle-menu' ).data( 'show-always' ) ) {
$( '#main-toggle-menu' ).addClass( 'show-always' );
$( '#main-toggle-menu' ).removeClass( 'closed' );
$( '#main-toggle-menu .menu-title' ).removeClass( 'closed' );
$( '#main-toggle-menu .toggle-menu-wrap' ).attr( 'style', '' );
}
}
}
self.is_sticky = false;
}
}
} else {
self.$header_main.show();
if ( self.$header.parent().hasClass( 'fixed-header' ) && $( '#wpadminbar' ).length && $( '#wpadminbar' ).css( 'position' ) == 'absolute' ) {
// self.$header.parent().css( 'top', ( $( '#wpadminbar' ).height() - scroll_top ) < 0 ? -$( '#wpadminbar' ).height() : -scroll_top );
} else if ( self.$header.parent().hasClass( 'fixed-header' ) ) {
self.$header.parent().attr( 'style', '' );
} else {
if ( self.$header.parent().hasClass( 'fixed-header' ) )
self.$header.parent().attr( 'style', '' );
}
if ( self.$header.hasClass( 'sticky-menu-header' ) && !theme.isTablet() ) {
self.$header_main.stop().css( 'top', 0 );
if ( self.change_logo ) self.$header_main.removeClass( 'change-logo' );
self.$header_main.removeClass( 'sticky' );
self.$header.removeClass( 'sticky-header' );
self.is_sticky = false;
self.sticky_height = 0;
} else {
if ( self.$menu_wrap )
self.$menu_wrap.stop().css( 'top', 0 );
if ( $pageWrapper.hasClass( 'sticky-scroll-up' ) ) {
scroll_top -= self.sticky_height;
if ( scroll_top > self.sticky_pos + 100 ) {
self.$header.addClass( 'sticky-ready' );
} else {
self.$header.removeClass( 'sticky-ready' );
}
}
if ( scroll_top > self.sticky_pos && ( !theme.isTablet() || ( theme.isTablet() && ( !theme.isMobile() && theme.show_sticky_header_tablet ) || ( theme.isMobile() && theme.show_sticky_header_tablet && theme.show_sticky_header_mobile ) ) ) ) {
if ( ! self.$header.hasClass( 'sticky-header' ) && ( ! $pageWrapper.hasClass( 'sticky-scroll-up' ) || ( $pageWrapper.hasClass( 'sticky-scroll-up' ) && 'undefined' !== typeof ( $pageWrapper.data( 'prev-scrollpos' ) ) ) ) ) {
var header_height = self.$header.outerHeight();
self.$header.addClass( 'sticky-header' ).css( 'height', header_height );
self.$header_main.addClass( 'sticky' );
if ( self.change_logo ) self.$header_main.addClass( 'change-logo' );
self.$header_main.stop().css( 'top', theme.adminBarHeight() );
if ( !self.init_toggle_menu ) {
self.init_toggle_menu = true;
theme.MegaMenu.build();
if ( $( '#main-toggle-menu' ).length ) {
if ( $( '#main-toggle-menu' ).hasClass( 'show-always' ) ) {
$( '#main-toggle-menu' ).data( 'show-always', true );
$( '#main-toggle-menu' ).removeClass( 'show-always' );
}
$( '#main-toggle-menu' ).addClass( 'closed' );
$( '#main-toggle-menu .menu-title' ).addClass( 'closed' );
$( '#main-toggle-menu .toggle-menu-wrap' ).attr( 'style', '' );
}
}
self.is_sticky = true;
}
} else {
if ( self.$header.hasClass( 'sticky-header' ) ) {
if ( self.change_logo ) self.$header_main.removeClass( 'change-logo' );
self.$header_main.removeClass( 'sticky' );
self.$header.removeClass( 'sticky-header' );
self.$header.css( 'height', '' );
self.$header_main.stop().css( 'top', 0 );
if ( self.init_toggle_menu ) {
self.init_toggle_menu = false;
theme.MegaMenu.build();
if ( $( '#main-toggle-menu' ).length ) {
if ( $( '#main-toggle-menu' ).data( 'show-always' ) ) {
$( '#main-toggle-menu' ).addClass( 'show-always' );
$( '#main-toggle-menu' ).removeClass( 'closed' );
$( '#main-toggle-menu .menu-title' ).removeClass( 'closed' );
$( '#main-toggle-menu .toggle-menu-wrap' ).attr( 'style', '' );
}
}
}
self.is_sticky = false;
}
}
}
}
if ( !self.$header.hasClass( 'header-loaded' ) )
self.$header.addClass( 'header-loaded' );
if ( !self.$header.find( '.logo' ).hasClass( 'logo-transition' ) )
self.$header.find( '.logo' ).addClass( 'logo-transition' );
if ( self.$header.find( '.overlay-logo' ).get( 0 ) && !self.$header.find( '.overlay-logo' ).hasClass( 'overlay-logo-transition' ) )
self.$header.find( '.overlay-logo' ).addClass( 'overlay-logo-transition' );
return self;
},
reset: function() {
var self = this;
if ( self.$header.find( '.logo' ).hasClass( 'logo-transition' ) )
self.$header.find( '.logo' ).removeClass( 'logo-transition' );
if ( self.$header.find( '.overlay-logo' ).get( 0 ) && self.$header.find( '.overlay-logo' ).hasClass( 'overlay-logo-transition' ) )
self.$header.find( '.overlay-logo' ).removeClass( 'overlay-logo-transition' );
if ( self.$menu_wrap && !theme.isTablet() ) {
// show main menu
self.$header.addClass( 'sticky-header sticky-header-calc' );
self.$header_main.addClass( 'sticky' );
if ( self.change_logo ) self.$header_main.addClass( 'change-logo' );
self.sticky_height = self.$menu_wrap.height() + parseInt( self.$menu_wrap.css( 'padding-top' ) ) + parseInt( self.$menu_wrap.css( 'padding-bottom' ) );
if ( self.change_logo ) self.$header_main.removeClass( 'change-logo' );
self.$header_main.removeClass( 'sticky' );
self.$header.removeClass( 'sticky-header sticky-header-calc' );
self.header_height = self.$header.height() + parseInt( self.$header.css( 'margin-top' ) );
self.menu_height = self.$menu_wrap.height() + parseInt( self.$menu_wrap.css( 'padding-top' ) ) + parseInt( self.$menu_wrap.css( 'padding-bottom' ) );
self.sticky_pos = ( self.header_height - self.sticky_height ) + parseInt( $( 'body' ).css( 'padding-top' ) ) + parseInt( self.$header.css( 'border-top-width' ) );
if ( $( '.banner-before-header' ).length ) {
self.sticky_pos += $( '.banner-before-header' ).height();
}
if ( $( '.porto-block-html-top' ).length ) {
self.sticky_pos += $( '.porto-block-html-top' ).height();
}
} else {
// show header main
self.$header.addClass( 'sticky-header sticky-header-calc' );
self.$header_main.addClass( 'sticky' );
if ( self.change_logo ) self.$header_main.addClass( 'change-logo' );
self.sticky_height = self.$header_main.outerHeight();
if ( self.change_logo ) self.$header_main.removeClass( 'change-logo' );
self.$header_main.removeClass( 'sticky' );
self.$header.removeClass( 'sticky-header sticky-header-calc' );
self.header_height = self.$header.height() + parseInt( self.$header.css( 'margin-top' ) );
self.main_height = self.$header_main.height();
if ( !( !theme.isTablet() || ( theme.isTablet() && !theme.isMobile() && theme.show_sticky_header_tablet ) || ( theme.isMobile() && theme.show_sticky_header_tablet && theme.show_sticky_header_mobile ) ) ) {
self.sticky_height = 0;
}
/*if (self.$header_main.length && self.$header.length) {
self.sticky_pos = self.$header_main.offset().top - self.$header.offset().top + $('.banner-before-header').height() + parseInt($('body').css('padding-top')) + parseInt(self.$header.css('border-top-width'));
} else {
self.sticky_pos = $('.banner-before-header').height() + parseInt($('body').css('padding-top')) + parseInt(self.$header.css('border-top-width'));
}
if (theme.adminBarHeight() && self.$header.offset().top > theme.adminBarHeight()) {
self.sticky_pos -= theme.adminBarHeight();
}
self.sticky_pos = (self.header_height - self.sticky_height) + $('.banner-before-header').height() + $('.porto-block-html-top').height() + parseInt($('body').css('padding-top')) + parseInt(self.$header.css('border-top-width'));*/
self.sticky_pos = self.$header.offset().top + self.header_height - self.sticky_height - theme.adminBarHeight() + parseInt( self.$header.css( 'border-top-width' ) );
}
if ( self.reveal ) {
if ( self.menu_height ) {
self.sticky_pos += self.menu_height + 30;
} else {
self.sticky_pos += 30;
}
}
if ( self.sticky_pos < 0 ) {
self.sticky_pos = 0;
}
self.init_toggle_menu = false;
self.$header_main.removeAttr( 'style' );
if ( !theme.isTablet() && self.$header.hasClass( 'header-side' ) && typeof self.$header.attr( 'data-plugin-sticky' ) != 'undefined' ) {
self.$header.css( 'height', '' );
} else {
self.$header.removeAttr( 'style' );
}
return self;
},
events: function() {
var self = this, win_width = 0;
$( window ).smartresize( function() {
if ( win_width != window.innerWidth ) {
self.reset().build();
win_width = window.innerWidth;
}
} );
var scrollEffect = function () {
theme.requestFrame( function() {
self.build();
var $pageWrapper = $( '.page-wrapper' );
if ( $pageWrapper.hasClass( 'sticky-scroll-up' ) && ! $( 'html' ).hasClass( 'porto-search-opened' ) ) {
var prevScrollPos = 0,
scrollTop = $( window ).scrollTop();
if ( $pageWrapper.data( 'prev-scrollpos' ) ) {
prevScrollPos = $pageWrapper.data( 'prev-scrollpos' );
}
if ( scrollTop >= prevScrollPos ) {
self.$header.addClass( 'scroll-down' );
} else {
self.$header.removeClass( 'scroll-down' );
}
$pageWrapper.data( 'prev-scrollpos', scrollTop );
}
} );
}
window.addEventListener( 'scroll', scrollEffect, { passive: true } );
scrollEffect();
return self;
}
}
} );
} ).apply( this, [window.theme, jQuery] );
// Side Nav
( function( theme, $ ) {
'use strict';
theme = theme || {};
$.extend( theme, {
SideNav: {
defaults: {
side_nav: $( '.header-side-nav #header' )
},
bc_pos_top: 0,
initialize: function( $side_nav ) {
this.$side_nav = ( $side_nav || this.defaults.side_nav );
if ( !this.$side_nav.length )
return this;
var self = this;
self.$side_nav.addClass( 'initialize' );
self.reset()
.build()
.events();
return self;
},
build: function() {
var self = this;
var $page_top = $( '.page-top' ),
$main = $( '#main' );
if ( theme.isTablet() ) {
//self.$side_nav.removeClass("fixed-bottom");
$page_top.removeClass( "fixed-pos" );
$page_top.attr( 'style', '' );
$main.attr( 'style', '' );
} else {
//var side_height = self.$side_nav.innerHeight();
//var window_height = window.innerHeight;
var scroll_top = $( window ).scrollTop();
/*if (side_height - window_height + theme.adminBarHeight() < scroll_top) {
if (!self.$side_nav.hasClass("fixed-bottom"))
self.$side_nav.addClass("fixed-bottom");
} else {
if (self.$side_nav.hasClass("fixed-bottom"))
self.$side_nav.removeClass("fixed-bottom");
}*/
if ( $page_top.length && $page_top.outerHeight() < 100 && !$( '.side-header-narrow-bar-top' ).length ) {
if ( self.page_top_offset == theme.adminBarHeight() || self.page_top_offset <= scroll_top ) {
if ( !$page_top.hasClass( "fixed-pos" ) ) {
$page_top.addClass( "fixed-pos" );
$page_top.css( 'top', theme.adminBarHeight() );
$main.css( 'padding-top', $page_top.outerHeight() );
}
} else {
if ( $page_top.hasClass( "fixed-pos" ) ) {
$page_top.removeClass( "fixed-pos" );
$page_top.attr( 'style', '' );
$main.attr( 'style', '' );
}
}
}
$main.css( 'min-height', window.innerHeight - theme.adminBarHeight() - $( '.page-top:not(.fixed-pos)' ).height() - $( '.footer-wrapper' ).height() );
}
return self;
},
reset: function() {
var self = this;
if ( theme.isTablet() && $( '.side-header-narrow-bar' ).length == 0 ) {
self.$side_nav.attr( 'style', '' );
} else {
var w_h = window.innerHeight,
$side_bottom = self.$side_nav.find( '.side-bottom' );
self.$side_nav.css( {
'min-height': w_h - theme.adminBarHeight(),
'padding-bottom': $side_bottom.length ? $side_bottom.height() + parseInt( $side_bottom.css( 'margin-top' ) ) + parseInt( $side_bottom.css( 'margin-bottom' ) ) : ''
} );
var appVersion = navigator.appVersion;
var webkitVersion_positionStart = appVersion.indexOf( "AppleWebKit/" ) + 12;
var webkitVersion_positionEnd = webkitVersion_positionStart + 3;
var webkitVersion = appVersion.slice( webkitVersion_positionStart, webkitVersion_positionEnd );
if ( webkitVersion < 537 ) {
self.$side_nav.css( '-webkit-backface-visibility', 'hidden' );
self.$side_nav.css( '-webkit-perspective', '1000' );
}
}
var $page_top = $( '.page-top' ),
$main = $( '#main' );
if ( $page_top.length ) {
$page_top.removeClass( "fixed-pos" );
$page_top.attr( 'style', '' );
$main.attr( 'style', '' );
self.page_top_offset = $page_top.offset().top;
}
return self;
},
events: function() {
var self = this;
$( window ).on( 'resize', function() {
self.reset()
.build();
} );
window.addEventListener( 'scroll', function() {
self.build();
}, { passive: true } );
if ( $( '.side-header-narrow-bar-top' ).length ) {
if ( $( window ).scrollTop() > theme.adminBarHeight() + $( '.side-header-narrow-bar-top' ).height() ) {
$( '.side-header-narrow-bar-top' ).addClass( 'side-header-narrow-bar-sticky' );
}
window.addEventListener( 'scroll', function() {
var scroll_top = $( this ).scrollTop();
if ( scroll_top > theme.adminBarHeight() + $( '.side-header-narrow-bar-top' ).height() ) {
$( '.side-header-narrow-bar-top' ).addClass( 'side-header-narrow-bar-sticky' );
} else {
$( '.side-header-narrow-bar-top' ).removeClass( 'side-header-narrow-bar-sticky' );
}
}, { passive: true } );
}
// Side Narrow Bar
$( '.side-header-narrow-bar .hamburguer-btn' ).on( 'click', function() {
$( this ).toggleClass( 'active' );
$( '#header' ).toggleClass( 'side-header-visible' );
if ( $( this ).closest( '.side-header-narrow-bar-top' ).length && !$( '#header > .hamburguer-btn' ).length ) {
$( this ).closest( '.side-header-narrow-bar-top' ).toggle();
}
} );
$( '.hamburguer-close' ).on( 'click', function() {
$( '.side-header-narrow-bar .hamburguer-btn' ).trigger( 'click' );
} );
return self;
}
}
} );
} ).apply( this, [window.theme, jQuery] );
// Hash Scroll
( function( theme, $ ) {
'use strict';
theme = theme || {};
$.extend( theme, {
HashScroll: {
initialize: function() {
this.build()
.events();
return this;
},
build: function() {
var self = this;
try {
var hash = window.location.hash;
var target = $( hash );
if ( target.length && !( hash == '#review_form' || hash == '#reviews' || hash.indexOf( '#comment-' ) != -1 ) ) {
$( 'html, body' ).delay( 600 ).stop().animate( {
scrollTop: target.offset().top - theme.StickyHeader.sticky_height - theme.adminBarHeight() - theme.sticky_nav_height + 1
}, 600, 'easeOutQuad' );
}
return self;
} catch ( err ) {
return self;
}
},
getTarget: function( href ) {
if ( '#' == href || href.endsWith( '#' ) ) {
return false;
}
var target;
if ( href.indexOf( '#' ) == 0 ) {
target = $( href );
} else {
var url = window.location.href;
url = url.substring( url.indexOf( '://' ) + 3 );
if ( url.indexOf( '#' ) != -1 )
url = url.substring( 0, url.indexOf( '#' ) );
href = href.substring( href.indexOf( '://' ) + 3 );
href = href.substring( href.indexOf( url ) + url.length );
if ( href.indexOf( '#' ) == 0 ) {
target = $( href );
}
}
return target;
},
activeMenuItem: function() {
var self = this;
var scroll_pos = $( window ).scrollTop();
var $menu_items = $( '.menu-item > a[href*="#"], .porto-sticky-nav .nav > li > a[href*="#"]' );
if ( $menu_items.length ) {
$menu_items.each( function() {
var $this = $( this ),
href = $this.attr( 'href' ),
target = self.getTarget( href );
if ( target && target.get( 0 ) ) {
if ( $this.parent().is( ':last-child' ) && scroll_pos + window.innerHeight >= target.offset().top + target.outerHeight() ) {
$this.parent().siblings().removeClass( 'active' );
$this.parent().addClass( 'active' );
} else {
var scroll_to = target.offset().top - theme.StickyHeader.sticky_height - theme.adminBarHeight() - theme.sticky_nav_height + 1,
$parent = $this.parent();
//if (scroll_to <= theme.StickyHeader.sticky_pos + theme.sticky_nav_height) {
//scroll_to = theme.StickyHeader.sticky_pos + theme.sticky_nav_height + 1;
//}
if ( scroll_to <= scroll_pos + 5 ) {
$parent.siblings().removeClass( 'active' );
$parent.addClass( 'active' );
if ( $parent.closest( '.secondary-menu' ).length ) {
$parent.closest( '#header' ).find( '.main-menu' ).eq( 0 ).children( '.menu-item.active' ).removeClass( 'active' );
}
} else {
$parent.removeClass( 'active' );
}
}
}
} );
}
return self;
},
events: function() {
var self = this;
$( '.menu-item > a[href*="#"], .porto-sticky-nav .nav > li > a[href*="#"], a[href*="#"].hash-scroll, .hash-scroll-wrap a[href*="#"]' ).on( 'click', function( e ) {
e.preventDefault();
var $this = $( this ),
href = $this.attr( 'href' ),
target = self.getTarget( href );
if ( target && target.get( 0 ) ) {
var $parent = $this.parent();
var scroll_to = target.offset().top - theme.StickyHeader.sticky_height - theme.adminBarHeight() - theme.sticky_nav_height + 1;
// if (scroll_to <= theme.StickyHeader.sticky_pos + theme.sticky_nav_height) {
// scroll_to = theme.StickyHeader.sticky_pos + theme.sticky_nav_height + 1;
// }
$( 'html, body' ).stop().animate( {
scrollTop: scroll_to
}, 600, 'easeOutQuad', function() {
//self.activeMenuItem();
$parent.siblings().removeClass( 'active' );
$parent.addClass( 'active' );
} );
if ( $this.closest( '.porto-popup-menu.opened' ).length ) {
$this.closest( '.porto-popup-menu.opened' ).children( '.hamburguer-btn' ).trigger( 'click' );
}
} else if ( ( '#' != href || !$this.closest( '.porto-popup-menu.opened' ).length ) && !$this.hasClass( 'nolink' ) ) {
window.location.href = $this.attr( 'href' );
}
} );
/*window.addEventListener( 'scroll', function () {
self.activeMenuItem();
}, { passive: true } );*/
var $menu_items = $( '.menu-item > a[href*="#"], .porto-sticky-nav .nav > li > a[href*="#"]' );
$menu_items.each( function() {
var rootMargin = '-20% 0px -79.9% 0px',
isLast = $( this ).parent().is( ':last-child' );
if ( isLast ) {
var obj = document.getElementById( this.hash.replace( '#', '' ) );
if ( obj && document.body.offsetHeight - obj.offsetTop < window.innerHeight ) {
var ratio = ( window.innerHeight - document.body.offsetHeight + obj.offsetTop ) / window.innerHeight * 0.8;
ratio = Math.round( ratio * 100 );
rootMargin = '-' + ( 20 + ratio ) + '% 0px -' + ( 79.9 - ratio ) + '% 0px';
}
}
var callback = function() {
if ( this && typeof this[0] != 'undefined' && this[0].id ) {
$( '.menu-item > a[href*="#' + this[0].id + '"], .porto-sticky-nav .nav > li > a[href*="#' + this[0].id + '"]' ).parent().addClass( 'active' ).siblings().removeClass( 'active' );
}
};
self.scrollSpyIntObs( this.hash, callback, {
rootMargin: rootMargin,
thresholds: 0
}, true, isLast, true, $menu_items, $( this ).parent().index() );
} );
//self.activeMenuItem();
return self;
},
scrollSpyIntObs: function( selector, functionName, intObsOptions, alwaysObserve, isLast, firstLoad, $allItems, index ) {
if ( typeof IntersectionObserver == 'undefined' ) {
return this;
}
var obj = document.getElementById( selector.replace( '#', '' ) );
if ( !obj ) {
return this;
}
var self = this;
var intersectionObserverOptions = {
rootMargin: '0px 0px 200px 0px'
}
if ( Object.keys( intObsOptions ).length ) {
intersectionObserverOptions = $.extend( intersectionObserverOptions, intObsOptions );
}
var observer = new IntersectionObserver( function( entries ) {
for ( var i = 0; i < entries.length; i++ ) {
var entry = entries[i];
if ( entry.intersectionRatio > 0 ) {
if ( typeof functionName === 'string' ) {
var func = Function( 'return ' + functionName )();
} else {
var callback = functionName;
callback.call( $( entry.target ) );
}
} else {
if ( firstLoad == false ) {
if ( isLast && ! $allItems.closest('.porto-sticky-nav').length ) {
$allItems.filter( '[href*="' + entry.target.id + '"]' ).parent().prev().addClass( 'active' ).siblings().removeClass( 'active' );
}
}
firstLoad = false;
}
}
}, intersectionObserverOptions );
observer.observe( obj );
return this;
}
}
} );
} ).apply( this, [window.theme, jQuery] );
// Float Element
( function( theme, $ ) {
'use strict';
theme = theme || {};
var instanceName = '__floatElement';
var PluginFloatElement = function( $el, opts ) {
return this.initialize( $el, opts );
};
PluginFloatElement.defaults = {
startPos: 'top',
speed: 3,
horizontal: false,
circle: false,
transition: false,
transitionDelay: 0,
transitionDuration: 500
};
PluginFloatElement.prototype = {
initialize: function( $el, opts ) {
if ( $el.data( instanceName ) ) {
return this;
}
this.$el = $el;
this
.setData()
.setOptions( opts )
.build();
return this;
},
setData: function() {
this.$el.data( instanceName, this );
return this;
},
setOptions: function( opts ) {
this.options = $.extend( true, {}, PluginFloatElement.defaults, opts, {
wrapper: this.$el
} );
return this;
},
build: function() {
var self = this,
$el = this.options.wrapper,
$window = $( window ),
minus;
if ( self.options.style ) {
$el.attr( 'style', self.options.style );
}
if ( self.options.circle ) {
// Set Transition
if ( self.options.transition ) {
$el.css( {
transition: 'ease-out transform ' + self.options.transitionDuration + 'ms ' + self.options.transitionDelay + 'ms'
} );
}
// Scroll
window.addEventListener( 'scroll', function() {
self.movement( minus );
}, { passive: true } );
} else if ( $window.width() > 767 ) {
// Set Start Position
if ( self.options.startPos == 'none' ) {
minus = '';
} else if ( self.options.startPos == 'top' ) {
$el.css( {
top: 0
} );
minus = '';
} else {
$el.css( {
bottom: 0
} );
minus = '-';
}
// Set Transition
if ( self.options.transition ) {
$el.css( {
transition: 'ease-out transform ' + self.options.transitionDuration + 'ms ' + self.options.transitionDelay + 'ms'
} );
}
// First Load
self.movement( minus );
// Scroll
window.addEventListener( 'scroll', function() {
self.movement( minus );
}, { passive: true } );
if ( theme.locomotiveScroll ) {
theme.locomotiveScroll.on( 'scroll', function( instance ) {
self.movement( minus, instance.scroll.y );
} );
}
}
return this;
},
movement: function( minus, isLocomotive = false ) {
var self = this,
$el = this.options.wrapper,
$window = $( window ),
scrollTop = isLocomotive === false ? $window.scrollTop() : isLocomotive,
elementOffset = $el.offset().top,
currentElementOffset = ( elementOffset - scrollTop );
if ( isLocomotive !== false ) {
currentElementOffset = $el.offset().top;
elementOffset = currentElementOffset + scrollTop;
}
if ( self.options.circle ) {
$el.css( {
transform: 'rotate(' + ( scrollTop * 0.25 ) + 'deg)'
} );
} else {
var scrollPercent = 100 * currentElementOffset / ( $window.height() );
if ( elementOffset + $el.height() >= scrollTop && elementOffset <= scrollTop + window.innerHeight ) {
if ( !self.options.horizontal ) {
$el.css( {
transform: 'translate3d(0, ' + minus + scrollPercent / self.options.speed + '%, 0)'
} );
} else {
$el.css( {
transform: 'translate3d(' + minus + scrollPercent / self.options.speed + '%, 0, 0)'
} );
}
}
}
}
};
// expose to scope
$.extend( theme, {
PluginFloatElement: PluginFloatElement
} );
// jquery plugin
$.fn.themePluginFloatElement = function( opts ) {
return this.map( function() {
var $this = $( this );
if ( $this.data( instanceName ) ) {
return $this.data( instanceName );
} else {
return new PluginFloatElement( $this, opts );
}
} );
}
} ).apply( this, [window.theme, jQuery] );
// Init Theme
function porto_init( $wrap ) {
'use strict';
jQuery( window ).on( 'touchstart', function() { } );
if ( !$wrap ) {
$wrap = jQuery( document.body );
}
var wrapObj = $wrap.get( 0 );
$wrap.trigger( 'porto_init_start', [wrapObj] );
( function( $ ) {
// Accordion
if ( $.fn.themeAccordion ) {
$( function() {
$wrap.find( '.accordion:not(.manual)' ).each( function() {
var $this = $( this ),
opts;
var pluginOptions = $this.data( 'plugin-options' );
if ( pluginOptions )
opts = pluginOptions;
$this.themeAccordion( opts );
} );
} );
}
// Accordion Menu
if ( $.fn.themeAccordionMenu ) {
$( function() {
$wrap.find( '.accordion-menu:not(.manual)' ).each( function() {
var $this = $( this ),
opts;
var pluginOptions = $this.data( 'plugin-options' );
if ( pluginOptions )
opts = pluginOptions;
$this.themeAccordionMenu( opts );
} );
} );
}
// Fit Video
if ( $.fn.themeFitVideo ) {
$( function() {
$wrap.find( '.fit-video:not(.manual)' ).each( function() {
var $this = $( this ),
opts;
var pluginOptions = $this.data( 'plugin-options' );
if ( pluginOptions )
opts = pluginOptions;
$this.themeFitVideo( opts );
} );
} );
}
// Video Background
if ( $.fn.themePluginVideoBackground ) {
$( function() {
$wrap.find( '[data-plugin-video-background]:not(.manual)' ).each( function() {
var $this = $( this ),
opts;
var pluginOptions = theme.getOptions( $this.data( 'plugin-options' ) );
if ( pluginOptions )
opts = pluginOptions;
$this.themePluginVideoBackground( opts );
} );
} );
}
// Flickr Zoom
if ( $.fn.themeFlickrZoom ) {
$( function() {
$wrap.find( '.wpb_flickr_widget:not(.manual)' ).each( function() {
var $this = $( this ),
opts;
var pluginOptions = $this.data( 'plugin-options' );
if ( pluginOptions )
opts = pluginOptions;
$this.themeFlickrZoom( opts );
} );
} );
}
// Lazy Load
if ( $.fn.themePluginLazyLoad ) {
$( function() {
$wrap.find( '[data-plugin-lazyload]:not(.manual)' ).each( function() {
var $this = $( this ),
opts;
var pluginOptions = $this.data( 'plugin-options' );
if ( pluginOptions )
opts = pluginOptions;
$this.themePluginLazyLoad( opts );
} );
if ( $wrap.find( '.porto-lazyload' ).length ) {
$wrap.find( '.porto-lazyload' ).filter( function() {
if ( $( this ).data( '__lazyload' ) || ( $( this ).closest( '.owl-carousel' ).length && $( this ).closest( '.owl-carousel' ).find( '.owl-item.cloned' ).length ) ) {
return false;
}
return true;
} ).themePluginLazyLoad( { effect: 'fadeIn', effect_speed: 400 } );
if ( $wrap.find( '.porto-lazyload' ).closest( '.nivoSlider' ).length ) {
theme.requestTimeout( function() {
$wrap.find( '.nivoSlider' ).each( function() {
if ( $( this ).find( '.porto-lazyload' ).length ) {
$( this ).closest( '.nivoSlider' ).find( '.nivo-main-image' ).attr( 'src', $( this ).closest( '.nivoSlider' ).find( '.porto-lazyload' ).eq( 0 ).attr( 'src' ) );
}
} );
}, 100 );
}
if ( $wrap.find( '.porto-lazyload' ).closest( '.porto-carousel-wrapper' ).length ) {
theme.requestTimeout( function() {
$wrap.find( '.porto-carousel-wrapper' ).each( function() {
if ( $( this ).find( '.porto-lazyload:not(.lazy-load-loaded)' ).length ) {
$( this ).find( '.slick-list' ).css( 'height', 'auto' );
//$( this ).find( '.porto-lazyload:not(.lazy-load-loaded)' ).trigger( 'appear' );
}
} );
}, 100 );
}
}
} );
}
// Masonry
if ( $.fn.themeMasonry ) {
$( function() {
$wrap.find( '[data-plugin-masonry]:not(.manual)' ).each( function() {
var $this = $( this ),
opts;
if ( $this.hasClass( 'elementor-row' ) ) {
$this.children( '.elementor-column' ).addClass( 'porto-grid-item' );
}
var pluginOptions = $this.data( 'plugin-options' );
if ( pluginOptions )
opts = pluginOptions;
$this.themeMasonry( opts );
} );
$wrap.find( '.posts-masonry .posts-container:not(.manual)' ).each( function() {
var pluginOptions = $( this ).data( 'plugin-options' );
if ( !pluginOptions ) {
pluginOptions = {};
}
pluginOptions.itemSelector = '.post';
$( this ).themeMasonry( pluginOptions );
} );
$wrap.find( '.page-portfolios .portfolio-row:not(.manual)' ).each( function() {
if ( $( this ).closest( '.porto-grid-container' ).length > 0 || typeof $( this ).attr( 'data-plugin-masonry' ) != 'undefined' ) {
return;
}
var $parent = $( this ).parent(), layoutMode = 'masonry', options, columnWidth = '.portfolio:not(.w2)', timer = null;
if ( $parent.hasClass( 'portfolios-grid' ) ) {
//layoutMode = 'fitRows';
} else if ( $parent.hasClass( 'portfolios-masonry' ) ) {
if ( !$parent.children( '.bounce-loader' ).length ) {
$parent.append( '
' );
}
}
options = {
itemSelector: '.portfolio',
layoutMode: layoutMode,
callback: function() {
timer && clearTimeout( timer );
timer = setTimeout( function() {
if ( typeof theme.FilterZoom !== 'undefined' ) {
theme.FilterZoom.initialize( $( '.page-portfolios' ) );
}
$parent.addClass( 'portfolio-iso-active' );
}, 400 );
}
};
if ( layoutMode == 'masonry' ) {
if ( !$parent.find( '.portfolio:not(.w2)' ).length )
columnWidth = '.portfolio';
options = $.extend( true, {}, options, {
masonry: { columnWidth: columnWidth }
} );
}
$( this ).themeMasonry( options );
} );
$wrap.find( '.page-members .member-row:not(.manual)' ).each( function() {
$( this ).themeMasonry( {
itemSelector: '.member',
//layoutMode: 'fitRows',
callback: function() {
setTimeout( function() {
if ( typeof theme.FilterZoom !== 'undefined' ) {
theme.FilterZoom.initialize( $( '.page-members' ) );
}
}, 400 );
}
} );
} );
} );
}
// Toggle
if ( $.fn.themeToggle ) {
$( function() {
$wrap.find( 'section.toggle:not(.manual)' ).each( function() {
var $this = $( this ),
opts;
var pluginOptions = $this.data( 'plugin-options' );
if ( pluginOptions )
opts = pluginOptions;
$this.themeToggle( opts );
} );
} );
}
// Parallax
if ( $.fn.themeParallax ) {
$( function() {
$wrap.find( '[data-plugin-parallax]:not(.manual)' ).each( function() {
var $this = $( this ),
opts;
var pluginOptions = $this.data( 'plugin-options' ),
parallaxScale = $this.attr( 'data-parallax-scale' );
if ( pluginOptions )
opts = pluginOptions;
if ( typeof parallaxScale !== 'undefined' ) {
opts['scale'] = true;
if ( parallaxScale == 'invert' ) {
opts['scaleInvert'] = true;
}
}
$this.themeParallax( opts );
} );
} );
}
// Scroll InViewPort
if ( $.fn.themePluginInViewportStyle ) {
$( function() {
$wrap.find( '[data-inviewport-style]:not(.manual)' ).each( function() {
var $this = $( this ),
opts = $this.data( 'plugin-options' );
$this.themePluginInViewportStyle( opts );
} );
} );
}
// Sticky
if ( $.fn.themeSticky ) {
$( function() {
$wrap.find( '[data-plugin-sticky]:not(.manual), .porto-sticky:not(.manual), .porto-sticky-nav:not(.manual)' ).each( function() {
var $this = $( this ),
opts;
var pluginOptions = $this.data( 'plugin-options' );
if ( pluginOptions )
opts = pluginOptions;
if ( $this.is( ':visible' ) ) {
$this.themeSticky( opts );
}
} );
} );
}
// Float Element
if ( $.fn['themePluginFloatElement'] ) {
$( function() {
$wrap.find( '[data-plugin-float-element]:not(.manual)' ).each( function() {
var $this = $( this ),
opts;
var pluginOptions = theme.getOptions( $this.data( 'plugin-options' ) );
if ( pluginOptions )
opts = pluginOptions;
$this.themePluginFloatElement( opts );
} );
} );
}
/* Common */
if ( typeof bootstrap != 'undefined' && typeof wrapObj != 'undefined' ) {
// Tooltip
var tooltipTriggerList = [].slice.call( wrapObj.querySelectorAll( "[data-bs-tooltip]:not(.manual), [data-toggle='tooltip']:not(.manual), .star-rating:not(.manual)" ) );
tooltipTriggerList.map( function( tooltipTriggerEl ) {
return new bootstrap.Tooltip( tooltipTriggerEl )
} );
}
// Tabs
$wrap.find( 'a[data-bs-toggle="tab"]' ).off( 'shown.bs.tab' ).on( 'shown.bs.tab', function( e ) {
$( this ).parents( '.nav-tabs' ).find( '.active' ).removeClass( 'active' );
$( this ).addClass( 'active' ).parent().addClass( 'active' );
if ( $( this ).closest( '.tabs' ) ) {
var _tabCarousel = $( this ).closest( '.tabs' ).find( '.tab-content>.active' ).find( '.owl-carousel' );
if ( ! _tabCarousel.data( 'owl.carousel' ) ) {
_tabCarousel.themeCarousel( _tabCarousel.data( 'plugin-options') );
}
}
} );
if ( $.fn.vcwaypoint ) {
// Progress bar tooltip
$wrap.find( '.vc_progress_bar' ).each( function() {
var $this = $( this );
if ( !$this.find( '.progress-bar-tooltip' ).length ) {
return;
}
$this.vcwaypoint( function() {
var $tooltips = $this.find( '.progress-bar-tooltip' ),
index = 0,
count = $tooltips.length;
function loop() {
theme.requestTimeout( function() {
$tooltips.animate( {
opacity: 1
} );
}, 200 );
index++;
if ( index < count ) {
loop();
}
}
loop();
}, {
offset: '85%'
} );
} );
}
// call async functions
if ( typeof theme.initAsync == 'function' ) {
theme.initAsync( $wrap, wrapObj );
} else {
$( document.body ).on( 'porto_async_init', function() {
theme.initAsync( $wrap, wrapObj );
} );
}
} )( jQuery );
jQuery( document.body ).trigger( 'porto_init', [$wrap] );
}
( function( theme, $ ) {
'use strict';
$( document ).ready( function() {
// update adminbar height
var win_width = 0;
$( window ).smartresize( function() {
if ( win_width != window.innerWidth ) {
theme.adminBarHeightNum = null;
win_width = window.innerWidth;
}
theme.bodyWidth = document.body.offsetWidth;
} );
// Scroll to Top
if ( typeof theme.ScrollToTop !== 'undefined' ) {
theme.ScrollToTop.initialize();
}
setTimeout( function() {
// Init Porto Theme
porto_init();
}, 0 );
( function() {
theme.bodyWidth = theme.bodyWidth || document.body.offsetWidth;
// Mega Menu
if ( typeof theme.MegaMenu !== 'undefined' ) {
theme.MegaMenu.initialize();
}
// Sidebar Menu
if ( typeof theme.SidebarMenu !== 'undefined' ) {
theme.SidebarMenu.initialize();
$( '.sidebar-menu.side-menu-accordion' ).themeAccordionMenu( { 'open_one': true } );
}
} )();
( function() {
// Overlay Menu
if ( $( '.porto-popup-menu' ).length ) {
$( '.porto-popup-menu .hamburguer-btn' ).on( 'click', function( e ) {
e.preventDefault();
var $this = $( this ), $html = $( 'html' );
if ( $( '.porto-popup-menu-spacer' ).length ) {
$( '.porto-popup-menu-spacer' ).remove();
} else {
$( '' ).insertBefore( $this.parent() );
$( '.porto-popup-menu-spacer' ).width( $this.parent().width() );
}
if ( $this.parent().hasClass( 'opened' ) ) {
$html.css( 'overflow', '' );
$html.css( 'margin-right', '' );
} else {
$html.css( 'margin-right', theme.getScrollbarWidth() );
$html.css( 'overflow', 'hidden' );
}
$this.parent().toggleClass( 'opened' );
theme.requestFrame( function() {
$this.toggleClass( 'active' );
} );
} );
$( '.porto-popup-menu .main-menu' ).scrollbar();
$( '.porto-popup-menu' ).on( 'click', 'li.menu-item-has-children > a', function( e ) {
e.preventDefault();
$( this ).parent().siblings( 'li.menu-item-has-children.opened' ).removeClass( 'opened' );
$( this ).parent().toggleClass( 'opened' );
} );
}
// Side Navigation
if ( typeof theme.SideNav !== 'undefined' ) {
theme.SideNav.initialize();
}
} )();
setTimeout( () => {
// Sticky Header
if ( typeof theme.StickyHeader !== 'undefined' ) {
theme.StickyHeader.initialize();
}
// Hash Scroll
if ( typeof theme.HashScroll !== 'undefined' ) {
theme.HashScroll.initialize();
}
} );
// Common
// skeleton screens
if ( js_porto_vars.use_skeleton_screen.length > 0 && $( '.skeleton-loading' ).length ) {
var dclFired = false,
dclPromise = ( function() {
var deferred = $.Deferred();
$( function() {
deferred.resolve();
dclFired = true;
} );
return deferred.promise();
} )(),
observer = false,
NativeMutationObserver = window.MutationObserver || window.WebkitMutationObserver || window.MozMutationObserver;
if ( typeof NativeMutationObserver != 'undefined' ) {
observer = new NativeMutationObserver( function( mutationsList, observer ) {
for ( var i in mutationsList ) {
var mutation = mutationsList[i];
if ( mutation.type == 'childList' ) {
$( mutation.target ).trigger( 'skeleton:initialised' );
}
}
} );
}
var killObserverTrigger = setTimeout( function() {
if ( observer ) {
observer.disconnect();
observer = undefined;
}
}, 4000 );
var skeletonTimer;
$( '.skeleton-loading' ).each( function( e ) {
var $this = $( this ),
skeletonInitialisedPromise = ( function() {
var deferred = $.Deferred();
$this.on( 'skeleton:initialised', function( evt ) {
if ( evt.target.classList.contains( 'skeleton-loading' ) ) {
deferred.resolve( evt );
}
} );
return deferred.promise();
} )(),
resourcesLoadedPromise = ( function() {
return $.Deferred().resolve().promise();
} )();
$.when( skeletonInitialisedPromise, resourcesLoadedPromise, dclPromise ).done( function( e ) {
var $real = $( e.target ),
$placeholder = $real.siblings( '.skeleton-body' );
if ( !$placeholder.length ) {
$placeholder = $real.parent().parent().parent().find( '[class="' + $real.attr( 'class' ).replace( 'skeleton-loading', 'skeleton-body' ) + '"]' );
}
porto_init( $real );
if ( $real.find( '.sidebar-menu:not(.side-menu-accordion)' ).length ) {
theme.SidebarMenu.initialize( $real.find( '.sidebar-menu:not(.side-menu-accordion)' ) );
}
if ( skeletonTimer ) {
theme.deleteTimeout( skeletonTimer );
}
$real.trigger( 'skeleton-loaded' );
theme.requestTimeout( function() {
if ( $placeholder.length ) {
// fix YITH Products Filters compatibility issue
if ( $placeholder.parent().hasClass( 'yit-wcan-container' ) ) {
$placeholder.parent().remove();
} else {
$placeholder.remove();
}
}
$real.removeClass( 'skeleton-loading' );
if ( $real.closest( '.skeleton-loading-wrap' ) ) {
$real.closest( '.skeleton-loading-wrap' ).removeClass( 'skeleton-loading-wrap' );
}
if ( $( document.body ).hasClass( 'elementor-default' ) || $( document.body ).hasClass( 'elementor-page' ) ) {
$( window ).trigger( 'resize' );
}
theme.refreshStickySidebar( false );
}, 100 );
if ( !$( '.skeleton-loading' ).length ) {
clearTimeout( killObserverTrigger );
observer.disconnect();
observer = undefined;
}
} );
if ( $this.children( 'script[type="text/template"]' ).length ) {
var content = $( JSON.parse( $this.children( 'script[type="text/template"]' ).eq( 0 ).html() ) );
$this.children( 'script[type="text/template"]' ).eq( 0 ).remove();
if ( observer ) {
observer.observe( this, { childList: true, subtree: false } );
}
$this.append( content );
if ( !observer ) {
$this.trigger( 'skeleton:initialised' );
}
}
} );
}
$( document ).trigger( 'porto_theme_init' );
theme.isThemeInit = true;
} );
$( window ).on( 'load', function() {
// Mobile Sidebar
// filter popup events
$( document ).on( 'click', '.sidebar-toggle', function( e ) {
e.preventDefault();
var $html = $( 'html' ),
$main = $( '#main' ),
$this = $( this );
if ( $this.siblings( '.porto-product-filters' ).length ) {
if ( $html.hasClass( 'filter-sidebar-opened' ) ) {
$html.removeClass( 'filter-sidebar-opened' );
$this.siblings( '.sidebar-overlay' ).removeClass( 'active' );
if ( $html.hasClass( 'sidebar-right-opened' ) ) {
$html.removeClass( 'sidebar-right-opened' );
}
} else {
$html.removeClass( 'sidebar-opened' );
$html.addClass( 'filter-sidebar-opened' );
$this.siblings( '.sidebar-overlay' ).addClass( 'active' );
if ( $main.hasClass( 'column2-right-sidebar' ) || $main.hasClass( 'column2-wide-right-sidebar' ) ) {
$html.addClass( 'sidebar-right-opened' );
}
}
} else {
if ( $html.hasClass( 'sidebar-opened' ) ) {
$html.removeClass( 'sidebar-opened' );
$( '.sidebar-overlay' ).removeClass( 'active' );
if ( $html.hasClass( 'sidebar-right-opened' ) ) {
$html.removeClass( 'sidebar-right-opened' );
}
} else {
$html.addClass( 'sidebar-opened' );
$( '.sidebar-overlay' ).addClass( 'active' );
//$( '.mobile-sidebar' ).find( '.porto-lazyload:not(.lazy-load-loaded)' ).trigger( 'appear' );
if ( $main.hasClass( 'column2-right-sidebar' ) || $main.hasClass( 'column2-wide-right-sidebar' ) ) {
$html.addClass( 'sidebar-right-opened' );
}
}
}
} );
$( '#header .mini-cart' ).on( 'click', function( e ) {
let $body = $( 'body' );
if ( js_porto_vars.cart_url && ( $body.hasClass( 'woocommerce-cart' ) || $body.hasClass( 'woocommerce-checkout' ) ) ) {
location.href = js_porto_vars.cart_url;
}
});
$( '.minicart-offcanvas .cart-head' ).on( 'click', function() {
let $body = $( 'body' );
if ( js_porto_vars.cart_url && ( $body.hasClass( 'woocommerce-cart' ) || $body.hasClass( 'woocommerce-checkout' ) ) ) {
return;
}
var $this = $( this );
$this.closest( '.minicart-offcanvas' ).toggleClass( 'minicart-opened' );
if ( $this.closest( '.minicart-offcanvas' ).hasClass( 'minicart-opened' ) ) {
$( 'html' ).css( 'margin-right', theme.getScrollbarWidth() );
$( 'html' ).css( 'overflow', 'hidden' );
} else {
$( 'html' ).css( 'overflow', '' );
$( 'html' ).css( 'margin-right', '' );
}
} );
$( '.minicart-offcanvas .minicart-overlay' ).on( 'click', function() {
$( this ).closest( '.minicart-offcanvas' ).removeClass( 'minicart-opened' );
$( 'html' ).css( 'overflow', '' );
$( 'html' ).css( 'margin-right', '' );
} );
$( document.body ).on( 'click', '.sidebar-overlay', function() {
var $html = $( 'html' );
$html.removeClass( 'sidebar-opened' );
$html.removeClass( 'filter-sidebar-opened' );
$( this ).removeClass( 'active' );
$html.removeClass( 'sidebar-right-opened' );
} );
// Section Tab
$( document.body ).on( 'click', '.section-tabs .nav-link', function( e ) {
e.preventDefault();
var $this = $( this ),
nav_id = $this.data( 'tab' ),
$section_tab = $this.closest( '.section-tabs' ),
$nav_wrap = $section_tab.children( 'ul.nav' ),
$tab_content = $section_tab.children( '.tab-content' );
if ( nav_id ) {
// Nav Item
$nav_wrap.find( '.active' ).removeClass( 'active' );
$this.addClass( 'active' ).parent( '.nav-item' ).addClass( 'active' );
// Content Item
$tab_content.find( '>.active' ).removeClass( 'show active' );
$tab_content.find( '>.tab-pane[id="' + nav_id + '"]' ).addClass( 'active' );
let _offsetHeight = $tab_content.find( '>.active' ).get(0).offsetHeight;
$tab_content.find( '>.active' ).addClass( 'show' );
var _tabCarousel = $tab_content.find( '>.active' ).find( '.owl-carousel' );
if ( ! _tabCarousel.data( 'owl.carousel' ) ) {
_tabCarousel.themeCarousel( _tabCarousel.data( 'plugin-options') );
}
}
} );
$( window ).on( 'resize', function( e ) {
if ( e.originalEvent && window.innerWidth > 991 && $( 'html' ).hasClass( 'sidebar-opened' ) ) {
$( '.sidebar-overlay' ).trigger( 'click' );
}
} );
// Match Height
var $matchHeightObj = $( '.tabs-simple .featured-box .box-content, .porto-content-box .featured-box .box-content, .vc_general.vc_cta3, .match-height' );
if ( $matchHeightObj.length ) {
if ( $.fn.matchHeight ) {
$matchHeightObj.matchHeight();
} else {
var script = document.createElement( "script" );
script.addEventListener( "load", function( event ) {
$matchHeightObj.matchHeight();
} );
script.src = js_porto_vars.ajax_loader_url.replace( '/images/ajax-loader@2x.gif', '/js/libs/jquery.matchHeight.min.js' );
script.async = true;
document.body.appendChild( script );
}
}
// WhatsApp Sharing
if ( /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test( navigator.userAgent ) ) {
$( '.share-whatsapp' ).css( 'display', 'inline-block' );
}
$( document ).ajaxComplete( function( event, xhr, options ) {
if ( /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test( navigator.userAgent ) ) {
$( '.share-whatsapp' ).css( 'display', 'inline-block' );
}
} );
// Add Ege Browser Class
var ua = window.navigator.userAgent,
ie12 = ua.indexOf( 'Edge/' ) > 0;
if ( ie12 ) $( 'html' ).addClass( 'ie12' );
// Portfolio Link Lightbox
$( document ).on( 'click', '.portfolios-lightbox a.portfolio-link', function( e ) {
$( this ).find( '.thumb-info-zoom' ).trigger( 'click' );
return false;
} );
$( '.porto-faqs' ).each( function() {
if ( $( this ).find( '.faq .toggle.active' ).length < 1 ) {
$( this ).find( '.faq' ).eq( 0 ).find( '.toggle' ).addClass( 'active' );
$( this ).find( '.faq' ).eq( 0 ).find( '.toggle-content' ).show();
}
} );
// refresh wpb content
$( document ).on( 'shown.bs.collapse', '.collapse', function() {
var panel = $( this );
theme.refreshVCContent( panel );
} );
$( document ).on( 'shown.bs.tab', 'a[data-bs-toggle="tab"]', function( e ) {
var panel = $( $( e.target ).attr( 'href' ) );
theme.refreshVCContent( panel );
} );
// porto tooltip for header, footer
$( '.porto-tooltip .tooltip-icon' ).on( 'click', function() {
if ( $( this ).parent().children( ".tooltip-popup" ).css( "display" ) == "none" ) {
$( this ).parent().children( ".tooltip-popup" ).fadeIn( 200 );
} else {
$( this ).parent().children( ".tooltip-popup" ).fadeOut( 200 );
}
} );
$( '.porto-tooltip .tooltip-close' ).on( 'click', function() {
$( this ).parent().fadeOut( 200 );
} );
// Add Scrollbar width
$( 'body' ).css( '--porto-scroll-w', theme.getScrollbarWidth() + 'px' );
} );
} ).apply( this, [window.theme, jQuery] );
( function( theme, $, undefined ) {
"use strict";
$( document ).ready( function() {
$( window ).on( 'vc_reload', function() {
porto_init();
$( '.type-post' ).addClass( 'post' );
$( '.type-portfolio' ).addClass( 'portfolio' );
$( '.type-member' ).addClass( 'member' );
$( '.type-block' ).addClass( 'block' );
} );
} );
/*
* Experience Timeline
*/
var timelineHeightAdjust = {
$timeline: $( '#exp-timeline' ),
$timelineBar: $( '#exp-timeline .timeline-bar' ),
$firstTimelineItem: $( '#exp-timeline .timeline-box' ).first(),
$lastTimelineItem: $( '#exp-timeline .timeline-box' ).last(),
build: function() {
var self = this;
self.adjustHeight();
},
adjustHeight: function() {
var self = this,
calcFirstItemHeight = ( self.$firstTimelineItem.outerHeight( true ) / 2 ) + 5,
calcLastItemHeight = ( self.$lastTimelineItem.outerHeight( true ) / 2 ) + 5;
// Set Timeline Bar Top and Bottom
self.$timelineBar.css( {
top: calcFirstItemHeight,
bottom: calcLastItemHeight
} );
}
}
if ( $( '#exp-timeline' ).get( 0 ) ) {
// Adjust Timeline Height On Resize
var timeline_timer = null;
$( window ).smartresize( function() {
if ( timeline_timer ) {
clearTimeout( timeline_timer );
}
timeline_timer = setTimeout( function() {
timelineHeightAdjust.build();
}, 800 );
} );
timelineHeightAdjust.build();
}
$( '.custom-view-our-location' ).on( 'click', function( e ) {
e.preventDefault();
var this_ = $( this );
$( '.custom-googlemap' ).slideDown( '1000', function() {
this_.delay( 700 ).hide();
} );
} );
// compatibility with w3 total cache
window.addEventListener(
'LazyLoad::Initialized',
function ( event ) {
theme.w3tcLazyLoadInstance = event.detail.instance;
},
false
);
} )( window.theme, jQuery );
// Porto 4.0 extra shortcodes
( function( theme, $, undefined ) {
'use strict';
window.addEventListener( 'load', function() {
theme.isLoaded = true;
} );
$( document ).ready( function() {
if ( typeof elementorFrontend != 'undefined' ) {
// fix Elementor ScrollTop
$( window ).on( 'elementor/frontend/init', function() {
elementorFrontend.hooks.addFilter( 'frontend/handlers/menu_anchor/scroll_top_distance', function( scrollTop ) {
if ( theme && theme.StickyHeader && typeof theme.sticky_nav_height != 'undefined' ) {
if ( elementorFrontend.elements.$wpAdminBar.length ) {
scrollTop += elementorFrontend.elements.$wpAdminBar.height();
}
scrollTop = scrollTop - theme.adminBarHeight() - theme.StickyHeader.sticky_height - theme.sticky_nav_height + 1;
}
return scrollTop;
} );
elementorFrontend.elements.$window.on( 'elementor/nested-tabs/activate', function( e, content ) {
var _tabCarousel = $( content ).find( '.owl-carousel' );
if ( ! _tabCarousel.data( 'owl.carousel' ) ) {
_tabCarousel.themeCarousel( _tabCarousel.data( 'plugin-options' ) );
}
});
} );
}
} );
// widget wysija
$( '#footer .widget_wysija .wysija-submit:not(.btn)' ).addClass( 'btn btn-default' );
// fixed visual compoer issue which has owl carousel
if ( $( '[data-vc-parallax] .owl-carousel' ).length ) {
theme.requestTimeout( function() { if ( typeof window.vcParallaxSkroll == 'object' ) { window.vcParallaxSkroll.refresh(); } }, 200 );
}
if ( $( '.page-content > .alignfull, .post-content > .alignfull' ).length ) {
var initAlignFull = function() {
$( '.page-content > .alignfull, .post-content > .alignfull' ).each( function() {
$( this ).css( 'left', -1 * $( this ).parent().offset().left ).css( 'right', -1 * $( this ).parent().offset().left ).css( 'width', $( 'body' ).width() - ( parseInt( $( this ).css( 'margin-left' ), 10 ) + parseInt( $( this ).css( 'margin-right' ), 10 ) ) );
} );
};
initAlignFull();
$( window ).smartresize( function() {
initAlignFull();
} );
}
} )( window.theme, jQuery );