;(function( $ ){
/**
* File navigation.js.
*
* Handles toggling the navigation menu for small screens and enables TAB key
* navigation support for dropdown menus.
*/
+( function() {
var container, button, menu, links, i, len;
container = document.getElementById( 'site-navigation' );
if ( ! container ) {
return;
}
button = container.getElementsByTagName( 'button' )[0];
if ( 'undefined' === typeof button ) {
return;
}
menu = container.getElementsByTagName( 'ul' )[0];
// Hide menu toggle button if menu is empty and return early.
if ( 'undefined' === typeof menu ) {
button.style.display = 'none';
return;
}
menu.setAttribute( 'aria-expanded', 'false' );
if ( -1 === menu.className.indexOf( 'nav-menu' ) ) {
menu.className += ' nav-menu';
}
button.onclick = function() {
if ( -1 !== container.className.indexOf( 'toggled' ) ) {
container.className = container.className.replace( ' toggled', '' );
button.setAttribute( 'aria-expanded', 'false' );
menu.setAttribute( 'aria-expanded', 'false' );
} else {
container.className += ' toggled';
button.setAttribute( 'aria-expanded', 'true' );
menu.setAttribute( 'aria-expanded', 'true' );
}
};
// Get all the link elements within the menu.
links = menu.getElementsByTagName( 'a' );
// Each time a menu link is focused or blurred, toggle focus.
for ( i = 0, len = links.length; i < len; i++ ) {
links[i].addEventListener( 'focus', toggleFocus, true );
links[i].addEventListener( 'blur', toggleFocus, true );
}
/**
* Sets or removes .focus class on an element.
*/
function toggleFocus() {
var self = this;
// Move up through the ancestors of the current link until we hit .nav-menu.
while ( -1 === self.className.indexOf( 'nav-menu' ) ) {
// On li elements toggle the class .focus.
if ( 'li' === self.tagName.toLowerCase() ) {
if ( -1 !== self.className.indexOf( 'focus' ) ) {
self.className = self.className.replace( ' focus', '' );
} else {
self.className += ' focus';
}
}
self = self.parentElement;
}
}
/**
* Toggles `focus` class to allow submenu access on tablets.
*/
( function( container ) {
var touchStartFn, i,
parentLink = container.querySelectorAll( '.menu-item-has-children > a, .page_item_has_children > a' );
if ( 'ontouchstart' in window ) {
touchStartFn = function( e ) {
var menuItem = this.parentNode, i;
if ( ! menuItem.classList.contains( 'focus' ) ) {
e.preventDefault();
for ( i = 0; i < menuItem.parentNode.children.length; ++i ) {
if ( menuItem === menuItem.parentNode.children[i] ) {
continue;
}
menuItem.parentNode.children[i].classList.remove( 'focus' );
}
menuItem.classList.add( 'focus' );
} else {
menuItem.classList.remove( 'focus' );
}
};
for ( i = 0; i < parentLink.length; ++i ) {
parentLink[i].addEventListener( 'touchstart', touchStartFn, false );
}
}
}( container ) );
} )();
jQuery.fn.scrollTo = function( offset ){
jQuery( document ).on( 'click', this.selector, function( e ){
e.preventDefault();
var target = jQuery( this ).attr( 'href' );
if( 'undefined' != typeof target ){
if( !offset ){
offset = 0;
}
var pos = jQuery( target ).offset().top - offset;
jQuery("html, body").animate({ scrollTop: pos }, 800);
}
});
return this;
};
function scrollToTop ( param ){
this.markup = null,
this.selector = null;
this.fixed = true;
this.visible = false;
this.init = function(){
if( this.valid() ){
if( typeof param != 'undefined' && typeof param.fixed != 'undefined' ){
this.fixed = param.fixed;
}
this.selector = ( param && param.selector ) ? param.selector : '#go-top';
this.getMarkup();
var that = this;
jQuery( 'body' ).append( this.markup );
if( this.fixed ){
jQuery( this.selector ).hide();
var windowHeight = jQuery( window ).height();
jQuery( window ).scroll(function(){
var scrollPos = jQuery( window ).scrollTop();
if( ( scrollPos > ( windowHeight - 100 ) ) ){
if( false == that.visible ){
jQuery( that.selector ).fadeIn();
that.visible = true;
}
}else{
if( true == that.visible ){
jQuery( that.selector ).fadeOut();
that.visible = false;
}
}
});
jQuery( this.selector ).scrollTo();
}
}
}
this.getMarkup = function(){
var position = this.fixed ? 'fixed':'absolute';
var wrapperStyle = 'style="position: '+position+'; z-index:999999; bottom: 20px; right: 20px;"';
var buttonStyle = 'style="cursor:pointer;display: inline-block;padding: 10px 20px;background: #f15151;color: #fff;border-radius: 2px;"';
var markup = '
Scroll To Top
';
this.markup = ( param && param.markup ) ? param.markup : markup;
}
this.valid = function(){
if( param && param.markup && !param.selector ){
alert( 'Please provide selector. eg. { markup: "", selector: "#scroll-top"}' );
return false;
}
return true;
}
};
/**
* File skip-link-focus-fix.js.
*
* Helps with accessibility for keyboard only users.
*
* Learn more: https://git.io/vWdr2
*/
+(function() {
var isIe = /(trident|msie)/i.test( navigator.userAgent );
if ( isIe && document.getElementById && window.addEventListener ) {
window.addEventListener( 'hashchange', function() {
var id = location.hash.substring( 1 ),
element;
if ( ! ( /^[A-z0-9_-]+$/.test( id ) ) ) {
return;
}
element = document.getElementById( id );
if ( element ) {
if ( ! ( /^(?:a|select|input|button|textarea)$/i.test( element.tagName ) ) ) {
element.tabIndex = -1;
}
element.focus();
}
}, false );
}
})();
/**
* Setting up functionality for alternative menu
* @since Businex 1.0.0
*/
function wpMenuAccordion( selector ){
var $ele = selector + ' .menu-item-has-children > a';
$( $ele ).each( function(){
var text = $( this ).text();
text = text + '';
$( this ).html( text );
});
$( document ).on( 'click', $ele + ' span.triangle', function( e ){
e.preventDefault();
e.stopPropagation();
$parentLi = $( this ).parent().parent( 'li' );
$childLi = $parentLi.find( 'li' );
if( $parentLi.hasClass( 'open' ) ){
/**
* Closing all the ul inside and
* removing open class for all the li's
*/
$parentLi.removeClass( 'open' );
$childLi.removeClass( 'open' );
$( this ).parent( 'a' ).next().slideUp();
$( this ).parent( 'a' ).next().find( 'ul' ).slideUp();
}else{
$parentLi.addClass( 'open' );
$( this ).parent( 'a' ).next().slideDown();
}
});
};
/**
* Main menu height
* @since Businex 1.0.0
*/
function maintainMenuHeight(){
var init = function(){
var h = parseInt( jQuery( '.site-header-primary .site-branding-outer' ).height() );
jQuery( '.site-header-primary #primary-nav-container' ).height( h );
}
init();
jQuery( window ).resize( init );
}
/**
* Increase cart count when product is added by ajax
* @uses Woocommerce
* @since Businex 1.0.0
*/
jQuery( document ).on( 'added_to_cart', function(){
$ele = $( '.cart-icon .count' );
var count = $ele.text();
$ele.text( parseInt( count ) + 1 );
});
/**
* Show or Hide Search field on clicking search icon
* @since Businex 1.0.0
*/
jQuery( document ).on( 'click', '.search-icon a', function( e ){
e.preventDefault();
jQuery( '#search-form' ).toggleClass('search-slide');
});
/**
* Fire Slider for Testimonials
* @link https://owlcarousel2.github.io/OwlCarousel2/docs/started-welcome.html
* @since Businex 1.0.0
*/
function testimonialSlider(){
$(".testimonial-carousel").owlCarousel({
items: 1,
animateOut: 'fadeOut',
navContainer: '.block-testimonial .controls',
dotsContainer: '#testimonial-pager',
responsiveClass:true,
responsive:{
0:{
items:1,
nav:true
}
},
rtl: ( BUSINEX.is_rtl == '1' ) ? true : false ,
loop : false,
dots: true
});
};
/**
* Fire highlight slider for homepage
* @link https://owlcarousel2.github.io/OwlCarousel2/docs/started-welcome.html
* @since Businex 1.0.0
*/
function highlightSlider(){
var item_count = parseInt(jQuery( '.block-highlight .slide-item').length);
jQuery(".highlight-slider").owlCarousel({
items: 1,
autoHeight: false,
autoHeightClass: 'name',
animateOut: 'fadeOut',
navContainer: '.block-highlight .controls',
margin: 30,
autoplay : BUSINEX.highlight.autoplay,
loop : ( item_count > 1 ) ? true : false,
rtl: ( BUSINEX.is_rtl == '1' ) ? true : false,
responsive:{
768:{
items: 3,
nav: true,
}
},
});
};
/**
* Fire equal height
* @since Businex Pro 1.0.0
*/
function equaleHeight( ele ){
var getMaxHeight = function(){
var height = 0 ;
jQuery( ele ).height( 'auto' );
jQuery( ele ).each( function(){
if( jQuery( this ).height() > height ){
height = jQuery( this ).height();
}
});
return height;
};
var init = function(){
var width = jQuery( window ).width();
var height = getMaxHeight();
jQuery( ele ).each( function(){
jQuery( this ).height( height );
});
};
jQuery( document ).ready( function(){
init();
});
jQuery( window ).resize( function(){
init();
});
jQuery( window ).load( function(){
init();
});
};
equaleHeight( '.block-slider .slide-item' );
equaleHeight( '.block-highlight .slide-item' );
/**
* Animate contact form fields when they are focused
* @since Businex 1.0.0
*/
jQuery( '.kt-contact-form-area input, .kt-contact-form-area textarea' ).on( 'focus',function(){
var target = jQuery( this ).attr( 'id' );
jQuery('label[for="'+target+'"]').addClass( 'move' );
});
jQuery( '.kt-contact-form-area input, .kt-contact-form-area textarea' ).on( 'blur',function(){
var target = jQuery( this ).attr( 'id' );
jQuery('label[for="'+target+'"]').removeClass( 'move' );
});
jQuery( document ).ready( function(){
maintainMenuHeight();
testimonialSlider();
highlightSlider();
$( '.scroll-to' ).scrollTo();
/**
* Initializing scroll top js
*/
new scrollToTop({
markup : '',
selector : '#go-top'
}).init();
wpMenuAccordion( '#offcanvas-menu' );
$( document ).on( 'click', '.offcanvas-menu-toggler, .close-offcanvas-menu, .kt-offcanvas-overlay', function( e ){
e.preventDefault();
$( 'body' ).toggleClass( 'offcanvas-menu-open' );
});
jQuery( 'body' ).append( '' );
/**
* Make sure if the masonry wrapper exists
*/
if( jQuery( '.masonry-wrapper' ).length > 0 ){
$grid = jQuery( '.masonry-wrapper' ).masonry({
itemSelector: '.masonry-grid',
percentPosition: true,
});
}
/**
* Make support for Jetpack's infinite scroll on masonry layout
*/
infinite_count = 0;
$( document.body ).on( 'post-load', function () {
infinite_count = infinite_count + 1;
var container = '#infinite-view-' + infinite_count;
$( container ).hide();
$( $( container + ' .masonry-grid' ) ).each( function(){
$items = $( this );
$grid.append( $items ).masonry( 'appended', $items );
});
setTimeout( function(){
$grid.masonry('layout');
},500);
});
/**
* Modify default search placeholder
*/
$( '#masthead #s' ).attr( 'placeholder', BUSINEX.search_placeholder );
$( '#searchform #s' ).attr( 'placeholder', BUSINEX.search_default_placeholder );
});
jQuery( window ).load( function(){
if( 'undefined' !== typeof $grid ){
$grid.masonry('reloadItems');
$grid.masonry('layout');
}
});
jQuery( window ).load( function(){
jQuery( '#site-loader' ).fadeOut( 500 );
});
})( jQuery );