subsurface/desktop-widgets/tripselectiondialog.cpp
Berthold Stoeger eacad89531 core: turn trip-table into our own sorted_owning_table
Since the sorted_owning_table depends on the fact that
different elements never compare as equal, make the
comparison function safer in that respect. If all failes,
compare the pointers.

Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
2024-08-13 19:28:30 +02:00

48 lines
1.5 KiB
C++

// SPDX-License-Identifier: GPL-2.0
#include "tripselectiondialog.h"
#include "core/divelog.h"
#include "core/string-format.h"
#include "core/trip.h"
#include <QShortcut>
#include <QPushButton>
TripSelectionDialog::TripSelectionDialog(QWidget *parent) : QDialog(parent)
{
ui.setupUi(this);
connect(ui.trips, &QListWidget::itemSelectionChanged, this, &TripSelectionDialog::selectionChanged);
QShortcut *close = new QShortcut(QKeySequence(Qt::CTRL | Qt::Key_W), this);
connect(close, &QShortcut::activated, this, &QDialog::close);
QShortcut *quit = new QShortcut(QKeySequence(Qt::CTRL | Qt::Key_Q), this);
connect(quit, &QShortcut::activated, parent, &QWidget::close);
// We could use a model, but it seems barely worth the hassle.
QStringList list;
list.reserve(divelog.trips->size());
for (auto &trip: *divelog.trips)
list.push_back(formatTripTitleWithDives(*trip));
ui.trips->addItems(list);
}
void TripSelectionDialog::selectionChanged()
{
ui.buttonBox->button(QDialogButtonBox::Ok)->setEnabled(selectedTrip() != nullptr);
}
dive_trip *TripSelectionDialog::selectedTrip() const
{
// Accessing the selected index of a QListWidget is ridiculously cumbersome.
// Note that "currentItem" is a different beast.
QModelIndexList rows = ui.trips->selectionModel()->selectedRows();
if (rows.size() != 1)
return nullptr;
int idx = rows[0].row();
if (idx < 0 || static_cast<size_t>(idx) >= divelog.trips->size())
return nullptr;
return (*divelog.trips)[idx].get();
}
dive_trip *TripSelectionDialog::getTrip()
{
return exec() ? selectedTrip() : nullptr;
}