Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Right-click menu in queue doesn't stay open #1710

Open
yang-musa opened this issue Sep 25, 2024 · 11 comments
Open

Right-click menu in queue doesn't stay open #1710

yang-musa opened this issue Sep 25, 2024 · 11 comments
Labels
bug This issue identifies a bug in Nuclear.

Comments

@yang-musa
Copy link

Platform:
Fedora 40 Workstation (Gnome, Wayland), fully updated as of 9/25/24

Nuclear version:
0.6.38 installed from Flathub

Description of the issue:
Steps to reproduce:

  1. Search or navigate to an album or playlist
  2. Select Play to populate queue on right
  3. If the first search result for a song is incorrect, right-click on song to bring up menu to try alternative search results
  4. right-click menu flickers up but doesn't stay open. It's impossible to select new songs from the dropdown menu
  5. This bug is slightly inconsistent. Very occasionally it DOES work as intended. But it's rare, almost always it flickers and I can't use it.

Please let me know if there's additional info I can provide to help resolve.

Thanks as always for a great app!

@yang-musa yang-musa added the bug This issue identifies a bug in Nuclear. label Sep 25, 2024
@nukeop
Copy link
Owner

nukeop commented Sep 25, 2024

Hey, thanks for reporting. Is it happening when there's other stuff in the queue? I think this is happening when other songs have their streams loaded, too many components are re-rendered then.

@yang-musa
Copy link
Author

I usually load a full album, so yes there would be 7-12 (?) other songs in the queue.

As a test I tried emptying the queue and then adding one song, and then trying to right-click. You're right - it worked as expected. So, there's something when there are multiple songs in the queue.

@nukeop
Copy link
Owner

nukeop commented Sep 25, 2024

Great, so this issue has been also reported by one more person, and I noticed it myself, pretty sure i know how to fix that so it shouldn't be long.

@yang-musa
Copy link
Author

I tested adding songs one at a time to see where the limit is. It worked fine until one of the songs was unable to load (the circular loading icon just keeps spinning). Then the right-click doesn't work.

@nukeop
Copy link
Owner

nukeop commented Sep 25, 2024

In the meantime you can just wait until all the songs in the queue finish loading, then the menu should be fine.

@yang-musa
Copy link
Author

yang-musa commented Sep 26, 2024

Sometimes the queue never finishes loading... See example. If there is an error on one song it just spins and spins. In that case there's no way to correct other songs.
Screenshot from 2024-09-26 11-05-10

Anyway, sounds like a fix is on the way, I can be patient :-)

Thanks!

@waldo121
Copy link
Contributor

Hey, thanks for reporting. Is it happening when there's other stuff in the queue? I think this is happening when other songs have their streams loaded, too many components are re-rendered then.

Yes, feels like the whole queue re-renders whenever 1 of the element changes.

@waldo121
Copy link
Contributor

@nukeop if you're not working on this already, mind sharing how you thought of fixing this?

@nukeop
Copy link
Owner

nukeop commented Oct 16, 2024

This is caused by the entire queue component re-rendering whenever anything in the queue subtree of Redux changes. The solution is to prevent these re-renders, either by picking parts of the Redux tree more selectively (e.g. individual songs in each queue item), or by memoizing something.

@nukeop
Copy link
Owner

nukeop commented Oct 16, 2024

Also to prevent errored out tracks from blocking the rest of the queue, it would be good to have a "locked with error" state where Nuclear won't make any further attempts at fetching the stream (this can happen when Youtube blocks playback on third party websites).

@waldo121
Copy link
Contributor

waldo121 commented Oct 17, 2024

This is caused by the entire queue component re-rendering whenever anything in the queue subtree of Redux changes. The solution is to prevent these re-renders, either by picking parts of the Redux tree more selectively (e.g. individual songs in each queue item), or by memoizing something.

I have another suggestion since I am not sure that fix would be enough to solve the problem(not sure I fully get yet how redux works). We could move the stream selection ui out of the popup and into the right panel (next to stream verification or at the top of the queue for example) or elsewhere. Stream selection might need rethinking then.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug This issue identifies a bug in Nuclear.
Projects
None yet
Development

No branches or pull requests

3 participants