/*
*openPilotLog - A FOSS Pilot Logbook Application
*Copyright (C) 2020-2021 Felix Turowsky
*
*This program is free software: you can redistribute it and/or modify
*it under the terms of the GNU General Public License as published by
*the Free Software Foundation, either version 3 of the License, or
*(at your option) any later version.
*
*This program is distributed in the hope that it will be useful,
*but WITHOUT ANY WARRANTY; without even the implied warranty of
*MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
*GNU General Public License for more details.
*
*You should have received a copy of the GNU General Public License
*along with this program. If not, see .
*/
#ifndef LOGBOOKWIDGET_H
#define LOGBOOKWIDGET_H
#include
#include
#include
#include
#include
#include
#include
#include "src/gui/widgets/settingswidget.h"
#include "src/classes/acompletiondata.h"
#include "src/opl.h"
namespace Ui {
class LogbookWidget;
}
/*!
* \brief The LogbookWidget displays data from the database in a QSqlTableView fed by a QSqlQuery Model
*
* \details The LogbookWidget is the primary display interface for flights logged in the database. It fetches and stores
* flight data from the database via a QSqlQueryModel and displays it in a QTableView. With the way the flight data is
* written in the database, it would not be human-readable, so some processing is done on the database side to present
* a nicely formatted, human-readable display. This is achieved by means of a [SQL View](https://sqlite.org/lang_createview.html).
*
* The user can select a view from a list of available views in the SettingsWidget.
*
*/
class LogbookWidget : public QWidget
{
Q_OBJECT
public:
explicit LogbookWidget(ACompletionData &completion_data, QWidget *parent = nullptr);
~LogbookWidget();
private slots:
void flightsTableView_selectionChanged();
void on_tableView_customContextMenuRequested(const QPoint &pos);
void on_actionDelete_Flight_triggered();
void on_tableView_doubleClicked();
void on_flightSearchLlineEdit_textChanged(const QString &arg1);
void on_flightSearchComboBox_currentIndexChanged(int);
void on_viewsComboBox_currentIndexChanged(int index);
void on_actionEdit_Flight_triggered();
void on_actionEdit_Sim_triggered();
public slots:
void refresh();
void onLogbookWidget_viewSelectionChanged(SettingsWidget::SettingSignal signal);
void repopulateModel();
private:
Ui::LogbookWidget *ui;
QTableView* view;
QSqlTableModel* displayModel;
QItemSelectionModel* selectionModel;
QMenu* menu;
QVector selectedEntries;
void setupModelAndView(int view_id);
void connectSignalsAndSlots();
ACompletionData completionData;
/*!
* \brief isFlight Determines whether an entry shown in a view is a Flight or a Simulator.
* \param model_row_id the row id in the QSqlTableModel used for displaying
* \details In the composite views (SQL UNION) with Simulators included, the row_id of the
* simulator entries is inverted to a negative value. A positive row id is thus a row id from
* the flights table, whereas a negative rowid is a row id from the simulators table.
*/
inline bool isFlight(int model_row_id) { return model_row_id > 0; }
protected:
/*!
* \brief Handles change events, like updating the UI to new localisation
*/
void changeEvent(QEvent* event) override;
};
#endif // LOGBOOKWIDGET_H