diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2020-04-13 23:04:30 +0200 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2020-04-13 16:55:15 -0700 |
commit | 0ccc0f04bb960ac00fa6175130125c8eed752072 (patch) | |
tree | c43303a2bf35f34ae8d17b099e10d8ec464ca5f8 | |
parent | b4e0968ed5a8ff197272c58ed08c949d9c2c0813 (diff) | |
download | subsurface-0ccc0f04bb960ac00fa6175130125c8eed752072.tar.gz |
dive sites: properly reload dive site model on desktop
In 9310d72943390f95d6742c2d5b40f025a40b4008, resetting of the dive
sites was moved to DiveTripModelBase::reset(). This seemed like a
good idea, because it means that the location list is reloaded
every time the dive list is reset.
Unfortunately that function is only used on mobile, thus on desktop
the dive site model is not updated. Do that in
MultiFilterSortModel::resetModel(), because this is always called
when the dive list is reset. Desktop differs from mobile in that
two different models are used depending on whether we are in list
or in tree mode.
Fixes #2749
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
-rw-r--r-- | qt-models/divetripmodel.cpp | 1 | ||||
-rw-r--r-- | qt-models/filtermodels.cpp | 2 |
2 files changed, 3 insertions, 0 deletions
diff --git a/qt-models/divetripmodel.cpp b/qt-models/divetripmodel.cpp index 174e5af54..784013bce 100644 --- a/qt-models/divetripmodel.cpp +++ b/qt-models/divetripmodel.cpp @@ -490,6 +490,7 @@ void DiveTripModelBase::clear() emit diveListNotifier.numShownChanged(); } +// Currently only used by the mobile models void DiveTripModelBase::reset() { beginResetModel(); diff --git a/qt-models/filtermodels.cpp b/qt-models/filtermodels.cpp index 2d081e6e6..9b2ab6a7b 100644 --- a/qt-models/filtermodels.cpp +++ b/qt-models/filtermodels.cpp @@ -6,6 +6,7 @@ #include "core/subsurface-string.h" #include "core/subsurface-qt/divelistnotifier.h" #include "qt-models/divetripmodel.h" +#include "qt-models/divelocationmodel.h" MultiFilterSortModel *MultiFilterSortModel::instance() { @@ -29,6 +30,7 @@ void MultiFilterSortModel::resetModel(DiveTripModelBase::Layout layout) connect(model.get(), &DiveTripModelBase::selectionChanged, this, &MultiFilterSortModel::selectionChangedSlot); connect(model.get(), &DiveTripModelBase::currentDiveChanged, this, &MultiFilterSortModel::currentDiveChangedSlot); model->initSelection(); + LocationInformationModel::instance()->update(); } void MultiFilterSortModel::clear() |