X-Git-Url: https://vcs.maemo.org/git/?a=blobdiff_plain;f=mainwidget.cpp;h=4e049095756e497fac66f2bc54264e1f0cd0de88;hb=0e91a5627bb3858961b9715a739cd93a1411595c;hp=76fc3ed5a7eff0906a16a8cdf9a68a57be2091fe;hpb=9c472d47e0c491fb45d00c3761689bd40eb627c4;p=yandex-traffic diff --git a/mainwidget.cpp b/mainwidget.cpp index 76fc3ed..4e04909 100644 --- a/mainwidget.cpp +++ b/mainwidget.cpp @@ -1,7 +1,13 @@ #include +#include "globals.hpp" #include "mainwidget.hpp" #include "settingsDialog.hpp" +#include "connection.hpp" +#include "devstate.hpp" +#include "settings.hpp" +#include "log.hpp" +#include "menudialog.hpp" // -------------------------------------------------- @@ -10,28 +16,29 @@ MainWidget::MainWidget () : QWidget () { - setMinimumSize (300, 80); #ifdef Q_WS_MAEMO_5 setAttribute(Qt::WA_TranslucentBackground); #endif _light = new TrafficLight (this); _label = new QLabel (this); + _timer = new QTimer (this); + + _label->setAlignment (Qt::AlignHCenter | Qt::AlignVCenter); _traffic = new Traffic; _regions = new RegionsTable; - _settings = new Settings; + _settings = Settings::instance (); QHBoxLayout *layout = new QHBoxLayout; layout->addWidget (_light); layout->addWidget (_label); setLayout (layout); - _light->setVisible (_settings->check (Settings::C_Light)); + applySettings (); connect (_traffic, SIGNAL (updated ()), SLOT (trafficUpdated ())); - - // every 5 minutes (TODO, make option) - startTimer (5*60*1000); + connect (_timer, SIGNAL (timeout ()), SLOT (updateData ())); + connect (DeviceState::instance (), SIGNAL (lockChanged (bool)), SLOT (deviceLockChanged (bool))); updateData (); } @@ -60,51 +67,64 @@ void MainWidget::paintEvent(QPaintEvent *event) } -void MainWidget::timerEvent (QTimerEvent *) -{ - updateData (); -} - - - void MainWidget::trafficUpdated () { - ExtendedTrafficInfo info = _traffic->lookup_ext ("1"); + ExtendedTrafficInfo info = _traffic->lookup_ext (_settings->regionID ()); if (info.valid ()) { QString data; bool first = true; _light->setColor (info.color ()); - if (_settings->check (Settings::C_Rank)) { - data.append (QString::number (info.level ())); - data.append (info.level () > 1 ? tr (" points") : tr (" point")); + if (_settings->check (Settings::C_ShowRank)) { + data.append (tr ("%n point(s)", "", info.level ())); first = false; } - if (_settings->check (Settings::C_Time)) { + if (_settings->check (Settings::C_ShowTime)) { if (!first) data.append (", "); data.append (info.localtime ()); first = false; } - if (_settings->check (Settings::C_Hint)) { - data.append ("\n"); + if (_settings->check (Settings::C_ShowHint)) { + if (!first) + data.append ("\n"); data.append (info.hint ()); } _label->setText (data); } - else + else { _light->setColor (ExtendedTrafficInfo::Unknown); + _label->setText (tr ("No data")); + } } void MainWidget::updateData () { - // Here we need to check for internet connection - _traffic->update (); + bool update = true; + + Log::instance ()->add ("updateData called"); + +#if CHECK_FOR_CONNECTION + update = ConnectionChecker::instance ()->checkConnection (_settings->check (Settings::C_UpdateOnGSM), + _settings->check (Settings::C_UpdateOnWiFi)); + Log::instance ()->add (QString ("checkConnection returned %1").arg (update ? "true" : "false")); + if (!_settings->check (Settings::C_UpdateWhenLocked)) { + Log::instance ()->add ("Check for device state"); + update &= !DeviceState::instance ()->locked (); + } +#endif + + if (update) { + Log::instance ()->add ("Perform update"); + _traffic->update (); + } + else + Log::instance ()->add ("Update not performed"); } @@ -114,8 +134,76 @@ void MainWidget::settingsDialog () dlg.exec (); - // Handle settings - _light->setVisible (_settings->check (Settings::C_Light)); - + applySettings (); trafficUpdated (); } + + +void MainWidget::updateSize () +{ + QSize minSize (0, 80); + + if (_settings->check (Settings::C_ShowLight)) + minSize += QSize (80, 0); + if (_settings->check (Settings::C_ShowHint)) + minSize += QSize (270, 0); + else { + if (_settings->check (Settings::C_ShowTime)) + minSize += QSize (75, 0); + if (_settings->check (Settings::C_ShowRank)) + minSize += QSize (75, 0); + } + + setFixedSize (minSize); +} + + + +void MainWidget::applySettings () +{ + _light->setVisible (_settings->check (Settings::C_ShowLight)); + + updateSize (); + + Log::instance ()->add (QString ("applySettings: updateInterval is %1").arg (_settings->updateInterval ())); + + if (_settings->updateInterval () < 0) { + _timer->stop (); + Log::instance ()->add ("Timer disabled"); + } + else { + _timer->setInterval (1000 * 60 * _settings->updateInterval ()); + _timer->start (); + Log::instance ()->add (QString ("Timer interval set to %1 ms").arg (1000 * 60 * _settings->updateInterval ())); + } +} + + +bool MainWidget::event (QEvent *event) +{ + if (event->type () != QEvent::WindowActivate) + return QWidget::event (event); + + MenuDialog menu (tr ("Yandex.Traffic")); + + menu.addEntry (tr ("Settings")).addEntry (tr ("Update")); + + switch (menu.run ()) { + case 0: + settingsDialog (); + break; + case 1: + _traffic->update (); + break; + } + + return QWidget::event (event); +} + + +void MainWidget::deviceLockChanged (bool locked) +{ + if (!_settings->check (Settings::C_UpdateWhenLocked)) + if (!locked) + updateData (); +}