From bf081866e9a15a8e9bdee46cbdf3058fcdab3450 Mon Sep 17 00:00:00 2001 From: Berthold Stoeger Date: Thu, 15 Aug 2019 00:15:30 +0200 Subject: Mobile: return dive-id directly from DiveListModel We don't want to generate a DiveObjectHelper numerous times for every item in the dive list. Therefore, return this datum directly from the model. In this case, don't remove from DiveObjectHelper, as this datum might be used by grantlee templates. Signed-off-by: Berthold Stoeger --- mobile-widgets/qml/DiveList.qml | 8 ++++---- qt-models/divelistmodel.cpp | 2 ++ qt-models/divelistmodel.h | 3 ++- 3 files changed, 8 insertions(+), 5 deletions(-) diff --git a/mobile-widgets/qml/DiveList.qml b/mobile-widgets/qml/DiveList.qml index ddcb81834..7d887368a 100644 --- a/mobile-widgets/qml/DiveList.qml +++ b/mobile-widgets/qml/DiveList.qml @@ -229,11 +229,11 @@ Kirigami.ScrollablePage { copyButtonVisible = false pasteButtonVisible = false timer.stop() - manager.copyDiveData(dive.id) + manager.copyDiveData(id) } onPressAndHold: { globalDrawer.close() - manager.copyDiveData(dive.id) + manager.copyDiveData(id) pageStack.push(settingsCopyWindow) } } @@ -270,7 +270,7 @@ Kirigami.ScrollablePage { copyButtonVisible = false pasteButtonVisible = false timer.stop() - manager.pasteDiveData(dive.id) + manager.pasteDiveData(id) } } } @@ -307,7 +307,7 @@ Kirigami.ScrollablePage { copyButtonVisible = false pasteButtonVisible = false timer.stop() - manager.deleteDive(dive.id) + manager.deleteDive(id) } } } diff --git a/qt-models/divelistmodel.cpp b/qt-models/divelistmodel.cpp index b41a16003..ba2a7a407 100644 --- a/qt-models/divelistmodel.cpp +++ b/qt-models/divelistmodel.cpp @@ -254,6 +254,7 @@ QVariant DiveListModel::data(const QModelIndex &index, int role) const return QStringLiteral("%1 %2").arg(localTime.date().toString(prefs.date_format_short), localTime.time().toString(prefs.time_format)); } + case IdRole: return d->id; } return QVariant(); } @@ -266,6 +267,7 @@ QHash DiveListModel::roleNames() const roles[TripIdRole] = "tripId"; roles[TripNrDivesRole] = "tripNrDives"; roles[DateTimeRole] = "dateTime"; + roles[IdRole] = "id"; return roles; } diff --git a/qt-models/divelistmodel.h b/qt-models/divelistmodel.h index c0d7aa0a0..9b39e5513 100644 --- a/qt-models/divelistmodel.h +++ b/qt-models/divelistmodel.h @@ -40,7 +40,8 @@ public: DiveDateRole, TripIdRole, TripNrDivesRole, - DateTimeRole + DateTimeRole, + IdRole }; static DiveListModel *instance(); -- cgit v1.2.3-70-g09d2