diff --git a/deluge/ui/gtkui/glade/preferences_dialog.glade b/deluge/ui/gtkui/glade/preferences_dialog.glade
index 189c81793..16bab196a 100644
--- a/deluge/ui/gtkui/glade/preferences_dialog.glade
+++ b/deluge/ui/gtkui/glade/preferences_dialog.glade
@@ -7,11 +7,12 @@
5
Preferences
center-on-parent
- 510
- 530
+ 500
+ 560
True
dialog
False
+
diff --git a/deluge/ui/gtkui/gtkui.py b/deluge/ui/gtkui/gtkui.py
index 76392b986..bbb99ffcf 100644
--- a/deluge/ui/gtkui/gtkui.py
+++ b/deluge/ui/gtkui/gtkui.py
@@ -125,6 +125,8 @@ DEFAULT_PREFS = {
"window_y_pos": 0,
"window_width": 640,
"window_height": 480,
+ "pref_dialog_width": None,
+ "pref_dialog_height": None,
"window_pane_position": -1,
"tray_download_speed_list" : [5.0, 10.0, 30.0, 80.0, 300.0],
"tray_upload_speed_list" : [5.0, 10.0, 30.0, 80.0, 300.0],
diff --git a/deluge/ui/gtkui/preferences.py b/deluge/ui/gtkui/preferences.py
index 5525211d1..7a40fed2f 100644
--- a/deluge/ui/gtkui/preferences.py
+++ b/deluge/ui/gtkui/preferences.py
@@ -51,7 +51,6 @@ import deluge.configmanager
class Preferences(component.Component):
def __init__(self):
component.Component.__init__(self, "Preferences")
- self.window = component.get("MainWindow")
self.glade = gtk.glade.XML(
pkg_resources.resource_filename("deluge.ui.gtkui",
"glade/preferences_dialog.glade"))
@@ -61,6 +60,8 @@ class Preferences(component.Component):
self.notebook = self.glade.get_widget("notebook")
self.gtkui_config = ConfigManager("gtkui.conf")
+ self.load_pref_dialog_state()
+
self.glade.get_widget("image_magnet").set_from_file(
deluge.common.get_pixmap("magnet.png"))
@@ -111,7 +112,8 @@ class Preferences(component.Component):
"on_button_find_plugins_clicked": self._on_button_find_plugins_clicked,
"on_button_cache_refresh_clicked": self._on_button_cache_refresh_clicked,
"on_combo_proxy_type_changed": self._on_combo_proxy_type_changed,
- "on_button_associate_magnet_clicked": self._on_button_associate_magnet_clicked
+ "on_button_associate_magnet_clicked": self._on_button_associate_magnet_clicked,
+ "on_pref_dialog_configure_event": self.on_pref_dialog_configure_event,
})
# These get updated by requests done to the core
@@ -768,6 +770,16 @@ class Preferences(component.Component):
self.hide()
return True
+ def load_pref_dialog_state(self):
+ w = self.gtkui_config["pref_dialog_width"]
+ h = self.gtkui_config["pref_dialog_height"]
+ if w != None and h != None:
+ self.pref_dialog.resize(w, h)
+
+ def on_pref_dialog_configure_event(self, widget, event):
+ self.gtkui_config["pref_dialog_width"] = event.width
+ self.gtkui_config["pref_dialog_height"] = event.height
+
def on_toggle(self, widget):
"""Handles widget sensitivity based on radio/check button values."""
try: