From 8834fc0443aadfe4e98a2b8db3253a9bf61645f8 Mon Sep 17 00:00:00 2001 From: Stefan Fuchs Date: Mon, 13 Mar 2017 08:25:32 +0100 Subject: Correctly trigger update of cylinder table trash icons in planner Signed-off-by: Stefan Fuchs --- qt-models/cylindermodel.cpp | 5 +++++ qt-models/cylindermodel.h | 1 + qt-models/diveplannermodel.cpp | 3 +++ 3 files changed, 9 insertions(+) (limited to 'qt-models') diff --git a/qt-models/cylindermodel.cpp b/qt-models/cylindermodel.cpp index ad6c502a5..bca6003b9 100644 --- a/qt-models/cylindermodel.cpp +++ b/qt-models/cylindermodel.cpp @@ -600,6 +600,11 @@ void CylindersModel::updateDecoDepths(pressure_t olddecopo2) emit dataChanged(createIndex(0, 0), createIndex(MAX_CYLINDERS - 1, COLUMNS - 1)); } +void CylindersModel::updateTrashIcon() +{ + emit dataChanged(createIndex(0, 0), createIndex(MAX_CYLINDERS - 1, 0)); +} + bool CylindersModel::updateBestMixes() { // Check if any of the cylinders are best mixes, update if needed diff --git a/qt-models/cylindermodel.h b/qt-models/cylindermodel.h index 88da8048c..1aa2daaec 100644 --- a/qt-models/cylindermodel.h +++ b/qt-models/cylindermodel.h @@ -38,6 +38,7 @@ public: void updateDive(); void copyFromDive(struct dive *d); void updateDecoDepths(pressure_t olddecopo2); + void updateTrashIcon(); cylinder_t *cylinderAt(const QModelIndex &index); bool changed; virtual QVariant headerData(int section, Qt::Orientation orientation, int role) const; diff --git a/qt-models/diveplannermodel.cpp b/qt-models/diveplannermodel.cpp index f4b821e6e..26e4fc1ba 100644 --- a/qt-models/diveplannermodel.cpp +++ b/qt-models/diveplannermodel.cpp @@ -24,6 +24,7 @@ void DivePlannerPointsModel::removeSelectedPoints(const QVector &rows) divepoints.remove(v2[i]); } endRemoveRows(); + CylindersModel::instance()->updateTrashIcon(); } void DivePlannerPointsModel::createSimpleDive() @@ -314,6 +315,7 @@ bool DivePlannerPointsModel::setData(const QModelIndex &index, const QVariant &v case GAS: if (value.toInt() >= 0 && value.toInt() < MAX_CYLINDERS) p.cylinderid = value.toInt(); + CylindersModel::instance()->updateTrashIcon(); break; } editStop(index.row(), p); @@ -732,6 +734,7 @@ void DivePlannerPointsModel::remove(const QModelIndex &index) divepoints.remove(index.row()); } endRemoveRows(); + CylindersModel::instance()->updateTrashIcon(); } struct diveplan &DivePlannerPointsModel::getDiveplan() -- cgit v1.2.3-70-g09d2