summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--desktop-widgets/tab-widgets/TabDiveEquipment.cpp70
-rw-r--r--desktop-widgets/tab-widgets/TabDiveEquipment.h10
-rw-r--r--desktop-widgets/tab-widgets/TabDiveEquipment.ui15
-rw-r--r--desktop-widgets/tab-widgets/maintab.cpp22
-rw-r--r--desktop-widgets/tab-widgets/maintab.h2
-rw-r--r--desktop-widgets/tab-widgets/maintab.ui28
6 files changed, 102 insertions, 45 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();
+}
+
+
diff --git a/desktop-widgets/tab-widgets/TabDiveEquipment.h b/desktop-widgets/tab-widgets/TabDiveEquipment.h
index 44c67cb27..1edc20cef 100644
--- a/desktop-widgets/tab-widgets/TabDiveEquipment.h
+++ b/desktop-widgets/tab-widgets/TabDiveEquipment.h
@@ -4,6 +4,8 @@
#include "TabBase.h"
#include "ui_TabDiveEquipment.h"
+#include "qt-models/completionmodels.h"
+#include "desktop-widgets/divelistview.h"
namespace Ui {
class TabDiveEquipment;
@@ -21,15 +23,21 @@ public:
void clear() override;
void acceptChanges();
void rejectChanges();
+ void divesEdited(int i);
+ void closeWarning();
+
private slots:
+ void divesChanged(const QVector<dive *> &dives, DiveField field);
void addCylinder_clicked();
void addWeight_clicked();
void toggleTriggeredColumn();
void editCylinderWidget(const QModelIndex &index);
void editWeightWidget(const QModelIndex &index);
+ void on_suit_editingFinished();
+
private:
Ui::TabDiveEquipment ui;
-
+ SuitCompletionModel suitModel;
CylindersModel *cylindersModel;
WeightModel *weightModel;
};
diff --git a/desktop-widgets/tab-widgets/TabDiveEquipment.ui b/desktop-widgets/tab-widgets/TabDiveEquipment.ui
index 08dd32698..d81df5914 100644
--- a/desktop-widgets/tab-widgets/TabDiveEquipment.ui
+++ b/desktop-widgets/tab-widgets/TabDiveEquipment.ui
@@ -7,6 +7,9 @@
</attribute>
<layout class="QVBoxLayout" name="verticalLayout_10">
<item>
+ <widget class="KMessageWidget" name="multiDiveWarningMessage"/>
+ </item>
+ <item>
<widget class="QScrollArea" name="scrollArea">
<property name="frameShape">
<enum>QFrame::NoFrame</enum>
@@ -61,11 +64,21 @@
<number>0</number>
</property>
<item>
- <widget class="QSplitter" name="splitter">
+ <widget class="QSplitter" name="splitter">
<property name="orientation">
<enum>Qt::Vertical</enum>
</property>
<widget class="TableView" name="cylinders" native="true"/>
+ <widget class="QLabel" name="suitText">
+ <property name="text">
+ <string>Suit</string>
+ </property>
+ </widget>
+ <widget class="QLineEdit" name="suit">
+ <property name="readOnly">
+ <bool>false</bool>
+ </property>
+ </widget>
<widget class="TableView" name="weights" native="true"/>
</widget>
</item>
diff --git a/desktop-widgets/tab-widgets/maintab.cpp b/desktop-widgets/tab-widgets/maintab.cpp
index 5d06bca4b..a13dd34bf 100644
--- a/desktop-widgets/tab-widgets/maintab.cpp
+++ b/desktop-widgets/tab-widgets/maintab.cpp
@@ -44,7 +44,6 @@
struct Completers {
QCompleter *divemaster;
QCompleter *buddy;
- QCompleter *suit;
QCompleter *tags;
};
@@ -126,15 +125,12 @@ MainTab::MainTab(QWidget *parent) : QTabWidget(parent),
Completers completers;
completers.buddy = new QCompleter(&buddyModel, ui.buddy);
completers.divemaster = new QCompleter(&diveMasterModel, ui.divemaster);
- completers.suit = new QCompleter(&suitModel, ui.suit);
completers.tags = new QCompleter(&tagModel, ui.tagWidget);
completers.buddy->setCaseSensitivity(Qt::CaseInsensitive);
completers.divemaster->setCaseSensitivity(Qt::CaseInsensitive);
- completers.suit->setCaseSensitivity(Qt::CaseInsensitive);
completers.tags->setCaseSensitivity(Qt::CaseInsensitive);
ui.buddy->setCompleter(completers.buddy);
ui.divemaster->setCompleter(completers.divemaster);
- ui.suit->setCompleter(completers.suit);
ui.tagWidget->setCompleter(completers.tags);
ui.diveNotesMessage->hide();
ui.multiDiveWarningMessage->hide();
@@ -308,9 +304,6 @@ void MainTab::divesChanged(const QVector<dive *> &dives, DiveField field)
case DiveField::VISIBILITY:
ui.visibility->setCurrentStars(current_dive->visibility);
break;
- case DiveField::SUIT:
- ui.suit->setText(QString(current_dive->suit));
- break;
case DiveField::NOTES:
updateNotes(current_dive);
break;
@@ -474,8 +467,6 @@ void MainTab::updateDiveInfo()
ui.DivemasterLabel->setVisible(false);
ui.buddy->setVisible(false);
ui.BuddyLabel->setVisible(false);
- ui.suit->setVisible(false);
- ui.SuitLabel->setVisible(false);
ui.rating->setVisible(false);
ui.RatingLabel->setVisible(false);
ui.visibility->setVisible(false);
@@ -530,8 +521,6 @@ void MainTab::updateDiveInfo()
ui.editDiveSiteButton->show();
ui.divemaster->setVisible(true);
ui.buddy->setVisible(true);
- ui.suit->setVisible(true);
- ui.SuitLabel->setVisible(true);
ui.rating->setVisible(true);
ui.RatingLabel->setVisible(true);
ui.visibility->setVisible(true);
@@ -566,7 +555,6 @@ void MainTab::updateDiveInfo()
updateMode(current_dive);
updateDiveSite(current_dive);
updateDateTime(current_dive);
- ui.suit->setText(current_dive->suit);
ui.divemaster->setText(current_dive->divemaster);
ui.buddy->setText(current_dive->buddy);
ui.airtemp->setText(get_temperature_string(current_dive->airtemp, true));
@@ -589,7 +577,6 @@ void MainTab::updateDiveInfo()
ui.rating->setCurrentStars(0);
ui.visibility->setCurrentStars(0);
ui.location->clear();
- ui.suit->clear();
ui.divemaster->clear();
ui.buddy->clear();
ui.airtemp->clear();
@@ -612,7 +599,6 @@ void MainTab::updateDiveInfo()
void MainTab::reload()
{
- suitModel.updateModel();
buddyModel.updateModel();
diveMasterModel.updateModel();
tagModel.updateModel();
@@ -889,14 +875,6 @@ void MainTab::on_diveTripLocation_editingFinished()
Command::editTripLocation(currentTrip, ui.diveTripLocation->text());
}
-void MainTab::on_suit_editingFinished()
-{
- if (editMode == IGNORE || !current_dive)
- return;
-
- divesEdited(Command::editSuit(ui.suit->text(), false));
-}
-
void MainTab::on_notes_editingFinished()
{
if (!currentTrip && !current_dive)
diff --git a/desktop-widgets/tab-widgets/maintab.h b/desktop-widgets/tab-widgets/maintab.h
index 2d620eff1..a60ac5613 100644
--- a/desktop-widgets/tab-widgets/maintab.h
+++ b/desktop-widgets/tab-widgets/maintab.h
@@ -61,7 +61,6 @@ slots:
void on_locationPopupButton_clicked();
void on_divemaster_editingFinished();
void on_buddy_editingFinished();
- void on_suit_editingFinished();
void on_diveTripLocation_editingFinished();
void on_notes_editingFinished();
void on_airtemp_editingFinished();
@@ -86,7 +85,6 @@ private:
EditMode editMode;
BuddyCompletionModel buddyModel;
DiveMasterCompletionModel diveMasterModel;
- SuitCompletionModel suitModel;
TagCompletionModel tagModel;
bool modified;
bool lastSelectedDive;
diff --git a/desktop-widgets/tab-widgets/maintab.ui b/desktop-widgets/tab-widgets/maintab.ui
index 30bfaa413..606f1dd54 100644
--- a/desktop-widgets/tab-widgets/maintab.ui
+++ b/desktop-widgets/tab-widgets/maintab.ui
@@ -337,13 +337,6 @@
</property>
</widget>
</item>
- <item row="0" column="2">
- <widget class="QLabel" name="SuitLabel">
- <property name="text">
- <string>Suit</string>
- </property>
- </widget>
- </item>
<item row="1" column="0" alignment="Qt::AlignVCenter">
<widget class="StarWidget" name="rating" native="true">
<property name="sizePolicy">
@@ -371,17 +364,20 @@
</widget>
</item>
<item row="1" column="2">
- <widget class="QLineEdit" name="suit">
- <property name="sizePolicy">
- <sizepolicy hsizetype="Expanding" vsizetype="Fixed">
- <horstretch>0</horstretch>
- <verstretch>0</verstretch>
- </sizepolicy>
+ <spacer>
+ <property name="orientation">
+ <enum>Qt::Horizontal</enum>
</property>
- <property name="readOnly">
- <bool>false</bool>
+ <property name="sizeType">
+ <enum>QSizePolicy::Expanding</enum>
</property>
- </widget>
+ <property name="sizeHint" stdset="0">
+ <size>
+ <width>20</width>
+ <height>20</height>
+ </size>
+ </property>
+ </spacer>
</item>
</layout>
</item>