improved disconnect

This commit is contained in:
Martin Wagner 2020-08-13 17:40:27 +02:00
parent 0171b257d1
commit 7a75ad74e9

View File

@ -1531,6 +1531,12 @@ class AlbumIconView(Gtk.IconView):
self.stop_flag=True self.stop_flag=True
pass pass
def clear(self):
self.store.clear()
# workaround (scrollbar still visible after clear)
self.set_model(None)
self.set_model(self.store)
def tooltip_settings(self, *args): def tooltip_settings(self, *args):
if self.settings.get_boolean("show-album-view-tooltips"): if self.settings.get_boolean("show-album-view-tooltips"):
self.set_tooltip_column(3) self.set_tooltip_column(3)
@ -1713,7 +1719,7 @@ class AlbumView(FocusFrame):
def clear(self, *args): def clear(self, *args):
if self.done: if self.done:
self.iconview.store.clear() self.iconview.clear()
elif not self.clear in self.pending: elif not self.clear in self.pending:
self.iconview.stop_flag=True self.iconview.stop_flag=True
self.pending.append(self.clear) self.pending.append(self.clear)
@ -3250,6 +3256,8 @@ class PlaybackOptions(Gtk.Box):
self.single_changed=self.client.emitter.connect("single", self.single_refresh) self.single_changed=self.client.emitter.connect("single", self.single_refresh)
self.consume_changed=self.client.emitter.connect("consume", self.consume_refresh) self.consume_changed=self.client.emitter.connect("consume", self.consume_refresh)
self.volume_changed=self.client.emitter.connect("volume_changed", self.volume_refresh) self.volume_changed=self.client.emitter.connect("volume_changed", self.volume_refresh)
self.client.emitter.connect("disconnected", self.on_disconnected)
self.client.emitter.connect("reconnected", self.on_reconnected)
self.settings.connect("changed::icon-size", self.on_icon_size_changed) self.settings.connect("changed::icon-size", self.on_icon_size_changed)
# packing # packing
@ -3305,6 +3313,17 @@ class PlaybackOptions(Gtk.Box):
icon.set_pixel_size(pixel_size) icon.set_pixel_size(pixel_size)
self.volume_button.set_property("size", self.settings.get_gtk_icon_size("icon-size")) self.volume_button.set_property("size", self.settings.get_gtk_icon_size("icon-size"))
def on_reconnected(self, *args):
self.set_sensitive(True)
def on_disconnected(self, *args):
self.set_sensitive(False)
self.repeat_refresh(None, False)
self.random_refresh(None, False)
self.single_refresh(None, False)
self.consume_refresh(None, False)
self.volume_refresh(None, 0)
################# #################
# other dialogs # # other dialogs #
################# #################
@ -3560,7 +3579,6 @@ class MainWindow(Gtk.ApplicationWindow):
def on_reconnected(self, *args): def on_reconnected(self, *args):
self.dbus_service.acquire_name() self.dbus_service.acquire_name()
self.control.set_sensitive(True) self.control.set_sensitive(True)
self.play_opts.set_sensitive(True)
def on_disconnected(self, *args): def on_disconnected(self, *args):
self.dbus_service.release_name() self.dbus_service.release_name()
@ -3571,7 +3589,6 @@ class MainWindow(Gtk.ApplicationWindow):
self.set_title("mpdevil (not connected)") self.set_title("mpdevil (not connected)")
self.songid_playing=None self.songid_playing=None
self.control.set_sensitive(False) self.control.set_sensitive(False)
self.play_opts.set_sensitive(False)
def on_key_press_event(self, widget, event): def on_key_press_event(self, widget, event):
ctrl = (event.state & Gdk.ModifierType.CONTROL_MASK) ctrl = (event.state & Gdk.ModifierType.CONTROL_MASK)