mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-01-14 08:50:08 -05:00
Select entry above deleted entry
* Fix #6304 - Don't cause the list view to scroll to the top when deleting any entry in the list.
This commit is contained in:
parent
746276edea
commit
af9eb6d6b1
@ -462,8 +462,16 @@ void DatabaseWidget::deleteSelectedEntries()
|
|||||||
|
|
||||||
void DatabaseWidget::deleteEntries(QList<Entry*> selectedEntries, bool confirm)
|
void DatabaseWidget::deleteEntries(QList<Entry*> selectedEntries, bool confirm)
|
||||||
{
|
{
|
||||||
|
if (selectedEntries.isEmpty()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Find the index above the first entry for selection after deletion
|
||||||
|
auto index = m_entryView->indexFromEntry(selectedEntries.first());
|
||||||
|
index = m_entryView->indexAbove(index);
|
||||||
|
|
||||||
// Confirm entry removal before moving forward
|
// Confirm entry removal before moving forward
|
||||||
auto* recycleBin = m_db->metadata()->recycleBin();
|
auto recycleBin = m_db->metadata()->recycleBin();
|
||||||
bool permanent = (recycleBin && recycleBin->findEntryByUuid(selectedEntries.first()->uuid()))
|
bool permanent = (recycleBin && recycleBin->findEntryByUuid(selectedEntries.first()->uuid()))
|
||||||
|| !m_db->metadata()->recycleBinEnabled();
|
|| !m_db->metadata()->recycleBinEnabled();
|
||||||
|
|
||||||
@ -475,8 +483,15 @@ void DatabaseWidget::deleteEntries(QList<Entry*> selectedEntries, bool confirm)
|
|||||||
|
|
||||||
refreshSearch();
|
refreshSearch();
|
||||||
|
|
||||||
|
// Select the row above the deleted entries
|
||||||
|
if (index.isValid()) {
|
||||||
|
m_entryView->setCurrentIndex(index);
|
||||||
|
} else {
|
||||||
m_entryView->setFirstEntryActive();
|
m_entryView->setFirstEntryActive();
|
||||||
auto* currentEntry = currentSelectedEntry();
|
}
|
||||||
|
|
||||||
|
// Update the preview widget
|
||||||
|
auto currentEntry = currentSelectedEntry();
|
||||||
if (currentEntry) {
|
if (currentEntry) {
|
||||||
m_previewView->setEntry(currentEntry);
|
m_previewView->setEntry(currentEntry);
|
||||||
} else {
|
} else {
|
||||||
|
@ -289,6 +289,11 @@ Entry* EntryView::entryFromIndex(const QModelIndex& index)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QModelIndex EntryView::indexFromEntry(Entry* entry)
|
||||||
|
{
|
||||||
|
return m_sortModel->mapFromSource(m_model->indexFromEntry(entry));
|
||||||
|
}
|
||||||
|
|
||||||
int EntryView::currentEntryIndex()
|
int EntryView::currentEntryIndex()
|
||||||
{
|
{
|
||||||
QModelIndexList list = selectionModel()->selectedRows();
|
QModelIndexList list = selectionModel()->selectedRows();
|
||||||
|
@ -39,6 +39,7 @@ public:
|
|||||||
Entry* currentEntry();
|
Entry* currentEntry();
|
||||||
void setCurrentEntry(Entry* entry);
|
void setCurrentEntry(Entry* entry);
|
||||||
Entry* entryFromIndex(const QModelIndex& index);
|
Entry* entryFromIndex(const QModelIndex& index);
|
||||||
|
QModelIndex indexFromEntry(Entry* entry);
|
||||||
int currentEntryIndex();
|
int currentEntryIndex();
|
||||||
bool inSearchMode();
|
bool inSearchMode();
|
||||||
bool isSorted();
|
bool isSorted();
|
||||||
|
Loading…
Reference in New Issue
Block a user