From 00617aa9248dc300fab3bacc4b40d52def7db86e Mon Sep 17 00:00:00 2001 From: Dirk Hohndel Date: Wed, 1 Apr 2020 07:37:35 -0700 Subject: core/models: give progress update while populating models Especially with large dive logs this will prevent the user from thinking that the app is hung. Signed-off-by: Dirk Hohndel --- qt-models/divetripmodel.cpp | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/qt-models/divetripmodel.cpp b/qt-models/divetripmodel.cpp index 207962906..2e5359b89 100644 --- a/qt-models/divetripmodel.cpp +++ b/qt-models/divetripmodel.cpp @@ -494,10 +494,14 @@ void DiveTripModelBase::reset() beginResetModel(); clearData(); populate(); + uiNotification(tr("setting up dive sites")); LocationInformationModel::instance()->update(); + uiNotification(tr("finish populating data store")); endResetModel(); + uiNotification(tr("setting up internal data structures")); initSelection(); emit diveListNotifier.numShownChanged(); + uiNotification(tr("done setting up internal data structures")); } DiveTripModelBase::DiveTripModelBase(QObject *parent) : QAbstractItemModel(parent), @@ -716,7 +720,12 @@ DiveTripModelTree::DiveTripModelTree(QObject *parent) : DiveTripModelBase(parent void DiveTripModelTree::populate() { + // we want this to be two calls as the second text is overwritten below by the lines starting with "\r" + uiNotification(QObject::tr("populate data model")); + uiNotification(QObject::tr("start processing")); for (int i = 0; i < dive_table.nr; ++i) { + if (i % 100 == 99) + uiNotification(QObject::tr("\r%1 dives processed").arg(i + 1)); dive *d = get_dive(i); update_cylinder_related_info(d); if (d->hidden_by_filter) @@ -744,6 +753,7 @@ void DiveTripModelTree::populate() // Remember the index of the current dive oldCurrent = current_dive; + uiNotification(QObject::tr("\r%1 dives processed").arg(dive_table.nr)); } int DiveTripModelTree::rowCount(const QModelIndex &parent) const -- cgit v1.2.3-70-g09d2