mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-03-22 23:05:36 +08:00
Ref T659, login (new/advanced) component for dialog
* using new components * removed unused parts (now in components)
This commit is contained in:
committed by
Mat Sutcliffe
parent
83254e97aa
commit
c97bb2288c
@@ -17,23 +17,23 @@
|
||||
#include "blackgui/ticklabel.h"
|
||||
#include "blackgui/uppercasevalidator.h"
|
||||
#include "blackcore/context/contextaudio.h"
|
||||
#include "blackcore/context/contextnetwork.h"
|
||||
#include "blackcore/context/contextownaircraft.h"
|
||||
#include "blackcore/context/contextsimulator.h"
|
||||
#include "blackcore/webdataservices.h"
|
||||
#include "blackcore/context/contextnetwork.h"
|
||||
#include "blackcore/data/globalsetup.h"
|
||||
#include "blackcore/webdataservices.h"
|
||||
#include "blackcore/network.h"
|
||||
#include "blackcore/simulator.h"
|
||||
#include "blackmisc/aviation/aircrafticaocode.h"
|
||||
#include "blackmisc/aviation/airlineicaocode.h"
|
||||
#include "blackmisc/aviation/airporticaocode.h"
|
||||
#include "blackmisc/icons.h"
|
||||
#include "blackmisc/logmessage.h"
|
||||
#include "blackmisc/network/entityflags.h"
|
||||
#include "blackmisc/network/serverlist.h"
|
||||
#include "blackmisc/simulation/simulatorinternals.h"
|
||||
#include "blackmisc/simulation/aircraftmodel.h"
|
||||
#include "blackmisc/simulation/simulatedaircraft.h"
|
||||
#include "blackmisc/aviation/aircrafticaocode.h"
|
||||
#include "blackmisc/aviation/airlineicaocode.h"
|
||||
#include "blackmisc/aviation/airporticaocode.h"
|
||||
#include "blackmisc/network/entityflags.h"
|
||||
#include "blackmisc/network/serverlist.h"
|
||||
#include "blackmisc/icons.h"
|
||||
#include "blackmisc/logmessage.h"
|
||||
#include "blackmisc/statusmessage.h"
|
||||
#include "blackmisc/crashhandler.h"
|
||||
#include "blackconfig/buildconfig.h"
|
||||
@@ -78,37 +78,11 @@ namespace BlackGui
|
||||
ui(new Ui::CLoginAdvComponent)
|
||||
{
|
||||
ui->setupUi(this);
|
||||
ui->tw_Details->setCurrentWidget(ui->tb_LoginMode);
|
||||
m_logoffCountdownTimer.setObjectName("CLoginAdvComponent:m_logoffCountdownTimer");
|
||||
|
||||
ui->tw_Network->setCurrentIndex(0);
|
||||
ui->selector_AircraftIcao->displayWithIcaoDescription(false);
|
||||
ui->selector_AirlineIcao->displayWithIcaoDescription(false);
|
||||
ui->selector_AircraftIcao->displayMode(CDbAircraftIcaoSelectorComponent::DisplayIcaoAndId);
|
||||
ui->selector_AirlineIcao->displayMode(CDbAirlineIcaoSelectorComponent::DisplayVDesignatorAndId);
|
||||
|
||||
this->setLogoffCountdown();
|
||||
connect(&m_logoffCountdownTimer, &QTimer::timeout, this, &CLoginAdvComponent::logoffCountdown);
|
||||
connect(ui->comp_OtherServers, &CServerListSelector::serverChanged, this, &CLoginAdvComponent::onSelectedServerChanged);
|
||||
connect(ui->comp_VatsimServers, &CServerListSelector::serverChanged, this, &CLoginAdvComponent::onSelectedServerChanged);
|
||||
connect(ui->pb_RefreshOtherServers, &QToolButton::clicked, this, &CLoginAdvComponent::reloadOtherServersSetup);
|
||||
connect(ui->tw_Network, &QTabWidget::currentChanged, this, &CLoginAdvComponent::onServerTabWidgetChanged);
|
||||
connect(ui->pb_Cancel, &QPushButton::clicked, this, &CLoginAdvComponent::loginCancelled, Qt::QueuedConnection);
|
||||
connect(ui->pb_Ok, &QPushButton::clicked, this, &CLoginAdvComponent::toggleNetworkConnection, Qt::QueuedConnection);
|
||||
connect(ui->pb_OtherServersGotoSettings, &QPushButton::pressed, this, &CLoginAdvComponent::requestNetworkSettings);
|
||||
connect(ui->pb_MappingWizard, &QToolButton::clicked, this, &CLoginAdvComponent::mappingWizard, Qt::QueuedConnection);
|
||||
connect(&m_networkSetup, &CNetworkSetup::setupChanged, this, &CLoginAdvComponent::reloadOtherServersSetup, Qt::QueuedConnection);
|
||||
|
||||
ui->form_FsdDetails->showEnableInfo(true);
|
||||
ui->form_FsdDetails->setFsdSetupEnabled(false);
|
||||
|
||||
ui->form_Voice->showEnableInfo(true);
|
||||
ui->form_Voice->setVoiceSetupEnabled(false);
|
||||
|
||||
ui->lblp_AircraftCombinedType->setToolTips("ok", "wrong");
|
||||
ui->lblp_AirlineIcao->setToolTips("ok", "wrong");
|
||||
ui->lblp_AircraftIcao->setToolTips("ok", "wrong");
|
||||
ui->lblp_Callsign->setToolTips("ok", "wrong");
|
||||
connect(ui->pb_Cancel, &QPushButton::clicked, this, &CLoginAdvComponent::loginCancelled, Qt::QueuedConnection);
|
||||
connect(ui->pb_Ok, &QPushButton::clicked, this, &CLoginAdvComponent::toggleNetworkConnection, Qt::QueuedConnection);
|
||||
connect(ui->comp_NetworkDetails, &CNetworkDetailsComponent::overridePilot, this, &CLoginAdvComponent::overrideCredentialsToPilot, Qt::QueuedConnection);
|
||||
connect(ui->comp_NetworkDetails, &CNetworkDetailsComponent::requestNetworkSettings, this, &CLoginAdvComponent::requestNetworkSettings, Qt::QueuedConnection);
|
||||
|
||||
// overlay
|
||||
this->setOverlaySizeFactors(0.8, 0.5);
|
||||
@@ -121,64 +95,15 @@ namespace BlackGui
|
||||
|
||||
// Remark: The validators affect the signals such as returnPressed, editingFinished
|
||||
// So I use no ranges in the CUpperCaseValidators, as this disables the signals for invalid values
|
||||
|
||||
// own aircraft
|
||||
constexpr int MaxLength = 10;
|
||||
constexpr int MinLength = 0;
|
||||
CUpperCaseValidator *ucv = new CUpperCaseValidator(MinLength, MaxLength, ui->le_Callsign);
|
||||
// ucv->setAllowedCharacters09AZ();
|
||||
ui->le_Callsign->setMaxLength(MaxLength);
|
||||
ui->le_Callsign->setValidator(ucv);
|
||||
connect(ui->le_Callsign, &QLineEdit::editingFinished, this, &CLoginAdvComponent::validateAircraftValues);
|
||||
|
||||
ui->le_AircraftCombinedType->setMaxLength(3);
|
||||
ui->le_AircraftCombinedType->setValidator(new CUpperCaseValidator(this));
|
||||
connect(ui->le_AircraftCombinedType, &QLineEdit::editingFinished, this, &CLoginAdvComponent::validateAircraftValues);
|
||||
connect(ui->selector_AircraftIcao, &CDbAircraftIcaoSelectorComponent::changedAircraftIcao, this, &CLoginAdvComponent::changedAircraftIcao, Qt::QueuedConnection);
|
||||
connect(ui->selector_AirlineIcao, &CDbAirlineIcaoSelectorComponent::changedAirlineIcao, this, &CLoginAdvComponent::changedAirlineIcao, Qt::QueuedConnection);
|
||||
connect(ui->pb_SimulatorLookup, &QToolButton::clicked, this, &CLoginAdvComponent::lookupOwnAircraftModel);
|
||||
connect(ui->tw_Details, &QTabWidget::currentChanged, this, &CLoginAdvComponent::onDetailsTabChanged);
|
||||
|
||||
if (sGui && sGui->getIContextSimulator())
|
||||
{
|
||||
connect(sGui->getIContextSimulator(), &IContextSimulator::ownAircraftModelChanged, this, &CLoginAdvComponent::onSimulatorModelChanged, Qt::QueuedConnection);
|
||||
connect(sGui->getIContextSimulator(), &IContextSimulator::vitalityLost, this, &CLoginAdvComponent::autoLogoffDetection, Qt::QueuedConnection);
|
||||
connect(sGui->getIContextSimulator(), &IContextSimulator::simulatorStatusChanged, this, &CLoginAdvComponent::onSimulatorStatusChanged, Qt::QueuedConnection);
|
||||
}
|
||||
|
||||
// server and UI elements when in disconnect state
|
||||
ui->frp_CurrentServer->setReadOnly(true);
|
||||
ui->frp_CurrentServer->showPasswordField(false);
|
||||
ui->tb_Timeout->setIcon(m_iconPause);
|
||||
connect(ui->tb_Timeout, &QToolButton::clicked, this, &CLoginAdvComponent::toggleTimeout);
|
||||
|
||||
// web service data
|
||||
if (sGui && sGui->getWebDataServices())
|
||||
{
|
||||
connect(sGui->getWebDataServices(), &CWebDataServices::dataRead, this, &CLoginAdvComponent::onWebServiceDataRead, Qt::QueuedConnection);
|
||||
}
|
||||
|
||||
// inital setup, if data already available
|
||||
this->validateAircraftValues();
|
||||
ui->form_Pilot->validate();
|
||||
ui->cb_AutoLogoff->setChecked(m_networkSetup.useAutoLogoff());
|
||||
this->onWebServiceDataRead(CEntityFlags::VatsimDataFile, CEntityFlags::ReadFinished, -1);
|
||||
this->reloadOtherServersSetup();
|
||||
|
||||
connect(ui->pb_OverrideCredentialsVatsim, &QPushButton::clicked, this, &CLoginAdvComponent::overrideCredentialsToPilot);
|
||||
connect(ui->pb_OverrideCredentialsOtherServers, &QPushButton::clicked, this, &CLoginAdvComponent::overrideCredentialsToPilot);
|
||||
|
||||
this->setUiLoginState(false);
|
||||
|
||||
const int tab = m_networkSetup.wasLastUsedWithOtherServer() ? LoginOthers : LoginVATSIM;
|
||||
ui->tw_Network->setCurrentIndex(tab);
|
||||
|
||||
QPointer<CLoginAdvComponent> myself(this);
|
||||
QTimer::singleShot(5000, this, [ = ]
|
||||
{
|
||||
if (!myself) { return; }
|
||||
this->updateGui();
|
||||
});
|
||||
}
|
||||
|
||||
CLoginAdvComponent::~CLoginAdvComponent()
|
||||
@@ -187,12 +112,10 @@ namespace BlackGui
|
||||
void CLoginAdvComponent::mainInfoAreaChanged(const QWidget *currentWidget)
|
||||
{
|
||||
if (!sGui || sGui->isShuttingDown()) { return; }
|
||||
m_logoffCountdownTimer.stop(); // in any case stop the timer
|
||||
if (currentWidget != this && currentWidget != this->parentWidget())
|
||||
{
|
||||
// const bool wasVisible = m_visible;
|
||||
m_visible = false;
|
||||
m_logoffCountdownTimer.stop();
|
||||
|
||||
/** T639
|
||||
if (!wasVisible)
|
||||
@@ -213,10 +136,7 @@ namespace BlackGui
|
||||
else
|
||||
{
|
||||
m_visible = true;
|
||||
this->setOwnModelAndIcaoValues();
|
||||
const bool isConnected = sGui->getIContextNetwork()->isConnected();
|
||||
this->setUiLoginState(isConnected);
|
||||
if (isConnected) { this->startLogoffTimerCountdown(); }
|
||||
ui->comp_OwnAircraft->setOwnModelAndIcaoValues();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -227,19 +147,8 @@ namespace BlackGui
|
||||
}
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::setLogoffCountdown(int timeoutSeconds)
|
||||
{
|
||||
if (timeoutSeconds < 0) { timeoutSeconds = LogoffIntervalSeconds; }
|
||||
|
||||
ui->pb_LogoffTimeout->setMaximum(timeoutSeconds);
|
||||
ui->pb_LogoffTimeout->setValue(timeoutSeconds);
|
||||
m_logoffIntervalSeconds = timeoutSeconds;
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::loginCancelled()
|
||||
{
|
||||
m_logoffCountdownTimer.stop();
|
||||
this->setLogoffCountdown(); // reset time
|
||||
this->closeOverlay();
|
||||
emit this->loginOrLogoffCancelled();
|
||||
}
|
||||
@@ -250,21 +159,18 @@ namespace BlackGui
|
||||
if (!sGui->getIContextNetwork() || !sGui->getIContextAudio()) { return; }
|
||||
|
||||
const bool isConnected = sGui && sGui->getIContextNetwork()->isConnected();
|
||||
const bool vatsimLogin = this->isVatsimNetworkTabSelected();
|
||||
const bool vatsimLogin = ui->comp_NetworkDetails->isVatsimServerSelected();
|
||||
m_networkSetup.setAutoLogoff(ui->cb_AutoLogoff->isChecked());
|
||||
|
||||
ui->form_Pilot->setVatsimValidation(vatsimLogin);
|
||||
this->setUiLoginState(isConnected);
|
||||
|
||||
// reset time
|
||||
this->setLogoffCountdown();
|
||||
|
||||
CServer currentServer; // used for login
|
||||
CSimulatedAircraft ownAircraft; // used own aircraft
|
||||
CStatusMessage msg;
|
||||
if (!isConnected)
|
||||
{
|
||||
if (!this->validateAircraftValues())
|
||||
const CStatusMessageList aircraftMsgs = ui->comp_OwnAircraft->validate();
|
||||
if (aircraftMsgs.isFailure())
|
||||
{
|
||||
this->showOverlayHTMLMessage(CStatusMessage(this).validationWarning(u"Invalid aircraft data, login not possible"), OverlayMessageMs);
|
||||
return;
|
||||
@@ -279,10 +185,10 @@ namespace BlackGui
|
||||
|
||||
// sync values with GUI values
|
||||
this->updateOwnAircraftCallsignAndPilotFromGuiValues();
|
||||
this->updateOwnAircaftIcaoValuesFromGuiValues();
|
||||
ui->comp_OwnAircraft->updateOwnAircaftIcaoValuesFromGuiValues();
|
||||
|
||||
// Login mode
|
||||
const INetwork::LoginMode mode = ui->frp_LoginMode->getLoginMode();
|
||||
const INetwork::LoginMode mode = ui->comp_NetworkDetails->getLoginMode();
|
||||
switch (mode)
|
||||
{
|
||||
case INetwork::LoginStealth: CLogMessage(this).info(u"login in stealth mode"); break;
|
||||
@@ -296,19 +202,18 @@ namespace BlackGui
|
||||
currentServer.setUser(user);
|
||||
|
||||
// FSD setup, then override
|
||||
if (ui->form_FsdDetails->isFsdSetupEnabled())
|
||||
if (ui->comp_NetworkDetails->isFsdSetupOverrideEnabled())
|
||||
{
|
||||
const CFsdSetup fsd = ui->form_FsdDetails->getValue();
|
||||
const CFsdSetup fsd = ui->comp_NetworkDetails->getFsdSetup();
|
||||
currentServer.setFsdSetup(fsd);
|
||||
}
|
||||
|
||||
if (ui->form_Voice->isVoiceSetupEnabled())
|
||||
if (ui->comp_NetworkDetails->isVoiceSetupOverrideEnabled())
|
||||
{
|
||||
const CVoiceSetup voice = ui->form_Voice->getValue();
|
||||
const CVoiceSetup voice = ui->comp_NetworkDetails->getVoiceSetup();
|
||||
currentServer.setVoiceSetup(voice);
|
||||
}
|
||||
|
||||
ui->frp_CurrentServer->setServer(currentServer);
|
||||
sGui->getIContextOwnAircraft()->updateOwnAircraftPilot(currentServer.getUser());
|
||||
|
||||
// set own aircraft from all values
|
||||
@@ -329,9 +234,6 @@ namespace BlackGui
|
||||
CCrashHandler::instance()->crashAndLogInfoFlightNetwork(currentServer.getEcosystem().toQString(true));
|
||||
CCrashHandler::instance()->crashAndLogAppendInfo(currentServer.getServerSessionId(false));
|
||||
m_networkSetup.setLastServer(currentServer);
|
||||
m_lastAircraftModel.set(ownAircraft.getModel());
|
||||
ui->le_LoginCallsign->setText(ownAircraft.getCallsignAsString());
|
||||
ui->le_LoginHomeBase->setText(currentServer.getUser().getHomeBase().asString());
|
||||
if (vatsimLogin) { m_networkSetup.setLastVatsimServer(currentServer); }
|
||||
}
|
||||
else
|
||||
@@ -361,66 +263,16 @@ namespace BlackGui
|
||||
}
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::onWebServiceDataRead(CEntityFlags::Entity entity, CEntityFlags::ReadState state, int number)
|
||||
{
|
||||
if (!CEntityFlags::isFinishedReadState(state)) { return; }
|
||||
Q_UNUSED(number);
|
||||
|
||||
if (entity == CEntityFlags::VatsimDataFile)
|
||||
{
|
||||
CServerList vatsimFsdServers = sGui->getIContextNetwork()->getVatsimFsdServers();
|
||||
if (vatsimFsdServers.isEmpty()) { return; }
|
||||
vatsimFsdServers.sortBy(&CServer::getName);
|
||||
const CServer currentServer = m_networkSetup.getLastVatsimServer();
|
||||
ui->comp_VatsimServers->setServers(vatsimFsdServers, true);
|
||||
ui->comp_VatsimServers->preSelect(currentServer.getName());
|
||||
}
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::loadRememberedUserData()
|
||||
{
|
||||
const CServer lastServer = m_networkSetup.getLastServer();
|
||||
if (!lastServer.isNull())
|
||||
{
|
||||
ui->tw_Network->setCurrentWidget(
|
||||
lastServer.getServerType() == CServer::FSDServerVatsim ?
|
||||
ui->tb_NetworkVatsim : ui->tb_OtherServers);
|
||||
}
|
||||
|
||||
const CUser lastUser = lastServer.getUser();
|
||||
ui->form_Pilot->setUser(lastUser);
|
||||
if (lastUser.hasCallsign())
|
||||
{
|
||||
ui->le_Callsign->setText(lastUser.getCallsign().asString());
|
||||
}
|
||||
else if (CBuildConfig::isLocalDeveloperDebugBuild())
|
||||
{
|
||||
ui->le_Callsign->setText("SWIFT");
|
||||
}
|
||||
ui->comp_OwnAircraft->setUser(lastUser);
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::overrideCredentialsToPilot()
|
||||
void CLoginAdvComponent::overrideCredentialsToPilot(const CUser &user)
|
||||
{
|
||||
CServer server;
|
||||
const QObject *s = QObject::sender();
|
||||
if (s == ui->pb_OverrideCredentialsOtherServers)
|
||||
{
|
||||
server = this->getCurrentOtherServer();
|
||||
}
|
||||
else if (s == ui->pb_OverrideCredentialsVatsim)
|
||||
{
|
||||
// the VATSIM server selected has no valid user credentials
|
||||
server = m_networkSetup.getLastVatsimServer();
|
||||
}
|
||||
else { return; }
|
||||
ui->form_Pilot->setUser(server.getUser(), true);
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::onSelectedServerChanged(const CServer &server)
|
||||
{
|
||||
if (!m_updatePilotOnServerChanges) { return; }
|
||||
const bool vatsim = this->isVatsimNetworkTabSelected();
|
||||
const CUser user = vatsim ? this->getCurrentVatsimServer().getUser() : server.getUser();
|
||||
ui->form_Pilot->setUser(user, true);
|
||||
}
|
||||
|
||||
@@ -438,15 +290,6 @@ namespace BlackGui
|
||||
}
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::onServerTabWidgetChanged(int index)
|
||||
{
|
||||
Q_UNUSED(index);
|
||||
if (!m_updatePilotOnServerChanges) { return; }
|
||||
const bool vatsim = this->isVatsimNetworkTabSelected();
|
||||
const CServer server = vatsim ? this->getCurrentVatsimServer() : this->getCurrentOtherServer();
|
||||
ui->form_Pilot->setUser(server.getUser(), true);
|
||||
}
|
||||
|
||||
bool CLoginAdvComponent::hasValidContexts() const
|
||||
{
|
||||
if (!sGui || !sGui->supportsContexts()) { return false; }
|
||||
@@ -457,162 +300,19 @@ namespace BlackGui
|
||||
return true;
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::setServerButtonsVisible(bool visible)
|
||||
{
|
||||
ui->wi_OtherServersButtons->setVisible(visible);
|
||||
ui->wi_VatsimButtons->setVisible(visible);
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::onDetailsTabChanged(int index)
|
||||
{
|
||||
Q_UNUSED(index);
|
||||
const bool showNetwork = (ui->tw_Details->currentWidget() != ui->tb_FsdDetails);
|
||||
|
||||
const CServer server = this->getCurrentServer();
|
||||
|
||||
// only override if not yet enabled
|
||||
if (!ui->form_FsdDetails->isFsdSetupEnabled()) { ui->form_FsdDetails->setValue(server.getFsdSetup()); }
|
||||
if (!ui->form_Voice->isVoiceSetupEnabled()) { ui->form_Voice->setValue(server.getVoiceSetup()); }
|
||||
|
||||
ui->tw_Network->setVisible(showNetwork);
|
||||
ui->tw_Details->setMinimumHeight(showNetwork ? 0 : 125);
|
||||
}
|
||||
|
||||
CLoginAdvComponent::CGuiAircraftValues CLoginAdvComponent::getAircraftValuesFromGui() const
|
||||
{
|
||||
CGuiAircraftValues values;
|
||||
values.ownCallsign = CCallsign(ui->le_Callsign->text().trimmed().toUpper());
|
||||
values.ownAircraftIcao = ui->selector_AircraftIcao->getAircraftIcao();
|
||||
values.ownAirlineIcao = ui->selector_AirlineIcao->getAirlineIcao();
|
||||
values.ownAircraftCombinedType = ui->le_AircraftCombinedType->text().trimmed().toUpper();
|
||||
values.ownAircraftSimulatorModel = ui->le_SimulatorModel->text().trimmed().toUpper();
|
||||
return values;
|
||||
}
|
||||
|
||||
CUser CLoginAdvComponent::getUserFromPilotGuiValues() const
|
||||
{
|
||||
CUser user = ui->form_Pilot->getUser();
|
||||
user.setCallsign(this->getCallsignFromGui());
|
||||
user.setCallsign(ui->comp_OwnAircraft->getCallsignFromGui());
|
||||
return user;
|
||||
}
|
||||
|
||||
CCallsign CLoginAdvComponent::getCallsignFromGui() const
|
||||
{
|
||||
const CCallsign cs(ui->le_Callsign->text().trimmed().toUpper());
|
||||
return cs;
|
||||
}
|
||||
|
||||
CServer CLoginAdvComponent::getCurrentVatsimServer() const
|
||||
{
|
||||
CServer server = ui->comp_VatsimServers->currentServer();
|
||||
if (!server.getUser().hasValidVatsimId())
|
||||
{
|
||||
// normally VATSIM server have no valid user associated
|
||||
const CUser user = m_networkSetup.getLastVatsimServer().getUser();
|
||||
server.setUser(user);
|
||||
}
|
||||
return server;
|
||||
}
|
||||
|
||||
CServer CLoginAdvComponent::getCurrentOtherServer() const
|
||||
{
|
||||
return ui->comp_OtherServers->currentServer();
|
||||
}
|
||||
|
||||
CServer CLoginAdvComponent::getCurrentServer() const
|
||||
{
|
||||
return this->isVatsimNetworkTabSelected() ? this->getCurrentVatsimServer() : this->getCurrentOtherServer();
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::startLogoffTimerCountdown()
|
||||
{
|
||||
ui->pb_LogoffTimeout->setValue(m_logoffIntervalSeconds);
|
||||
m_logoffCountdownTimer.setInterval(1000);
|
||||
m_logoffCountdownTimer.start();
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::setOwnModelAndIcaoValues(const CAircraftModel &ownModel)
|
||||
{
|
||||
if (!this->hasValidContexts()) { return; }
|
||||
CAircraftModel model = ownModel;
|
||||
const bool simulating = sGui->getIContextSimulator() &&
|
||||
(sGui->getIContextSimulator()->getSimulatorStatus() & ISimulator::Simulating);
|
||||
if (simulating)
|
||||
{
|
||||
if (!model.hasModelString())
|
||||
{
|
||||
model = sGui->getIContextOwnAircraft()->getOwnAircraft().getModel();
|
||||
}
|
||||
const QString modelAndKey(model.getModelStringAndDbKey());
|
||||
ui->le_SimulatorModel->setText(modelAndKey);
|
||||
ui->le_SimulatorModel->home(false);
|
||||
this->highlightModelField(model);
|
||||
|
||||
const CSimulatorInfo sim = sGui->getIContextSimulator()->getSimulatorPluginInfo().getSimulator();
|
||||
const CSimulatorInternals simulatorInternals = sGui->getIContextSimulator()->getSimulatorInternals();
|
||||
const QString simStr = sim.toQString() + QStringLiteral(" ") + simulatorInternals.getSimulatorVersion();
|
||||
CCrashHandler::instance()->crashAndLogInfoSimulator(simStr);
|
||||
}
|
||||
else
|
||||
{
|
||||
if (!model.hasModelString())
|
||||
{
|
||||
model = this->getPrefillModel();
|
||||
}
|
||||
ui->le_SimulatorModel->clear();
|
||||
this->highlightModelField();
|
||||
}
|
||||
ui->le_SimulatorModel->setToolTip(model.asHtmlSummary());
|
||||
|
||||
// reset the model
|
||||
if (model.isLoadedFromDb() || (model.getAircraftIcaoCode().isLoadedFromDb() && model.getLivery().isLoadedFromDb()))
|
||||
{
|
||||
// full model from DB, take all values
|
||||
this->setGuiIcaoValues(model, false);
|
||||
}
|
||||
else
|
||||
{
|
||||
if (sGui->getIContextSimulator()->isSimulatorAvailable())
|
||||
{
|
||||
// sim. attached, but no model data from DB
|
||||
ui->le_AircraftCombinedType->clear();
|
||||
ui->selector_AircraftIcao->clear();
|
||||
ui->selector_AirlineIcao->clear();
|
||||
}
|
||||
}
|
||||
|
||||
const bool changedOwnAircraftCallsignPilot = this->updateOwnAircraftCallsignAndPilotFromGuiValues();
|
||||
const bool changedOwnAircraftIcaoValues = this->updateOwnAircaftIcaoValuesFromGuiValues();
|
||||
if (changedOwnAircraftIcaoValues || changedOwnAircraftCallsignPilot)
|
||||
{
|
||||
m_changedLoginDataDigestSignal.inputSignal();
|
||||
}
|
||||
}
|
||||
|
||||
bool CLoginAdvComponent::setGuiIcaoValues(const CAircraftModel &model, bool onlyIfEmpty)
|
||||
{
|
||||
bool changed = false;
|
||||
if (!onlyIfEmpty || !ui->selector_AircraftIcao->isSet())
|
||||
{
|
||||
changed = ui->selector_AircraftIcao->setAircraftIcao(model.getAircraftIcaoCode());
|
||||
}
|
||||
if (!onlyIfEmpty || !ui->selector_AirlineIcao->isSet())
|
||||
{
|
||||
const bool c = ui->selector_AirlineIcao->setAirlineIcao(model.getAirlineIcaoCode());
|
||||
changed |= c;
|
||||
}
|
||||
if (!onlyIfEmpty || ui->le_AircraftCombinedType->text().trimmed().isEmpty())
|
||||
{
|
||||
const QString combined(model.getAircraftIcaoCode().getCombinedType());
|
||||
if (ui->le_AircraftCombinedType->text() != combined)
|
||||
{
|
||||
ui->le_AircraftCombinedType->setText(combined);
|
||||
changed = true;
|
||||
}
|
||||
}
|
||||
const bool valid = this->validateAircraftValues();
|
||||
return valid ? changed : false;
|
||||
}
|
||||
// const bool changedOwnAircraftCallsignPilot = this->updateOwnAircraftCallsignAndPilotFromGuiValues();
|
||||
// const bool changedOwnAircraftIcaoValues = this->updateOwnAircaftIcaoValuesFromGuiValues();
|
||||
// if (changedOwnAircraftIcaoValues || changedOwnAircraftCallsignPilot)
|
||||
// {
|
||||
// m_changedLoginDataDigestSignal.inputSignal();
|
||||
// }
|
||||
|
||||
void CLoginAdvComponent::setGuiLoginAsValues(const CSimulatedAircraft &ownAircraft)
|
||||
{
|
||||
@@ -621,72 +321,21 @@ namespace BlackGui
|
||||
(ownAircraft.hasAirlineDesignator() ? (u' ' % ownAircraft.getAirlineIcaoCodeDesignator()) : QString()) %
|
||||
(ownAircraft.hasModelString() ? (u' ' % ownAircraft.getModelString()) : QString())
|
||||
);
|
||||
ui->le_LoginSince->setText(QDateTime::currentDateTimeUtc().toString());
|
||||
ui->le_LoginAsAircaft->setText(ac);
|
||||
ui->le_LoginCallsign->setText(ownAircraft.getCallsignAsString());
|
||||
ui->le_LoginAsAircaft->home(false);
|
||||
}
|
||||
|
||||
bool CLoginAdvComponent::validateAircraftValues()
|
||||
CServer CLoginAdvComponent::getCurrentVatsimServer() const
|
||||
{
|
||||
CGuiAircraftValues values = this->getAircraftValuesFromGui();
|
||||
|
||||
// fill in combined type if empty
|
||||
if (ui->le_AircraftCombinedType->text().isEmpty() && values.ownAircraftIcao.isLoadedFromDb())
|
||||
{
|
||||
ui->le_AircraftCombinedType->setText(values.ownAircraftIcao.getCombinedType());
|
||||
values.ownAircraftCombinedType = values.ownAircraftIcao.getCombinedType();
|
||||
}
|
||||
|
||||
const bool validCombinedType = CAircraftIcaoCode::isValidCombinedType(values.ownAircraftCombinedType);
|
||||
ui->lblp_AircraftCombinedType->setTicked(validCombinedType);
|
||||
|
||||
// airline is optional, e.g. C172 has no airline
|
||||
const bool validAirlineDesignator = values.ownAirlineIcao.hasValidDesignator() || values.ownAirlineIcao.getDesignator().isEmpty();
|
||||
ui->lblp_AirlineIcao->setTicked(validAirlineDesignator);
|
||||
|
||||
const bool validAircraftDesignator = values.ownAircraftIcao.hasValidDesignator();
|
||||
ui->lblp_AircraftIcao->setTicked(validAircraftDesignator);
|
||||
|
||||
const bool validCallsign = CCallsign::isValidAircraftCallsign(values.ownCallsign);
|
||||
ui->lblp_Callsign->setTicked(validCallsign);
|
||||
|
||||
// model intentionally ignored
|
||||
return validCombinedType && validAirlineDesignator && validAircraftDesignator && validCallsign;
|
||||
return ui->comp_NetworkDetails->getCurrentVatsimServer();
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::changedAircraftIcao(const CAircraftIcaoCode &icao)
|
||||
CServer CLoginAdvComponent::getCurrentOtherServer() const
|
||||
{
|
||||
if (icao.isLoadedFromDb())
|
||||
{
|
||||
ui->le_AircraftCombinedType->setText(icao.getCombinedType());
|
||||
}
|
||||
this->validateAircraftValues();
|
||||
return ui->comp_NetworkDetails->getCurrentOtherServer();
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::changedAirlineIcao(const CAirlineIcaoCode &icao)
|
||||
CServer CLoginAdvComponent::getCurrentServer() const
|
||||
{
|
||||
Q_UNUSED(icao);
|
||||
this->validateAircraftValues();
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::reloadOtherServersSetup()
|
||||
{
|
||||
const CServerList otherServers(m_networkSetup.getOtherServersPlusPredefinedServers());
|
||||
ui->comp_OtherServers->setServers(otherServers);
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::logoffCountdown()
|
||||
{
|
||||
int v = ui->pb_LogoffTimeout->value();
|
||||
v -= 1;
|
||||
if (v < 0) { v = 0; }
|
||||
ui->pb_LogoffTimeout->setValue(v);
|
||||
if (v <= 0)
|
||||
{
|
||||
m_logoffCountdownTimer.stop();
|
||||
this->toggleNetworkConnection();
|
||||
}
|
||||
return ui->comp_NetworkDetails->getCurrentServer();
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::autoLogoffDetection()
|
||||
@@ -698,19 +347,11 @@ namespace BlackGui
|
||||
const CStatusMessage m = CStatusMessage(this, CStatusMessage::SeverityInfo, u"Auto logoff in progress (could be simulator shutdown, crash, closing simulator)");
|
||||
const int delaySecs = 30;
|
||||
this->showOverlayHTMLMessage(m, qRound(1000 * delaySecs * 0.8));
|
||||
this->setLogoffCountdown(delaySecs);
|
||||
|
||||
emit this->requestLoginPage();
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::lookupOwnAircraftModel()
|
||||
{
|
||||
if (!this->hasValidContexts()) { return; }
|
||||
if (!sGui->getIContextSimulator()->isSimulatorAvailable()) { return; }
|
||||
const CAircraftModel model(sGui->getIContextOwnAircraft()->getOwnAircraft().getModel());
|
||||
this->onSimulatorModelChanged(model);
|
||||
}
|
||||
|
||||
/**
|
||||
void CLoginAdvComponent::onSimulatorModelChanged(const CAircraftModel &model)
|
||||
{
|
||||
if (!sGui || !sGui->getIContextNetwork() || sApp->isShuttingDown()) { return; }
|
||||
@@ -746,86 +387,18 @@ namespace BlackGui
|
||||
// let others know data changed
|
||||
m_changedLoginDataDigestSignal.inputSignal();
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::mappingWizard()
|
||||
{
|
||||
if (!sGui || !sGui->getIContextOwnAircraft() || sGui->isShuttingDown()) { return; }
|
||||
if (!sGui->hasMinimumMappingVersion()) { return; }
|
||||
|
||||
if (!m_mappingWizard)
|
||||
{
|
||||
m_mappingWizard.reset(new CDbQuickMappingWizard(this));
|
||||
}
|
||||
|
||||
if (sGui->getIContextSimulator()->isSimulatorAvailable())
|
||||
{
|
||||
// preset on model
|
||||
const CAircraftModel model(sGui->getIContextOwnAircraft()->getOwnAircraft().getModel());
|
||||
m_mappingWizard->presetModel(model);
|
||||
}
|
||||
else
|
||||
{
|
||||
// preset on GUI values only
|
||||
const CAircraftIcaoCode icao(ui->selector_AircraftIcao->getAircraftIcao());
|
||||
m_mappingWizard->presetAircraftIcao(icao);
|
||||
}
|
||||
m_mappingWizard->show();
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::toggleTimeout()
|
||||
{
|
||||
if (m_logoffCountdownTimer.isActive())
|
||||
{
|
||||
m_logoffCountdownTimer.stop();
|
||||
ui->tb_Timeout->setIcon(m_iconPlay);
|
||||
}
|
||||
else
|
||||
{
|
||||
m_logoffCountdownTimer.start();
|
||||
ui->tb_Timeout->setIcon(m_iconPause);
|
||||
}
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::setUiLoginState(bool connected)
|
||||
{
|
||||
ui->fr_LoginDisconnected->setVisible(!connected);
|
||||
ui->fr_LogoffConfirmationConnected->setVisible(connected);
|
||||
|
||||
const QString s = connected ? QStringLiteral("disconnect") : QStringLiteral("connect");
|
||||
ui->pb_Ok->setText(s);
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::highlightModelField(const CAircraftModel &model)
|
||||
{
|
||||
if (!model.hasModelString()) { ui->le_SimulatorModel->setProperty("validation", "error"); }
|
||||
else if (!model.isLoadedFromDb()) { ui->le_SimulatorModel->setProperty("validation", "warning"); }
|
||||
else { ui->le_SimulatorModel->setProperty("validation", "ok"); }
|
||||
ui->le_SimulatorModel->setStyleSheet(""); // force update
|
||||
}
|
||||
|
||||
bool CLoginAdvComponent::isVatsimNetworkTabSelected() const
|
||||
{
|
||||
return (ui->tw_Network->currentWidget() == ui->tb_NetworkVatsim);
|
||||
}
|
||||
|
||||
CAircraftModel CLoginAdvComponent::getPrefillModel() const
|
||||
{
|
||||
const CAircraftModel model = m_lastAircraftModel.get();
|
||||
if (model.hasAircraftDesignator()) { return model; }
|
||||
return IContextOwnAircraft::getDefaultOwnAircraftModel();
|
||||
}
|
||||
**/
|
||||
|
||||
bool CLoginAdvComponent::updateOwnAircraftCallsignAndPilotFromGuiValues()
|
||||
{
|
||||
if (!this->hasValidContexts()) { return false; }
|
||||
CSimulatedAircraft ownAircraft(sGui->getIContextOwnAircraft()->getOwnAircraft());
|
||||
const QString cs(ui->le_Callsign->text().trimmed().toUpper());
|
||||
const CCallsign cs = ui->comp_OwnAircraft->getCallsignFromGui();
|
||||
bool changedCallsign = false;
|
||||
if (!cs.isEmpty() && ownAircraft.getCallsignAsString() != cs)
|
||||
if (!cs.isEmpty() && ownAircraft.getCallsign() != cs)
|
||||
{
|
||||
const CCallsign callsign(cs);
|
||||
sGui->getIContextOwnAircraft()->updateOwnCallsign(callsign);
|
||||
ownAircraft.setCallsign(callsign); // also update
|
||||
sGui->getIContextOwnAircraft()->updateOwnCallsign(cs);
|
||||
ownAircraft.setCallsign(cs); // also update
|
||||
changedCallsign = true;
|
||||
}
|
||||
CUser pilot = ownAircraft.getPilot();
|
||||
@@ -833,7 +406,7 @@ namespace BlackGui
|
||||
pilot.setRealName(uiUser.getRealName());
|
||||
pilot.setHomeBase(uiUser.getHomeBase());
|
||||
pilot.setId(uiUser.getId());
|
||||
pilot.setCallsign(CCallsign(cs));
|
||||
pilot.setCallsign(cs);
|
||||
bool changedPilot = false;
|
||||
if (ownAircraft.getPilot() != pilot)
|
||||
{
|
||||
@@ -843,48 +416,18 @@ namespace BlackGui
|
||||
return changedCallsign || changedPilot;
|
||||
}
|
||||
|
||||
bool CLoginAdvComponent::updateOwnAircaftIcaoValuesFromGuiValues()
|
||||
{
|
||||
if (!this->hasValidContexts()) { return false; }
|
||||
const CSimulatedAircraft ownAircraft(sGui->getIContextOwnAircraft()->getOwnAircraft());
|
||||
const CGuiAircraftValues aircraftValues = this->getAircraftValuesFromGui();
|
||||
|
||||
CAircraftIcaoCode aircraftCode(ownAircraft.getAircraftIcaoCode());
|
||||
CAirlineIcaoCode airlineCode(ownAircraft.getAirlineIcaoCode());
|
||||
|
||||
bool changedIcaoCodes = false;
|
||||
if (aircraftValues.ownAircraftIcao.hasValidDesignator() && aircraftValues.ownAircraftIcao != aircraftCode)
|
||||
{
|
||||
aircraftCode = aircraftValues.ownAircraftIcao;
|
||||
changedIcaoCodes = true;
|
||||
}
|
||||
if (aircraftValues.ownAirlineIcao.hasValidDesignator() && aircraftValues.ownAirlineIcao != airlineCode)
|
||||
{
|
||||
airlineCode = aircraftValues.ownAirlineIcao;
|
||||
changedIcaoCodes = true;
|
||||
}
|
||||
|
||||
if (changedIcaoCodes)
|
||||
{
|
||||
sGui->getIContextOwnAircraft()->updateOwnIcaoCodes(aircraftCode, airlineCode);
|
||||
}
|
||||
|
||||
return changedIcaoCodes;
|
||||
}
|
||||
|
||||
void CLoginAdvComponent::updateGui()
|
||||
{
|
||||
if (!this->hasValidContexts()) { return; }
|
||||
if (!sGui->getIContextNetwork()) { return; }
|
||||
IContextNetwork *nwc = sGui->getIContextNetwork();
|
||||
const IContextNetwork *nwc = sGui->getIContextNetwork();
|
||||
const bool connected = nwc->isConnected();
|
||||
if (!connected) { return; }
|
||||
this->setUiLoginState(connected);
|
||||
this->setOwnModelAndIcaoValues();
|
||||
|
||||
// in any case override if connected
|
||||
ui->comp_OwnAircraft->setOwnModelAndIcaoValues();
|
||||
const CServer server = nwc->getConnectedServer();
|
||||
ui->le_LoginHomeBase->setText(server.getUser().getHomeBase().asString());
|
||||
ui->frp_CurrentServer->setServer(server);
|
||||
ui->frp_LoginMode->setLoginMode(nwc->getLoginMode());
|
||||
ui->comp_NetworkDetails->setLoginMode(nwc->getLoginMode());
|
||||
const CSimulatedAircraft ownAircraft = sGui->getIContextOwnAircraft()->getOwnAircraft();
|
||||
this->setGuiLoginAsValues(ownAircraft);
|
||||
}
|
||||
|
||||
@@ -19,8 +19,6 @@
|
||||
#include "blackmisc/simulation/data/lastmodel.h"
|
||||
#include "blackmisc/simulation/simulatedaircraft.h"
|
||||
#include "blackmisc/aviation/callsign.h"
|
||||
#include "blackmisc/network/data/lastserver.h"
|
||||
#include "blackmisc/network/entityflags.h"
|
||||
#include "blackmisc/network/server.h"
|
||||
#include "blackmisc/network/user.h"
|
||||
#include "blackmisc/digestsignal.h"
|
||||
@@ -57,14 +55,6 @@ namespace BlackGui
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
//! The tabs
|
||||
enum Tab
|
||||
{
|
||||
LoginVATSIM,
|
||||
LoginOthers,
|
||||
LoginFSD
|
||||
};
|
||||
|
||||
//! Log categories
|
||||
static const BlackMisc::CLogCategoryList &getLogCategories();
|
||||
|
||||
@@ -80,9 +70,6 @@ namespace BlackGui
|
||||
//! Main info area changed
|
||||
void mainInfoAreaChanged(const QWidget *currentWidget);
|
||||
|
||||
//! Set a logoff time
|
||||
void setLogoffCountdown(int timeoutSeconds = -1);
|
||||
|
||||
//! Login requested
|
||||
void toggleNetworkConnection();
|
||||
|
||||
@@ -93,54 +80,33 @@ namespace BlackGui
|
||||
//! Cancelled
|
||||
void loginOrLogoffCancelled();
|
||||
|
||||
//! Request network settings
|
||||
void requestNetworkSettings();
|
||||
|
||||
//! Request to be shown
|
||||
void requestLoginPage();
|
||||
|
||||
//! Request server settigs
|
||||
void requestNetworkSettings();
|
||||
|
||||
//! Relevant login data changed (digest version)
|
||||
void loginDataChangedDigest();
|
||||
|
||||
private:
|
||||
//! GUI aircraft values, formatted
|
||||
struct CGuiAircraftValues
|
||||
{
|
||||
BlackMisc::Aviation::CCallsign ownCallsign;
|
||||
BlackMisc::Aviation::CAircraftIcaoCode ownAircraftIcao;
|
||||
BlackMisc::Aviation::CAirlineIcaoCode ownAirlineIcao;
|
||||
QString ownAircraftCombinedType;
|
||||
QString ownAircraftSimulatorModel;
|
||||
};
|
||||
|
||||
// -------------- values from GUI -----------------
|
||||
|
||||
//! Values from GUI
|
||||
CGuiAircraftValues getAircraftValuesFromGui() const;
|
||||
|
||||
//! User from VATSIM data
|
||||
BlackMisc::Network::CUser getUserFromPilotGuiValues() const;
|
||||
|
||||
//! Callsign from GUI
|
||||
BlackMisc::Aviation::CCallsign getCallsignFromGui() const;
|
||||
// BlackMisc::Aviation::CCallsign getCallsignFromGui() const;
|
||||
|
||||
//! Update own callsign (own aircraft from what is set in the GUI)
|
||||
//! \return changed?
|
||||
bool updateOwnAircraftCallsignAndPilotFromGuiValues();
|
||||
|
||||
//! Update own ICAO values (own aircraft from what is set in the GUI)
|
||||
//! \return changed?
|
||||
bool updateOwnAircaftIcaoValuesFromGuiValues();
|
||||
|
||||
// -------------- values to GUI -----------------
|
||||
|
||||
//! Update GUI values
|
||||
void updateGui();
|
||||
|
||||
//! Set ICAO values
|
||||
//! \return changed values?
|
||||
bool setGuiIcaoValues(const BlackMisc::Simulation::CAircraftModel &model, bool onlyIfEmpty);
|
||||
|
||||
//! Set the "login as" values
|
||||
void setGuiLoginAsValues(const BlackMisc::Simulation::CSimulatedAircraft &ownAircraft);
|
||||
|
||||
@@ -155,102 +121,36 @@ namespace BlackGui
|
||||
//! Current server based on selected tab
|
||||
BlackMisc::Network::CServer getCurrentServer() const;
|
||||
|
||||
//! Get a prefill model
|
||||
BlackMisc::Simulation::CAircraftModel getPrefillModel() const;
|
||||
|
||||
//! Login cancelled
|
||||
void loginCancelled();
|
||||
|
||||
//! VATSIM data file was loaded
|
||||
void onWebServiceDataRead(BlackMisc::Network::CEntityFlags::Entity entity, BlackMisc::Network::CEntityFlags::ReadState state, int number);
|
||||
|
||||
//! Validate aircaft
|
||||
bool validateAircraftValues();
|
||||
|
||||
//! Aircraft ICAO code has been changed
|
||||
void changedAircraftIcao(const BlackMisc::Aviation::CAircraftIcaoCode &icao);
|
||||
|
||||
//! Airline ICAO code has been changed
|
||||
void changedAirlineIcao(const BlackMisc::Aviation::CAirlineIcaoCode &icao);
|
||||
|
||||
//! Settings have been changed
|
||||
void reloadOtherServersSetup();
|
||||
|
||||
//! Logoff countdown
|
||||
void logoffCountdown();
|
||||
|
||||
//! Auto-logoff detection
|
||||
void autoLogoffDetection();
|
||||
|
||||
//! Lookup own model
|
||||
void lookupOwnAircraftModel();
|
||||
|
||||
//! Simulator model has been changed
|
||||
void onSimulatorModelChanged(const BlackMisc::Simulation::CAircraftModel &model);
|
||||
|
||||
//! Launch mapping wizard
|
||||
void mappingWizard();
|
||||
|
||||
//! Pause/Continue timeout
|
||||
void toggleTimeout();
|
||||
|
||||
//! Show / hide elements for UI depending on login state
|
||||
void setUiLoginState(bool connected);
|
||||
|
||||
//! Own model and ICAO data for GUI and own aircraft
|
||||
void setOwnModelAndIcaoValues(const BlackMisc::Simulation::CAircraftModel &ownModel = {});
|
||||
|
||||
//! Set OK button string
|
||||
void setOkButtonString(bool connected);
|
||||
|
||||
//! Logoff countdown
|
||||
void startLogoffTimerCountdown();
|
||||
|
||||
//! Highlight model field according to model data
|
||||
void highlightModelField(const BlackMisc::Simulation::CAircraftModel &model = {});
|
||||
|
||||
//! Is the VATSIM network tab selected?
|
||||
bool isVatsimNetworkTabSelected() const;
|
||||
|
||||
//! Load from settings
|
||||
void loadRememberedUserData();
|
||||
|
||||
//! Copy credentials to pilot
|
||||
void overrideCredentialsToPilot();
|
||||
|
||||
//! Server changed
|
||||
void onSelectedServerChanged(const BlackMisc::Network::CServer &server);
|
||||
void overrideCredentialsToPilot(const BlackMisc::Network::CUser &user);
|
||||
|
||||
//! Simulator status changed
|
||||
void onSimulatorStatusChanged(int status);
|
||||
|
||||
//! Tab widget (server) changed
|
||||
void onServerTabWidgetChanged(int index);
|
||||
|
||||
//! Has contexts?
|
||||
bool hasValidContexts() const;
|
||||
|
||||
//! Set the server buttons visible
|
||||
void setServerButtonsVisible(bool visible);
|
||||
|
||||
//! Tab index changed
|
||||
void onDetailsTabChanged(int index);
|
||||
|
||||
static constexpr int OverlayMessageMs = 5000;
|
||||
static constexpr int LogoffIntervalSeconds = 20; //!< time before logoff
|
||||
|
||||
QScopedPointer<Ui::CLoginAdvComponent> ui;
|
||||
QScopedPointer<CDbQuickMappingWizard> m_mappingWizard; //!< mapping wizard
|
||||
BlackMisc::CDigestSignal m_changedLoginDataDigestSignal { this, &CLoginAdvComponent::loginDataChangedDigest, 1500, 10 };
|
||||
bool m_autoPopupWizard = false; //!< automatically popup wizard if mapping is needed
|
||||
bool m_visible = false; //!< is this component selected?
|
||||
bool m_updatePilotOnServerChanges = true;
|
||||
const QIcon m_iconPlay {":/famfamfam/icons/famfamfam/icons/silk/control_play_blue.png"};
|
||||
const QIcon m_iconPause {":/famfamfam/icons/famfamfam/icons/silk/control_pause_blue.png"};
|
||||
int m_logoffIntervalSeconds = LogoffIntervalSeconds;
|
||||
QTimer m_logoffCountdownTimer; //!< timer for logoff countdown
|
||||
|
||||
BlackMisc::CData<BlackMisc::Simulation::Data::TLastModel> m_lastAircraftModel { this }; //!< recently used aircraft model
|
||||
BlackCore::Data::CNetworkSetup m_networkSetup; //!< servers last used
|
||||
};
|
||||
} // namespace
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user