diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2018-10-13 08:57:46 +0200 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2018-10-13 21:41:41 -0400 |
commit | 954820aa81cb52cfe4442f2c6e81117827e32ccc (patch) | |
tree | 5392d9b44ed57542fb60be46a384bf783ed43c59 /desktop-widgets/locationinformation.cpp | |
parent | f0e349cdd68c259f07fd5867d8360cd8d65d50ef (diff) | |
download | subsurface-954820aa81cb52cfe4442f2c6e81117827e32ccc.tar.gz |
Dive site: explicitly init displayed_dive_site on show widget
The global object "displayed_dive_site" is used to store the
old dive site data for the edit-dive-site widget. The fields
of the widget were initialized from this object in the show
event. Therefore the object was updated in numerous parts of
the code to make sure that it was up-to-date. Instead, move
the initialization of the object to the function that also
initiatlizes the fields. Call this function explicitly before
showing the widget.
This makes the data-fow distinctly easier to understand.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'desktop-widgets/locationinformation.cpp')
-rw-r--r-- | desktop-widgets/locationinformation.cpp | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/desktop-widgets/locationinformation.cpp b/desktop-widgets/locationinformation.cpp index c7d537374..3f87454da 100644 --- a/desktop-widgets/locationinformation.cpp +++ b/desktop-widgets/locationinformation.cpp @@ -200,7 +200,6 @@ void LocationInformationWidget::acceptChanges() LocationInformationModel::instance()->removeRow(get_divesite_idx(currentDs)); displayed_dive.dive_site_uuid = 0; } - copy_dive_site(currentDs, &displayed_dive_site); mark_divelist_changed(true); resetState(); } @@ -210,9 +209,10 @@ void LocationInformationWidget::rejectChanges() resetState(); } -void LocationInformationWidget::showEvent(QShowEvent *ev) +void LocationInformationWidget::initFields(dive_site *ds) { - if (displayed_dive_site.uuid) { + if (ds) { + copy_dive_site(ds, &displayed_dive_site); filter_model.set(displayed_dive_site.uuid, displayed_dive_site.latitude, displayed_dive_site.longitude); updateLabels(); enableLocationButtons(dive_site_has_gps_location(&displayed_dive_site)); @@ -221,11 +221,11 @@ void LocationInformationWidget::showEvent(QShowEvent *ev) if (m) m->invalidate(); } else { + clear_dive_site(&displayed_dive_site); filter_model.set(0, degrees_t{ 0 }, degrees_t{ 0 }); clearLabels(); } MapWidget::instance()->prepareForGetDiveCoordinates(displayed_dive_site.uuid); - QGroupBox::showEvent(ev); } void LocationInformationWidget::markChangedWidget(QWidget *w) |