summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Tomaz Canabrava <tomaz.canabrava@gmail.com>2015-05-29 23:15:12 -0300
committerGravatar Dirk Hohndel <dirk@hohndel.org>2015-05-29 20:59:47 -0700
commit80fe3f88f92c55400afe87092ef02492f7bafac2 (patch)
tree1d409a4ffdaed850a022924de9fe6424d1c1222d
parentb0d7d0f3b9beb25a523e5c4db396a859c4562a23 (diff)
downloadsubsurface-80fe3f88f92c55400afe87092ef02492f7bafac2.tar.gz
Correctly set the dive site id on the dive
When changing the index of the combobox we were discarting the dive_site_id. This fixes it. Now I need to understand what's happening to the globe. Signed-off-by: Tomaz Canabrava <tomaz.canabrava@gmail.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--qt-models/divelocationmodel.cpp1
-rw-r--r--qt-models/divelocationmodel.h1
-rw-r--r--qt-ui/maintab.cpp3
3 files changed, 5 insertions, 0 deletions
diff --git a/qt-models/divelocationmodel.cpp b/qt-models/divelocationmodel.cpp
index 973452b16..164d85d95 100644
--- a/qt-models/divelocationmodel.cpp
+++ b/qt-models/divelocationmodel.cpp
@@ -25,6 +25,7 @@ QVariant LocationInformationModel::data(const QModelIndex &index, int role) cons
switch(role) {
case Qt::DisplayRole : return qPrintable(ds->name);
+ case DIVE_SITE_UUID : return ds->uuid;
}
return QVariant();
diff --git a/qt-models/divelocationmodel.h b/qt-models/divelocationmodel.h
index ee5f3c362..9238c4b5b 100644
--- a/qt-models/divelocationmodel.h
+++ b/qt-models/divelocationmodel.h
@@ -6,6 +6,7 @@
class LocationInformationModel : public QAbstractListModel {
Q_OBJECT
public:
+ enum { DIVE_SITE_UUID = Qt::UserRole+1};
static LocationInformationModel *instance();
int rowCount(const QModelIndex &parent = QModelIndex()) const;
QVariant data(const QModelIndex &index = QModelIndex(), int role = Qt::DisplayRole) const;
diff --git a/qt-ui/maintab.cpp b/qt-ui/maintab.cpp
index 01c342ad6..f344b1b82 100644
--- a/qt-ui/maintab.cpp
+++ b/qt-ui/maintab.cpp
@@ -1270,6 +1270,9 @@ void MainTab::on_location_currentTextChanged(const QString &text)
}
if (current_dive && text == QString(get_dive_site_by_uuid(current_dive->dive_site_uuid)->name))
return;
+
+ uint32_t uuid = ui.location->currentData(LocationInformationModel::DIVE_SITE_UUID).toInt();
+ displayed_dive.dive_site_uuid = uuid;
markChangedWidget(ui.location);
}