- Issue created by @rraney
- πΊπΈUnited States themodularlabAre you seeing any errors drupal watchdog or other php logs? If so can you share them? Are you only seeing issues with the mega menu when using webforms or is it occurring on other pages without webforms? I would also suggest upgrading to https://www.drupal.org/project/tb_megamenu/releases/3.0.0-alpha4 β . 
- πΊπΈUnited States rraneyI am seeing this php error. 
 Symfony\Component\HttpKernel\Exception\HttpException: The specified #ajax callback is empty or not callable. in Drupal\Core\Form\FormAjaxResponseBuilder->buildResponse() (line 67 of /home/limestonedouglas/public_html/web/core/lib/Drupal/Core/Form/FormAjaxResponseBuilder.php).I should say that I removed our captcha form field and the problem persisted. I also turned off Ajax, and completely refreshed cache in Drupal and browser, and the problem persisted. I never turned off Honeypot to see if that was the conflict. It did feel like an Ajax type of issue, which seem to be utterly inexplicable. I believe the issue happened on Mega Menu alpha4, then I downgraded to alpha2, and it still was a problem. 
- πΊπΈUnited States themodularlabAnd this is only occurring on pages using webform? In a non-production environment, what happens if you exclude the TB Megamenu block from a page that is experiencing the issue? Some ajax is used on the megamenu admin builder ui, but not really for rendering on a page on the front-end. 
- πΊπΈUnited States rraneyThe reason I am pinpointing this module is because the most recent change I made was adding the module. I started getting reports of issues. I simply started working backwards to see what may have caused it. When I uninstalled the module, there were no more issues with the webform. I wonder if there might be a conflict with a module used by webform. I will start doing more troubleshooting in my development environment. I'll try excluding the block from the webform page. I'll try different versions of the module. I'll try uninstalling honeypot and captcha modules. I will test other non-webform type pages. Thanks for your initial questions which help me figure out how to troubleshoot locally and in dev. 
- πΊπΈUnited States themodularlabNo problem. I'll leave this issue open in case others encounter this issue and/or you can find some more concrete evidence that this is a bug in TB Megamenu. Just out of curiosity, since you said you recently added this module, do you have at least one menu item added and have saved the mega menu builder? There's another issue in the issue queue ( https://www.drupal.org/project/tb_megamenu/issues/3291741 π¬ TB MegaMenu error: Post was missing the following information: menu_config Active ) where some folks narrowed it down to rendering a megamenu without any items in the menu. 
- πΊπΈUnited States rraneyYes I have items. It was working in production and I've reverted back to the old menu. 
- πΊπΈUnited States rraneyI cloned our production site to development less than 2 days ago. The site should be exactly what it was when I reported this issue. However, I noticed on development that the module is using version alpha2, while production is on alpha4. I am not having the issue on the development site, which is confounding. I decided to try upgrading the module in development. I noticed it upgrade the field_hidden module from 2.1.0 to 2.1.1. Is this a required module for TBM? Interestingly, this module is still at 2.1.0 in production while the TBM module has been upgraded there. I cleared cached and did some testing. I was unable to recreate the problem in development. Currently in development, the TBM module is alpha4 and the field_hidden module is 2.1.1. I decided to try upgrading field_hidden module to 2.1.1 in production, reinstall TBM and replace the menu block, then test again. Since I uninstalled the module (which I probably shouldn't have done), my menu is now not working. I'll have to spend time trying to get it to work again before I know anything more. 
- πΊπΈUnited States rraneyI got the Mega Menu working again. I went to the webform and tested it. The same issue as reported was there. I do not understand why it's working okay in test/dev but not in production. They should be almost identical. I'm going to have to think about what might be happening here. Again, the TBM module versions are the same - alpha4. The field_hidden modules are also the same. 
- πΊπΈUnited States rraneyI'm in a cPanel environment, not using git yet. So when I clone production to development, it actually doesn't do everything. I've noticed that I also have to manually copy the libraries folder. It also doesn't clone the root folder above /web, so I have to manually copy vendors (and composer files, etc.). The only thing I can think of right now is there might be a library or extension that is different in production right now which is possibly used by Mega Menu. I'd like to know all the dependencies for this module. 
- πΊπΈUnited States rraneySo sorry - I just noticed that the alpha4 module in development didn't successfully update. I'm running both of these commands in composer and it's not updating the module: 
 composer require 'drupal/tb_megamenu:^3.0@alpha'
 composer require 'drupal/tb_megamenu:3.0.0-alpha4'It says "nothing to remove or update". When I clear cache, the module still shows alpha2 being used in production. I'm going to try to downgrade the module in production and test the form again. 
- πΊπΈUnited States rraneyVoila. I downgraded to alpha2 and the issue has gone away! Now we're getting somewhere. Something that was changed in alpha3 or 4 is causing our issue, it seems. Here are some of our modules which are definitely or possibly associated with webform: 
 honeypot
 field_hidden
 conditional_fields
 webform_attachment
 honeypot
 field_permissions
 field_ui
 captcha
 recaptcha
 recaptcha_v3
- πΊπΈUnited States rraneyThere were no logged errors this morning when I did testing. However, here's a full trace for an error found on this page yesterday. Type php Date Tuesday, April 16, 2024 - 11:55 User Anonymous (not verified) Location https://www.douglascountyks.org/form/court-records-request?_wrapper_format=drupal_ajax&ajax_form=1 Referrer https://www.douglascountyks.org/form/court-records-request Message Symfony\Component\HttpKernel\Exception\HttpException: The specified #ajax callback is empty or not callable. in Drupal\Core\Form\FormAjaxResponseBuilder->buildResponse() (line 67 of /home/limestonedouglas/public_html/web/core/lib/Drupal/Core/Form/FormAjaxResponseBuilder.php). Severity Error Hostname 172.59.74.243 Operations Backtrace #0 /home/limestonedouglas/public_html/web/core/lib/Drupal/Core/Form/EventSubscriber/FormAjaxSubscriber.php(112): Drupal\Core\Form\FormAjaxResponseBuilder->buildResponse(Object(Symfony\Component\HttpFoundation\Request), Array, Object(Drupal\Core\Form\FormState), Array) #1 [internal function]: Drupal\Core\Form\EventSubscriber\FormAjaxSubscriber->onException(Object(Symfony\Component\HttpKernel\Event\ExceptionEvent), 'kernel.exceptio...', Object(Drupal\Component\EventDispatcher\ContainerAwareEventDispatcher)) #2 /home/limestonedouglas/public_html/web/core/lib/Drupal/Component/EventDispatcher/ContainerAwareEventDispatcher.php(111): call_user_func(Array, Object(Symfony\Component\HttpKernel\Event\ExceptionEvent), 'kernel.exceptio...', Object(Drupal\Component\EventDispatcher\ContainerAwareEventDispatcher)) #3 /home/limestonedouglas/public_html/vendor/symfony/http-kernel/HttpKernel.php(239): Drupal\Component\EventDispatcher\ContainerAwareEventDispatcher->dispatch(Object(Symfony\Component\HttpKernel\Event\ExceptionEvent), 'kernel.exceptio...') #4 /home/limestonedouglas/public_html/vendor/symfony/http-kernel/HttpKernel.php(91): Symfony\Component\HttpKernel\HttpKernel->handleThrowable(Object(Drupal\Core\Form\FormAjaxException), Object(Symfony\Component\HttpFoundation\Request), 1) #5 /home/limestonedouglas/public_html/web/core/lib/Drupal/Core/StackMiddleware/Session.php(58): Symfony\Component\HttpKernel\HttpKernel->handle(Object(Symfony\Component\HttpFoundation\Request), 1, true) #6 /home/limestonedouglas/public_html/web/core/lib/Drupal/Core/StackMiddleware/KernelPreHandle.php(48): Drupal\Core\StackMiddleware\Session->handle(Object(Symfony\Component\HttpFoundation\Request), 1, true) #7 /home/limestonedouglas/public_html/web/core/lib/Drupal/Core/StackMiddleware/ContentLength.php(28): Drupal\Core\StackMiddleware\KernelPreHandle->handle(Object(Symfony\Component\HttpFoundation\Request), 1, true) #8 /home/limestonedouglas/public_html/web/core/modules/big_pipe/src/StackMiddleware/ContentLength.php(32): Drupal\Core\StackMiddleware\ContentLength->handle(Object(Symfony\Component\HttpFoundation\Request), 1, true) #9 /home/limestonedouglas/public_html/web/core/modules/page_cache/src/StackMiddleware/PageCache.php(106): Drupal\big_pipe\StackMiddleware\ContentLength->handle(Object(Symfony\Component\HttpFoundation\Request), 1, true) #10 /home/limestonedouglas/public_html/web/core/modules/page_cache/src/StackMiddleware/PageCache.php(85): Drupal\page_cache\StackMiddleware\PageCache->pass(Object(Symfony\Component\HttpFoundation\Request), 1, true) #11 /home/limestonedouglas/public_html/web/core/modules/ban/src/BanMiddleware.php(50): Drupal\page_cache\StackMiddleware\PageCache->handle(Object(Symfony\Component\HttpFoundation\Request), 1, true) #12 /home/limestonedouglas/public_html/web/core/lib/Drupal/Core/StackMiddleware/ReverseProxyMiddleware.php(48): Drupal\ban\BanMiddleware->handle(Object(Symfony\Component\HttpFoundation\Request), 1, true) #13 /home/limestonedouglas/public_html/web/core/lib/Drupal/Core/StackMiddleware/NegotiationMiddleware.php(51): Drupal\Core\StackMiddleware\ReverseProxyMiddleware->handle(Object(Symfony\Component\HttpFoundation\Request), 1, true) #14 /home/limestonedouglas/public_html/web/core/lib/Drupal/Core/StackMiddleware/AjaxPageState.php(36): Drupal\Core\StackMiddleware\NegotiationMiddleware->handle(Object(Symfony\Component\HttpFoundation\Request), 1, true) #15 /home/limestonedouglas/public_html/web/core/lib/Drupal/Core/StackMiddleware/StackedHttpKernel.php(51): Drupal\Core\StackMiddleware\AjaxPageState->handle(Object(Symfony\Component\HttpFoundation\Request), 1, true) #16 /home/limestonedouglas/public_html/web/core/lib/Drupal/Core/DrupalKernel.php(704): Drupal\Core\StackMiddleware\StackedHttpKernel->handle(Object(Symfony\Component\HttpFoundation\Request), 1, true) #17 /home/limestonedouglas/public_html/web/index.php(19): Drupal\Core\DrupalKernel->handle(Object(Symfony\Component\HttpFoundation\Request)) #18 {main}
- π©πͺGermany LAKdevWe don't have webform installed but the error occurs on any form after firering too many click events, i. e. editing a lot of textfields or check/uncheck checkboxes several times. Here's how to reproduce the error: - Upgrading tb_megamenu to alpha4
- Open a form. On Firefox it is enough to check and uncheck a checkbox several times until the tab gets slower and then completely freezes. On Chrome I needed to edit a lot of textfields until the tab also freezed.
- CPU usage of tb_megamenu/dist/js/frontend.js skyrocketed
 I found out that this commit https://git.drupalcode.org/project/tb_megamenu/-/commit/a90a1c892369945a... is causing the issue. After commentig the following code in plugin.js out and running yarn build, everything works again: // Anytime there's a click outside a desktop menu that has arrows, close the menu. document.addEventListener('click', event => { if (!event.target.closest('.tbm') && !this.isMobile && this.hasArrows) { this.closeMenu(); } });
- πΊπΈUnited States rraneyThat's great you isolated the issue. The code seems like it should have a conditional 
 // Anytime the menu is open && there's a click outside the menu, close the menu
- πΊπΈUnited States dasginganinja Bethlehem, PAI can confirm that there are event listeners getting added on each click event for things not in the TB Megamenu. It seems that more and more of these listeners keep getting added as well and that causes a linear/exponential amount of work to stack up, causing the page to become unresponsive. This click event should be faster. Maybe the handleTouch() function needs some love so we don't get all of these defined? 
- First commit to issue fork.
- Status changed to Needs reviewover 1 year ago 1:02am 24 April 2024
- πΊπΈUnited States kurttrowbridgeWe also ran into this problem, just as described in #16 (whenever a click event is triggered; you don't even have to click on interactive elements, though things like forms and accordions that require user interaction are naturally where it's most obvious), while running alpha3. Downgrading to alpha2 fixed the issue. Based on the suggestion in #15, I provided an MR that tracks whether or not the menu is open, and adjusted the JavaScript in two problematic places so closeMenu()is only called if the menu isn't currently open. (I also snuck in a minor typo fix.) This appears to be working for us, but additional reviews/suggestions are much appreciated. Thanks!If credited, please also credit my coworker joshcavindergmailcom β , who helped me troubleshoot. 
- Status changed to RTBCover 1 year ago 2:47pm 30 April 2024
- πΊπΈUnited States dasginganinja Bethlehem, PAI can confirm that the changes in #19 in MR !88 were able to resolve our issues on our site. --- on a sidenote: 
 That nvmrc is WAY outdated @ Node 10...
- πΊπΈUnited States rraneyI upgraded the module in my test environment. Then I replaced code using the MR!18. I tested my webform after flushing cache. I do not have the same issue as before. I cannot confirm that the menu is actually working at this time. I am having issues with the dropdowns regardless of the module version, but regarding this issue, the merge request is working for me. 
- Status changed to Needs workover 1 year ago 2:08pm 6 May 2024
- Status changed to Needs reviewover 1 year ago 2:13pm 6 May 2024
- πΊπΈUnited States rraneyMy apologies. In my deployment to production, I missed a step apparently. I tried a second time and it's now working in production. I don't want to change the status again since I'm not a collaborator for this module. If you feel it's been tested enough, feel free to change it back to "tested". Again, sorry but thanks for everyone's assistance. 
- Status changed to RTBCover 1 year ago 10:13am 14 May 2024
- π¬π§United Kingdom heblHey, I can also confirm that the changes in #19 and MR !88 fixed this issue for our case. Changing status to RTBC. Thanks to @KurtTrowbridge for your work on this. 
- First commit to issue fork.
- π³πΏNew Zealand fraserthompson Dunedin, New ZealandMR !88 solves the problem, but doesn't address the root cause. There are also numerous other issues with event listeners in this release. Multiple identical document level event listeners are being added more than once, which may or may not effect performance, but in any case is bad practice. Even if we check for the menu being open before trying to close it, it still adds an event listener unnecessarily every time the menu is closed. It also adds event listeners multiple times for each menu link. The above merge request should fix all of this. 
- First commit to issue fork.
- Status changed to Needs reviewover 1 year ago 4:38pm 21 May 2024
- πΊπΈUnited States knaffles@ fraserthompson - Thanks for your work fixing those event listeners. I made one additional change so that `isOpen` is set to true if/when the user opens the mobile menu by clicking the mobile toggle button. Otherwise, the clicks/focus outside of the menu only result in a closure on mobile if one of the submenus has already been opened. 
- 
            
              knaffles β
             committed cd3750b8 on 3.x authored by 
            
              fraserthompson β
            
Issue #3441346 by fraserthompson, KurtTrowbridge, LAKdev, rraney: Mega... 
 
- 
            
              knaffles β
             committed cd3750b8 on 3.x authored by 
            
              fraserthompson β
            
- Status changed to Fixedover 1 year ago 9:27pm 22 May 2024
- Automatically closed - issue fixed for 2 weeks with no activity. 
- πΊπΈUnited States cpierce42This is still not released. Downloading the latest tb_megamenu the patch is not present as of 3.x-apha-4. 
 Thought I would mention it in case anyone else is having the same problem thinking it is fixed.
- π΅π°Pakistan masood ahmad#34, Yes, I am facing the same issue even with the latest release. 
- πΊπΈUnited States bcobinThank you SO much for this! I was getting complaints from a client that some form submissions weren't getting through and I was going nuts trying to reproduce the issue. It's been several days now and it looks like the merge and patch did the trick... thank you SO much! I suggest this should be committed soonest β thanks again! 
- πΊπΈUnited States rraneyAm I correct that a patch is currently the only solution to this issue? Is there a maintainer following this? 
- πΊπΈUnited States themodularlab@rraney, Yes, I have been following this. Really sorry this issue (and others are still unreleased) I hope to release this and other fixes soon. For now, it seems the patch resolves things. The other maintainers who used to help with module are not longer able to and I have extremely limited bandwidth these days. I'm going to update the module page soon to look for maintainer help. I really appreciate everyone's help on this. 
- πΊπΈUnited States rraneyUnderstandable! I just wanted some clarification because it said it was merged and fixed. I am not as knowledgeable as I should be about the whole process. 
- πΊπΈUnited States themodularlabSetting this state back to reviewed and tested. I will update once I can get a release out. 
- Status changed to RTBC6 months ago 6:33pm 7 May 2025
- π¨π΄Colombia jucedogiJust ran into this whilst trying to enable slider/carousel modules such as splide and slick. MR 88 fixes this as has been stated in previous comments. The issue I am seeing is that MR 90 can't be applied if MR 88 has been applied and vice versa. What I understand is going on here is that this thread originally set out to fix what MR 88 fixes and this other issue was fixed here with MR 90 instead. Resulting now with MR 88 not being able to merge. So basically if you are having issues with this as I did, get the patch file for MR 88 and ignore MR 90 for now since you will only be able to apply one of the two. 
- πΊπΈUnited States earthday47 New York+1 we experienced this issue and applying MR 88 resolved it. 
 Since this is pretty nasty and hard to catch during QA, any chance we can get a new release published?
- πΊπΈUnited States superfluousapostrophe+1 MR 90 fixed the issues for us on 10.5.1 
- πΊπΈUnited States themodularlabJust to be clear, MR 90 includes fixes from MR 88 as well as other changes. As far as I can tell, MR 90 fixes this issue. It has been merged. I'm going to mark this as fixed. Please raise a new ticket if there are still issues here. And make sure to related it to this ticket. Users can either apply MR 90 as a patch OR switch to the dev version until a new release is out.