#include "advsettingsdlg.h"
#include "selectremotedlg.h"
#include "aboutdlg.h"
-#include "remote.h"
#include <QHBoxLayout>
#include <QVBoxLayout>
SettingsDlg::SettingsDlg(QWidget *parent)
: QDialog(parent)
- , remote(NULL)
{
- layout = new QVBoxLayout(this);
- btnLayout = new QHBoxLayout(this);
- remoteNameLayout = new QHBoxLayout(this);
+ QSettings settings(this);
+ m_layout = new QVBoxLayout(this);
+ m_btnLayout = new QHBoxLayout();
+ m_remoteNameLayout = new QHBoxLayout();
- advSettingsBtn = new QPushButton(tr("Advanced"), this);
- selectRemoteBtn = new QPushButton(tr("Select remote"), this);
- aboutBtn = new QPushButton(tr("About"), this);
- rateUpBtn = new QPushButton(
+ m_advSettingsBtn = new QPushButton(tr("Advanced"), this);
+ m_selectRemoteBtn = new QPushButton(tr("Select remote"), this);
+ m_aboutBtn = new QPushButton(tr("About"), this);
+ m_rateUpBtn = new QPushButton(
QIcon(settings.value("rateUpIcon",
"/usr/share/icons/hicolor/48x48/hildon/chat_smiley_happy.png").
toString()),
"", this);
- rateDownBtn = new QPushButton(
+ m_rateDownBtn = new QPushButton(
QIcon(settings.value("rateDownIcon",
"/usr/share/icons/hicolor/48x48/hildon/chat_smiley_sad.png").
toString()),
"", this);
- rateUpBtn->setMaximumSize(72, 72);
- rateDownBtn->setMaximumSize(72, 72);
+ m_rateUpBtn->setMaximumSize(72, 72);
+ m_rateDownBtn->setMaximumSize(72, 72);
- btnLayout->addWidget(advSettingsBtn);
- btnLayout->addWidget(selectRemoteBtn);
- btnLayout->addWidget(aboutBtn);
+ m_btnLayout->addWidget(m_advSettingsBtn);
+ m_btnLayout->addWidget(m_selectRemoteBtn);
+ m_btnLayout->addWidget(m_aboutBtn);
- remoteNameLabel = new QLabel(this);
- ratingLabel = new QLabel(this);
- remoteNameLayout->addWidget(remoteNameLabel);
- remoteNameLayout->addWidget(ratingLabel);
- remoteNameLayout->addWidget(rateUpBtn);
- remoteNameLayout->addWidget(rateDownBtn);
+ m_remoteNameLabel = new QLabel(this);
+ m_ratingLabel = new QLabel(this);
+ m_remoteNameLayout->addWidget(m_remoteNameLabel);
+ m_remoteNameLayout->addWidget(m_ratingLabel);
+ m_remoteNameLayout->addWidget(m_rateUpBtn);
+ m_remoteNameLayout->addWidget(m_rateDownBtn);
- connect(advSettingsBtn, SIGNAL(clicked()),
+ connect(m_advSettingsBtn, SIGNAL(clicked()),
this, SLOT(showAdvSettingsDlg()));
- connect(selectRemoteBtn, SIGNAL(clicked()),
+ connect(m_selectRemoteBtn, SIGNAL(clicked()),
this, SLOT(showSelectRemoteDlg()));
- connect(aboutBtn, SIGNAL(clicked()),
+ connect(m_aboutBtn, SIGNAL(clicked()),
this, SLOT(showAboutDlg()));
- connect(rateUpBtn, SIGNAL(clicked()),
+ connect(m_rateUpBtn, SIGNAL(clicked()),
this, SLOT(rateUpClicked()));
- connect(rateDownBtn, SIGNAL(clicked()),
+ connect(m_rateDownBtn, SIGNAL(clicked()),
this, SLOT(rateDownClicked()));
- layout->addLayout(remoteNameLayout);
- layout->addLayout(btnLayout);
- this->setLayout(layout);
+ m_layout->addLayout(m_remoteNameLayout);
+ m_layout->addLayout(m_btnLayout);
+ this->setLayout(m_layout);
- changeRemote();
+ QString selectedRemote = QSettings(this).value("remoteName", "").toString();
+ if (selectedRemote == "") {
+ m_remoteNameLabel->setText("No remote selected");
+ enableRateBtns(false);
+ } else {
+ setRemote(selectedRemote);
+ setBusy();
+ }
}
SettingsDlg::~SettingsDlg()
{
- delete advSettingsBtn;
- delete selectRemoteBtn;
- delete rateUpBtn;
- delete rateDownBtn;
- delete aboutBtn;
- delete remoteNameLabel;
- delete ratingLabel;
- delete btnLayout;
- delete remoteNameLayout;
- delete layout;
- if (remote) {
- delete remote;
- }
+ delete m_advSettingsBtn;
+ delete m_selectRemoteBtn;
+ delete m_rateUpBtn;
+ delete m_rateDownBtn;
+ delete m_aboutBtn;
+ delete m_remoteNameLabel;
+ delete m_ratingLabel;
+ delete m_btnLayout;
+ delete m_remoteNameLayout;
+ delete m_layout;
+}
+
+void SettingsDlg::setBusy(bool busy)
+{
+ setAttribute(Qt::WA_Maemo5ShowProgressIndicator, busy);
+ setEnabled(!busy);
}
void SettingsDlg::showAdvSettingsDlg()
{
- AdvSettingsDlg dlg(this);
+ AdvSettingsDlg dlg;
dlg.exec();
}
void SettingsDlg::showSelectRemoteDlg()
{
- SelectRemoteDlg dlg(this);
- changeRemote();
+ SelectRemoteDlg dlg;
+ connect(&dlg, SIGNAL(remoteChanged(Remote)),
+ this, SLOT(setRemote(Remote)));
dlg.exec();
}
void SettingsDlg::showAboutDlg()
{
- AboutDlg dlg(this);
+ AboutDlg dlg;
dlg.exec();
}
-void SettingsDlg::changeRemote()
+void SettingsDlg::setRemote(Remote r)
{
- QString selectedRemote = settings.value("remoteName", "").toString();
- if (selectedRemote == "") {
- remoteNameLabel->setText("No remote selected");
- enableRateBtns(false);
- } else {
- if (remote) {
- delete remote;
- }
- remote = new Remote(selectedRemote);
- connect(remote, SIGNAL(infoUpdated()),
- this, SLOT(updateRemoteInfo()));
- remote->updateInfo();
- enableRateBtns();
- }
+ m_remote = r;
+ processRemoteChange();
+ updateRemoteInfo();
+}
+
+void SettingsDlg::setRemote(const QString &name)
+{
+ setBusy();
+ m_remote = Remote(name);
+ processRemoteChange();
+ m_remote.updateInfo(); // request update from server
+}
+
+void SettingsDlg::processRemoteChange()
+{
+ connect(&m_remote, SIGNAL(infoUpdated()),
+ this, SLOT(updateRemoteInfo()));
+ enableRateBtns();
}
void SettingsDlg::updateRemoteInfo()
{
- remoteNameLabel->setText(remote->mfg() + " " + remote->name());
- ratingLabel->setText(tr("Rating") + ": " + remote->rating());
+ setBusy(false);
+ m_remoteNameLabel->setText(m_remote.mfg() + " " + m_remote.name());
+ m_ratingLabel->setText(tr("Rating") + ": "
+ + QString::number(m_remote.rating()));
}
void SettingsDlg::rateUpClicked()
{
- remote->sendRating(Rating::Up);
- enableRateBtns(false);
+ m_remote.sendRating(Rating::Up);
+ processRatingSent();
}
void SettingsDlg::rateDownClicked()
{
- remote->sendRating(Rating::Down);
+ m_remote.sendRating(Rating::Down);
+ processRatingSent();
+}
+
+void SettingsDlg::processRatingSent()
+{
enableRateBtns(false);
+ m_remote.updateInfo();
}
void SettingsDlg::enableRateBtns(bool enable)
{
- rateUpBtn->setEnabled(enable);
- rateDownBtn->setEnabled(enable);
+ m_rateUpBtn->setEnabled(enable);
+ m_rateDownBtn->setEnabled(enable);
}