Compare commits

...

2 Commits

Author SHA1 Message Date
Parnassius c23f07acf9
Merge 27ba337097 into 9cabbbd193 2024-04-16 22:40:07 +02:00
Parnassius 27ba337097 Ignore case when sorting the profile list 2024-04-16 22:19:04 +02:00
2 changed files with 13 additions and 7 deletions

View File

@ -59,10 +59,10 @@ class TrayMenu(QSystemTrayIcon):
cancel_action.triggered.connect(self.app.backup_cancelled_event.emit)
else:
status.setText(self.tr('Next Task: %s') % next_task_time)
profiles = BackupProfileModel.select().order_by(BackupProfileModel.name)
profiles = BackupProfileModel.select()
if profiles.count() > 1:
profile_menu = menu.addMenu(self.tr('Backup Now'))
for profile in profiles:
for profile in sorted(profiles, key=lambda p: (p.name.casefold(), p.name)):
new_item = profile_menu.addAction(profile.name)
new_item.triggered.connect(lambda state, i=profile.id: self.app.create_backup_action(i))
else:

View File

@ -65,7 +65,8 @@ class MainWindow(MainWindowBase, MainWindowUI):
prev_profile_id = SettingsModel.get(key='previous_profile_id')
self.current_profile = BackupProfileModel.get_or_none(id=prev_profile_id.str_value)
if self.current_profile is None:
self.current_profile = BackupProfileModel.select().order_by('name').first()
profiles = BackupProfileModel.select()
self.current_profile = min(profiles, key=lambda p: (p.name.casefold(), p.name))
# Load tab models
self.repoTab = RepoTab(self.repoTabSlot)
@ -161,7 +162,8 @@ class MainWindow(MainWindowBase, MainWindowUI):
current_item = None
# Add items to the QListWidget
for profile in BackupProfileModel.select().order_by(BackupProfileModel.name):
profiles = BackupProfileModel.select()
for profile in sorted(profiles, key=lambda p: (p.name.casefold(), p.name)):
item = QListWidgetItem(profile.name)
item.setData(Qt.ItemDataRole.UserRole, profile.id)
@ -291,9 +293,13 @@ class MainWindow(MainWindowBase, MainWindowUI):
profile = QListWidgetItem(profile_name)
profile.setData(Qt.ItemDataRole.UserRole, profile_id)
# Insert the profile at the correct position
row = len(
[i for i in range(self.profileSelector.count()) if self.profileSelector.item(i).text() < profile.text()]
)
# Both the casefolded and the original name are used as the key to keep the order stable
profile_key = (profile.text().casefold(), profile.text())
row = 0
for i in range(self.profileSelector.count()):
item_name = self.profileSelector.item(i).text()
if (item_name.casefold(), item_name) < profile_key:
row += 1
self.profileSelector.insertItem(row, profile)
self.profileSelector.setCurrentItem(profile)