Don't throw errors when de-registering notifications.

If sound notifications is not possible or disabled, also disable the sound customization notebook page.
This commit is contained in:
Pedro Algarvio 2009-11-22 08:14:09 +00:00
parent 7812f7b4e4
commit 1cb42252b8
3 changed files with 39 additions and 22 deletions

View File

@ -107,15 +107,18 @@ class CustomNotifications(object):
client.register_event_handler(eventtype, wrapper) client.register_event_handler(eventtype, wrapper)
def _deregister_custom_provider(self, kind, eventtype): def _deregister_custom_provider(self, kind, eventtype):
wrapper, handler = self.custom_notifications[kind][eventtype]
try: try:
component.get("EventManager").deregister_event_handler( wrapper, handler = self.custom_notifications[kind][eventtype]
eventtype, wrapper try:
) component.get("EventManager").deregister_event_handler(
eventtype, wrapper
)
except KeyError:
from deluge.ui.client import client
client.deregister_event_handler(eventtype, wrapper)
self.custom_notifications[kind].pop(eventtype)
except KeyError: except KeyError:
from deluge.ui.client import client pass
client.deregister_event_handler(eventtype, wrapper)
self.custom_notifications[kind].pop(eventtype)
def _handled_eventtype(self, eventtype, handler): def _handled_eventtype(self, eventtype, handler):
if eventtype not in known_events: if eventtype not in known_events:

View File

@ -454,7 +454,7 @@
</widget> </widget>
</child> </child>
<child> <child>
<widget class="GtkLabel" id="label10"> <widget class="GtkLabel" id="settings_page_label">
<property name="visible">True</property> <property name="visible">True</property>
<property name="label" translatable="yes">Settings</property> <property name="label" translatable="yes">Settings</property>
</widget> </widget>
@ -507,7 +507,7 @@
</packing> </packing>
</child> </child>
<child> <child>
<widget class="GtkLabel" id="label11"> <widget class="GtkLabel" id="subscriptions_page_label">
<property name="visible">True</property> <property name="visible">True</property>
<property name="label" translatable="yes">Subscriptions</property> <property name="label" translatable="yes">Subscriptions</property>
</widget> </widget>
@ -518,7 +518,7 @@
</packing> </packing>
</child> </child>
<child> <child>
<widget class="GtkVBox" id="vbox6"> <widget class="GtkVBox" id="sounds_page">
<property name="visible">True</property> <property name="visible">True</property>
<property name="orientation">vertical</property> <property name="orientation">vertical</property>
<child> <child>
@ -588,7 +588,7 @@
</packing> </packing>
</child> </child>
<child> <child>
<widget class="GtkLabel" id="label13"> <widget class="GtkLabel" id="sounds_page_label">
<property name="visible">True</property> <property name="visible">True</property>
<property name="label" translatable="yes">Sound Customization</property> <property name="label" translatable="yes">Sound Customization</property>
</widget> </widget>

View File

@ -295,9 +295,17 @@ class GtkUI(GtkPluginBase, GtkUiNotifications):
self.glade.get_widget("popup_enabled").set_property('sensitive', self.glade.get_widget("popup_enabled").set_property('sensitive',
False) False)
if not SOUND_AVAILABLE: if not SOUND_AVAILABLE:
# for widget_name in ('sound_enabled', 'sound_path', 'sounds_page',
# 'sounds_page_label'):
# self.glade.get_widget(widget_name).set_property('sensitive',
# False)
self.glade.get_widget("sound_enabled").set_property('sensitive', self.glade.get_widget("sound_enabled").set_property('sensitive',
False) False)
self.glade.get_widget('sound_path').set_property('sensitive', False) self.glade.get_widget('sound_path').set_property('sensitive', False)
self.glade.get_widget('sounds_page').set_property('sensitive',
False)
self.glade.get_widget('sounds_page_label').set_property('sensitive',
False)
self.systray = component.get("SystemTray") self.systray = component.get("SystemTray")
if not hasattr(self.systray, 'tray'): if not hasattr(self.systray, 'tray'):
@ -654,23 +662,29 @@ class GtkUI(GtkPluginBase, GtkUiNotifications):
log.debug("dialog should have been shown") log.debug("dialog should have been shown")
def on_enabled_toggled(self, widget): def on_enabled_toggled(self, widget):
if widget.get_active(): for widget_name in ('smtp_host', 'smtp_port', 'smtp_user', 'smtp_pass',
for widget in ('smtp_host', 'smtp_port', 'smtp_user', 'smtp_pass', 'smtp_pass', 'smtp_tls', 'smtp_from',
'smtp_pass', 'smtp_tls', 'smtp_from', 'smtp_recipients'):
'smtp_recipients'): self.glade.get_widget(widget_name).set_property('sensitive',
self.glade.get_widget(widget).set_property('sensitive', True) widget.get_active())
else:
for widget in ('smtp_host', 'smtp_port', 'smtp_user', 'smtp_pass',
'smtp_pass', 'smtp_tls', 'smtp_from',
'smtp_recipients'):
self.glade.get_widget(widget).set_property('sensitive', False)
def on_sound_enabled_toggled(self, widget): def on_sound_enabled_toggled(self, widget):
if widget.get_active(): if widget.get_active():
self.glade.get_widget('sound_path').set_property('sensitive', True) self.glade.get_widget('sound_path').set_property('sensitive', True)
self.glade.get_widget('sounds_page').set_property('sensitive',
True)
self.glade.get_widget('sounds_page_label').set_property('sensitive',
True)
else: else:
self.glade.get_widget('sound_path').set_property('sensitive', False) self.glade.get_widget('sound_path').set_property('sensitive', False)
self.glade.get_widget('sounds_page').set_property('sensitive',
False)
self.glade.get_widget('sounds_page_label').set_property('sensitive',
False)
# for widget_name in ('sounds_path', 'sounds_page', 'sounds_page_label'):
# self.glade.get_widget(widget_name).set_property('sensitive',
# widget.get_active())
def _on_email_col_toggled(self, cell, path): def _on_email_col_toggled(self, cell, path):
self.subscriptions_model[path][SUB_NOT_EMAIL] = \ self.subscriptions_model[path][SUB_NOT_EMAIL] = \