mirror of
https://github.com/onionshare/onionshare.git
synced 2025-01-26 03:02:58 -03:00
Merge pull request #905 from mig5/902_dont_clear_in_progress
Don't clear in-progress transfers from the History list
This commit is contained in:
commit
8921bfeb56
1 changed files with 27 additions and 12 deletions
|
@ -31,6 +31,10 @@ class HistoryItem(QtWidgets.QWidget):
|
||||||
"""
|
"""
|
||||||
The base history item
|
The base history item
|
||||||
"""
|
"""
|
||||||
|
STATUS_STARTED = 0
|
||||||
|
STATUS_FINISHED = 1
|
||||||
|
STATUS_CANCELED = 2
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
super(HistoryItem, self).__init__()
|
super(HistoryItem, self).__init__()
|
||||||
|
|
||||||
|
@ -90,6 +94,7 @@ class ShareHistoryItem(HistoryItem):
|
||||||
self.downloaded_bytes = 0
|
self.downloaded_bytes = 0
|
||||||
self.started = time.time()
|
self.started = time.time()
|
||||||
self.started_dt = datetime.fromtimestamp(self.started)
|
self.started_dt = datetime.fromtimestamp(self.started)
|
||||||
|
self.status = HistoryItem.STATUS_STARTED
|
||||||
|
|
||||||
# Label
|
# Label
|
||||||
self.label = QtWidgets.QLabel(strings._('gui_all_modes_transfer_started').format(self.started_dt.strftime("%b %d, %I:%M%p")))
|
self.label = QtWidgets.QLabel(strings._('gui_all_modes_transfer_started').format(self.started_dt.strftime("%b %d, %I:%M%p")))
|
||||||
|
@ -124,6 +129,7 @@ class ShareHistoryItem(HistoryItem):
|
||||||
|
|
||||||
# Change the label
|
# Change the label
|
||||||
self.label.setText(self.get_finished_label_text(self.started_dt))
|
self.label.setText(self.get_finished_label_text(self.started_dt))
|
||||||
|
self.status = HistoryItem.STATUS_FINISHED
|
||||||
|
|
||||||
else:
|
else:
|
||||||
elapsed = time.time() - self.started
|
elapsed = time.time() - self.started
|
||||||
|
@ -142,6 +148,7 @@ class ShareHistoryItem(HistoryItem):
|
||||||
|
|
||||||
def cancel(self):
|
def cancel(self):
|
||||||
self.progress_bar.setFormat(strings._('gui_canceled'))
|
self.progress_bar.setFormat(strings._('gui_canceled'))
|
||||||
|
self.status = HistoryItem.STATUS_CANCELED
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def estimated_time_remaining(self):
|
def estimated_time_remaining(self):
|
||||||
|
@ -237,6 +244,7 @@ class ReceiveHistoryItem(HistoryItem):
|
||||||
self.id = id
|
self.id = id
|
||||||
self.content_length = content_length
|
self.content_length = content_length
|
||||||
self.started = datetime.now()
|
self.started = datetime.now()
|
||||||
|
self.status = HistoryItem.STATUS_STARTED
|
||||||
|
|
||||||
# Label
|
# Label
|
||||||
self.label = QtWidgets.QLabel(strings._('gui_all_modes_transfer_started').format(self.started.strftime("%b %d, %I:%M%p")))
|
self.label = QtWidgets.QLabel(strings._('gui_all_modes_transfer_started').format(self.started.strftime("%b %d, %I:%M%p")))
|
||||||
|
@ -313,6 +321,9 @@ class ReceiveHistoryItem(HistoryItem):
|
||||||
self.files[data['filename']].set_dir(data['dir'])
|
self.files[data['filename']].set_dir(data['dir'])
|
||||||
|
|
||||||
elif data['action'] == 'finished':
|
elif data['action'] == 'finished':
|
||||||
|
# Change the status
|
||||||
|
self.status = HistoryItem.STATUS_FINISHED
|
||||||
|
|
||||||
# Hide the progress bar
|
# Hide the progress bar
|
||||||
self.progress_bar.hide()
|
self.progress_bar.hide()
|
||||||
|
|
||||||
|
@ -320,6 +331,9 @@ class ReceiveHistoryItem(HistoryItem):
|
||||||
self.label.setText(self.get_finished_label_text(self.started))
|
self.label.setText(self.get_finished_label_text(self.started))
|
||||||
|
|
||||||
elif data['action'] == 'canceled':
|
elif data['action'] == 'canceled':
|
||||||
|
# Change the status
|
||||||
|
self.status = HistoryItem.STATUS_CANCELED
|
||||||
|
|
||||||
# Hide the progress bar
|
# Hide the progress bar
|
||||||
self.progress_bar.hide()
|
self.progress_bar.hide()
|
||||||
|
|
||||||
|
@ -389,11 +403,11 @@ class HistoryItemList(QtWidgets.QScrollArea):
|
||||||
"""
|
"""
|
||||||
Reset all items, emptying the list. Override this method.
|
Reset all items, emptying the list. Override this method.
|
||||||
"""
|
"""
|
||||||
for item in self.items.values():
|
for key, item in self.items.copy().items():
|
||||||
|
if item.status != HistoryItem.STATUS_STARTED:
|
||||||
self.items_layout.removeWidget(item)
|
self.items_layout.removeWidget(item)
|
||||||
item.close()
|
item.close()
|
||||||
self.items = {}
|
del self.items[key]
|
||||||
|
|
||||||
|
|
||||||
class History(QtWidgets.QWidget):
|
class History(QtWidgets.QWidget):
|
||||||
"""
|
"""
|
||||||
|
@ -494,17 +508,18 @@ class History(QtWidgets.QWidget):
|
||||||
Reset all items.
|
Reset all items.
|
||||||
"""
|
"""
|
||||||
self.item_list.reset()
|
self.item_list.reset()
|
||||||
|
if len(self.item_list.items) == 0:
|
||||||
# Hide not empty, show empty
|
# Hide not empty, show empty
|
||||||
self.not_empty.hide()
|
self.not_empty.hide()
|
||||||
self.empty.show()
|
self.empty.show()
|
||||||
|
# Reset in-progress counter
|
||||||
# Reset counters
|
|
||||||
self.completed_count = 0
|
|
||||||
self.in_progress_count = 0
|
self.in_progress_count = 0
|
||||||
self.update_completed()
|
|
||||||
self.update_in_progress()
|
self.update_in_progress()
|
||||||
|
|
||||||
|
# Reset completed counter
|
||||||
|
self.completed_count = 0
|
||||||
|
self.update_completed()
|
||||||
|
|
||||||
def update_completed(self):
|
def update_completed(self):
|
||||||
"""
|
"""
|
||||||
Update the 'completed' widget.
|
Update the 'completed' widget.
|
||||||
|
|
Loading…
Add table
Reference in a new issue