123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277 |
- #include <QToolBar>
- #include "mainwindow.h"
- #include "src/gui/widgets/airporttableeditwidget.h"
- #include "src/gui/widgets/logbooktableeditwidget.h"
- #include "src/gui/widgets/pilottableeditwidget.h"
- #include "src/gui/widgets/tailtableeditwidget.h"
- #include "ui_mainwindow.h"
- #include "src/database/database.h"
- #include "src/classes/style.h"
- #include "src/gui/dialogues/firstrundialog.h"
- #include "src/database/databasecache.h"
- #include "src/classes/settings.h"
- void MainWindow::doDebugStuff()
- {
- }
- MainWindow::MainWindow(QWidget *parent)
- : QMainWindow(parent)
- , ui(new Ui::MainWindow)
- {
- ui->setupUi(this);
- init();
- }
- MainWindow::~MainWindow()
- {
- delete ui;
- }
- void MainWindow::init()
- {
- connectDatabase();
- initialiseWidgets();
- setupToolbar();
- connectWidgets();
- setActionIcons(OPL::Style::getStyleType());
- ui->stackedWidget->setCurrentWidget(homeWidget);
- }
- void MainWindow::setupToolbar()
- {
-
- auto *toolBar = new QToolBar(this);
- toolBar->addAction(ui->actionHome);
- toolBar->addAction(ui->actionNewFlight);
- toolBar->addAction(ui->actionNewSim);
- toolBar->addAction(ui->actionLogbook);
- toolBar->addAction(ui->actionAircraft);
- toolBar->addAction(ui->actionPilots);
- toolBar->addAction(ui->actionAirports);
- toolBar->addAction(ui->actionSettings);
- toolBar->addAction(ui->actionQuit);
- toolBar->setSizePolicy(QSizePolicy::MinimumExpanding, QSizePolicy::Minimum);
- toolBar->setMovable(false);
- addToolBar(Qt::ToolBarArea::LeftToolBarArea, toolBar);
- }
- void MainWindow::initialiseWidgets()
- {
-
- homeWidget = new HomeWidget(this);
- ui->stackedWidget->addWidget(homeWidget);
- logbookWidget = new LogbookTableEditWidget(this);
- logbookWidget->init();
- ui->stackedWidget->addWidget(logbookWidget);
- tailsWidget = new TailTableEditWidget(this);
- tailsWidget->init();
- ui->stackedWidget->addWidget(tailsWidget);
- pilotsWidget = new PilotTableEditWidget(this);
- pilotsWidget->init();
- ui->stackedWidget->addWidget(pilotsWidget);
- airportWidget = new AirportTableEditWidget(this);
- airportWidget->init();
- ui->stackedWidget->addWidget(airportWidget);
- settingsWidget = new SettingsWidget(this);
- ui->stackedWidget->addWidget(settingsWidget);
- debugWidget = new DebugWidget(this);
- ui->stackedWidget->addWidget(debugWidget);
- }
- void MainWindow::connectDatabase()
- {
-
- if (OPL::Paths::databaseFileInfo().size() == 0)
- onDatabaseInvalid();
- if(!DB->connect()){
- WARN(tr("Error establishing database connection. The following error has ocurred:<br><br>%1")
- .arg(DB->lastError.text()));
- }
-
- DBCache->init();
- }
- void MainWindow::setActionIcons(OPL::Style::StyleType style)
- {
- switch (style){
- case OPL::Style::StyleType::Light:
- LOG << "Setting Light Icon theme";
- ui->actionHome->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_HOME));
- ui->actionNewFlight->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_NEW_FLIGHT));
- ui->actionNewSim->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_NEW_FLIGHT));
- ui->actionLogbook->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_LOGBOOK));
- ui->actionAircraft->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_AIRCRAFT));
- ui->actionPilots->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_PILOT));
- ui->actionAirports->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_BACKUP));
- ui->actionSettings->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_SETTINGS));
- ui->actionQuit->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_QUIT));
- break;
- case OPL::Style::StyleType::Dark:
- LOG << "Setting Dark Icon theme";
- ui->actionHome->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_HOME_DARK));
- ui->actionNewFlight->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_NEW_FLIGHT_DARK));
- ui->actionNewSim->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_NEW_FLIGHT_DARK));
- ui->actionLogbook->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_LOGBOOK_DARK));
- ui->actionAircraft->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_AIRCRAFT_DARK));
- ui->actionPilots->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_PILOT_DARK));
- ui->actionAirports->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_BACKUP_DARK));
- ui->actionSettings->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_SETTINGS_DARK));
- ui->actionQuit->setIcon( QIcon(OPL::Assets::ICON_TOOLBAR_QUIT_DARK));
- break;
- }
- }
- void MainWindow::nope()
- {
- QMessageBox message_box(this);
- message_box.setText(tr("This feature is not yet available!"));
- message_box.exec();
- }
- void MainWindow::connectWidgets()
- {
- QObject::connect(settingsWidget, &SettingsWidget::settingChanged,
- logbookWidget, &LogbookTableEditWidget::viewSelectionChanged);
- QObject::connect(this, &MainWindow::addFlightEntryRequested,
- logbookWidget, &LogbookTableEditWidget::addEntryRequested);
- QObject::connect(this, &MainWindow::addSimulatorEntryRequested,
- logbookWidget, &LogbookTableEditWidget::addSimulatorEntryRequested);
- QObject::connect(settingsWidget, &SettingsWidget::settingChanged,
- this, &MainWindow::onStyleChanged);
- }
- void MainWindow::onDatabaseInvalid()
- {
- QMessageBox db_error(this);
- db_error.addButton(tr("Restore Backup"), QMessageBox::ButtonRole::AcceptRole);
- db_error.addButton(tr("Create New Database"), QMessageBox::ButtonRole::RejectRole);
- db_error.addButton(tr("Abort"), QMessageBox::ButtonRole::DestructiveRole);
- db_error.setIcon(QMessageBox::Warning);
- db_error.setWindowTitle(tr("No valid database found"));
- db_error.setText(tr("No valid database has been found.<br>"
- "Would you like to create a new database or import a backup?<br><br>"));
- int ret = db_error.exec();
- if (ret == QMessageBox::DestructiveRole) {
- DEB << "No valid database found. Exiting.";
- on_actionQuit_triggered();
- } else if (ret == QMessageBox::ButtonRole::AcceptRole) {
- DEB << "Yes(Import Backup)";
- QString db_path = QDir::toNativeSeparators(
- (QFileDialog::getOpenFileName(this,
- tr("Select Database"),
- OPL::Paths::directory(OPL::Paths::Backup).canonicalPath(),
- tr("Database file (*.db)"))));
- if (!db_path.isEmpty()) {
- if(!DB->restoreBackup(db_path)) {
- WARN(tr("Unable to restore backup file:<br><br>%1").arg(db_path));
- on_actionQuit_triggered();
- }
- }
- } else if (ret == QMessageBox::ButtonRole::RejectRole){
- DEB << "No(Create New)";
- if(FirstRunDialog().exec() == QDialog::Rejected){
- LOG << "Initial setup incomplete or unsuccessfull.";
- on_actionQuit_triggered();
- }
- Settings::setSetupCompleted(true);
- LOG << "Initial Setup Completed successfully";
- }
- }
- void MainWindow::on_actionHome_triggered()
- {
- ui->stackedWidget->setCurrentWidget(homeWidget);
- }
- void MainWindow::on_actionNewFlight_triggered()
- {
- ui->stackedWidget->setCurrentWidget(logbookWidget);
- emit addFlightEntryRequested();
- }
- void MainWindow::on_actionNewSim_triggered()
- {
-
-
- ui->stackedWidget->setCurrentWidget(logbookWidget);
- emit addSimulatorEntryRequested();
- }
- void MainWindow::on_actionLogbook_triggered()
- {
- ui->stackedWidget->setCurrentWidget(logbookWidget);
- }
- void MainWindow::on_actionAircraft_triggered()
- {
- ui->stackedWidget->setCurrentWidget(tailsWidget);
- }
- void MainWindow::on_actionPilots_triggered()
- {
- ui->stackedWidget->setCurrentWidget(pilotsWidget);
- }
- void MainWindow::on_actionAirports_triggered()
- {
- ui->stackedWidget->setCurrentWidget(airportWidget);
- }
- void MainWindow::on_actionSettings_triggered()
- {
- ui->stackedWidget->setCurrentWidget(settingsWidget);
- }
- void MainWindow::on_actionQuit_triggered()
- {
- QApplication::quit();
- exit(0);
- }
- void MainWindow::on_actionDebug_triggered()
- {
- ui->stackedWidget->setCurrentWidget(debugWidget);
- }
|