Skip to content

Commit

Permalink
Cleanup welcome screen recent databases view (#4822)
Browse files Browse the repository at this point in the history
* Press "Delete" to remove recent database
* Refresh recent databases on becoming visible
  • Loading branch information
JMcKiern authored Jun 6, 2020
1 parent 712b822 commit 6c91254
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 8 deletions.
40 changes: 32 additions & 8 deletions src/gui/WelcomeWidget.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -40,11 +40,6 @@ WelcomeWidget::WelcomeWidget(QWidget* parent)

refreshLastDatabases();

bool recent_visibility = (m_ui->recentListWidget->count() > 0);
m_ui->startLabel->setVisible(!recent_visibility);
m_ui->recentListWidget->setVisible(recent_visibility);
m_ui->recentLabel->setVisible(recent_visibility);

connect(m_ui->buttonNewDatabase, SIGNAL(clicked()), SIGNAL(newDatabase()));
connect(m_ui->buttonOpenDatabase, SIGNAL(clicked()), SIGNAL(openDatabase()));
connect(m_ui->buttonImportKeePass1, SIGNAL(clicked()), SIGNAL(importKeePass1Database()));
Expand All @@ -62,12 +57,26 @@ WelcomeWidget::~WelcomeWidget()

void WelcomeWidget::openDatabaseFromFile(QListWidgetItem* item)
{
if (item->text().isEmpty()) {
if (!item || item->text().isEmpty()) {
return;
}
emit openDatabaseFile(item->text());
}

void WelcomeWidget::removeFromLastDatabases(QListWidgetItem* item)
{
if (!item || item->text().isEmpty()) {
return;
}

if (config()->get(Config::RememberLastDatabases).toBool()) {
QStringList lastDatabases = config()->get(Config::LastDatabases).toStringList();
lastDatabases.removeOne(item->text());
config()->set(Config::LastDatabases, lastDatabases);
}
refreshLastDatabases();
}

void WelcomeWidget::refreshLastDatabases()
{
m_ui->recentListWidget->clear();
Expand All @@ -77,13 +86,28 @@ void WelcomeWidget::refreshLastDatabases()
itm->setText(database);
m_ui->recentListWidget->addItem(itm);
}

bool recent_visibility = (m_ui->recentListWidget->count() > 0);
m_ui->startLabel->setVisible(!recent_visibility);
m_ui->recentListWidget->setVisible(recent_visibility);
m_ui->recentLabel->setVisible(recent_visibility);
}

void WelcomeWidget::keyPressEvent(QKeyEvent* event)
{
if (m_ui->recentListWidget->hasFocus() && (event->key() == Qt::Key_Return || event->key() == Qt::Key_Enter)) {
openDatabaseFromFile(m_ui->recentListWidget->currentItem());
if (m_ui->recentListWidget->hasFocus()) {
if (event->key() == Qt::Key_Return || event->key() == Qt::Key_Enter) {
openDatabaseFromFile(m_ui->recentListWidget->currentItem());
} else if (event->key() == Qt::Key_Delete || event->key() == Qt::Key_Backspace) {
removeFromLastDatabases(m_ui->recentListWidget->currentItem());
}
}

QWidget::keyPressEvent(event);
}

void WelcomeWidget::showEvent(QShowEvent* event)
{
refreshLastDatabases();
QWidget::showEvent(event);
}
2 changes: 2 additions & 0 deletions src/gui/WelcomeWidget.h
Original file line number Diff line number Diff line change
Expand Up @@ -46,12 +46,14 @@ class WelcomeWidget : public QWidget

protected:
void keyPressEvent(QKeyEvent* event) override;
void showEvent(QShowEvent* event) override;

private slots:
void openDatabaseFromFile(QListWidgetItem* item);

private:
const QScopedPointer<Ui::WelcomeWidget> m_ui;
void removeFromLastDatabases(QListWidgetItem* item);
};

#endif // KEEPASSX_WELCOMEWIDGET_H

0 comments on commit 6c91254

Please sign in to comment.