summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCalum Lind <calumlind+deluge@gmail.com>2023-12-02 19:41:09 +0100
committerCalum Lind <calumlind+deluge@gmail.com>2023-12-02 22:20:22 +0100
commitfa8d19335ea78f59ee17a5d86ac65ca60d219804 (patch)
tree97faeef9ac9979a4aaca7051f9c86a2e113470f9
parent[Core] Remove usage of deprecated torrent status.paused (diff)
downloaddeluge-fa8d19335ea78f59ee17a5d86ac65ca60d219804.tar.xz
deluge-fa8d19335ea78f59ee17a5d86ac65ca60d219804.zip
[GTK3] Fix changing torrent ownership
The change ownership menu item was broken due to Gtk deprecation changes in commit #bcaaeac. Fixed by correctly setting the RadioMenuItem group Refactored to simplify the code Removed dead or unneeded code Fixes: https://dev.deluge-torrent.org/ticket/3610
-rw-r--r--deluge/ui/gtk3/menubar.py44
-rw-r--r--deluge/ui/gtk3/preferences.py1
2 files changed, 14 insertions, 31 deletions
diff --git a/deluge/ui/gtk3/menubar.py b/deluge/ui/gtk3/menubar.py
index 328cb7e4d..9165320fe 100644
--- a/deluge/ui/gtk3/menubar.py
+++ b/deluge/ui/gtk3/menubar.py
@@ -578,42 +578,26 @@ class MenuBar(component.Component):
component.get('FilterTreeView').update()
def _on_known_accounts(self, known_accounts):
- known_accounts_to_log = []
- for account in known_accounts:
- account_to_log = {}
- for key, value in account.copy().items():
- if key == 'password':
- value = '*' * 10
- account_to_log[key] = value
- known_accounts_to_log.append(account_to_log)
- log.debug('_on_known_accounts: %s', known_accounts_to_log)
+ menuitem_change_owner = self.builder.get_object('menuitem_change_owner')
if len(known_accounts) <= 1:
+ menuitem_change_owner.set_visible(False)
return
- self.builder.get_object('menuitem_change_owner').set_visible(True)
-
- self.change_owner_submenu = Gtk.Menu()
- self.change_owner_submenu_items = {}
- maingroup = Gtk.RadioMenuItem()
-
- self.change_owner_submenu_items[None] = Gtk.RadioMenuItem(maingroup)
+ self.users_menu = Gtk.Menu()
+ self.users_menu_items = {}
+ menu_group = None
for account in known_accounts:
username = account['username']
- item = Gtk.RadioMenuItem.new_with_label(maingroup, username)
- self.change_owner_submenu_items[username] = item
- self.change_owner_submenu.append(item)
+ item = Gtk.RadioMenuItem.new_with_label(menu_group, username)
+ menu_group = item.get_group()
item.connect('toggled', self._on_change_owner_toggled, username)
+ self.users_menu_items[username] = item
+ self.users_menu.append(item)
- self.change_owner_submenu.show_all()
- self.change_owner_submenu_items[None].set_active(True)
- self.change_owner_submenu_items[None].hide()
- self.builder.get_object('menuitem_change_owner').connect(
- 'activate', self._on_change_owner_submenu_active
- )
- self.builder.get_object('menuitem_change_owner').set_submenu(
- self.change_owner_submenu
- )
+ self.users_menu.show_all()
+ menuitem_change_owner.set_submenu(self.users_menu)
+ menuitem_change_owner.set_visible(True)
def _on_known_accounts_fail(self, reason):
self.builder.get_object('menuitem_change_owner').set_visible(False)
@@ -622,13 +606,13 @@ class MenuBar(component.Component):
log.debug('_on_change_owner_submenu_active')
selected = component.get('TorrentView').get_selected_torrents()
if len(selected) > 1:
- self.change_owner_submenu_items[None].set_active(True)
+ self.users_menu_items[None].set_active(True)
return
torrent_owner = component.get('TorrentView').get_torrent_status(selected[0])[
'owner'
]
- for username, item in self.change_owner_submenu_items.items():
+ for username, item in self.users_menu_items.items():
item.set_active(username == torrent_owner)
def _on_change_owner_toggled(self, widget, username):
diff --git a/deluge/ui/gtk3/preferences.py b/deluge/ui/gtk3/preferences.py
index 3463b70c0..a024a5958 100644
--- a/deluge/ui/gtk3/preferences.py
+++ b/deluge/ui/gtk3/preferences.py
@@ -117,7 +117,6 @@ class Preferences(component.Component):
# Setup accounts tab lisview
self.accounts_levels_mapping = None
- self.accounts_authlevel = self.builder.get_object('accounts_authlevel')
self.accounts_liststore = Gtk.ListStore(str, str, str, int)
self.accounts_liststore.set_sort_column_id(
ACCOUNTS_USERNAME, Gtk.SortType.ASCENDING