mirror of
https://github.com/codex-storage/deluge.git
synced 2025-01-15 22:14:24 +00:00
Massive clean up in UI update code. Update torrents info UI instantly when we
click on them in torrents list.
This commit is contained in:
parent
d07e8cddb6
commit
b5aff38295
129
src/interface.py
129
src/interface.py
@ -423,7 +423,6 @@ class DelugeGTK:
|
|||||||
self.torrent_view.set_rules_hint(True)
|
self.torrent_view.set_rules_hint(True)
|
||||||
self.torrent_view.set_reorderable(True)
|
self.torrent_view.set_reorderable(True)
|
||||||
self.torrent_view.get_selection().set_mode(gtk.SELECTION_MULTIPLE)
|
self.torrent_view.get_selection().set_mode(gtk.SELECTION_MULTIPLE)
|
||||||
self.torrent_selected = None
|
|
||||||
|
|
||||||
def size(column, cell, model, iter, data):
|
def size(column, cell, model, iter, data):
|
||||||
size = long(model.get_value(iter, data))
|
size = long(model.get_value(iter, data))
|
||||||
@ -501,6 +500,8 @@ class DelugeGTK:
|
|||||||
# Now for the File tab
|
# Now for the File tab
|
||||||
self.file_store.clear()
|
self.file_store.clear()
|
||||||
|
|
||||||
|
self.update_torrent_info_widget(unique_id)
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def torrent_view_clicked(self, widget, event):
|
def torrent_view_clicked(self, widget, event):
|
||||||
@ -901,44 +902,42 @@ class DelugeGTK:
|
|||||||
self.statusbar.pop(1)
|
self.statusbar.pop(1)
|
||||||
self.statusbar.push(1, self.statusbar_temp_msg)
|
self.statusbar.push(1, self.statusbar_temp_msg)
|
||||||
|
|
||||||
# If no torrent is selected, select the first torrent:
|
|
||||||
if self.torrent_selected is None:
|
|
||||||
self.torrent_view.get_selection().select_path("0")
|
|
||||||
#Torrent List
|
#Torrent List
|
||||||
itr = self.torrent_model.get_iter_first()
|
itr = self.torrent_model.get_iter_first()
|
||||||
|
|
||||||
|
# Disable torrent options if there are no torrents
|
||||||
|
self.wtree.get_widget("menu_torrent").set_sensitive(itr is not None)
|
||||||
|
self.wtree.get_widget("toolbutton_remove").set_sensitive(itr is not None)
|
||||||
|
self.wtree.get_widget("toolbutton_pause").set_sensitive(itr is not None)
|
||||||
|
self.wtree.get_widget("toolbutton_up").set_sensitive(itr is not None)
|
||||||
|
self.wtree.get_widget("toolbutton_down").set_sensitive(itr is not None)
|
||||||
|
|
||||||
if itr is None:
|
if itr is None:
|
||||||
return True
|
return True
|
||||||
|
|
||||||
while itr is not None:
|
while itr is not None:
|
||||||
uid = self.torrent_model.get_value(itr, 0)
|
uid = self.torrent_model.get_value(itr, 0)
|
||||||
try:
|
state = self.manager.get_torrent_state(uid)
|
||||||
state = self.manager.get_torrent_state(uid)
|
tlist = self.get_list_from_unique_id(uid)
|
||||||
tlist = self.get_list_from_unique_id(uid)
|
for i in range(len(tlist)):
|
||||||
for i in range(len(tlist)):
|
try:
|
||||||
try:
|
self.torrent_model.set_value(itr, i, tlist[i])
|
||||||
self.torrent_model.set_value(itr, i, tlist[i])
|
except:
|
||||||
except:
|
print "ERR", i, type(tlist[i]), tlist[i]
|
||||||
print "ERR", i, type(tlist[i]), tlist[i]
|
itr = self.torrent_model.iter_next(itr)
|
||||||
itr = self.torrent_model.iter_next(itr)
|
|
||||||
except core.InvalidUniqueIDError:
|
|
||||||
self.torrent_model.remove(itr)
|
|
||||||
if not self.torrent_model.iter_is_valid(itr):
|
|
||||||
itr = None
|
|
||||||
|
|
||||||
# Disable torrent options if no torrents are selected
|
|
||||||
torrent_selection = self.torrent_view.get_selection()
|
|
||||||
selection_count = torrent_selection.count_selected_rows()
|
|
||||||
|
|
||||||
self.wtree.get_widget("menu_torrent").set_sensitive(selection_count > 0)
|
|
||||||
self.wtree.get_widget("toolbutton_remove").set_sensitive(selection_count > 0)
|
|
||||||
self.wtree.get_widget("toolbutton_pause").set_sensitive(selection_count > 0)
|
|
||||||
self.wtree.get_widget("toolbutton_up").set_sensitive(selection_count > 0)
|
|
||||||
self.wtree.get_widget("toolbutton_down").set_sensitive(selection_count > 0)
|
|
||||||
|
|
||||||
# Disable moving top torrents up or bottom torrents down
|
# Disable moving top torrents up or bottom torrents down
|
||||||
top_torrents_selected = True
|
top_torrents_selected = True
|
||||||
bottom_torrents_selected = True
|
bottom_torrents_selected = True
|
||||||
|
|
||||||
|
torrent_selection = self.torrent_view.get_selection()
|
||||||
|
selection_count = torrent_selection.count_selected_rows()
|
||||||
|
|
||||||
|
# If no torrent is selected, select the first torrent:
|
||||||
|
if selection_count == 0:
|
||||||
|
torrent_selection.select_path("0")
|
||||||
|
selection_count = 1
|
||||||
|
|
||||||
for i in range(selection_count):
|
for i in range(selection_count):
|
||||||
if not torrent_selection.path_is_selected(i):
|
if not torrent_selection.path_is_selected(i):
|
||||||
top_torrents_selected = False
|
top_torrents_selected = False
|
||||||
@ -953,39 +952,43 @@ class DelugeGTK:
|
|||||||
self.wtree.get_widget("toolbutton_up").set_sensitive(not top_torrents_selected)
|
self.wtree.get_widget("toolbutton_up").set_sensitive(not top_torrents_selected)
|
||||||
self.wtree.get_widget("toolbutton_down").set_sensitive(not bottom_torrents_selected)
|
self.wtree.get_widget("toolbutton_down").set_sensitive(not bottom_torrents_selected)
|
||||||
|
|
||||||
if selection_count == 0:
|
unique_id = None
|
||||||
return True
|
if selection_count == 1:
|
||||||
|
unique_id = self.get_selected_torrent()
|
||||||
|
self.update_torrent_info_widget(unique_id)
|
||||||
|
else: # selection_count > 1
|
||||||
|
self.clear_details_pane()
|
||||||
|
|
||||||
try:
|
# Update tool buttons below based on the first selected torrent's state
|
||||||
if self.manager.get_torrent_state(self.get_selected_torrent())["is_paused"]:
|
path = torrent_selection.get_selected_rows()[1][0]
|
||||||
self.wtree.get_widget("toolbutton_pause").set_stock_id(gtk.STOCK_MEDIA_PLAY)
|
unique_id = self.torrent_model.get_value(self.torrent_model.get_iter(path), 0)
|
||||||
self.wtree.get_widget("toolbutton_pause").set_label(_("Resume"))
|
|
||||||
else:
|
|
||||||
self.wtree.get_widget("toolbutton_pause").set_stock_id(gtk.STOCK_MEDIA_PAUSE)
|
|
||||||
self.wtree.get_widget("toolbutton_pause").set_label(_("Pause"))
|
|
||||||
|
|
||||||
except KeyError:
|
if self.manager.get_torrent_state(unique_id)["is_paused"]:
|
||||||
pass
|
self.wtree.get_widget("toolbutton_pause").set_stock_id(gtk.STOCK_MEDIA_PLAY)
|
||||||
|
self.wtree.get_widget("toolbutton_pause").set_label(_("Resume"))
|
||||||
|
else:
|
||||||
|
self.wtree.get_widget("toolbutton_pause").set_stock_id(gtk.STOCK_MEDIA_PAUSE)
|
||||||
|
self.wtree.get_widget("toolbutton_pause").set_label(_("Pause"))
|
||||||
|
|
||||||
try:
|
return True
|
||||||
state = self.manager.get_torrent_state(self.get_selected_torrent())
|
|
||||||
except core.InvalidUniqueIDError:
|
|
||||||
return True
|
|
||||||
|
|
||||||
|
def update_torrent_info_widget(self, unique_id):
|
||||||
|
tab = self.wtree.get_widget("torrent_info").get_current_page()
|
||||||
|
state = self.manager.get_torrent_state(unique_id)
|
||||||
|
|
||||||
if tab == 0: #Details Pane
|
if tab == 0: #Details Pane
|
||||||
self.wtree.get_widget("summary_name").set_text(state['name'])
|
self.wtree.get_widget("summary_name").set_text(state['name'])
|
||||||
self.text_summary_total_size.set_text(common.fsize(state["total_size"]))
|
self.text_summary_total_size.set_text(common.fsize(state["total_size"]))
|
||||||
self.text_summary_pieces.set_text(str(state["num_pieces"]))
|
self.text_summary_pieces.set_text(str(state["num_pieces"]))
|
||||||
self.text_summary_total_downloaded.set_text(common.fsize(state["total_done"]) + " (" + common.fsize(state["total_download"]) + ")")
|
self.text_summary_total_downloaded.set_text(common.fsize(state["total_done"]) + " (" + common.fsize(state["total_download"]) + ")")
|
||||||
self.text_summary_total_uploaded.set_text(common.fsize(self.manager.unique_IDs[self.get_selected_torrent()].uploaded_memory + state["total_payload_upload"]) + " (" + common.fsize(state["total_upload"]) + ")")
|
self.text_summary_total_uploaded.set_text(common.fsize(self.manager.unique_IDs[unique_id].uploaded_memory + state["total_payload_upload"]) + " (" + common.fsize(state["total_upload"]) + ")")
|
||||||
self.text_summary_download_speed.set_text(common.fspeed(state["download_rate"]))
|
self.text_summary_download_speed.set_text(common.fspeed(state["download_rate"]))
|
||||||
self.text_summary_upload_speed.set_text(common.fspeed(state["upload_rate"]))
|
self.text_summary_upload_speed.set_text(common.fspeed(state["upload_rate"]))
|
||||||
self.text_summary_seeders.set_text(common.fseed(state))
|
self.text_summary_seeders.set_text(common.fseed(state))
|
||||||
self.text_summary_peers.set_text(common.fpeer(state))
|
self.text_summary_peers.set_text(common.fpeer(state))
|
||||||
self.wtree.get_widget("progressbar").set_fraction(float(state['progress']))
|
self.wtree.get_widget("progressbar").set_fraction(float(state['progress']))
|
||||||
self.wtree.get_widget("progressbar").set_text(common.fpcnt(state["progress"]))
|
self.wtree.get_widget("progressbar").set_text(common.fpcnt(state["progress"]))
|
||||||
self.text_summary_share_ratio.set_text('%.3f'%(self.calc_share_ratio(self.get_selected_torrent(), state)))
|
self.text_summary_share_ratio.set_text('%.3f'%(self.calc_share_ratio(unique_id, state)))
|
||||||
self.text_summary_tracker.set_text(str(state["tracker"]))
|
self.text_summary_tracker.set_text(str(state["tracker"]))
|
||||||
self.text_summary_tracker_status.set_text(str(state["tracker_ok"]))
|
self.text_summary_tracker_status.set_text(str(state["tracker_ok"]))
|
||||||
self.text_summary_next_announce.set_text(str(state["next_announce"]))
|
self.text_summary_next_announce.set_text(str(state["next_announce"]))
|
||||||
@ -1007,8 +1010,6 @@ class DelugeGTK:
|
|||||||
else:
|
else:
|
||||||
return False
|
return False
|
||||||
|
|
||||||
unique_id = self.get_selected_torrent()
|
|
||||||
|
|
||||||
new_peer_info = self.manager.get_torrent_peer_info(unique_id)
|
new_peer_info = self.manager.get_torrent_peer_info(unique_id)
|
||||||
|
|
||||||
new_ips = {}
|
new_ips = {}
|
||||||
@ -1046,8 +1047,6 @@ class DelugeGTK:
|
|||||||
peer["download_speed"],
|
peer["download_speed"],
|
||||||
peer["upload_speed"]])
|
peer["upload_speed"]])
|
||||||
elif tab == 2: #file tab
|
elif tab == 2: #file tab
|
||||||
unique_id = self.get_selected_torrent()
|
|
||||||
|
|
||||||
# Fill self.file_store with files only once and only when we click to
|
# Fill self.file_store with files only once and only when we click to
|
||||||
# file tab or it's already open
|
# file tab or it's already open
|
||||||
if not self.file_store.iter_n_children(None):
|
if not self.file_store.iter_n_children(None):
|
||||||
@ -1074,10 +1073,7 @@ class DelugeGTK:
|
|||||||
if file['path'] in curr_files and \
|
if file['path'] in curr_files and \
|
||||||
self.file_store.get_value(iter, 3) != round(file['progress'], 2):
|
self.file_store.get_value(iter, 3) != round(file['progress'], 2):
|
||||||
self.file_store.set(iter, 3, file['progress'])
|
self.file_store.set(iter, 3, file['progress'])
|
||||||
else:
|
|
||||||
pass
|
|
||||||
|
|
||||||
return True
|
|
||||||
|
|
||||||
def calc_share_ratio(self, unique_id, torrent_state):
|
def calc_share_ratio(self, unique_id, torrent_state):
|
||||||
r = float(self.manager.calc_ratio(unique_id, torrent_state))
|
r = float(self.manager.calc_ratio(unique_id, torrent_state))
|
||||||
@ -1087,11 +1083,14 @@ class DelugeGTK:
|
|||||||
def get_selected_torrent(self):
|
def get_selected_torrent(self):
|
||||||
try:
|
try:
|
||||||
if self.torrent_view.get_selection().count_selected_rows() == 1:
|
if self.torrent_view.get_selection().count_selected_rows() == 1:
|
||||||
self.torrent_selected = self.torrent_view.get_selection().get_selected_rows()[1][0]
|
selected_path = self.torrent_view.get_selection().\
|
||||||
selected_torrent = self.torrent_model.get_value(self.torrent_model.get_iter(self.torrent_selected), 0)
|
get_selected_rows()[1][0]
|
||||||
return selected_torrent
|
selected_torrent = self.torrent_model.get_value(self.torrent_model.get_iter(selected_path), 0)
|
||||||
except TypeError, ValueError:
|
return selected_torrent
|
||||||
return None
|
except (TypeError, ValueError):
|
||||||
|
pass
|
||||||
|
|
||||||
|
return None
|
||||||
|
|
||||||
# Return a list of ids of the selected torrents
|
# Return a list of ids of the selected torrents
|
||||||
def get_selected_torrent_rows(self):
|
def get_selected_torrent_rows(self):
|
||||||
@ -1217,12 +1216,20 @@ class DelugeGTK:
|
|||||||
response = asker.run()
|
response = asker.run()
|
||||||
asker.destroy()
|
asker.destroy()
|
||||||
if response == 1:
|
if response == 1:
|
||||||
torrent_list = self.get_selected_torrent_rows()
|
|
||||||
self.clear_details_pane()
|
self.clear_details_pane()
|
||||||
self.torrent_selected = None
|
|
||||||
for torrent in torrent_list:
|
torrents = self.get_selected_torrent_rows()
|
||||||
self.manager.remove_torrent(torrent, data_also.get_active(), torrent_also.get_active())
|
paths = self.torrent_view.get_selection().get_selected_rows()[1]
|
||||||
self.update()
|
row_references = [gtk.TreeRowReference(self.torrent_model, x)
|
||||||
|
for x in paths]
|
||||||
|
|
||||||
|
for unique_id, row_ref in izip(torrents, row_references):
|
||||||
|
self.manager.remove_torrent(unique_id, data_also.get_active(),
|
||||||
|
torrent_also.get_active())
|
||||||
|
iter = self.torrent_model.get_iter(row_ref.get_path())
|
||||||
|
self.torrent_model.remove(iter)
|
||||||
|
|
||||||
|
self.update()
|
||||||
|
|
||||||
def clear_details_pane(self):
|
def clear_details_pane(self):
|
||||||
self.wtree.get_widget("progressbar").set_text("")
|
self.wtree.get_widget("progressbar").set_text("")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user