summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar willemferguson <willemferguson@zoology.up.ac.za>2019-11-11 11:47:12 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2019-11-11 20:18:41 +0100
commit2fe1121b1c7493e7951a8f66ce5ac10d11331aa4 (patch)
tree38e61285dd10b705620ee957af21abf1c1806377
parent7a4abd7477dc2a4f8e52f7bb00c19890c6ec2ca2 (diff)
downloadsubsurface-2fe1121b1c7493e7951a8f66ce5ac10d11331aa4.tar.gz
Information tab: Make air and water tempertatures editable
The undo stack is preserved. This is in preparation of removing temperatures from the Notes tab. Signed-off-by: willemferguson <willemferguson@zoology.up.ac.za>
-rw-r--r--desktop-widgets/tab-widgets/TabDiveInformation.cpp29
-rw-r--r--desktop-widgets/tab-widgets/TabDiveInformation.h2
-rw-r--r--desktop-widgets/tab-widgets/TabDiveInformation.ui8
3 files changed, 29 insertions, 10 deletions
diff --git a/desktop-widgets/tab-widgets/TabDiveInformation.cpp b/desktop-widgets/tab-widgets/TabDiveInformation.cpp
index 641e762f2..b97ca1cdf 100644
--- a/desktop-widgets/tab-widgets/TabDiveInformation.cpp
+++ b/desktop-widgets/tab-widgets/TabDiveInformation.cpp
@@ -63,8 +63,8 @@ void TabDiveInformation::clear()
ui->surfaceIntervalText->clear();
ui->maximumDepthText->clear();
ui->averageDepthText->clear();
- ui->waterTemperatureText->clear();
- ui->airTemperatureText->clear();
+ ui->watertemp->clear();
+ ui->airtemp->clear();
ui->atmPressVal->clear();
ui->salinityText->clear();
ui->waterTypeText->clear();
@@ -170,8 +170,8 @@ void TabDiveInformation::updateData()
updateProfile();
updateWhen();
- ui->waterTemperatureText->setText(get_temperature_string(current_dive->watertemp, true));
- ui->airTemperatureText->setText(get_temperature_string(current_dive->airtemp, true));
+ ui->watertemp->setText(get_temperature_string(current_dive->watertemp, true));
+ ui->airtemp->setText(get_temperature_string(current_dive->airtemp, true));
ui->atmPressType->setItemText(1, get_depth_unit()); // Check for changes in depth unit (imperial/metric)
ui->atmPressType->setCurrentIndex(0); // Set the atmospheric pressure combo box to mbar
updateMode(current_dive);
@@ -194,9 +194,9 @@ void TabDiveInformation::divesChanged(const QVector<dive *> &dives, DiveField fi
if (field.duration || field.depth || field.mode)
updateProfile();
if (field.air_temp)
- ui->airTemperatureText->setText(get_temperature_string(current_dive->airtemp, true));
+ ui->airtemp->setText(get_temperature_string(current_dive->airtemp, true));
if (field.water_temp)
- ui->waterTemperatureText->setText(get_temperature_string(current_dive->watertemp, true));
+ ui->watertemp->setText(get_temperature_string(current_dive->watertemp, true));
if (field.atm_press)
ui->atmPressVal->setText(ui->atmPressVal->text().sprintf("%d",current_dive->surface_pressure.mbar));
if (field.salinity)
@@ -222,6 +222,23 @@ void TabDiveInformation::diveModeChanged(int index)
divesEdited(Command::editMode(dc_number, (enum divemode_t)index, false));
}
+void TabDiveInformation::on_airtemp_editingFinished()
+{
+ // If the field wasn't modified by the user, don't post a new undo command.
+ // Owing to rounding errors, this might lead to undo commands that have
+ // no user visible effects. These can be very confusing.
+ if (ui->airtemp->isModified() && current_dive)
+ divesEdited(Command::editAirTemp(parseTemperatureToMkelvin(ui->airtemp->text()), false));
+}
+
+void TabDiveInformation::on_watertemp_editingFinished()
+{
+ // If the field wasn't modified by the user, don't post a new undo command.
+ // Owing to rounding errors, this might lead to undo commands that have
+ // no user visible effects. These can be very confusing.
+ if (ui->watertemp->isModified() && current_dive)
+ divesEdited(Command::editWaterTemp(parseTemperatureToMkelvin(ui->watertemp->text()), false));
+}
void TabDiveInformation::on_atmPressType_currentIndexChanged(int index) { updateTextBox(COMBO_CHANGED); }
void TabDiveInformation::on_atmPressVal_editingFinished() { updateTextBox(TEXT_EDITED); }
diff --git a/desktop-widgets/tab-widgets/TabDiveInformation.h b/desktop-widgets/tab-widgets/TabDiveInformation.h
index 8b38797c3..96b2896e9 100644
--- a/desktop-widgets/tab-widgets/TabDiveInformation.h
+++ b/desktop-widgets/tab-widgets/TabDiveInformation.h
@@ -22,6 +22,8 @@ private slots:
void on_atmPressVal_editingFinished();
void on_atmPressType_currentIndexChanged(int index);
void on_visibility_valueChanged(int value);
+ void on_airtemp_editingFinished();
+ void on_watertemp_editingFinished();
private:
Ui::TabDiveInformation *ui;
void updateProfile();
diff --git a/desktop-widgets/tab-widgets/TabDiveInformation.ui b/desktop-widgets/tab-widgets/TabDiveInformation.ui
index 41be1bd8a..6c5588d6a 100644
--- a/desktop-widgets/tab-widgets/TabDiveInformation.ui
+++ b/desktop-widgets/tab-widgets/TabDiveInformation.ui
@@ -374,7 +374,7 @@
</item>
<item row="5" column="0">
- <widget class="QGroupBox" name="groupBox_9">
+ <widget class="QGroupBox" name="groupBox_airtemp">
<property name="title">
<string>Air temp.</string>
</property>
@@ -389,7 +389,7 @@
</property>
<layout class="QHBoxLayout" name="diveInfoAirTempLayout">
<item>
- <widget class="QLabel" name="airTemperatureText">
+ <widget class="QLineEdit" name="airtemp">
<property name="text">
<string/>
</property>
@@ -403,7 +403,7 @@
</item>
<item row="5" column="1">
- <widget class="QGroupBox" name="groupBox_8">
+ <widget class="QGroupBox" name="groupBox_watertemp">
<property name="title">
<string>Water temp.</string>
</property>
@@ -418,7 +418,7 @@
</property>
<layout class="QHBoxLayout" name="diveInfoWaterTempLayout">
<item>
- <widget class="QLabel" name="waterTemperatureText">
+ <widget class="QLineEdit" name="watertemp">
<property name="text">
<string/>
</property>