nheko/src/dialogs/JoinRoom.cc

62 lines
1.6 KiB
C++
Raw Normal View History

#include <QLabel>
2017-12-10 14:22:01 +01:00
#include <QStyleOption>
#include <QVBoxLayout>
#include "Config.h"
2017-10-28 14:46:39 +02:00
#include "FlatButton.h"
2017-12-10 14:22:01 +01:00
#include "TextField.h"
#include "Theme.h"
#include "dialogs/JoinRoom.h"
2017-11-30 12:53:28 +01:00
using namespace dialogs;
JoinRoom::JoinRoom(QWidget *parent)
: QFrame(parent)
{
setMaximumSize(400, 400);
auto layout = new QVBoxLayout(this);
layout->setSpacing(30);
layout->setMargin(20);
auto buttonLayout = new QHBoxLayout();
buttonLayout->setSpacing(0);
buttonLayout->setMargin(0);
confirmBtn_ = new FlatButton("JOIN", this);
confirmBtn_->setFontSize(conf::btn::fontSize);
cancelBtn_ = new FlatButton(tr("CANCEL"), this);
cancelBtn_->setFontSize(conf::btn::fontSize);
buttonLayout->addStretch(1);
buttonLayout->addWidget(confirmBtn_);
buttonLayout->addWidget(cancelBtn_);
QFont font;
font.setPixelSize(conf::headerFontSize);
2017-12-10 14:22:01 +01:00
roomInput_ = new TextField(this);
roomInput_->setLabel(tr("Room ID or alias"));
2017-12-10 14:22:01 +01:00
layout->addWidget(roomInput_);
layout->addLayout(buttonLayout);
2017-12-10 14:22:01 +01:00
// TODO: input validation with error messages.
connect(confirmBtn_, &QPushButton::clicked, [=]() {
2017-12-10 14:22:01 +01:00
emit closing(true, roomInput_->text());
roomInput_->clear();
});
2017-12-10 14:22:01 +01:00
connect(cancelBtn_, &QPushButton::clicked, [=]() { emit closing(false, ""); });
}
void
JoinRoom::paintEvent(QPaintEvent *)
{
QStyleOption opt;
opt.init(this);
QPainter p(this);
style()->drawPrimitive(QStyle::PE_Widget, &opt, &p, this);
}