// SPDX-License-Identifier: GPL-2.0 /* * maintab.cpp * * "notebook" area of the main window of Subsurface * */ #include "maintab.h" #include "TabDiveEquipment.h" #include "TabDiveExtraInfo.h" #include "TabDiveInformation.h" #include "TabDiveNotes.h" #include "TabDivePhotos.h" #include "TabDiveStatistics.h" #include "core/selection.h" #include "qt-models/diveplannermodel.h" #include 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(); } MainTab::MainTab(QWidget *parent) : QTabWidget(parent), currentDive(nullptr), lastSelectedDive(true), lastTabSelectedDive(0), lastTabSelectedDiveTrip(0) { extraWidgets << new TabDiveNotes(this); addTab(extraWidgets.last(), tr("Notes")); extraWidgets << new TabDiveEquipment(this); addTab(extraWidgets.last(), tr("Equipment")); extraWidgets << new TabDiveInformation(this); addTab(extraWidgets.last(), tr("Information")); extraWidgets << new TabDiveStatistics(this); addTab(extraWidgets.last(), tr("Summary")); extraWidgets << new TabDivePhotos(this); addTab(extraWidgets.last(), tr("Media")); extraWidgets << new TabDiveExtraInfo(this); addTab(extraWidgets.last(), tr("Extra Info")); // make sure we know if this is a light or dark mode isDark = paletteIsDark(palette()); // call colorsChanged() for the initial setup now that the extraWidgets are loaded colorsChanged(); connect(&diveListNotifier, &DiveListNotifier::settingsChanged, this, &MainTab::settingsChanged); QShortcut *closeKey = new QShortcut(QKeySequence(Qt::Key_Escape), this); connect(closeKey, &QShortcut::activated, this, &MainTab::escDetected); if (qApp->style()->objectName() == "oxygen") setDocumentMode(true); else setDocumentMode(false); // QLineEdit and QLabels should have minimal margin on the left and right but not waste vertical space QMargins margins(3, 2, 1, 0); for (QLabel *label: findChildren()) label->setContentsMargins(margins); } void MainTab::nextInputField(QKeyEvent *event) { keyPressEvent(event); } void MainTab::settingsChanged() { // TODO: remember these updateDiveInfo(getDiveSelection(), currentDive, currentDC); } void MainTab::updateDiveInfo(const std::vector &selection, dive *currentDiveIn, int currentDCIn) { // Remember current dive and divecomputer. This is needed to refresh the // display, for example when the settings change. currentDive = currentDiveIn; currentDC = currentDCIn; // don't execute this while planning a dive if (DivePlannerPointsModel::instance()->isPlanner()) return; // If there is no current dive, disable all widgets. bool enabled = current_dive != nullptr; for (TabBase *widget: extraWidgets) widget->setEnabled(enabled); if (currentDive) { for (TabBase *widget: extraWidgets) widget->updateData(selection, currentDive, currentDC); if (single_selected_trip()) { // Remember the tab selected for last dive but only if we're not on the dive site tab if (lastSelectedDive) lastTabSelectedDive = currentIndex(); setTabText(0, tr("Trip notes")); // Recover the tab selected for last dive trip but only if we're not on the dive site tab if (lastSelectedDive) setCurrentIndex(lastTabSelectedDiveTrip); lastSelectedDive = false; } else { // Remember the tab selected for last dive trip but only if we're not on the dive site tab if (!lastSelectedDive) lastTabSelectedDiveTrip = currentIndex(); setTabText(0, tr("Notes")); // Recover the tab selected for last dive but only if we're not on the dive site tab if (!lastSelectedDive) setCurrentIndex(lastTabSelectedDive); lastSelectedDive = true; } } else { clearTabs(); } } // 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(); } void MainTab::escDetected() { stealFocus(); } void MainTab::clearTabs() { for (auto widget: extraWidgets) widget->clear(); } 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); } // setup the colors of 'header' elements in the tab widget void MainTab::colorsChanged() { QString colorText = isDark ? QStringLiteral("lightblue") : QStringLiteral("mediumblue"); 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 QListgroupBoxes = this->findChildren(); for (QGroupBox *gb: groupBoxes) gb->setStyleSheet(QString(CSSTitlecolor)); // apply to all labels that are marked as headers in the .ui file QListlabels = this->findChildren(); 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 for (TabBase *widget: extraWidgets) widget->updateUi(colorText); } // Called when dives changed. Checks whether the currently displayed // dive is affected by the change. bool MainTab::includesCurrentDive(const QVector &dives) const { return currentDive && dives.contains(currentDive); } divecomputer *MainTab::getCurrentDC() const { return currentDive ? currentDive->get_dc(currentDC) : nullptr; }