Website updated.
[irwi] / src / selectremotedlg.cpp
index 898c6e1..cc73668 100644 (file)
@@ -1,53 +1,46 @@
 #include "selectremotedlg.h"
 
-#include "remotelist.h"
-#include "model.h"
+#include "remote.h"
+#include "onlinepollerthread.h"
+#include "remotetable.h"
 
-#include <cstdlib>
-
-#include <QDebug>
 #include <QHBoxLayout>
 #include <QLabel>
 #include <QString>
 #include <QListWidget>
 #include <QListWidgetItem>
 #include <QSettings>
-#include <QtNetwork/QNetworkAccessManager>
-#include <QtNetwork/QNetworkReply>
-#include <QBuffer>
-#include <QByteArray>
-#include <QFile>
 #include <QMap>
 #include <QList>
 #include <QMessageBox>
 #include <QPushButton>
-#include <QListWidgetItem>
-#include <QDomDocument>
 
 SelectRemoteDlg::SelectRemoteDlg(QWidget *parent)
     : QDialog(parent)
 {
+    onlinePollerThread = NULL;
     this->setWindowTitle(tr("Select remote"));
     this->setMinimumHeight(320);
 
-    deviceNameMap = new QMap<QString, QString>();
-    settings = new QSettings(this);
-    remoteList = NULL;
-
     layout = new QHBoxLayout(this);
 
     alphabetList = new QListWidget(this);
-    alphabetList->setMaximumWidth(96);
+    alphabetList->setMaximumWidth(64);
     layout->addWidget(alphabetList);
-    connect(alphabetList, SIGNAL(currentItemChanged(QListWidgetItem*, QListWidgetItem*)),
-                this, SLOT(alphabetItemChanged(QListWidgetItem*, QListWidgetItem*)));
+    connect(alphabetList,
+            SIGNAL(currentItemChanged(QListWidgetItem*, QListWidgetItem*)),
+            this,
+            SLOT(alphabetItemChanged(QListWidgetItem*, QListWidgetItem*)));
     
     mfgList = new QListWidget(this);
+    mfgList->setMaximumWidth(192);
     layout->addWidget(mfgList);
-    connect(mfgList, SIGNAL(currentItemChanged(QListWidgetItem*, QListWidgetItem*)),
-                this, SLOT(mfgItemChanged(QListWidgetItem*, QListWidgetItem*)));
+    connect(mfgList,
+            SIGNAL(currentItemChanged(QListWidgetItem*, QListWidgetItem*)),
+            this,
+            SLOT(mfgItemChanged(QListWidgetItem*, QListWidgetItem*)));
 
-    modelList = new QListWidget(this);
+    modelList = new RemoteTable(this);
     layout->addWidget(modelList);
 
     downloadBtn = new QPushButton(tr("Download"), this);
@@ -56,133 +49,105 @@ SelectRemoteDlg::SelectRemoteDlg(QWidget *parent)
             this, SLOT(downloadRemote()));
 
     this->setLayout(layout);
-
-    //TODO caching?
-    listNetAM = new QNetworkAccessManager(this);
-    connect(listNetAM, SIGNAL(finished(QNetworkReply*)), 
-            this,  SLOT(listDownloadFinished(QNetworkReply*)));
-
-    remoteNetAM = new QNetworkAccessManager(this);
-    connect(remoteNetAM, SIGNAL(finished(QNetworkReply*)), 
-            this,  SLOT(remoteDownloadFinished(QNetworkReply*)));
-    beginDownload(settings->value("dbUrl", 
-                "http://mercury.wipsl.com/irwi/db.xml").toString(), listNetAM); 
+    connect(&remoteDBMgr, SIGNAL(dbReady(RemoteDB*)),
+            this, SLOT(setDB(RemoteDB*)));
+    connect(&remoteDBMgr, SIGNAL(downloadFailed(int)),
+            this, SLOT(onDBError(int)));
 }
 
 SelectRemoteDlg::~SelectRemoteDlg()
 {
     delete layout;
-    delete settings;
-    delete listNetAM;
-    delete remoteNetAM;
-    delete deviceNameMap;
-    if (remoteList)
-    {
-        delete remoteList;
+    if (onlinePollerThread != NULL) {
+        delete onlinePollerThread;
+        onlinePollerThread = NULL;
     }
 }
 
-void SelectRemoteDlg::setBusy(bool busy)
+void SelectRemoteDlg::setDB(RemoteDB *db)
 {
-    setAttribute(Qt::WA_Maemo5ShowProgressIndicator, busy);
-    setEnabled(!busy);
+    remoteDB = db;
+    alphabetList->addItems(remoteDB->keys());
+    setBusy(false);
 }
 
-void SelectRemoteDlg::beginDownload(const QString &url,
-                                    QNetworkAccessManager *nam)
+void SelectRemoteDlg::setBusy(bool busy)
 {
-    nam->get(QNetworkRequest(QUrl(url)));
-    setBusy(true);
+#ifdef Q_WS_MAEMO_5
+    setAttribute(Qt::WA_Maemo5ShowProgressIndicator, busy);
+#endif
+    setEnabled(!busy);
 }
 
 void SelectRemoteDlg::alphabetItemChanged(QListWidgetItem *current,
                                       QListWidgetItem * /*previous*/)
 {
     mfgList->clear();
-    modelList->clear();
-    if (current)
-    {
-        mfgList->addItems(remoteList->manufacturers(current->text()));
+    modelList->removeAllRows();
+    if (current) {
+        mfgList->addItems((*remoteDB)[current->text()].keys());
     }
 }
 
-void SelectRemoteDlg::listDownloadFinished(QNetworkReply *reply)
+void SelectRemoteDlg::mfgItemChanged(QListWidgetItem *current,
+                                     QListWidgetItem * /*previous*/)
 {
-    if (reply->error() == QNetworkReply::NoError) {
-        QByteArray ba = reply->readAll();
-        QBuffer buf(&ba, this);
-        buf.open(QIODevice::ReadOnly);
-        buf.seek(0);
-        QDomDocument doc;
-        doc.setContent(&buf);
-        remoteList = new RemoteList(doc);
-        QStringList alist = remoteList->letters();
-        for (int i = 0; i < alist.size(); ++i)
-        {
-            alphabetList->addItem(QString(alist[i]));
+    modelList->removeAllRows();
+    if (current) {
+        RemoteList remotes =
+            (*remoteDB)[alphabetList->currentItem()->text()][current->text()];
+        foreach(Remote *remote, remotes) {
+            modelList->addItem(remote);
         }
-    } else {
-        //qDebug() << (int)reply->error();
     }
-    reply->close();
-    reply->deleteLater();
-    setBusy(false);
 }
 
-void SelectRemoteDlg::mfgItemChanged(QListWidgetItem *current,
-                                     QListWidgetItem * /*previous*/)
+void SelectRemoteDlg::downloadRemote()
 {
-    modelList->clear();
-    deviceNameMap->clear();
-    if (current)
-    {
-        QList<Model> models = remoteList->models(current->text());
-        for (int i = 0; i < models.size(); ++i)
-        {
-            modelList->addItem(models[i].name);
-            deviceNameMap->insert(models[i].name, models[i].file);
-        }
-
+    Remote *currentModel = modelList->selected();
+    if (currentModel) {
+        setResult(QDialog::Accepted);
+        setBusy();
+        connect(currentModel, SIGNAL(saveFinished()),
+                this, SLOT(close()));
+        currentModel->saveToFile();
+
+        emit remoteChanged(*currentModel);
     }
 }
 
-void SelectRemoteDlg::downloadRemote()
+void SelectRemoteDlg::getDB()
 {
-    QListWidgetItem *currentModel = modelList->currentItem();
-    if (currentModel)
-    {
-        QString name = currentModel->text();
-        if (!name.isEmpty()) {
-            QString url = settings->value(
-                    "remoteUrl",
-                    "http://mercury.wipsl.com/irwi/uploaded/").toString() 
-                    + (*deviceNameMap)[name];
-            beginDownload(url, remoteNetAM);
-            settings->setValue("remoteName", name);
-        }
+    if (onlinePollerThread != NULL) {
+        delete onlinePollerThread;
+        onlinePollerThread = NULL;
     }
+    remoteDBMgr.getDBAsync();
 }
 
-void SelectRemoteDlg::remoteDownloadFinished(QNetworkReply *reply)
+void SelectRemoteDlg::refreshDB()
 {
-    if (reply->error() == QNetworkReply::NoError) {
-        QFile file(settings->value("lircConf", "/etc/lircd.conf").toString());
-        if(file.open(QIODevice::WriteOnly))
-        {
-            file.write(reply->readAll());
-            file.close();
-        }
+    setBusy(true);
+    if (onlinePollerThread != NULL) {
+        delete onlinePollerThread;
+        onlinePollerThread = NULL;
     }
-    reply->close();
-    reply->deleteLater();
+    onlinePollerThread = new OnlinePollerThread();
+    connect(onlinePollerThread, SIGNAL(online()),
+            this, SLOT(getDB()));
+    onlinePollerThread->start();
+}
 
-    std::system("sudo /etc/init.d/lirc reload");
+void SelectRemoteDlg::showEvent(QShowEvent *event)
+{
+    refreshDB();
+    QDialog::showEvent(event);
+}
 
-    emit remoteDownloaded();
+void SelectRemoteDlg::onDBError(int error)
+{
+    this->setWindowTitle(tr("Network error") + " " + QString::number(error));
     setBusy(false);
-    QMessageBox mbox(QMessageBox::Information, tr("Success"),
-            tr("Remote downloaded"), QMessageBox::Ok, this);
-    mbox.exec();
-    this->close();
+    downloadBtn->setVisible(false);
 }