Files
pilotclient/src/swiftdata/swiftdata.cpp
Klaus Basan b74652c94a Ref T220, renamed some main window / widget functions
Make clearer if dealing with a window or widget
2018-01-14 18:47:03 +01:00

207 lines
6.3 KiB
C++

/* Copyright (C) 2015
* swift project Community / Contributors
*
* This file is part of swift project. It is subject to the license terms in the LICENSE file found in the top-level
* directory of this distribution and at http://www.swift-project.org/license.html. No part of swift project,
* including this file, may be copied, modified, propagated, or distributed except according to the terms
* contained in the LICENSE file.
*/
#include "swiftdata.h"
#include "blackcore/data/globalsetup.h"
#include "blackgui/components/datamaininfoareacomponent.h"
#include "blackgui/components/dbmappingcomponent.h"
#include "blackgui/components/logcomponent.h"
#include "blackgui/components/datasettingscomponent.h"
#include "blackgui/guiapplication.h"
#include "blackgui/stylesheetutility.h"
#include "blackmisc/loghandler.h"
#include "blackmisc/statusmessage.h"
#include "blackmisc/logmessage.h"
#include "blackmisc/logpattern.h"
#include "blackmisc/network/url.h"
#include "blackmisc/simulation/distributorlist.h"
#include "blackconfig/buildconfig.h"
#include "ui_swiftdata.h"
#include <QAction>
#include <QString>
#include <QStyle>
#include <QtGlobal>
#include <QVersionNumber>
class QWidget;
using namespace BlackMisc;
using namespace BlackMisc::Network;
using namespace BlackMisc::Simulation;
using namespace BlackCore;
using namespace BlackCore::Data;
using namespace BlackCore::Db;
using namespace BlackGui;
using namespace BlackGui::Components;
using namespace BlackConfig;
CSwiftData::CSwiftData(QWidget *parent) :
QMainWindow(parent),
CIdentifiable(this),
ui(new Ui::CSwiftData)
{
ui->setupUi(this);
this->init();
}
void CSwiftData::initStyleSheet()
{
const QString s = sGui->getStyleSheetUtility().styles(
{
CStyleSheetUtility::fileNameFonts(),
CStyleSheetUtility::fileNameStandardWidget(),
CStyleSheetUtility::fileNameSwiftData()
}
);
this->setStyleSheet(s);
}
CSwiftData::~CSwiftData()
{ }
void CSwiftData::closeEvent(QCloseEvent *event)
{
if (sGui)
{
// save settings
if (sGui->showCloseDialog(this, event) == QDialog::Rejected) { return; }
}
this->performGracefulShutdown();
}
void CSwiftData::appendLogMessage(const CStatusMessage &message)
{
if (!ui->comp_MainInfoArea) { return; } // not initialized yet
CLogComponent *logComponent = ui->comp_MainInfoArea->getLogComponent();
Q_ASSERT_X(logComponent, Q_FUNC_INFO, "missing log component");
logComponent->appendStatusMessageToList(message);
// status bar
m_statusBar.displayStatusMessage(message);
}
void CSwiftData::onStyleSheetsChanged()
{
this->initStyleSheet();
}
void CSwiftData::init()
{
sGui->initMainApplicationWidget(this);
this->initLogDisplay();
m_mwaLogComponent = ui->comp_MainInfoArea->getLogComponent();
m_mwaStatusBar = &m_statusBar;
m_mwaOverlayFrame = ui->comp_MainInfoArea->getMappingComponent();
this->initStyleSheet();
connect(sGui, &CGuiApplication::styleSheetsChanged, this, &CSwiftData::onStyleSheetsChanged);
this->initMenu();
// update title
const CGlobalSetup s(sApp->getGlobalSetup());
if (!s.getDbHomePageUrl().isEmpty())
{
this->setWindowTitle(QString("%1 %2").arg(this->windowTitle(), s.getDbHomePageUrl().toQString(true)));
}
sGui->triggerNewVersionCheck(15 * 1000);
QTimer::singleShot(15 * 1000, this, &CSwiftData::checkMinimumVersion);
emit sGui->startUpCompleted(true);
}
void CSwiftData::initLogDisplay()
{
m_statusBar.initStatusBar(ui->sb_SwiftData);
CLogHandler::instance()->install(true);
CLogHandler::instance()->enableConsoleOutput(false); // default disable
auto logHandler = CLogHandler::instance()->handlerForPattern(
CLogPattern().withSeverityAtOrAbove(CStatusMessage::SeverityInfo)
);
logHandler->subscribe(this, &CSwiftData::appendLogMessage);
}
void CSwiftData::initMenu()
{
// menu
this->initDynamicMenus();
ui->menu_WindowMinimize->setIcon(this->style()->standardIcon(QStyle::SP_TitleBarMinButton));
connect(ui->menu_WindowFont, &QAction::triggered, this, &CSwiftData::onMenuClicked);
connect(ui->menu_MappingMaxData, &QAction::triggered, this, &CSwiftData::onMenuClicked);
connect(ui->menu_MappingMaxMapping, &QAction::triggered, this, &CSwiftData::onMenuClicked);
sGui->addMenuFile(*ui->menu_File);
sGui->addMenuInternals(*ui->menu_Internals);
sGui->addMenuWindow(*ui->menu_Window);
sGui->addMenuHelp(*ui->menu_Help);
}
void CSwiftData::performGracefulShutdown()
{
if (m_updater)
{
m_updater->abandonAndWait();
}
}
void CSwiftData::consolidationSettingChanged()
{
const int consolidationSecs = m_consolidationSettings.get();
if (consolidationSecs < 0)
{
if (m_updater)
{
ui->comp_MainInfoArea->getDataSettingsComponent()->setBackgroundUpdater(nullptr);
disconnect(m_updater.data());
m_updater->abandonAndWait();
m_updater = nullptr;
}
}
else
{
if (!m_updater)
{
m_updater = m_updater.create(this);
connect(m_updater.data(), &CBackgroundDataUpdater::consolidating, ui->comp_InfoBar, &CInfoBarWebReadersStatusComponent::consolidationRunning, Qt::QueuedConnection);
m_updater->start(QThread::LowestPriority);
ui->comp_MainInfoArea->getDataSettingsComponent()->setBackgroundUpdater(m_updater.data());
}
m_updater->startUpdating(consolidationSecs);
}
}
void CSwiftData::displayConsole()
{
ui->comp_MainInfoArea->displayConsole();
}
void CSwiftData::displayLog()
{
ui->comp_MainInfoArea->displayLog();
}
void CSwiftData::checkMinimumVersion()
{
Q_ASSERT_X(sApp, Q_FUNC_INFO, "Need sApp");
if (sApp->getGlobalSetup().isSwiftVersionMinimumMappingVersion())
{
CLogMessage(this).info("Checked mapping tool version, required '%1', this version '%2'") << sApp->getGlobalSetup().getMappingMinimumVersionString() << CBuildConfig::getVersionString();
}
else
{
const CStatusMessage sm = CStatusMessage(this, CStatusMessage::SeverityWarning, "Your are using swift version: '%1'. Creating mappings requires at least '%2'.") << CBuildConfig::getVersionString() << sApp->getGlobalSetup().getMappingMinimumVersionString();
CLogMessage::preformatted(sm);
this->displayInOverlayWindow(sm);
}
}