1
0
Fork 0
mirror of https://github.com/borgbase/vorta synced 2025-01-03 13:45:49 +00:00

Fix log table sorting. By @rblenis (#881)

Fixes #880
This commit is contained in:
Robert Blenis 2021-02-21 20:38:35 -05:00 committed by GitHub
parent 563b0a0bb7
commit d701211037
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -8,6 +8,14 @@
ScheduleUI, ScheduleBase = uic.loadUiType(uifile) ScheduleUI, ScheduleBase = uic.loadUiType(uifile)
class LogTableColumn:
Time = 0
Category = 1
Subcommand = 2
Repository = 3
ReturnCode = 4
class ScheduleTab(ScheduleBase, ScheduleUI, BackupProfileMixin): class ScheduleTab(ScheduleBase, ScheduleUI, BackupProfileMixin):
def __init__(self, parent=None): def __init__(self, parent=None):
@ -116,15 +124,17 @@ def save_repo_attr(self, attr, new_value):
def populate_logs(self): def populate_logs(self):
event_logs = [s for s in EventLogModel.select().order_by(EventLogModel.start_time.desc())] event_logs = [s for s in EventLogModel.select().order_by(EventLogModel.start_time.desc())]
sorting = self.logTableWidget.isSortingEnabled()
self.logTableWidget.setSortingEnabled(False) # disable sorting while modifying the table.
self.logTableWidget.setRowCount(len(event_logs)) # go ahead and set table length and then update the rows
for row, log_line in enumerate(event_logs): for row, log_line in enumerate(event_logs):
self.logTableWidget.insertRow(row)
formatted_time = log_line.start_time.strftime('%Y-%m-%d %H:%M') formatted_time = log_line.start_time.strftime('%Y-%m-%d %H:%M')
self.logTableWidget.setItem(row, 0, QTableWidgetItem(formatted_time)) self.logTableWidget.setItem(row, LogTableColumn.Time, QTableWidgetItem(formatted_time))
self.logTableWidget.setItem(row, 1, QTableWidgetItem(log_line.category)) self.logTableWidget.setItem(row, LogTableColumn.Category, QTableWidgetItem(log_line.category))
self.logTableWidget.setItem(row, 2, QTableWidgetItem(log_line.subcommand)) self.logTableWidget.setItem(row, LogTableColumn.Subcommand, QTableWidgetItem(log_line.subcommand))
self.logTableWidget.setItem(row, 3, QTableWidgetItem(log_line.repo_url)) self.logTableWidget.setItem(row, LogTableColumn.Repository, QTableWidgetItem(log_line.repo_url))
self.logTableWidget.setItem(row, 4, QTableWidgetItem(str(log_line.returncode))) self.logTableWidget.setItem(row, LogTableColumn.ReturnCode, QTableWidgetItem(str(log_line.returncode)))
self.logTableWidget.setRowCount(len(event_logs)) self.logTableWidget.setSortingEnabled(sorting) # restore sorting now that modifications are done
def _draw_next_scheduled_backup(self): def _draw_next_scheduled_backup(self):
self.nextBackupDateTimeLabel.setText(self.app.scheduler.next_job_for_profile(self.profile().id)) self.nextBackupDateTimeLabel.setText(self.app.scheduler.next_job_for_profile(self.profile().id))