forked from blue/squawk
context menu to trust or distrust keys
This commit is contained in:
parent
b72a837754
commit
73d83f55af
5 changed files with 144 additions and 18 deletions
|
@ -26,7 +26,8 @@ Omemo::Omemo(QWidget* parent):
|
|||
keysDelegate(),
|
||||
unusedKeysDelegate(),
|
||||
keysModel(),
|
||||
unusedKeysModel()
|
||||
unusedKeysModel(),
|
||||
contextMenu(new QMenu())
|
||||
{
|
||||
m_ui->setupUi(this);
|
||||
|
||||
|
@ -36,15 +37,17 @@ Omemo::Omemo(QWidget* parent):
|
|||
m_ui->keysView->setModel(&keysModel);
|
||||
m_ui->unusedKeysView->setItemDelegate(&unusedKeysDelegate);
|
||||
m_ui->unusedKeysView->setModel(&unusedKeysModel);
|
||||
|
||||
m_ui->keysView->setContextMenuPolicy(Qt::CustomContextMenu);
|
||||
connect(m_ui->keysView, &QWidget::customContextMenuRequested, this, &Omemo::onActiveKeysContextMenu);
|
||||
}
|
||||
|
||||
Omemo::~Omemo()
|
||||
{
|
||||
|
||||
contextMenu->deleteLater();
|
||||
}
|
||||
|
||||
void Omemo::generateMockData()
|
||||
{
|
||||
void Omemo::generateMockData() {
|
||||
std::random_device rd;
|
||||
std::uniform_int_distribution<char> dist(CHAR_MIN, CHAR_MAX);
|
||||
for (int i = 0; i < 5; ++i) {
|
||||
|
@ -63,3 +66,46 @@ void Omemo::generateMockData()
|
|||
keysModel.addKey(info);
|
||||
}
|
||||
}
|
||||
|
||||
void Omemo::onActiveKeysContextMenu(const QPoint& pos) {
|
||||
contextMenu->clear();
|
||||
QModelIndex index = m_ui->keysView->indexAt(pos);
|
||||
if (index.isValid()) {
|
||||
QVariant dirtyV = index.data(UI::KeysModel::Dirty);
|
||||
if (dirtyV.isValid() && dirtyV.toBool()) {
|
||||
QAction* rev = contextMenu->addAction(Shared::icon("clean"), tr("Revert changes"));
|
||||
connect(rev, &QAction::triggered, std::bind(&UI::KeysModel::revertKey, &keysModel, index.row()));
|
||||
}
|
||||
|
||||
QVariant levelV = index.data(UI::KeysModel::TrustLevel);
|
||||
if (levelV.isValid()) {
|
||||
Shared::TrustLevel level = static_cast<Shared::TrustLevel>(levelV.toUInt());
|
||||
if (level == Shared::TrustLevel::undecided ||
|
||||
level == Shared::TrustLevel::automaticallyDistrusted ||
|
||||
level == Shared::TrustLevel::manuallyDistrusted
|
||||
) {
|
||||
QAction* rev = contextMenu->addAction(Shared::icon("favorite"), tr("Trust"));
|
||||
connect(rev, &QAction::triggered,
|
||||
std::bind(&UI::KeysModel::setTrustLevel, &keysModel,
|
||||
index.row(), Shared::TrustLevel::manuallyTrusted
|
||||
)
|
||||
);
|
||||
}
|
||||
|
||||
if (level == Shared::TrustLevel::undecided ||
|
||||
level == Shared::TrustLevel::automaticallyTrusted ||
|
||||
level == Shared::TrustLevel::manuallyTrusted ||
|
||||
level == Shared::TrustLevel::authenticated
|
||||
) {
|
||||
QAction* rev = contextMenu->addAction(Shared::icon("unfavorite"), tr("Distrust"));
|
||||
connect(rev, &QAction::triggered,
|
||||
std::bind(&UI::KeysModel::setTrustLevel, &keysModel,
|
||||
index.row(), Shared::TrustLevel::manuallyDistrusted
|
||||
)
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
contextMenu->popup(m_ui->keysView->viewport()->mapToGlobal(pos));
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue