text icon indicating copy to clipboard operation
text copied to clipboard

MenuBar throws errors on master (focus-trap too much recursion)

Open susnux opened this issue 3 years ago • 5 comments

On master the emoji picker does not work any more after switching to the beta version of the @nextcloud/vue components. Clicking on an emoji does not insert it. Using any other menu entry with a submenu (like callouts or headings) slows down the whole browser thread.

The console is spammed with the following error message on Firefox (103.0.2):

Uncaught InternalError: too much recursion

``` r focus-visible.js:41 t focus-visible.js:98 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 focus-visible.js:41:6 r focus-visible.js:41 t focus-visible.js:98 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 e focus-trap.esm.js:379 g focus-trap.esm.js:446 e focus-trap.esm.js:379 g focus-trap.esm.js:447 ```

On chromium (104.0.5112) I get this errors: localhost-1661521467910.log

susnux avatar Aug 26 '22 13:08 susnux

cc @vinicius73 since you worked on the focus trap bits as well

juliusknorr avatar Aug 26 '22 13:08 juliusknorr

I'm also seeing this when trying to change a text file share to be editable.

screenshots of the trace

Bildschirmfoto vom 2022-08-31 10-38-37 Bildschirmfoto vom 2022-08-31 10-39-06 Bildschirmfoto vom 2022-08-31 10-40-12

max-nextcloud avatar Aug 31 '22 08:08 max-nextcloud

Related: https://github.com/nextcloud/nextcloud-vue/issues/3154

vinicius73 avatar Sep 06 '22 18:09 vinicius73

https://github.com/focus-trap/focus-trap/issues/428

vinicius73 avatar Sep 12 '22 17:09 vinicius73

The same is true for the formatting help when trying to open it on mobile.

mejo- avatar Sep 13 '22 09:09 mejo-