mirror of https://github.com/Nheko-Reborn/nheko
Merge pull request #1523 from Nheko-Reborn/qmlFallbackAuth
QML the fallback auth dialogpull/1548/head
commit
ff079f6b6a
@ -0,0 +1,63 @@ |
||||
// SPDX-FileCopyrightText: Nheko Contributors |
||||
// |
||||
// SPDX-License-Identifier: GPL-3.0-or-later |
||||
|
||||
import QtQuick |
||||
import QtQuick.Controls |
||||
import im.nheko |
||||
|
||||
ApplicationWindow { |
||||
id: fallbackRoot |
||||
|
||||
required property FallbackAuth fallback |
||||
|
||||
function accept() { |
||||
fallback.confirm(); |
||||
fallbackRoot.close(); |
||||
} |
||||
|
||||
function reject() { |
||||
fallback.cancel(); |
||||
fallbackRoot.close(); |
||||
} |
||||
|
||||
color: palette.window |
||||
title: qsTr("Fallback authentication") |
||||
flags: Qt.Tool | Qt.WindowStaysOnTopHint | Qt.WindowCloseButtonHint | Qt.WindowTitleHint |
||||
height: msg.implicitHeight + footer.implicitHeight |
||||
width: Math.max(msg.implicitWidth, footer.implicitWidth) |
||||
|
||||
Shortcut { |
||||
sequence: StandardKey.Cancel |
||||
onActivated: fallbackRoot.reject() |
||||
} |
||||
|
||||
Label { |
||||
id: msg |
||||
|
||||
anchors.fill: parent |
||||
padding: 8 |
||||
text: qsTr("Open the fallback, follow the steps, and confirm after completing them.") |
||||
} |
||||
|
||||
footer: DialogButtonBox { |
||||
onAccepted: fallbackRoot.accept() |
||||
onRejected: fallbackRoot.reject() |
||||
|
||||
Button { |
||||
text: qsTr("Open Fallback in Browser") |
||||
onClicked: fallback.openFallbackAuth() |
||||
} |
||||
|
||||
Button { |
||||
text: qsTr("Cancel") |
||||
DialogButtonBox.buttonRole: DialogButtonBox.RejectRole |
||||
} |
||||
|
||||
Button { |
||||
text: qsTr("Confirm") |
||||
DialogButtonBox.buttonRole: DialogButtonBox.AcceptRole |
||||
} |
||||
} |
||||
|
||||
} |
@ -0,0 +1,29 @@ |
||||
// SPDX-FileCopyrightText: Nheko Contributors
|
||||
//
|
||||
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||
|
||||
#include "FallbackAuth.h" |
||||
|
||||
#include <QDesktopServices> |
||||
#include <QUrl> |
||||
|
||||
#include "MatrixClient.h" |
||||
|
||||
FallbackAuth::FallbackAuth(const QString &session, const QString &authType, QObject *parent) |
||||
: QObject{parent} |
||||
, m_session{session} |
||||
, m_authType{authType} |
||||
{ |
||||
} |
||||
|
||||
void |
||||
FallbackAuth::openFallbackAuth() |
||||
{ |
||||
const auto url = QString("https://%1:%2/_matrix/client/r0/auth/%4/" |
||||
"fallback/web?session=%3") |
||||
.arg(QString::fromStdString(http::client()->server())) |
||||
.arg(http::client()->port()) |
||||
.arg(m_session, m_authType); |
||||
|
||||
QDesktopServices::openUrl(url); |
||||
} |
@ -0,0 +1,32 @@ |
||||
// SPDX-FileCopyrightText: Nheko Contributors
|
||||
//
|
||||
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||
|
||||
#pragma once |
||||
|
||||
#include <QQmlEngine> |
||||
|
||||
class FallbackAuth : public QObject |
||||
{ |
||||
Q_OBJECT |
||||
QML_ELEMENT |
||||
QML_UNCREATABLE("") |
||||
|
||||
Q_PROPERTY(QString authType MEMBER m_authType CONSTANT) |
||||
Q_PROPERTY(QString session MEMBER m_session CONSTANT) |
||||
|
||||
public: |
||||
FallbackAuth(const QString &session, const QString &authType, QObject *parent = nullptr); |
||||
|
||||
Q_INVOKABLE void openFallbackAuth(); |
||||
Q_INVOKABLE void confirm() { emit confirmation(); } |
||||
Q_INVOKABLE void cancel() { emit cancelled(); } |
||||
|
||||
signals: |
||||
void confirmation(); |
||||
void cancelled(); |
||||
|
||||
private: |
||||
const QString m_session; |
||||
const QString m_authType; |
||||
}; |
@ -1,75 +0,0 @@ |
||||
// SPDX-FileCopyrightText: Nheko Contributors
|
||||
//
|
||||
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||
|
||||
#include <QDesktopServices> |
||||
#include <QLabel> |
||||
#include <QPushButton> |
||||
#include <QUrl> |
||||
#include <QVBoxLayout> |
||||
|
||||
#include "dialogs/FallbackAuth.h" |
||||
|
||||
#include "Config.h" |
||||
#include "MatrixClient.h" |
||||
|
||||
using namespace dialogs; |
||||
|
||||
FallbackAuth::FallbackAuth(const QString &authType, const QString &session, QWidget *parent) |
||||
: QWidget(parent) |
||||
{ |
||||
setAutoFillBackground(true); |
||||
setWindowFlags(Qt::Tool | Qt::WindowStaysOnTopHint); |
||||
setWindowModality(Qt::WindowModal); |
||||
setAttribute(Qt::WA_DeleteOnClose, true); |
||||
|
||||
auto layout = new QVBoxLayout(this); |
||||
layout->setSpacing(conf::modals::WIDGET_SPACING); |
||||
layout->setContentsMargins(conf::modals::WIDGET_MARGIN, |
||||
conf::modals::WIDGET_MARGIN, |
||||
conf::modals::WIDGET_MARGIN, |
||||
conf::modals::WIDGET_MARGIN); |
||||
|
||||
auto buttonLayout = new QHBoxLayout(); |
||||
buttonLayout->setSpacing(8); |
||||
buttonLayout->setContentsMargins(0, 0, 0, 0); |
||||
|
||||
openBtn_ = new QPushButton(tr("Open Fallback in Browser"), this); |
||||
cancelBtn_ = new QPushButton(tr("Cancel"), this); |
||||
confirmBtn_ = new QPushButton(tr("Confirm"), this); |
||||
confirmBtn_->setDefault(true); |
||||
|
||||
buttonLayout->addStretch(1); |
||||
buttonLayout->addWidget(openBtn_); |
||||
buttonLayout->addWidget(cancelBtn_); |
||||
buttonLayout->addWidget(confirmBtn_); |
||||
|
||||
QFont font; |
||||
font.setPointSizeF(font.pointSizeF() * conf::modals::LABEL_MEDIUM_SIZE_RATIO); |
||||
|
||||
auto label = new QLabel( |
||||
tr("Open the fallback, follow the steps, and confirm after completing them."), this); |
||||
label->setFont(font); |
||||
|
||||
layout->addWidget(label); |
||||
layout->addLayout(buttonLayout); |
||||
|
||||
connect(openBtn_, &QPushButton::clicked, [session, authType]() { |
||||
const auto url = QString("https://%1:%2/_matrix/client/r0/auth/%4/" |
||||
"fallback/web?session=%3") |
||||
.arg(QString::fromStdString(http::client()->server())) |
||||
.arg(http::client()->port()) |
||||
.arg(session, authType); |
||||
|
||||
QDesktopServices::openUrl(url); |
||||
}); |
||||
|
||||
connect(confirmBtn_, &QPushButton::clicked, this, [this]() { |
||||
emit confirmation(); |
||||
emit close(); |
||||
}); |
||||
connect(cancelBtn_, &QPushButton::clicked, this, [this]() { |
||||
emit cancel(); |
||||
emit close(); |
||||
}); |
||||
} |
@ -1,30 +0,0 @@ |
||||
// SPDX-FileCopyrightText: Nheko Contributors
|
||||
//
|
||||
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||
|
||||
#pragma once |
||||
|
||||
#include <QWidget> |
||||
|
||||
class QPushButton; |
||||
class QLabel; |
||||
|
||||
namespace dialogs { |
||||
|
||||
class FallbackAuth final : public QWidget |
||||
{ |
||||
Q_OBJECT |
||||
|
||||
public: |
||||
FallbackAuth(const QString &authType, const QString &session, QWidget *parent = nullptr); |
||||
|
||||
signals: |
||||
void confirmation(); |
||||
void cancel(); |
||||
|
||||
private: |
||||
QPushButton *openBtn_; |
||||
QPushButton *confirmBtn_; |
||||
QPushButton *cancelBtn_; |
||||
}; |
||||
} // dialogs
|
Loading…
Reference in new issue