reworked back_to_current_album and genre filter logic

This commit is contained in:
Martin Wagner 2021-04-08 14:56:01 +02:00
parent 6511fdd4af
commit af667eab8b

View File

@ -2128,6 +2128,16 @@ class ArtistWindow(FocusFrame):
current_char=artist[0] current_char=artist[0]
except: except:
self._store.append([artist, Pango.Weight.BOOK, "", Pango.Weight.BOOK]) self._store.append([artist, Pango.Weight.BOOK, "", Pango.Weight.BOOK])
if genre is not None:
self._treeview.set_cursor(Gtk.TreePath(0), None, False)
self._treeview.row_activated(Gtk.TreePath(0), self._column_name)
else:
song=ClientHelper.song_to_first_str_dict(self._client.currentsong())
if song != {}:
artist=song.get(self._settings.get_artist_type())
if artist is None:
artist=song.get("artist", "")
self.select(artist)
def _on_button_press_event(self, widget, event): def _on_button_press_event(self, widget, event):
if event.button in (2,3) and event.type == Gdk.EventType.BUTTON_PRESS: if event.button in (2,3) and event.type == Gdk.EventType.BUTTON_PRESS:
@ -2505,24 +2515,15 @@ class Browser(Gtk.Paned):
self.pack2(self._stack, True, False) self.pack2(self._stack, True, False)
def _back_to_current_album(self, *args): def _back_to_current_album(self, *args):
def callback():
try:
song=ClientHelper.song_to_first_str_dict(self._client.currentsong()) song=ClientHelper.song_to_first_str_dict(self._client.currentsong())
if song == {}: if song != {}:
return False
except MPDBase.ConnectionError:
return False
self.search_button.set_active(False) self.search_button.set_active(False)
# get artist name # get artist name
try: artist=song.get(self._settings.get_artist_type())
artist=song[self._settings.get_artist_type()] if artist is None:
except:
artist=song.get("artist", "") artist=song.get("artist", "")
# deactivate genre filter to show all artists (if needed) # deactivate genre filter to show all artists (if needed)
try: if song.get("genre", "") != self._genre_select.get_selected_genre():
if song["genre"] != self._genre_select.get_selected_genre():
self._genre_select.deactivate()
except:
self._genre_select.deactivate() self._genre_select.deactivate()
# select artist # select artist
if len(self._artist_window.get_selected_artists()) <= 1: # one artist selected if len(self._artist_window.get_selected_artists()) <= 1: # one artist selected
@ -2531,8 +2532,6 @@ class Browser(Gtk.Paned):
self.search_button.set_active(False) self.search_button.set_active(False)
self._artist_window.highlight_selected() self._artist_window.highlight_selected()
self._album_window.scroll_to_current_album() self._album_window.scroll_to_current_album()
return False
GLib.idle_add(callback) # ensure it will be executed even when albums are still loading
def _on_search_toggled(self, widget): def _on_search_toggled(self, widget):
if widget.get_active(): if widget.get_active():
@ -2542,7 +2541,6 @@ class Browser(Gtk.Paned):
self._stack.set_visible_child_name("albums") self._stack.set_visible_child_name("albums")
def _on_reconnected(self, *args): def _on_reconnected(self, *args):
self._back_to_current_album()
self.back_to_current_album_button.set_sensitive(True) self.back_to_current_album_button.set_sensitive(True)
self.search_button.set_sensitive(True) self.search_button.set_sensitive(True)