[gnome-music/wip/jfelder/songwidget-listboxrow: 8/8] songwidget: Directly inherit from GtkListBoxRow




commit 3ede6188e13170ac906870fe493a149a2ef74ae7
Author: Jean Felder <jfelder src gnome org>
Date:   Sat May 8 17:53:16 2021 +0200

    songwidget: Directly inherit from GtkListBoxRow
    
    This removes a need for a GtkEventBox

 data/ui/SongWidget.ui                   |  3 ++-
 gnomemusic/views/searchview.py          | 12 +++---------
 gnomemusic/widgets/disclistboxwidget.py | 15 ++++-----------
 gnomemusic/widgets/playlistswidget.py   | 13 +++++--------
 gnomemusic/widgets/songwidget.py        |  2 +-
 5 files changed, 15 insertions(+), 30 deletions(-)
---
diff --git a/data/ui/SongWidget.ui b/data/ui/SongWidget.ui
index bb9e6596f..e60ad30e6 100644
--- a/data/ui/SongWidget.ui
+++ b/data/ui/SongWidget.ui
@@ -2,8 +2,9 @@
 <!-- Generated with glade 3.20.0 -->
 <interface>
   <requires lib="gtk+" version="3.10"/>
-  <template class="SongWidget" parent="GtkEventBox">
+  <template class="SongWidget" parent="GtkListBoxRow">
     <property name="visible">True</property>
+    <property name="selectable">False</property>
     <property name="can_focus">False</property>
     <signal name="drag_data_received" handler="_on_drag_data_received"/>
     <child>
diff --git a/gnomemusic/views/searchview.py b/gnomemusic/views/searchview.py
index 918ae05b9..6dc50a325 100644
--- a/gnomemusic/views/searchview.py
+++ b/gnomemusic/views/searchview.py
@@ -163,11 +163,7 @@ class SearchView(Gtk.Stack):
             GObject.BindingFlags.BIDIRECTIONAL
             | GObject.BindingFlags.SYNC_CREATE)
 
-        row = Gtk.ListBoxRow()
-        row.props.selectable = False
-        row.add(song_widget)
-
-        return row
+        return song_widget
 
     def _create_album_widget(self, corealbum):
         album_widget = AlbumCover(corealbum)
@@ -246,8 +242,7 @@ class SearchView(Gtk.Stack):
 
     @Gtk.Template.Callback()
     def _song_activated(
-            self, list_box: Gtk.ListBox, row: Gtk.ListBoxRow) -> bool:
-        song_widget = row.get_child()
+            self, list_box: Gtk.ListBox, song_widget: SongWidget) -> bool:
         if song_widget.props.select_click:
             song_widget.props.select_click = False
             return True
@@ -433,8 +428,7 @@ class SearchView(Gtk.Stack):
         if self.props.state == SearchView.State.MAIN:
             with self._model.freeze_notify():
                 def song_select(child):
-                    song_widget = child.get_child()
-                    song_widget.props.coresong.props.selected = value
+                    child.props.coresong.props.selected = value
 
                 self._songs_listbox.foreach(song_select)
                 self._album_flowbox.foreach(child_select)
diff --git a/gnomemusic/widgets/disclistboxwidget.py b/gnomemusic/widgets/disclistboxwidget.py
index 2a7c31fdc..77ee0d871 100644
--- a/gnomemusic/widgets/disclistboxwidget.py
+++ b/gnomemusic/widgets/disclistboxwidget.py
@@ -73,16 +73,14 @@ class DiscBox(Gtk.ListBoxRow):
     def select_all(self):
         """Select all songs"""
         def child_select_all(child):
-            song_widget = child.get_child()
-            song_widget.props.coresong.props.selected = True
+            child.props.coresong.props.selected = True
 
         self._list_box.foreach(child_select_all)
 
     def deselect_all(self):
         """Deselect all songs"""
         def child_deselect_all(child):
-            song_widget = child.get_child()
-            song_widget.props.coresong.props.selected = False
+            child.props.coresong.props.selected = False
 
         self._list_box.foreach(child_deselect_all)
 
@@ -94,16 +92,11 @@ class DiscBox(Gtk.ListBoxRow):
             GObject.BindingFlags.BIDIRECTIONAL
             | GObject.BindingFlags.SYNC_CREATE)
 
-        row = Gtk.ListBoxRow()
-        row.props.selectable = False
-        row.add(song_widget)
-
-        return row
+        return song_widget
 
     @Gtk.Template.Callback()
     def _song_activated(
-            self, list_box: Gtk.ListBox, row: Gtk.ListBoxRow) -> bool:
-        song_widget = row.get_child()
+            self, list_box: Gtk.ListBox, song_widget: SongWidget) -> bool:
         if song_widget.props.select_click:
             song_widget.props.select_click = False
             return True
diff --git a/gnomemusic/widgets/playlistswidget.py b/gnomemusic/widgets/playlistswidget.py
index 3cc2e4b96..ce3668fc4 100644
--- a/gnomemusic/widgets/playlistswidget.py
+++ b/gnomemusic/widgets/playlistswidget.py
@@ -118,8 +118,8 @@ class PlaylistsWidget(Gtk.Box):
 
     @Gtk.Template.Callback()
     def _on_song_activated(
-            self, list_box: Gtk.ListBox, row: Gtk.ListBoxRow) -> bool:
-        coresong = row.get_child().props.coresong
+            self, list_box: Gtk.ListBox, song_widget: SongWidget) -> bool:
+        coresong = song_widget.props.coresong
         self._play(coresong)
         return True
 
@@ -163,15 +163,13 @@ class PlaylistsWidget(Gtk.Box):
 
     def _play_song(self, menuitem, data=None):
         selected_row = self._songs_list.get_selected_row()
-        song_widget = selected_row.get_child()
-        coresong = song_widget.props.coresong
+        coresong = selected_row.props.coresong
         self._songs_list.unselect_all()
         self._play(coresong)
 
     def _add_song_to_playlist(self, menuitem, data=None):
         selected_row = self._songs_list.get_selected_row()
-        song_widget = selected_row.get_child()
-        coresong = song_widget.props.coresong
+        coresong = selected_row.props.coresong
 
         playlist_dialog = PlaylistDialog(self._application)
         playlist_dialog.props.transient_for = self._window
@@ -185,8 +183,7 @@ class PlaylistsWidget(Gtk.Box):
     def _stage_song_for_deletion(self, menuitem, data=None):
         selected_row = self._songs_list.get_selected_row()
         position = selected_row.get_index()
-        song_widget = selected_row.get_child()
-        coresong = song_widget.props.coresong
+        coresong = selected_row.props.coresong
 
         current_playlist = self._playlists_view.props.current_playlist
 
diff --git a/gnomemusic/widgets/songwidget.py b/gnomemusic/widgets/songwidget.py
index 2a1d61776..45a1a0e62 100644
--- a/gnomemusic/widgets/songwidget.py
+++ b/gnomemusic/widgets/songwidget.py
@@ -36,7 +36,7 @@ from gnomemusic.widgets.starimage import StarImage  # noqa: F401
 
 
 @Gtk.Template(resource_path='/org/gnome/Music/ui/SongWidget.ui')
-class SongWidget(Gtk.EventBox):
+class SongWidget(Gtk.ListBoxRow):
     """The single song widget used in DiscListBox
 
     Contains


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]