mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-01-27 14:57:09 -05:00
Select new entry after cloning
Also fixes re-selecting entries during a search refresh
This commit is contained in:
parent
0167ce60bd
commit
cbbabf477a
@ -18,8 +18,6 @@
|
||||
#include "CloneDialog.h"
|
||||
#include "ui_CloneDialog.h"
|
||||
|
||||
#include "config-keepassx.h"
|
||||
|
||||
CloneDialog::CloneDialog(DatabaseWidget* parent, Database* db, Entry* entry)
|
||||
: QDialog(parent)
|
||||
, m_ui(new Ui::CloneDialog())
|
||||
@ -29,8 +27,9 @@ CloneDialog::CloneDialog(DatabaseWidget* parent, Database* db, Entry* entry)
|
||||
m_parent = parent;
|
||||
|
||||
m_ui->setupUi(this);
|
||||
this->setFixedSize(this->sizeHint());
|
||||
|
||||
window()->layout()->setSizeConstraint(QLayout::SetFixedSize);
|
||||
setWindowFlag(Qt::WindowContextHelpButtonHint, false);
|
||||
setAttribute(Qt::WA_DeleteOnClose);
|
||||
|
||||
connect(m_ui->buttonBox, SIGNAL(rejected()), SLOT(close()));
|
||||
@ -54,10 +53,10 @@ void CloneDialog::cloneEntry()
|
||||
flags |= Entry::CloneIncludeHistory;
|
||||
}
|
||||
|
||||
Entry* entry = m_entry->clone(flags);
|
||||
auto entry = m_entry->clone(flags);
|
||||
entry->setGroup(m_entry->group());
|
||||
|
||||
m_parent->refreshSearch();
|
||||
emit entryCloned(entry);
|
||||
close();
|
||||
}
|
||||
|
||||
|
@ -34,6 +34,9 @@ public:
|
||||
explicit CloneDialog(DatabaseWidget* parent = nullptr, Database* db = nullptr, Entry* entry = nullptr);
|
||||
~CloneDialog();
|
||||
|
||||
signals:
|
||||
void entryCloned(Entry* clone);
|
||||
|
||||
private:
|
||||
QScopedPointer<Ui::CloneDialog> m_ui;
|
||||
|
||||
|
@ -6,16 +6,17 @@
|
||||
<rect>
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>347</width>
|
||||
<height>136</height>
|
||||
<width>319</width>
|
||||
<height>132</height>
|
||||
</rect>
|
||||
</property>
|
||||
<property name="windowTitle">
|
||||
<string>Clone Entry Options</string>
|
||||
</property>
|
||||
<property name="modal">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<layout class="QVBoxLayout" name="verticalLayout">
|
||||
<item>
|
||||
<layout class="QVBoxLayout" name="verticalLayout_2">
|
||||
<item>
|
||||
<widget class="QCheckBox" name="titleClone">
|
||||
<property name="text">
|
||||
@ -43,17 +44,18 @@
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</item>
|
||||
<item>
|
||||
<spacer name="verticalSpacer">
|
||||
<property name="orientation">
|
||||
<enum>Qt::Vertical</enum>
|
||||
</property>
|
||||
<property name="sizeType">
|
||||
<enum>QSizePolicy::Minimum</enum>
|
||||
</property>
|
||||
<property name="sizeHint" stdset="0">
|
||||
<size>
|
||||
<width>20</width>
|
||||
<height>40</height>
|
||||
<height>6</height>
|
||||
</size>
|
||||
</property>
|
||||
</spacer>
|
||||
|
@ -447,6 +447,11 @@ void DatabaseWidget::cloneEntry()
|
||||
}
|
||||
|
||||
auto cloneDialog = new CloneDialog(this, m_db.data(), currentEntry);
|
||||
connect(cloneDialog, &CloneDialog::entryCloned, this, [this](auto entry) {
|
||||
refreshSearch();
|
||||
m_entryView->setCurrentEntry(entry);
|
||||
});
|
||||
|
||||
cloneDialog->show();
|
||||
}
|
||||
|
||||
@ -1399,7 +1404,10 @@ void DatabaseWidget::performUnlockDatabase(const QString& password, const QStrin
|
||||
void DatabaseWidget::refreshSearch()
|
||||
{
|
||||
if (isSearchActive()) {
|
||||
auto selectedEntry = m_entryView->currentEntry();
|
||||
search(m_lastSearchText);
|
||||
// Re-select the previous entry if it is still in the search
|
||||
m_entryView->setCurrentEntry(selectedEntry);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -50,8 +50,10 @@ Entry* EntryModel::entryFromIndex(const QModelIndex& index) const
|
||||
QModelIndex EntryModel::indexFromEntry(Entry* entry) const
|
||||
{
|
||||
int row = m_entries.indexOf(entry);
|
||||
Q_ASSERT(row != -1);
|
||||
if (row >= 0) {
|
||||
return index(row, 1);
|
||||
}
|
||||
return {};
|
||||
}
|
||||
|
||||
void EntryModel::setGroup(Group* group)
|
||||
|
@ -279,8 +279,11 @@ int EntryView::numberOfSelectedEntries()
|
||||
|
||||
void EntryView::setCurrentEntry(Entry* entry)
|
||||
{
|
||||
selectionModel()->setCurrentIndex(m_sortModel->mapFromSource(m_model->indexFromEntry(entry)),
|
||||
auto index = m_model->indexFromEntry(entry);
|
||||
if (index.isValid()) {
|
||||
selectionModel()->setCurrentIndex(m_sortModel->mapFromSource(index),
|
||||
QItemSelectionModel::ClearAndSelect | QItemSelectionModel::Rows);
|
||||
}
|
||||
}
|
||||
|
||||
Entry* EntryView::entryFromIndex(const QModelIndex& index)
|
||||
|
@ -1200,6 +1200,7 @@ void TestGui::testCloneEntry()
|
||||
Entry* entryClone = entryView->entryFromIndex(entryView->model()->index(1, 1));
|
||||
QVERIFY(entryOrg->uuid() != entryClone->uuid());
|
||||
QCOMPARE(entryClone->title(), entryOrg->title() + QString(" - Clone"));
|
||||
QVERIFY(m_dbWidget->currentSelectedEntry()->uuid() == entryClone->uuid());
|
||||
}
|
||||
|
||||
void TestGui::testEntryPlaceholders()
|
||||
|
Loading…
x
Reference in New Issue
Block a user