Bugfix, two connection dialogs opened when opening select remote dlg
[irwi] / src / settingsdlg.cpp
index 5d3c3ca..c88da36 100644 (file)
 #include "settingsdlg.h"
+#include "advsettingsdlg.h"
+#include "selectremotedlg.h"
+#include "aboutdlg.h"
 
-#include <QDebug>
 #include <QHBoxLayout>
+#include <QVBoxLayout>
+#include <QWidget>
+#include <QDialog>
+#include <QPushButton>
 #include <QLabel>
-#include <QString>
-#include <QListWidget>
-#include <QListWidgetItem>
-#include <QSettings>
-#include <QtNetwork/QNetworkAccessManager>
-#include <QtNetwork/QNetworkReply>
-#include <QBuffer>
-#include <QByteArray>
-#include <QFile>
+#include <QDebug>
 
 SettingsDlg::SettingsDlg(QWidget *parent)
     : QDialog(parent)
 {
-    this->setWindowTitle(tr("Settings"));
-
-    //TODO caching?
-    mfgNetAM = new QNetworkAccessManager(this);
-    connect(mfgNetAM, SIGNAL(finished(QNetworkReply*)), 
-            this,  SLOT(mfgListDownloadFinished(QNetworkReply*)));
-
-    modelNetAM = new QNetworkAccessManager(this);
-    connect(modelNetAM, SIGNAL(finished(QNetworkReply*)), 
-            this,  SLOT(modelListDownloadFinished(QNetworkReply*)));
-
-    remoteNetAM = new QNetworkAccessManager(this);
-    connect(remoteNetAM, SIGNAL(finished(QNetworkReply*)), 
-            this,  SLOT(remoteDownloadFinished(QNetworkReply*)));
+    QSettings settings(this);
+    m_layout = new QVBoxLayout(this);
+    m_btnLayout = new QHBoxLayout();
+    m_remoteNameLayout = new QHBoxLayout();
     
-    settings = new QSettings(this);
+    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);
+    m_rateDownBtn = new QPushButton(
+            QIcon(settings.value("rateDownIcon",
+                "/usr/share/icons/hicolor/48x48/hildon/chat_smiley_sad.png").
+                toString()),
+            "", this);
+    m_rateUpBtn->setMaximumSize(72, 72);
+    m_rateDownBtn->setMaximumSize(72, 72);
+
+    m_btnLayout->addWidget(m_advSettingsBtn);
+    m_btnLayout->addWidget(m_selectRemoteBtn);
+    m_btnLayout->addWidget(m_aboutBtn);
+
+    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(m_advSettingsBtn, SIGNAL(clicked()),
+            this, SLOT(showAdvSettingsDlg()));
+    connect(m_selectRemoteBtn, SIGNAL(clicked()),
+            this, SLOT(showSelectRemoteDlg()));
+    connect(m_aboutBtn, SIGNAL(clicked()),
+            this, SLOT(showAboutDlg()));
+    connect(m_rateUpBtn, SIGNAL(clicked()),
+            this, SLOT(rateUpClicked()));
+    connect(m_rateDownBtn, SIGNAL(clicked()),
+            this, SLOT(rateDownClicked()));
+    m_layout->addLayout(m_remoteNameLayout);
+    m_layout->addLayout(m_btnLayout);
+    this->setLayout(m_layout);
+
+    QString selectedRemote = QSettings(this).value("remoteName", "").toString();
+    if (selectedRemote == "") {
+        m_remoteNameLabel->setText("No remote selected");
+        enableRateBtns(false);
+    } else {
+        setRemote(selectedRemote);
+        setBusy();
+    }
+}
 
-    layout = new QHBoxLayout(this);
+SettingsDlg::~SettingsDlg()
+{
+    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;
+}
 
-    alphabetList = new QListWidget(this);
-    for (char c = 'a'; c <= 'z'; ++c)
-    {
-        alphabetList->addItem(QString(c));
-    }
-    layout->addWidget(alphabetList);
-    connect(alphabetList, SIGNAL(currentItemChanged(QListWidgetItem*, QListWidgetItem*)),
-                this, SLOT(alphabetItemChanged(QListWidgetItem*, QListWidgetItem*)));
-    
-    mfgList = new QListWidget(this);
-    layout->addWidget(mfgList);
-    connect(mfgList, SIGNAL(currentItemChanged(QListWidgetItem*, QListWidgetItem*)),
-                this, SLOT(mfgItemChanged(QListWidgetItem*, QListWidgetItem*)));
+void SettingsDlg::setBusy(bool busy)
+{
+    setAttribute(Qt::WA_Maemo5ShowProgressIndicator, busy);
+    setEnabled(!busy);
+}
+
+void SettingsDlg::showAdvSettingsDlg()
+{
+    AdvSettingsDlg dlg;
+    dlg.exec();
+}
 
-    modelList = new QListWidget(this);
-    layout->addWidget(modelList);
-    connect(modelList, SIGNAL(currentItemChanged(QListWidgetItem*, QListWidgetItem*)),
-                this, SLOT(modelItemChanged(QListWidgetItem*, QListWidgetItem*)));
+void SettingsDlg::showSelectRemoteDlg()
+{
+    SelectRemoteDlg dlg;
+    connect(&dlg, SIGNAL(remoteChanged(Remote)),
+            this, SLOT(setRemote(Remote)));
+    dlg.exec();
+}
 
-    this->setLayout(layout);
+void SettingsDlg::showAboutDlg()
+{
+    AboutDlg dlg;
+    dlg.exec();
 }
 
-SettingsDlg::~SettingsDlg()
+void SettingsDlg::setRemote(Remote r)
 {
-    delete layout;
-    delete settings;
-    delete mfgNetAM;
-    delete modelNetAM;
+    m_remote = r;
+    processRemoteChange();
+    updateRemoteInfo();
 }
 
-void SettingsDlg::alphabetItemChanged(QListWidgetItem *current, QListWidgetItem *previous)
+void SettingsDlg::setRemote(const QString &name)
 {
-    mfgNetAM->get(
-        QNetworkRequest(
-            QUrl(
-                settings->value(
-                    "remoteUrl",
-                    "http://mercury.wipsl.com/irwi/remotes/"
-                ).toString() 
-                + current->text() + ".txt"
-            )
-        )
-    );
+    setBusy();
+    m_remote = Remote(name);
+    processRemoteChange();
+    m_remote.updateInfo();  // request update from server
 }
 
-void SettingsDlg::mfgListDownloadFinished(QNetworkReply *reply)
+void SettingsDlg::processRemoteChange()
 {
-    mfgList->clear();
-    if (reply->error() == QNetworkReply::NoError) {
-        QByteArray ba = reply->readAll();
-        QBuffer buf(&ba, this);
-        buf.open(QIODevice::ReadOnly);
-        buf.seek(0);
-        while (buf.canReadLine())
-        {
-            QString str(buf.readLine());
-            str.chop(1);
-            mfgList->addItem(str);
-        }
-    } else {
-        //qDebug() << (int)reply->error();
-    }
-    reply->close();
-    reply->deleteLater();
+    connect(&m_remote, SIGNAL(infoUpdated()),
+            this, SLOT(updateRemoteInfo()));
+    enableRateBtns();
 }
 
-void SettingsDlg::mfgItemChanged(QListWidgetItem *current, QListWidgetItem *previous)
+void SettingsDlg::updateRemoteInfo()
 {
-    if (mfgList->currentItem() != NULL) {
-        modelNetAM->get(
-            QNetworkRequest(
-                QUrl(
-                    settings->value(
-                        "remoteUrl",
-                        "http://mercury.wipsl.com/irwi/remotes/"
-                    ).toString() 
-                    + alphabetList->currentItem()->text()
-                    + "/" + current->text() + ".txt"
-                )
-            )
-        );
-    }
+    setBusy(false);
+    m_remoteNameLabel->setText(m_remote.mfg() + " " + m_remote.name());
+    m_ratingLabel->setText(tr("Rating") + ": "
+            + QString::number(m_remote.rating()));
 }
 
-void SettingsDlg::modelListDownloadFinished(QNetworkReply *reply)
+void SettingsDlg::rateUpClicked()
 {
-    modelList->clear();
-    if (reply->error() == QNetworkReply::NoError) {
-        QByteArray ba = reply->readAll();
-        QBuffer buf(&ba, this);
-        buf.open(QIODevice::ReadOnly);
-        buf.seek(0);
-        while (buf.canReadLine())
-        {
-            QString str(buf.readLine());
-            str.chop(1);
-            modelList->addItem(str);
-        }
-    } else {
-        //qDebug() << (int)reply->error();
-    }
-    reply->close();
-    reply->deleteLater();
+    m_remote.sendRating(Rating::Up);
+    processRatingSent();
 }
 
-void SettingsDlg::modelItemChanged(QListWidgetItem *current, QListWidgetItem *previous)
+void SettingsDlg::rateDownClicked()
 {
-    if (current)
-    {
-        if (!current->text().isEmpty()) {
-             remoteNetAM->get(
-                QNetworkRequest(
-                    QUrl(
-                        settings->value(
-                            "remoteUrl",
-                            "http://mercury.wipsl.com/irwi/remotes/"
-                        ).toString() 
-                        + alphabetList->currentItem()->text()
-                        + "/" + mfgList->currentItem->text()
-                        + "/" + current->text()
-                    )
-                )
-            );
-            settings->setValue("remoteName", current->text());
-        }
-    }
+    m_remote.sendRating(Rating::Down);
+    processRatingSent();
 }
 
-void SettingsDlg::remoteDownloadFinished(QNetworkReply *reply)
+void SettingsDlg::processRatingSent()
 {
-    if (reply->error() == QNetworkReply::NoError) {
-        QFile file("/etc/lircd.conf");
-        if(file.open(QIODevice::WriteOnly))
-        {
-            file.write(reply->readAll());
-            file.close();
-        }
-    }
-    reply->close();
-    reply->deleteLater();
+    enableRateBtns(false);
+    m_remote.updateInfo();
+}
 
-    system("lircctl restart");
+void SettingsDlg::enableRateBtns(bool enable)
+{
+    m_rateUpBtn->setEnabled(enable);
+    m_rateDownBtn->setEnabled(enable);
 }
 
+