site_oueb_2/wp-content/plugins/ocean-extra/assets/js/sidr.js

122 lines
3.8 KiB
JavaScript
Raw Permalink Normal View History

2022-11-22 20:23:31 +01:00
var $j = jQuery.noConflict();
$j( document ).ready( function() {
"use strict";
// Mobile menu
oceanwpMobileMenu();
} );
/* ==============================================
MOBILE SCRIPT
============================================== */
function oceanwpMobileMenu( event ) {
"use strict"
if ( typeof oceanwpLocalize.sidrSource !== 'undefined' ) {
// Add sidr
$j( '.mobile-menu' ).sidr( {
name : 'sidr', // Name for the 'sidr'
source : oceanwpLocalize.sidrSource, // Override the source of the content
side : oceanwpLocalize.sidrSide, // Accepts 'left' or 'right'
displace : oceanwpLocalize.sidrDisplace, // Displace the body content or not
speed : 300, // Accepts standard jQuery effects speeds (i.e. fast, normal or milliseconds)
renaming : true, // The ids and classes will be prepended with a prefix when loading existent content
onOpen : function() {
// Declare useful vars
var $hasChildren = $j( '.sidr-class-menu-item-has-children' );
// Add dropdown toggle (plus)
$hasChildren.children( 'a' ).append( '<span class="sidr-class-dropdown-toggle"></span>' );
// Toggle dropdowns
var $sidrDropdownTarget = $j( '.sidr-class-dropdown-toggle' );
// Check localization
if ( oceanwpLocalize.sidrDropdownTarget == 'link' ) {
$sidrDropdownTarget = $j( '.sidr-class-sf-with-ul' );
}
// Add toggle click event
$sidrDropdownTarget.on( 'click', function( event ) {
// Define toggle vars
if ( oceanwpLocalize.sidrDropdownTarget == 'link' ) {
var $toggleParentLi = $j( this ).parent( 'li' );
} else {
var $toggleParentLink = $j( this ).parent( 'a' ),
$toggleParentLi = $toggleParentLink.parent( 'li' );
}
// Get parent items and dropdown
var $allParentLis = $toggleParentLi.parents( 'li' ),
$dropdown = $toggleParentLi.children( 'ul' );
// Toogle items
if ( ! $toggleParentLi.hasClass( 'active' ) ) {
$hasChildren.not( $allParentLis ).removeClass( 'active' ).children( 'ul' ).slideUp( 'fast' );
$toggleParentLi.addClass( 'active' ).children( 'ul' ).slideDown( 'fast' );
} else {
$toggleParentLi.removeClass( 'active' ).children( 'ul' ).slideUp( 'fast' );
}
// Return false
return false;
} );
// Add light overlay to content
$j( 'body' ).append( '<div class="oceanwp-sidr-overlay"></div>' );
$j( '.oceanwp-sidr-overlay' ).fadeIn( 300 );
// Close sidr when clicking overlay
$j( '.oceanwp-sidr-overlay' ).on( 'click', function() {
$j.sidr( 'close', 'sidr' );
return false;
} );
// Close on resize
$window.resize( function() {
if ( $window.width() >= 960 ) {
$j.sidr( 'close', 'sidr' );
}
} );
},
onClose : function() {
// Remove active dropdowns
$j( '.sidr-class-menu-item-has-children.active' ).removeClass( 'active' ).children( 'ul' ).hide();
// FadeOut overlay
$j( '.oceanwp-sidr-overlay' ).fadeOut( 300, function() {
$j( this ).remove();
} );
}
} );
// Replace sidr class in the icons classes
$j( '#sidr li.sidr-class-menu-item a i[class*="sidr-class-icon"]' ).each( function() {
var old_class = $j( this ).attr( 'class' ),
old_class = old_class.replace( 'sidr-class-icon-', 'icon-' );
$j( this ).attr( 'class', old_class );
} );
// Close sidr when clicking on close button
$j( 'a.sidr-class-toggle-sidr-close' ).on( 'click', function() {
$j.sidr( 'close', 'sidr' );
return false;
} );
// Close when clicking local scroll link
$j( 'li.sidr-class-local-scroll > a' ).on( 'click', function() {
$j.sidr( 'close', 'sidr' );
oceanwpScrollEffect();
return false;
} );
}
}