Muffin Menu widget - How to prevent dropdown menu from closing on click outside menu?

I'm using muffin menu widget to display menu inside sidebar on the page. Some menu items have dropdown submenus which close after clicking outside menu. It's very annoying if you have multilevel structure and you have to open every submenu again after clicking somewhere on the page. I'd like to prevent submenus from closing on click outside menu. How can I do this?

I've already tried to add this: $('.sub-menu').click(function(e) {e.stopPropagation();}) to custom JS, but it doesn't seem to work.

Comments

  • HI,
    sorry but we do not support custom JS modificationsa and ther is no option in the theme to change this.
    thanks
  • Thank you for your answer. I understand.

    I managed to found solution that works for me, so I will share it here for others.

    Just add this to custom JS in theme options:

    jQuery(function($){
          $( document ).ready(function() {
               if($('li.menu-item').hasClass('current-menu-ancestor')){
                     $('.current-menu-ancestor').toggleClass( 'hover' );
               }
          });
          $('body').on('click', function (e) {
          if (!$('li.menu-item').is(e.target) 
            && $('li.menu-item').has(e.target).length === 0 
            && $('.hover').has(e.target).length === 0
        ) {
            $('.current-menu-ancestor').toggleClass( 'hover' );
        }
    });
    });

Sign In or Register to comment.
This website uses cookies

We use cookies to personalise content and ads, to provide social media features and to analyse our traffic. We also share information about your use of our site with our social media, advertising and analytics partners who may combine it with other information that you’ve provided to them or that they’ve collected from your use of their services.

Cookies are small text files that can be used by websites to make a user's experience more efficient.

The law states that we can store cookies on your device if they are strictly necessary for the operation of this site. For all other types of cookies we need your permission. This means that cookies which are categorized as necessary, are processed based on GDPR Art. 6 (1) (f). All other cookies, meaning those from the categories preferences and marketing, are processed based on GDPR Art. 6 (1) (a) GDPR.

This site uses different types of cookies. Some cookies are placed by third party services that appear on our pages.

You can at any time change or withdraw your consent from the Cookie Declaration on our website.

Learn more about who we are, how you can contact us and how we process personal data in our Privacy Policy.

Please state your consent ID and date when you contact us regarding your consent.