diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2013-09-20 16:41:42 -0700 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2013-09-21 08:30:32 -0700 |
commit | a8888eaf26c9355f3f2d20c24526489e17d3404a (patch) | |
tree | b45150112874e018d80dba76cac913faec22393d /qt-ui/maintab.cpp | |
parent | acd35995484ba8b0a4ee416b5dcceb76b843439e (diff) | |
download | subsurface-a8888eaf26c9355f3f2d20c24526489e17d3404a.tar.gz |
Allow editing of date & time and air & water temperatures
Add two more rows to the widget - this is getting quite busy.
There still is some weirdness where the focus isn't returned where it
should be and a few other details, but overall getting there.
Added helper functions to parse a temperature and to deal with the
timezone offset - with that latter one I also fixed the time offset bug in
the planner.
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'qt-ui/maintab.cpp')
-rw-r--r-- | qt-ui/maintab.cpp | 60 |
1 files changed, 55 insertions, 5 deletions
diff --git a/qt-ui/maintab.cpp b/qt-ui/maintab.cpp index 779a9fc75..b9a539fef 100644 --- a/qt-ui/maintab.cpp +++ b/qt-ui/maintab.cpp @@ -56,6 +56,9 @@ MainTab::MainTab(QWidget *parent) : QTabWidget(parent), ui->notes->viewport()->installEventFilter(this); ui->rating->installEventFilter(this); ui->visibility->installEventFilter(this); + ui->airtemp->installEventFilter(this); + ui->watertemp->installEventFilter(this); + ui->dateTimeEdit->installEventFilter(this); QList<QObject *> statisticsTabWidgets = ui->statisticsTab->children(); Q_FOREACH(QObject* obj, statisticsTabWidgets) { @@ -142,6 +145,9 @@ void MainTab::enableEdition() notesBackup[mydive].latitude = mydive->latitude; notesBackup[mydive].longitude = mydive->longitude; notesBackup[mydive].coordinates = ui->coordinates->text(); + notesBackup[mydive].airtemp = get_temperature_string(mydive->airtemp, true); + notesBackup[mydive].watertemp = get_temperature_string(mydive->watertemp, true); + notesBackup[mydive].datetime = QDateTime::fromTime_t(mydive->when - gettimezoneoffset()).toString(QString("M/d/yy h:mm")); } editMode = DIVE; } @@ -149,7 +155,12 @@ void MainTab::enableEdition() bool MainTab::eventFilter(QObject* object, QEvent* event) { - if (isEnabled() && event->type() == QEvent::FocusIn && (object == ui->rating || object == ui->visibility)){ + if (isEnabled() && event->type() == QEvent::KeyPress && object == ui->dateTimeEdit) { + tabBar()->setTabIcon(currentIndex(), QIcon(":warning")); + enableEdition(); + } + + if (isEnabled() && event->type() == QEvent::FocusIn && (object == ui->rating || object == ui->visibility)) { tabBar()->setTabIcon(currentIndex(), QIcon(":warning")); enableEdition(); } @@ -197,6 +208,13 @@ void MainTab::clearStats() else \ ui->field->setText(d->field) +#define UPDATE_TEMP(d, field) \ + if (!d || d->field.mkelvin == 0) \ + ui->field->setText(""); \ + else \ + ui->field->setText(get_temperature_string(d->field, TRUE)); + + void MainTab::updateDiveInfo(int dive) { if(!isEnabled()) @@ -221,7 +239,9 @@ void MainTab::updateDiveInfo(int dive) UPDATE_TEXT(d, suit); UPDATE_TEXT(d, divemaster); UPDATE_TEXT(d, buddy); - + UPDATE_TEMP(d, airtemp); + UPDATE_TEMP(d, watertemp); + ui->dateTimeEdit->setDateTime(QDateTime::fromTime_t(d->when - gettimezoneoffset())); if (d) { char buffer[256]; print_gps_coordinates(buffer, sizeof buffer, d->latitude.udeg, d->longitude.udeg); @@ -385,10 +405,13 @@ void MainTab::acceptChanges() notesBackup[curr].divemaster != ui->divemaster->text() || notesBackup[curr].location != ui->location->text() || notesBackup[curr].coordinates != ui->coordinates->text() || - notesBackup[curr].rating != ui->visibility->currentStars() || - notesBackup[curr].visibility != ui->rating->currentStars()) - + notesBackup[curr].rating != ui->visibility->currentStars() || + notesBackup[curr].airtemp != ui->airtemp->text() || + notesBackup[curr].watertemp != ui->watertemp->text() || + notesBackup[curr].datetime != ui->dateTimeEdit->dateTime().toString(QString("M/d/yy h:mm")) || + notesBackup[curr].visibility != ui->rating->currentStars()) { mark_divelist_changed(TRUE); + } if (notesBackup[curr].location != ui->location->text() || notesBackup[curr].coordinates != ui->coordinates->text()) { mainWindow()->globe()->reload(); @@ -414,6 +437,9 @@ void MainTab::acceptChanges() ui->coordinates->setPalette(p); ui->divemaster->setPalette(p); ui->suit->setPalette(p); + ui->airtemp->setPalette(p); + ui->watertemp->setPalette(p); + ui->dateTimeEdit->setPalette(p); } #define EDIT_TEXT2(what, text) \ @@ -445,6 +471,9 @@ void MainTab::rejectChanges() ui->divemaster->setText(notesBackup[curr].divemaster); ui->rating->setCurrentStars(notesBackup[curr].rating); ui->visibility->setCurrentStars(notesBackup[curr].visibility); + ui->airtemp->setText(notesBackup[curr].airtemp); + ui->watertemp->setText(notesBackup[curr].watertemp); + ui->dateTimeEdit->setDateTime(QDateTime::fromString(notesBackup[curr].datetime, QString("M/d/y h:mm"))); struct dive *mydive; for (int i = 0; i < dive_table.nr; i++) { @@ -480,6 +509,9 @@ void MainTab::rejectChanges() ui->coordinates->setPalette(p); ui->divemaster->setPalette(p); ui->suit->setPalette(p); + ui->airtemp->setPalette(p); + ui->watertemp->setPalette(p); + ui->dateTimeEdit->setPalette(p); if (editMode == ADD) { // clean up delete_single_dive(selected_dive); @@ -525,6 +557,24 @@ void MainTab::on_divemaster_textChanged(const QString& text) markChangedWidget(ui->divemaster); } +void MainTab::on_airtemp_textChanged(const QString& text) +{ + EDIT_SELECTED_DIVES( mydive->airtemp.mkelvin = parseTemperatureToMkelvin(text) ); + markChangedWidget(ui->airtemp); +} + +void MainTab::on_watertemp_textChanged(const QString& text) +{ + EDIT_SELECTED_DIVES( mydive->watertemp.mkelvin = parseTemperatureToMkelvin(text) ); + markChangedWidget(ui->watertemp); +} + +void MainTab::on_dateTimeEdit_dateTimeChanged(const QDateTime& datetime) +{ + EDIT_SELECTED_DIVES( mydive->when = datetime.toTime_t() + gettimezoneoffset() ); + markChangedWidget(ui->dateTimeEdit); +} + void MainTab::on_location_textChanged(const QString& text) { if (editMode == NONE) |