summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Tomaz Canabrava <tcanabrava@kde.org>2013-07-18 11:53:47 -0300
committerGravatar Tomaz Canabrava <tcanabrava@kde.org>2013-07-18 11:53:47 -0300
commitedb1a7adb37639d50b2dc1672adde20d544211c1 (patch)
tree64c37379092c1acb8b457bffe35530ddf4930558
parent9b0a44196c1f619b37450ef77d00aedfdad106ae (diff)
downloadsubsurface-edb1a7adb37639d50b2dc1672adde20d544211c1.tar.gz
Added the code to revert Weigths when user cancels edition
This is a follow up commit to the previous one that enabled cancel for cylinders, everything in the commit log for the cylinders also applyes here. Signed-off-by: Tomaz Canabrava <tcanabrava@kde.org>
-rw-r--r--qt-ui/modeldelegates.cpp26
-rw-r--r--qt-ui/modeldelegates.h3
-rw-r--r--qt-ui/models.cpp5
-rw-r--r--qt-ui/models.h2
4 files changed, 33 insertions, 3 deletions
diff --git a/qt-ui/modeldelegates.cpp b/qt-ui/modeldelegates.cpp
index 16140bb8d..9ccf6608f 100644
--- a/qt-ui/modeldelegates.cpp
+++ b/qt-ui/modeldelegates.cpp
@@ -59,6 +59,8 @@ QSize StarWidgetsDelegate::sizeHint(const QStyleOptionViewItem& option, const QM
ComboBoxDelegate::ComboBoxDelegate(QAbstractItemModel *model, QObject* parent): QStyledItemDelegate(parent), model(model)
{
+ connect(this, SIGNAL(closeEditor(QWidget*,QAbstractItemDelegate::EndEditHint)),
+ this, SLOT(revertModelData(QWidget*, QAbstractItemDelegate::EndEditHint)));
}
void ComboBoxDelegate::setEditorData(QWidget* editor, const QModelIndex& index) const
@@ -173,8 +175,6 @@ void TankInfoDelegate::setModelData(QWidget* editor, QAbstractItemModel* model,
TankInfoDelegate::TankInfoDelegate(QObject* parent): ComboBoxDelegate(TankInfoModel::instance(), parent)
{
- connect(this, SIGNAL(closeEditor(QWidget*,QAbstractItemDelegate::EndEditHint)),
- this, SLOT(revertModelData(QWidget*, QAbstractItemDelegate::EndEditHint)));
}
void TankInfoDelegate::revertModelData(QWidget* widget, QAbstractItemDelegate::EndEditHint hint)
@@ -200,6 +200,20 @@ QWidget* TankInfoDelegate::createEditor(QWidget* parent, const QStyleOptionViewI
return delegate;
}
+struct RevertWeigthData {
+ QString type;
+ int weigth;
+} currWeigth;
+
+void WSInfoDelegate::revertModelData(QWidget* widget, QAbstractItemDelegate::EndEditHint hint)
+{
+ if (hint == QAbstractItemDelegate::NoHint || hint == QAbstractItemDelegate::RevertModelCache){
+ WeightModel *mymodel = qobject_cast<WeightModel *>(currCombo.model);
+ mymodel->setData(IDX(WeightModel::TYPE), currWeigth.type, Qt::EditRole);
+ mymodel->passInData(IDX(WeightModel::WEIGHT), currWeigth.weigth);
+ }
+}
+
void WSInfoDelegate::setModelData(QWidget* editor, QAbstractItemModel* model, const QModelIndex& thisindex) const
{
WeightModel *mymodel = qobject_cast<WeightModel *>(currCombo.model);
@@ -232,5 +246,11 @@ WSInfoDelegate::WSInfoDelegate(QObject* parent): ComboBoxDelegate(WSInfoModel::i
QWidget* WSInfoDelegate::createEditor(QWidget* parent, const QStyleOptionViewItem& option, const QModelIndex& index) const
{
- return ComboBoxDelegate::createEditor(parent, option, index);
+ /* First, call the combobox-create editor, it will setup our globals. */
+ QWidget *editor = ComboBoxDelegate::createEditor(parent, option, index);
+ WeightModel *mymodel = qobject_cast<WeightModel *>(currCombo.model);
+ weightsystem_t *ws = mymodel->weightSystemAt(index);
+ currWeigth.type = ws->description;
+ currWeigth.weigth = ws->weight.grams;
+ return editor;
}
diff --git a/qt-ui/modeldelegates.h b/qt-ui/modeldelegates.h
index 4ddf53df3..9603d5dce 100644
--- a/qt-ui/modeldelegates.h
+++ b/qt-ui/modeldelegates.h
@@ -24,6 +24,7 @@ public:
virtual bool eventFilter(QObject* object, QEvent* event);
public slots:
void testActivation(const QString& s);
+ virtual void revertModelData(QWidget* widget, QAbstractItemDelegate::EndEditHint hint) = 0;
protected:
QAbstractItemModel *model;
};
@@ -44,6 +45,8 @@ public:
explicit WSInfoDelegate(QObject* parent = 0);
virtual void setModelData(QWidget* editor, QAbstractItemModel* model, const QModelIndex& index) const;
virtual QWidget* createEditor(QWidget* parent, const QStyleOptionViewItem& option, const QModelIndex& index) const;
+public slots:
+ void revertModelData(QWidget* widget, QAbstractItemDelegate::EndEditHint hint);
};
#endif
diff --git a/qt-ui/models.cpp b/qt-ui/models.cpp
index fe15a98c3..347301424 100644
--- a/qt-ui/models.cpp
+++ b/qt-ui/models.cpp
@@ -348,6 +348,11 @@ WeightModel::WeightModel(QObject* parent): QAbstractTableModel(parent), current(
{
}
+weightsystem_t* WeightModel::weightSystemAt(const QModelIndex& index)
+{
+ return &current->weightsystem[index.row()];
+}
+
void WeightModel::remove(const QModelIndex& index)
{
if (index.column() != REMOVE) {
diff --git a/qt-ui/models.h b/qt-ui/models.h
index b7a72b1d2..e8a7daaf3 100644
--- a/qt-ui/models.h
+++ b/qt-ui/models.h
@@ -114,6 +114,8 @@ public:
void clear();
void update();
void setDive(struct dive *d);
+ weightsystem_t *weightSystemAt(const QModelIndex& index);
+
public slots:
void remove(const QModelIndex& index);