mirror of
https://github.com/subsurface/subsurface.git
synced 2024-12-01 06:30:26 +00:00
Mobile: pass section directly to tripTitle() and tripShortDate()
Instead of converting the section-heading string to a trip-pointer in QML and pass that to the tripTitle() and tripShortDate() functions, pass the string and convert in C++ code. Hopefully, this makes the code more robust. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
This commit is contained in:
parent
ce751bd696
commit
9322c54b6a
3 changed files with 12 additions and 15 deletions
|
@ -353,8 +353,7 @@ Kirigami.ScrollablePage {
|
|||
}
|
||||
Controls.Label {
|
||||
text: {
|
||||
var trip = diveListView.model.tripIdToObject(section);
|
||||
diveListView.model.tripShortDate(trip);
|
||||
diveListView.model.tripShortDate(section)
|
||||
}
|
||||
color: subsurfaceTheme.primaryTextColor
|
||||
font.pointSize: subsurfaceTheme.smallPointSize
|
||||
|
@ -379,8 +378,7 @@ Kirigami.ScrollablePage {
|
|||
Controls.Label {
|
||||
id: sectionText
|
||||
text: {
|
||||
var trip = diveListView.model.tripIdToObject(section);
|
||||
diveListView.model.tripTitle(trip);
|
||||
diveListView.model.tripTitle(section)
|
||||
}
|
||||
wrapMode: Text.WrapAtWordBoundaryOrAnywhere
|
||||
visible: text !== ""
|
||||
|
|
|
@ -79,26 +79,26 @@ void DiveListSortModel::reload()
|
|||
// In QtQuick ListView, section headings can only be strings. To identify dives
|
||||
// that belong to the same trip, a string containing the trip-id is passed in.
|
||||
// To format the trip heading, the string is then converted back with this function.
|
||||
QVariant DiveListSortModel::tripIdToObject(const QString &s)
|
||||
static dive_trip *tripIdToObject(const QString &s)
|
||||
{
|
||||
if (s.isEmpty())
|
||||
return QVariant();
|
||||
return nullptr;
|
||||
int id = s.toInt();
|
||||
dive_trip **trip = std::find_if(&trip_table.trips[0], &trip_table.trips[trip_table.nr],
|
||||
[id] (const dive_trip *t) { return t->id == id; });
|
||||
if (trip == &trip_table.trips[trip_table.nr]) {
|
||||
fprintf(stderr, "Warning: unknown trip id passed through QML: %d\n", id);
|
||||
return QVariant();
|
||||
return nullptr;
|
||||
}
|
||||
return QVariant::fromValue(*trip);
|
||||
return *trip;
|
||||
}
|
||||
|
||||
// the trip title is designed to be location (# dives)
|
||||
// or, if there is no location name date range (# dives)
|
||||
// where the date range is given as "month year" or "month-month year" or "month year - month year"
|
||||
QString DiveListSortModel::tripTitle(const QVariant &tripIn)
|
||||
QString DiveListSortModel::tripTitle(const QString §ion)
|
||||
{
|
||||
dive_trip *dt = tripIn.value<dive_trip *>();
|
||||
const dive_trip *dt = tripIdToObject(section);
|
||||
if (!dt)
|
||||
return QString();
|
||||
QString numDives = tr("(%n dive(s))", "", dt->dives.nr);
|
||||
|
@ -124,9 +124,9 @@ QString DiveListSortModel::tripTitle(const QVariant &tripIn)
|
|||
return QStringLiteral("%1 %2%3").arg(title, numDives, shownDives);
|
||||
}
|
||||
|
||||
QString DiveListSortModel::tripShortDate(const QVariant &tripIn)
|
||||
QString DiveListSortModel::tripShortDate(const QString §ion)
|
||||
{
|
||||
dive_trip *dt = tripIn.value<dive_trip *>();
|
||||
const dive_trip *dt = tripIdToObject(section);
|
||||
if (!dt)
|
||||
return QString();
|
||||
QDateTime firstTime = QDateTime::fromMSecsSinceEpoch(1000*trip_date(dt), Qt::UTC);
|
||||
|
|
|
@ -14,9 +14,8 @@ public:
|
|||
DiveListSortModel(QObject *parent = 0);
|
||||
void setSourceModel(QAbstractItemModel *sourceModel);
|
||||
Q_INVOKABLE void reload();
|
||||
Q_INVOKABLE QVariant tripIdToObject(const QString &s);
|
||||
Q_INVOKABLE QString tripTitle(const QVariant &trip);
|
||||
Q_INVOKABLE QString tripShortDate(const QVariant &trip);
|
||||
Q_INVOKABLE QString tripTitle(const QString &trip);
|
||||
Q_INVOKABLE QString tripShortDate(const QString &trip);
|
||||
public slots:
|
||||
int getIdxForId(int id);
|
||||
void setFilter(QString f);
|
||||
|
|
Loading…
Reference in a new issue