more work on dameon
[googlelatitude] / src / latitude.cpp
index 864f5c0..12ccf5c 100644 (file)
@@ -5,24 +5,8 @@ LatitudeGUI::LatitudeGUI(QMainWindow *parent) : QMainWindow(parent) {
     setAttribute(Qt::WA_Maemo5AutoOrientation, true);
 #endif
     setWindowTitle(tr("Latitude & Buzz"));
-
     setting = new QSettings();
 
-    // login input
-    QDialog *dialoglogin = new QDialog(this);
-    QLineEdit *login_user = new QLineEdit(setting->value("user","my_username").toString());
-    QLineEdit *login_pass = new QLineEdit(setting->value("pass","my_password").toString());
-    login_pass->setEchoMode(QLineEdit::Password);
-    QFormLayout *layout_login = new QFormLayout();
-    layout_login->addRow(tr("&Username"), login_user);
-    layout_login->addRow(tr("&Password"), login_pass);
-    connect(login_user, SIGNAL(textEdited(QString)), this, SLOT(save_user(QString)));
-    connect(login_pass, SIGNAL(textEdited(QString)), this, SLOT(save_pass(QString)));
-    connect(login_user, SIGNAL(returnPressed()), login_pass, SLOT(setFocus()));
-    connect(login_pass, SIGNAL(returnPressed()), dialoglogin, SLOT(accept()));
-    dialoglogin->setLayout(layout_login);
-    dialoglogin->exec();
-
     // GUI
     url = QUrl::fromEncoded("https://www.google.com/accounts/ServiceLogin?service=friendview&continue=http://www.google.com/maps/m?mode=latitude");
     maps = new QWebView();
@@ -31,6 +15,16 @@ LatitudeGUI::LatitudeGUI(QMainWindow *parent) : QMainWindow(parent) {
     maps->load(url);
     menuBar()->addAction(tr("&Latitude"), this, SLOT(mode_latitude()));
     menuBar()->addAction(tr("&Buzz"), this, SLOT(mode_buzz()));
+    menuBar()->addAction(tr("&Config"), this, SLOT(config()));
+
+    demonio = new QAction(this);
+    if ( system("killall -0 GoogleLatitudeDaemon 2> /dev/null" ) ) {
+        demonio->setText(tr("&Start Daemon"));
+    } else {
+        demonio->setText(tr("&Stop Daemon"));
+    }
+    connect(demonio, SIGNAL(triggered()), this, SLOT(mode_demonio()));
+    menuBar()->addAction(demonio);
 
     // updater
     glatitude = new GoogleLatitude(this);
@@ -43,33 +37,55 @@ LatitudeGUI::LatitudeGUI(QMainWindow *parent) : QMainWindow(parent) {
     setCentralWidget(maps);
 }
 
+void LatitudeGUI::config() {
+    // login input
+    QDialog *dialoglogin = new QDialog(this);
+    QLineEdit *login_user = new QLineEdit(setting->value("user","my_username").toString());
+    QLineEdit *login_pass = new QLineEdit(setting->value("pass","my_password").toString());
+    login_pass->setEchoMode(QLineEdit::Password);
+    QLineEdit *login_freq = new QLineEdit(setting->value("freq","120").toString());
+    QFormLayout *layout_login = new QFormLayout();
+    layout_login->addRow(tr("&Username"), login_user);
+    layout_login->addRow(tr("&Password"), login_pass);
+    layout_login->addRow(tr("&Interval"), login_freq);
+    connect(login_user, SIGNAL(textEdited(QString)), this, SLOT(save_user(QString)));
+    connect(login_pass, SIGNAL(textEdited(QString)), this, SLOT(save_pass(QString)));
+    connect(login_freq, SIGNAL(textEdited(QString)), this, SLOT(save_freq(QString)));
+    connect(login_user, SIGNAL(returnPressed()), login_pass, SLOT(setFocus()));
+    connect(login_pass, SIGNAL(returnPressed()), login_freq, SLOT(setFocus()));
+    connect(login_freq, SIGNAL(returnPressed()), dialoglogin, SLOT(accept()));
+    dialoglogin->setLayout(layout_login);
+    dialoglogin->exec();
+
+    set();
+    mode_latitude();
+    glatitude->reset();
+}
+
+
 void LatitudeGUI::set() {
-#ifdef Q_WS_MAEMO_5
-    QMaemo5InformationBox::information(this, "new position...", 1000);
-#else
-    qDebug() << "new position...";
-#endif
+    qDebug() << "LatitudeGUI: set";
     glatitude->login(setting->value("user","my_username").toString(),
                      setting->value("pass","my_password").toString());
+    glatitude->freq(setting->value("freq","120").toInt());
     glatitude->set(gps->get_lat(),
                    gps->get_lon(),
                    gps->get_acc());
 }
 
 void LatitudeGUI::latitude_OK() {
-#ifdef Q_WS_MAEMO_5
-    QMaemo5InformationBox::information(this, "...location Sent!", 1000);
-#else
-    qDebug() << "...location Sent!";
-#endif
+    qDebug() << "LatitudeGUI: send";
 }
 
 void LatitudeGUI::latitude_ERROR() {
 #ifdef Q_WS_MAEMO_5
-    QMaemo5InformationBox::information(this, "Error in Authentification !", 3000);
-#else
-    qDebug() << "Error in Authentification !";
+    QString error_message = tr("<b>Error in Authentification!</b><br><br>") +
+                            tr("Plese verify your login details<br>");
+    QMaemo5InformationBox::information(this, error_message,
+                                       QMaemo5InformationBox::NoTimeout);
 #endif
+    qDebug() << "LatitudeGUI: no auth";
+    config();
 }
 
 void LatitudeGUI::save_user(QString _user) {
@@ -78,7 +94,9 @@ void LatitudeGUI::save_user(QString _user) {
 void LatitudeGUI::save_pass(QString _pass) {
     setting->setValue("pass", _pass);
 }
-
+void LatitudeGUI::save_freq(QString _freq) {
+    setting->setValue("freq", _freq);
+}
 void LatitudeGUI::mode_buzz() {
     maps->load(QUrl::fromEncoded("http://www.google.com/maps/m?l-view=map&l-lci=m,com.google.latitudepublicupdates&ac=f,s,l"));
 }
@@ -98,3 +116,17 @@ void LatitudeGUI::maps_login() {
         maps->page()->mainFrame()->evaluateJavaScript("document.getElementById('gaia_loginform').submit();");
     }
 }
+
+void LatitudeGUI::mode_demonio() {
+    if ( ! system("killall -0 GoogleLatitudeDaemon 2> /dev/null" ) ) {
+        system("killall GoogleLatitudeDaemon 2> /dev/null");
+        demonio->setText(tr("&Start Daemon"));
+    } else {
+        QProcess *cli = new QProcess(this);
+        cli->start(QCoreApplication::applicationDirPath()+"/GoogleLatitudeDaemon");
+        qDebug() << "LatitudeGUI: demonio " << QCoreApplication::applicationDirPath()+"/GoogleLatitudeDaemon";
+        if ( ! system("killall -0 GoogleLatitudeDaemon 2> /dev/null" ) ) {
+            demonio->setText(tr("&Stop Daemon"));
+        }
+    }
+}