summaryrefslogtreecommitdiffstats
path: root/desktop-widgets/tab-widgets/TabDiveEquipment.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'desktop-widgets/tab-widgets/TabDiveEquipment.cpp')
-rw-r--r--desktop-widgets/tab-widgets/TabDiveEquipment.cpp70
1 files changed, 67 insertions, 3 deletions
diff --git a/desktop-widgets/tab-widgets/TabDiveEquipment.cpp b/desktop-widgets/tab-widgets/TabDiveEquipment.cpp
index 22bdd2ca6..db9754140 100644
--- a/desktop-widgets/tab-widgets/TabDiveEquipment.cpp
+++ b/desktop-widgets/tab-widgets/TabDiveEquipment.cpp
@@ -4,20 +4,23 @@
#include "desktop-widgets/mainwindow.h" // TODO: Only used temporarilly for edit mode changes
#include "desktop-widgets/simplewidgets.h" // For isGnome3Session()
#include "desktop-widgets/modeldelegates.h"
-
+#include "desktop-widgets/command.h"
#include "profile-widget/profilewidget2.h"
#include "qt-models/cylindermodel.h"
#include "qt-models/weightmodel.h"
-#include "core/divelist.h"
#include "core/subsurface-string.h"
+#include "core/divelist.h"
#include <QSettings>
+#include <QCompleter>
+
TabDiveEquipment::TabDiveEquipment(QWidget *parent) : TabBase(parent),
cylindersModel(new CylindersModel(this)),
weightModel(new WeightModel(this))
{
+ QCompleter *suitCompleter;
ui.setupUi(this);
// This makes sure we only delete the models
@@ -29,6 +32,7 @@ TabDiveEquipment::TabDiveEquipment(QWidget *parent) : TabBase(parent),
ui.cylinders->setModel(cylindersModel);
ui.weights->setModel(weightModel);
+ connect(&diveListNotifier, &DiveListNotifier::divesChanged, this, &TabDiveEquipment::divesChanged);
connect(ui.cylinders->view(), &QTableView::clicked, this, &TabDiveEquipment::editCylinderWidget);
connect(ui.weights->view(), &QTableView::clicked, this, &TabDiveEquipment::editWeightWidget);
@@ -53,6 +57,17 @@ TabDiveEquipment::TabDiveEquipment(QWidget *parent) : TabBase(parent),
ui.weights->setBtnToolTip(tr("Add weight system"));
connect(ui.weights, &TableView::addButtonClicked, this, &TabDiveEquipment::addWeight_clicked);
+ QAction *action = new QAction(tr("OK"), this);
+ connect(action, &QAction::triggered, this, &TabDiveEquipment::closeWarning);
+ ui.multiDiveWarningMessage->addAction(action);
+
+ action = new QAction(tr("Undo"), this);
+ connect(action, &QAction::triggered, Command::undoAction(this), &QAction::trigger);
+ connect(action, &QAction::triggered, this, &TabDiveEquipment::closeWarning);
+ ui.multiDiveWarningMessage->addAction(action);
+
+ ui.multiDiveWarningMessage->hide();
+
QSettings s;
s.beginGroup("cylinders_dialog");
for (int i = 0; i < CylindersModel::COLUMNS; i++) {
@@ -67,9 +82,11 @@ TabDiveEquipment::TabDiveEquipment(QWidget *parent) : TabBase(parent),
ui.cylinders->view()->setColumnHidden(i, checked);
ui.cylinders->view()->horizontalHeader()->addAction(action);
}
-
ui.cylinders->view()->horizontalHeader()->setContextMenuPolicy(Qt::ActionsContextMenu);
ui.weights->view()->horizontalHeader()->setContextMenuPolicy(Qt::ActionsContextMenu);
+ suitCompleter = new QCompleter(&suitModel, ui.suit);
+ suitCompleter->setCaseSensitivity(Qt::CaseInsensitive);
+ ui.suit->setCompleter(suitCompleter);
}
TabDiveEquipment::~TabDiveEquipment()
@@ -83,6 +100,23 @@ TabDiveEquipment::~TabDiveEquipment()
}
}
+// This function gets called if a field gets updated by an undo command.
+// Refresh the corresponding UI field.
+void TabDiveEquipment::divesChanged(const QVector<dive *> &dives, DiveField field)
+{
+ // If the current dive is not in list of changed dives, do nothing
+ if (!current_dive || !dives.contains(current_dive))
+ return;
+
+ switch(field) {
+ case DiveField::SUIT:
+ ui.suit->setText(QString(current_dive->suit));
+ break;
+ default:
+ break;
+ }
+}
+
void TabDiveEquipment::toggleTriggeredColumn()
{
QAction *action = qobject_cast<QAction *>(sender());
@@ -101,18 +135,24 @@ void TabDiveEquipment::updateData()
{
cylindersModel->updateDive();
weightModel->updateDive();
+ suitModel.updateModel();
ui.cylinders->view()->hideColumn(CylindersModel::DEPTH);
if (get_dive_dc(&displayed_dive, dc_number)->divemode == CCR)
ui.cylinders->view()->showColumn(CylindersModel::USE);
else
ui.cylinders->view()->hideColumn(CylindersModel::USE);
+ if (current_dive && current_dive->suit)
+ ui.suit->setText(QString(current_dive->suit));
+ else
+ ui.suit->clear();
}
void TabDiveEquipment::clear()
{
cylindersModel->clear();
weightModel->clear();
+ ui.suit->clear();
}
void TabDiveEquipment::addCylinder_clicked()
@@ -256,3 +296,27 @@ void TabDiveEquipment::rejectChanges()
cylindersModel->updateDive();
weightModel->updateDive();
}
+
+void TabDiveEquipment::divesEdited(int i)
+{
+ // No warning if only one dive was edited
+ if (i <= 1)
+ return;
+ ui.multiDiveWarningMessage->setCloseButtonVisible(false);
+ ui.multiDiveWarningMessage->setText(tr("Warning: edited %1 dives").arg(i));
+ ui.multiDiveWarningMessage->show();
+}
+
+void TabDiveEquipment::on_suit_editingFinished()
+{
+ if (!current_dive)
+ return;
+ divesEdited(Command::editSuit(ui.suit->text(), false));
+}
+
+void TabDiveEquipment::closeWarning()
+{
+ ui.multiDiveWarningMessage->hide();
+}
+
+