var mobile_menu_visible = 0, mobile_menu_initialized = false, toggle_initialized = false, bootstrap_nav_initialized = false; $(document).ready(function(){ $sidebar = $('.sidebar'); window_width = $(window).width(); mda.initSidebarCheck(); }); $(window).resize(function(){ mda.initSidebarCheck(); }); mda = { initSidebarCheck: function(){ if($(window).width() <= 991){ if($sidebar.length != 0){ mda.initRightMenu(); } else{ mda.initBootstrapNavbarMenu(); } } }, initRightMenu: debounce(function(){ $sidebar_wrapper = $('.sidebar-wrapper'); if(!mobile_menu_initialized){ $navbar = $('nav').find('.navbar-collapse').first().clone(true); nav_content = ''; mobile_menu_content = ''; $navbar.children('ul').each(function(){ content_buff = $(this).html(); nav_content = nav_content + content_buff; }); nav_content = '
'; $navbar_form = $('nav').find('.navbar-form').clone(true); $sidebar_nav = $sidebar_wrapper.find('.nav-container'); // insert the navbar form before the sidebar list $nav_content = $(nav_content); $nav_content.insertBefore($sidebar_nav); $navbar_form.insertBefore($nav_content); $(".sidebar-wrapper .dropdown .dropdown-menu > li > a").click(function(event) { event.stopPropagation(); }); mobile_menu_initialized = true; } else { if($(window).width() > 991){ // reset all the additions that we made for the sidebar wrapper only if the screen is bigger than 991px $sidebar_wrapper.find('.navbar-form').remove(); $sidebar_wrapper.find('.nav-mobile-menu').remove(); mobile_menu_initialized = false; } } if(!toggle_initialized){ $toggle = $('.navbar-toggle'); $toggle.click(function (){ if(mobile_menu_visible == 1) { $('html').removeClass('nav-open'); $('.close-layer').remove(); setTimeout(function(){ $toggle.removeClass('toggled'); }, 400); mobile_menu_visible = 0;; } else { setTimeout(function(){ $toggle.addClass('toggled'); }, 430); $layer = $(''); $layer.appendTo(".wrapper"); setTimeout(function(){ $layer.addClass('visible'); }, 100); $layer.click(function() { $('html').removeClass('nav-open'); mobile_menu_visible = 0; $layer.removeClass('visible'); setTimeout(function(){ $layer.remove(); $toggle.removeClass('toggled'); }, 400); }); $('html').addClass('nav-open'); mobile_menu_visible = 1; } }); toggle_initialized = true; } },200), initBootstrapNavbarMenu: debounce(function(){ if(!bootstrap_nav_initialized){ $navbar = $('nav').find('.navbar-collapse').first().clone(true); nav_content = ''; mobile_menu_content = ''; //add the content from the regular header to the mobile menu $navbar.children('ul').each(function(){ content_buff = $(this).html(); nav_content = nav_content + content_buff; }); nav_content = ' '; $navbar.html(nav_content); $navbar.addClass('bootstrap-navbar'); // append it to the body, so it will come from the right side of the screen $('body').append($navbar); $toggle = $('.navbar-toggle'); $navbar.find('a').removeClass('btn btn-round btn-default'); $navbar.find('button').removeClass('btn-round btn-fill btn-info btn-primary btn-success btn-danger btn-warning btn-neutral'); $navbar.find('button').addClass('btn-simple btn-block'); $toggle.click(function (){ if(mobile_menu_visible == 1) { $('html').removeClass('nav-open'); $('.close-layer').remove(); setTimeout(function(){ $toggle.removeClass('toggled'); }, 400); mobile_menu_visible = 0; } else { setTimeout(function(){ $toggle.addClass('toggled'); }, 430); $layer = $(''); $layer.appendTo(".wrapper-full-page"); setTimeout(function(){ $layer.addClass('visible'); }, 100); $layer.click(function() { $('html').removeClass('nav-open'); mobile_menu_visible = 0; $layer.removeClass('visible'); setTimeout(function(){ $layer.remove(); $toggle.removeClass('toggled'); }, 400); }); $('html').addClass('nav-open'); mobile_menu_visible = 1; } }); bootstrap_nav_initialized = true; } }, 500), } // Returns a function, that, as long as it continues to be invoked, will not // be triggered. The function will be called after it stops being called for // N milliseconds. If `immediate` is passed, trigger the function on the // leading edge, instead of the trailing. function debounce(func, wait, immediate) { var timeout; return function() { var context = this, args = arguments; clearTimeout(timeout); timeout = setTimeout(function() { timeout = null; if (!immediate) func.apply(context, args); }, wait); if (immediate && !timeout) func.apply(context, args); }; };