mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-01-14 00:39:53 -05:00
Disable some menu actions while searching.
This commit is contained in:
parent
6b6c109903
commit
0e19b47755
@ -25,6 +25,7 @@ EntryView::EntryView(QWidget* parent)
|
|||||||
: QTreeView(parent)
|
: QTreeView(parent)
|
||||||
, m_model(new EntryModel(this))
|
, m_model(new EntryModel(this))
|
||||||
, m_sortModel(new QSortFilterProxyModel(this))
|
, m_sortModel(new QSortFilterProxyModel(this))
|
||||||
|
, m_inSearch(false)
|
||||||
{
|
{
|
||||||
m_sortModel->setSourceModel(m_model);
|
m_sortModel->setSourceModel(m_model);
|
||||||
m_sortModel->setDynamicSortFilter(true);
|
m_sortModel->setDynamicSortFilter(true);
|
||||||
@ -58,6 +59,11 @@ void EntryView::search(QList<Entry*> entries)
|
|||||||
Q_EMIT entrySelectionChanged();
|
Q_EMIT entrySelectionChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool EntryView::inSearch()
|
||||||
|
{
|
||||||
|
return m_inSearch;
|
||||||
|
}
|
||||||
|
|
||||||
void EntryView::emitEntryActivated(const QModelIndex& index)
|
void EntryView::emitEntryActivated(const QModelIndex& index)
|
||||||
{
|
{
|
||||||
Q_EMIT entryActivated(entryFromIndex(index));
|
Q_EMIT entryActivated(entryFromIndex(index));
|
||||||
@ -98,9 +104,11 @@ Entry* EntryView::entryFromIndex(const QModelIndex& index)
|
|||||||
void EntryView::switchToSearch()
|
void EntryView::switchToSearch()
|
||||||
{
|
{
|
||||||
showColumn(0);
|
showColumn(0);
|
||||||
|
m_inSearch = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void EntryView::switchToView()
|
void EntryView::switchToView()
|
||||||
{
|
{
|
||||||
hideColumn(0);
|
hideColumn(0);
|
||||||
|
m_inSearch = false;
|
||||||
}
|
}
|
||||||
|
@ -37,6 +37,7 @@ public:
|
|||||||
void setCurrentEntry(Entry* entry);
|
void setCurrentEntry(Entry* entry);
|
||||||
Entry* entryFromIndex(const QModelIndex& index);
|
Entry* entryFromIndex(const QModelIndex& index);
|
||||||
void search(QList<Entry *> entries);
|
void search(QList<Entry *> entries);
|
||||||
|
bool inSearch();
|
||||||
|
|
||||||
public Q_SLOTS:
|
public Q_SLOTS:
|
||||||
void setGroup(Group* group);
|
void setGroup(Group* group);
|
||||||
@ -53,6 +54,7 @@ Q_SIGNALS:
|
|||||||
private:
|
private:
|
||||||
EntryModel* const m_model;
|
EntryModel* const m_model;
|
||||||
QSortFilterProxyModel* const m_sortModel;
|
QSortFilterProxyModel* const m_sortModel;
|
||||||
|
bool m_inSearch;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // KEEPASSX_ENTRYVIEW_H
|
#endif // KEEPASSX_ENTRYVIEW_H
|
||||||
|
@ -102,8 +102,13 @@ void MainWindow::setMenuActionState(DatabaseWidget::Mode mode)
|
|||||||
|
|
||||||
switch (mode) {
|
switch (mode) {
|
||||||
case DatabaseWidget::ViewMode:
|
case DatabaseWidget::ViewMode:
|
||||||
m_ui->actionEntryNew->setEnabled(true);
|
if (dbWidget->entryView()->inSearch()) {
|
||||||
m_ui->actionGroupNew->setEnabled(true);
|
m_ui->actionEntryNew->setEnabled(false);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
m_ui->actionEntryNew->setEnabled(true);
|
||||||
|
}
|
||||||
|
|
||||||
if (dbWidget->entryView()->currentIndex().isValid()) {
|
if (dbWidget->entryView()->currentIndex().isValid()) {
|
||||||
m_ui->actionEntryEdit->setEnabled(true);
|
m_ui->actionEntryEdit->setEnabled(true);
|
||||||
m_ui->actionEntryDelete->setEnabled(true);
|
m_ui->actionEntryDelete->setEnabled(true);
|
||||||
@ -112,13 +117,21 @@ void MainWindow::setMenuActionState(DatabaseWidget::Mode mode)
|
|||||||
m_ui->actionEntryEdit->setEnabled(false);
|
m_ui->actionEntryEdit->setEnabled(false);
|
||||||
m_ui->actionEntryDelete->setEnabled(false);
|
m_ui->actionEntryDelete->setEnabled(false);
|
||||||
}
|
}
|
||||||
m_ui->actionGroupEdit->setEnabled(true);
|
|
||||||
|
|
||||||
if (dbWidget->canDeleteCurrentGoup()) {
|
if (dbWidget->entryView()->inSearch()) {
|
||||||
m_ui->actionGroupDelete->setEnabled(true);
|
m_ui->actionGroupNew->setEnabled(false);
|
||||||
|
m_ui->actionGroupEdit->setEnabled(false);
|
||||||
|
m_ui->actionGroupDelete->setEnabled(false);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
m_ui->actionGroupDelete->setEnabled(false);
|
m_ui->actionGroupNew->setEnabled(true);
|
||||||
|
m_ui->actionGroupEdit->setEnabled(true);
|
||||||
|
if (dbWidget->canDeleteCurrentGoup()) {
|
||||||
|
m_ui->actionGroupDelete->setEnabled(true);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
m_ui->actionGroupDelete->setEnabled(false);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
m_ui->actionChangeMasterKey->setEnabled(true);
|
m_ui->actionChangeMasterKey->setEnabled(true);
|
||||||
m_ui->actionChangeDatabaseSettings->setEnabled(true);
|
m_ui->actionChangeDatabaseSettings->setEnabled(true);
|
||||||
|
Loading…
Reference in New Issue
Block a user