mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-04-03 20:47:37 +03:00
Add natural sort of entry list
Introduce a third unsorted status that shows entries in the order they occur in the KDBX file. * Add keyboard shortcut Ctrl+Alt+Up/Down to move entries up and down in sort order * Add entry context menu icons to achieve movement up/down * Only show menu icons when in natural sort order * Add Material Design icons for moving up/down * Add feature to track non-data changes and force a save on exit to ensure they are not lost when locking a database. This allows users to make entry movements and group expand/collapse operations and not lose that state. Remove saveas
This commit is contained in:
parent
43c82ccb09
commit
eb198271ac
24 changed files with 500 additions and 11 deletions
|
@ -612,3 +612,114 @@ void TestEntry::testIsRecycled()
|
|||
db.recycleGroup(group1);
|
||||
QVERIFY(entry1->isRecycled());
|
||||
}
|
||||
|
||||
void TestEntry::testMove()
|
||||
{
|
||||
Database db;
|
||||
Group* root = db.rootGroup();
|
||||
QVERIFY(root);
|
||||
|
||||
Entry* entry0 = new Entry();
|
||||
QVERIFY(entry0);
|
||||
entry0->setGroup(root);
|
||||
Entry* entry1 = new Entry();
|
||||
QVERIFY(entry1);
|
||||
entry1->setGroup(root);
|
||||
Entry* entry2 = new Entry();
|
||||
QVERIFY(entry2);
|
||||
entry2->setGroup(root);
|
||||
Entry* entry3 = new Entry();
|
||||
QVERIFY(entry3);
|
||||
entry3->setGroup(root);
|
||||
// default order, straight
|
||||
QCOMPARE(root->entries().at(0), entry0);
|
||||
QCOMPARE(root->entries().at(1), entry1);
|
||||
QCOMPARE(root->entries().at(2), entry2);
|
||||
QCOMPARE(root->entries().at(3), entry3);
|
||||
|
||||
entry0->moveDown();
|
||||
QCOMPARE(root->entries().at(0), entry1);
|
||||
QCOMPARE(root->entries().at(1), entry0);
|
||||
QCOMPARE(root->entries().at(2), entry2);
|
||||
QCOMPARE(root->entries().at(3), entry3);
|
||||
|
||||
entry0->moveDown();
|
||||
QCOMPARE(root->entries().at(0), entry1);
|
||||
QCOMPARE(root->entries().at(1), entry2);
|
||||
QCOMPARE(root->entries().at(2), entry0);
|
||||
QCOMPARE(root->entries().at(3), entry3);
|
||||
|
||||
entry0->moveDown();
|
||||
QCOMPARE(root->entries().at(0), entry1);
|
||||
QCOMPARE(root->entries().at(1), entry2);
|
||||
QCOMPARE(root->entries().at(2), entry3);
|
||||
QCOMPARE(root->entries().at(3), entry0);
|
||||
|
||||
// no effect
|
||||
entry0->moveDown();
|
||||
QCOMPARE(root->entries().at(0), entry1);
|
||||
QCOMPARE(root->entries().at(1), entry2);
|
||||
QCOMPARE(root->entries().at(2), entry3);
|
||||
QCOMPARE(root->entries().at(3), entry0);
|
||||
|
||||
entry0->moveUp();
|
||||
QCOMPARE(root->entries().at(0), entry1);
|
||||
QCOMPARE(root->entries().at(1), entry2);
|
||||
QCOMPARE(root->entries().at(2), entry0);
|
||||
QCOMPARE(root->entries().at(3), entry3);
|
||||
|
||||
entry0->moveUp();
|
||||
QCOMPARE(root->entries().at(0), entry1);
|
||||
QCOMPARE(root->entries().at(1), entry0);
|
||||
QCOMPARE(root->entries().at(2), entry2);
|
||||
QCOMPARE(root->entries().at(3), entry3);
|
||||
|
||||
entry0->moveUp();
|
||||
QCOMPARE(root->entries().at(0), entry0);
|
||||
QCOMPARE(root->entries().at(1), entry1);
|
||||
QCOMPARE(root->entries().at(2), entry2);
|
||||
QCOMPARE(root->entries().at(3), entry3);
|
||||
|
||||
// no effect
|
||||
entry0->moveUp();
|
||||
QCOMPARE(root->entries().at(0), entry0);
|
||||
QCOMPARE(root->entries().at(1), entry1);
|
||||
QCOMPARE(root->entries().at(2), entry2);
|
||||
QCOMPARE(root->entries().at(3), entry3);
|
||||
|
||||
entry2->moveUp();
|
||||
QCOMPARE(root->entries().at(0), entry0);
|
||||
QCOMPARE(root->entries().at(1), entry2);
|
||||
QCOMPARE(root->entries().at(2), entry1);
|
||||
QCOMPARE(root->entries().at(3), entry3);
|
||||
|
||||
entry0->moveDown();
|
||||
QCOMPARE(root->entries().at(0), entry2);
|
||||
QCOMPARE(root->entries().at(1), entry0);
|
||||
QCOMPARE(root->entries().at(2), entry1);
|
||||
QCOMPARE(root->entries().at(3), entry3);
|
||||
|
||||
entry3->moveUp();
|
||||
QCOMPARE(root->entries().at(0), entry2);
|
||||
QCOMPARE(root->entries().at(1), entry0);
|
||||
QCOMPARE(root->entries().at(2), entry3);
|
||||
QCOMPARE(root->entries().at(3), entry1);
|
||||
|
||||
entry3->moveUp();
|
||||
QCOMPARE(root->entries().at(0), entry2);
|
||||
QCOMPARE(root->entries().at(1), entry3);
|
||||
QCOMPARE(root->entries().at(2), entry0);
|
||||
QCOMPARE(root->entries().at(3), entry1);
|
||||
|
||||
entry2->moveDown();
|
||||
QCOMPARE(root->entries().at(0), entry3);
|
||||
QCOMPARE(root->entries().at(1), entry2);
|
||||
QCOMPARE(root->entries().at(2), entry0);
|
||||
QCOMPARE(root->entries().at(3), entry1);
|
||||
|
||||
entry1->moveUp();
|
||||
QCOMPARE(root->entries().at(0), entry3);
|
||||
QCOMPARE(root->entries().at(1), entry2);
|
||||
QCOMPARE(root->entries().at(2), entry1);
|
||||
QCOMPARE(root->entries().at(3), entry0);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue