2017-04-27 20:26:05 +02:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
2013-04-13 20:44:02 -07:00
|
|
|
/*
|
|
|
|
* maintab.cpp
|
|
|
|
*
|
2022-03-05 17:25:49 +01:00
|
|
|
* "notebook" area of the main window of Subsurface
|
2013-04-13 20:44:02 -07:00
|
|
|
*
|
|
|
|
*/
|
2022-03-05 17:25:49 +01:00
|
|
|
#include "maintab.h"
|
2015-06-01 16:58:23 -03:00
|
|
|
|
2019-04-13 17:43:45 +02:00
|
|
|
#include "TabDiveEquipment.h"
|
2017-04-04 19:21:30 +02:00
|
|
|
#include "TabDiveExtraInfo.h"
|
|
|
|
#include "TabDiveInformation.h"
|
2022-03-05 17:25:49 +01:00
|
|
|
#include "TabDiveNotes.h"
|
2017-04-04 19:21:30 +02:00
|
|
|
#include "TabDivePhotos.h"
|
|
|
|
#include "TabDiveStatistics.h"
|
|
|
|
|
2022-03-05 17:25:49 +01:00
|
|
|
#include "core/selection.h"
|
|
|
|
#include "qt-models/diveplannermodel.h"
|
2013-04-07 15:20:43 -07:00
|
|
|
|
2022-03-05 17:25:49 +01:00
|
|
|
#include <QShortcut>
|
2019-04-13 18:14:50 +02:00
|
|
|
|
2020-11-04 13:09:44 -08:00
|
|
|
static bool paletteIsDark(const QPalette &p)
|
|
|
|
{
|
|
|
|
// we consider a palette dark if the text color is lighter than the windows background
|
|
|
|
return p.window().color().valueF() < p.windowText().color().valueF();
|
|
|
|
}
|
|
|
|
|
2013-04-07 15:20:43 -07:00
|
|
|
MainTab::MainTab(QWidget *parent) : QTabWidget(parent),
|
2022-09-17 16:21:17 +02:00
|
|
|
currentDive(nullptr),
|
2018-03-15 22:41:59 +01:00
|
|
|
lastSelectedDive(true),
|
2017-11-30 20:33:43 +01:00
|
|
|
lastTabSelectedDive(0),
|
2022-03-05 17:25:49 +01:00
|
|
|
lastTabSelectedDiveTrip(0)
|
2013-04-07 15:20:43 -07:00
|
|
|
{
|
2022-03-05 17:25:49 +01:00
|
|
|
extraWidgets << new TabDiveNotes(this);
|
2022-03-12 15:15:05 +01:00
|
|
|
addTab(extraWidgets.last(), tr("Notes"));
|
2020-04-13 19:26:29 +02:00
|
|
|
extraWidgets << new TabDiveEquipment(this);
|
2022-03-12 15:15:05 +01:00
|
|
|
addTab(extraWidgets.last(), tr("Equipment"));
|
2020-04-13 19:26:29 +02:00
|
|
|
extraWidgets << new TabDiveInformation(this);
|
2022-03-12 15:15:05 +01:00
|
|
|
addTab(extraWidgets.last(), tr("Information"));
|
2020-04-13 19:26:29 +02:00
|
|
|
extraWidgets << new TabDiveStatistics(this);
|
2022-03-12 15:15:05 +01:00
|
|
|
addTab(extraWidgets.last(), tr("Summary"));
|
2020-04-13 19:26:29 +02:00
|
|
|
extraWidgets << new TabDivePhotos(this);
|
2022-03-12 15:15:05 +01:00
|
|
|
addTab(extraWidgets.last(), tr("Media"));
|
2020-04-13 19:26:29 +02:00
|
|
|
extraWidgets << new TabDiveExtraInfo(this);
|
2022-03-12 15:15:05 +01:00
|
|
|
addTab(extraWidgets.last(), tr("Extra Info"));
|
2017-04-04 19:21:30 +02:00
|
|
|
|
2020-11-04 13:09:44 -08:00
|
|
|
// make sure we know if this is a light or dark mode
|
|
|
|
isDark = paletteIsDark(palette());
|
|
|
|
|
2020-11-02 12:36:29 -08:00
|
|
|
// call colorsChanged() for the initial setup now that the extraWidgets are loaded
|
|
|
|
colorsChanged();
|
|
|
|
|
2022-09-04 11:04:01 +02:00
|
|
|
connect(&diveListNotifier, &DiveListNotifier::settingsChanged, this, &MainTab::settingsChanged);
|
2019-02-24 21:22:33 +01:00
|
|
|
|
2014-06-03 15:29:28 -07:00
|
|
|
QShortcut *closeKey = new QShortcut(QKeySequence(Qt::Key_Escape), this);
|
2022-02-19 12:53:52 +01:00
|
|
|
connect(closeKey, &QShortcut::activated, this, &MainTab::escDetected);
|
2014-06-03 15:29:28 -07:00
|
|
|
|
2013-09-26 17:02:27 -03:00
|
|
|
if (qApp->style()->objectName() == "oxygen")
|
2013-09-26 16:51:11 -03:00
|
|
|
setDocumentMode(true);
|
2013-09-26 17:02:27 -03:00
|
|
|
else
|
|
|
|
setDocumentMode(false);
|
|
|
|
|
2014-12-23 10:16:11 -08:00
|
|
|
// QLineEdit and QLabels should have minimal margin on the left and right but not waste vertical space
|
2015-01-02 12:42:02 -08:00
|
|
|
QMargins margins(3, 2, 1, 0);
|
2022-03-05 17:25:49 +01:00
|
|
|
for (QLabel *label: findChildren<QLabel *>())
|
2014-12-23 10:16:11 -08:00
|
|
|
label->setContentsMargins(margins);
|
2019-02-24 21:22:33 +01:00
|
|
|
}
|
|
|
|
|
2014-05-16 15:12:46 +09:00
|
|
|
void MainTab::nextInputField(QKeyEvent *event)
|
|
|
|
{
|
|
|
|
keyPressEvent(event);
|
|
|
|
}
|
|
|
|
|
2022-09-04 11:04:01 +02:00
|
|
|
void MainTab::settingsChanged()
|
|
|
|
{
|
|
|
|
// TODO: remember these
|
2022-09-17 16:21:17 +02:00
|
|
|
updateDiveInfo(getDiveSelection(), currentDive, currentDC);
|
2022-09-04 11:04:01 +02:00
|
|
|
}
|
|
|
|
|
2022-09-17 16:21:17 +02:00
|
|
|
void MainTab::updateDiveInfo(const std::vector<dive *> &selection, dive *currentDiveIn, int currentDCIn)
|
2013-05-06 13:23:14 -03:00
|
|
|
{
|
2022-09-17 16:21:17 +02:00
|
|
|
// Remember current dive and divecomputer. This is needed to refresh the
|
|
|
|
// display, for example when the settings change.
|
|
|
|
currentDive = currentDiveIn;
|
|
|
|
currentDC = currentDCIn;
|
|
|
|
|
2022-02-19 12:53:52 +01:00
|
|
|
// don't execute this while planning a dive
|
|
|
|
if (DivePlannerPointsModel::instance()->isPlanner())
|
2013-11-12 16:33:27 +09:00
|
|
|
return;
|
2019-04-12 20:33:43 +02:00
|
|
|
|
2022-09-18 13:49:29 +02:00
|
|
|
// If there is no current dive, disable all widgets.
|
2019-04-12 20:33:43 +02:00
|
|
|
bool enabled = current_dive != nullptr;
|
2022-09-18 13:49:29 +02:00
|
|
|
for (TabBase *widget: extraWidgets)
|
|
|
|
widget->setEnabled(enabled);
|
2019-04-12 20:33:43 +02:00
|
|
|
|
2022-09-04 11:04:01 +02:00
|
|
|
if (currentDive) {
|
2020-04-13 19:01:36 +02:00
|
|
|
for (TabBase *widget: extraWidgets)
|
2022-09-04 11:04:01 +02:00
|
|
|
widget->updateData(selection, currentDive, currentDC);
|
2022-03-05 17:25:49 +01:00
|
|
|
if (single_selected_trip()) {
|
2019-05-04 14:23:46 +02:00
|
|
|
// Remember the tab selected for last dive but only if we're not on the dive site tab
|
2022-09-18 13:49:29 +02:00
|
|
|
if (lastSelectedDive)
|
2022-03-12 15:15:05 +01:00
|
|
|
lastTabSelectedDive = currentIndex();
|
|
|
|
setTabText(0, tr("Trip notes"));
|
2019-05-04 14:23:46 +02:00
|
|
|
// Recover the tab selected for last dive trip but only if we're not on the dive site tab
|
2022-09-18 13:49:29 +02:00
|
|
|
if (lastSelectedDive)
|
2022-03-12 15:15:05 +01:00
|
|
|
setCurrentIndex(lastTabSelectedDiveTrip);
|
2017-11-30 20:33:43 +01:00
|
|
|
lastSelectedDive = false;
|
2013-06-14 09:17:46 -07:00
|
|
|
} else {
|
2019-05-04 14:23:46 +02:00
|
|
|
// Remember the tab selected for last dive trip but only if we're not on the dive site tab
|
2022-09-18 13:49:29 +02:00
|
|
|
if (!lastSelectedDive)
|
2022-03-12 15:15:05 +01:00
|
|
|
lastTabSelectedDiveTrip = currentIndex();
|
|
|
|
setTabText(0, tr("Notes"));
|
2019-05-04 14:23:46 +02:00
|
|
|
// Recover the tab selected for last dive but only if we're not on the dive site tab
|
2022-09-18 13:49:29 +02:00
|
|
|
if (!lastSelectedDive)
|
2022-03-12 15:15:05 +01:00
|
|
|
setCurrentIndex(lastTabSelectedDive);
|
2017-11-30 20:33:43 +01:00
|
|
|
lastSelectedDive = true;
|
2013-06-14 09:17:46 -07:00
|
|
|
}
|
2013-05-08 12:08:00 -07:00
|
|
|
} else {
|
2017-04-04 19:21:30 +02:00
|
|
|
clearTabs();
|
2013-05-08 12:08:00 -07:00
|
|
|
}
|
2013-05-18 20:42:59 -03:00
|
|
|
}
|
2013-05-20 06:25:16 -07:00
|
|
|
|
2019-04-01 21:07:51 +02:00
|
|
|
// Remove focus from any active field to update the corresponding value in the dive.
|
|
|
|
// Do this by setting the focus to ourself
|
|
|
|
void MainTab::stealFocus()
|
|
|
|
{
|
|
|
|
setFocus();
|
|
|
|
}
|
|
|
|
|
2014-06-03 15:29:28 -07:00
|
|
|
void MainTab::escDetected()
|
|
|
|
{
|
2022-02-19 12:53:52 +01:00
|
|
|
stealFocus();
|
2014-06-03 15:29:28 -07:00
|
|
|
}
|
2014-06-27 16:17:33 +04:00
|
|
|
|
2019-02-23 18:31:02 +01:00
|
|
|
void MainTab::clearTabs()
|
|
|
|
{
|
|
|
|
for (auto widget: extraWidgets)
|
2017-04-04 19:21:30 +02:00
|
|
|
widget->clear();
|
2015-10-20 22:36:59 +02:00
|
|
|
}
|
2020-11-02 12:10:33 -08:00
|
|
|
|
2020-11-04 13:09:44 -08:00
|
|
|
void MainTab::changeEvent(QEvent *ev)
|
|
|
|
{
|
|
|
|
if (ev->type() == QEvent::PaletteChange) {
|
|
|
|
// check if this is a light or dark mode
|
|
|
|
bool dark = paletteIsDark(palette());
|
|
|
|
if (dark != isDark) {
|
|
|
|
// things have changed, so setup the colors correctly
|
|
|
|
isDark = dark;
|
|
|
|
colorsChanged();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
QTabWidget::changeEvent(ev);
|
|
|
|
}
|
|
|
|
|
2020-11-02 12:36:29 -08:00
|
|
|
// setup the colors of 'header' elements in the tab widget
|
2020-11-02 12:10:33 -08:00
|
|
|
void MainTab::colorsChanged()
|
|
|
|
{
|
2020-11-04 13:09:44 -08:00
|
|
|
QString colorText = isDark ? QStringLiteral("lightblue") : QStringLiteral("mediumblue");
|
2020-11-02 12:36:29 -08:00
|
|
|
QString lastpart = colorText + " ;}";
|
|
|
|
|
|
|
|
// only set the color if the widget is enabled
|
|
|
|
QString CSSLabelcolor = "QLabel:enabled { color: " + lastpart;
|
|
|
|
QString CSSTitlecolor = "QGroupBox::title:enabled { color: " + lastpart ;
|
|
|
|
|
|
|
|
// apply to all the group boxes
|
|
|
|
QList<QGroupBox *>groupBoxes = this->findChildren<QGroupBox *>();
|
|
|
|
for (QGroupBox *gb: groupBoxes)
|
|
|
|
gb->setStyleSheet(QString(CSSTitlecolor));
|
|
|
|
|
|
|
|
// apply to all labels that are marked as headers in the .ui file
|
|
|
|
QList<QLabel *>labels = this->findChildren<QLabel *>();
|
|
|
|
for (QLabel *ql: labels) {
|
|
|
|
if (ql->property("isHeader").toBool())
|
|
|
|
ql->setStyleSheet(QString(CSSLabelcolor));
|
|
|
|
}
|
|
|
|
|
|
|
|
// finally call the individual updateUi() functions so they can overwrite these style sheets
|
2020-11-02 12:10:33 -08:00
|
|
|
for (TabBase *widget: extraWidgets)
|
2020-11-04 13:09:44 -08:00
|
|
|
widget->updateUi(colorText);
|
2020-11-02 12:10:33 -08:00
|
|
|
}
|
2022-09-17 16:21:17 +02:00
|
|
|
|
|
|
|
// Called when dives changed. Checks whether the currently displayed
|
|
|
|
// dive is affected by the change.
|
|
|
|
bool MainTab::includesCurrentDive(const QVector<dive *> &dives) const
|
|
|
|
{
|
|
|
|
return currentDive && dives.contains(currentDive);
|
|
|
|
}
|
|
|
|
|
|
|
|
divecomputer *MainTab::getCurrentDC() const
|
|
|
|
{
|
2024-06-30 20:38:12 +02:00
|
|
|
return currentDive ? currentDive->get_dc(currentDC) : nullptr;
|
2022-09-17 16:21:17 +02:00
|
|
|
}
|