Switch current tab when opening a single-instance tab (#5651)

This commit is contained in:
RickyRister 2025-03-02 06:30:55 -08:00 committed by GitHub
parent 3d0f4868df
commit 87c5d07807
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 127 additions and 56 deletions

View file

@ -285,9 +285,15 @@ void TabSupervisor::initStartupTabs()
{ {
addDeckEditorTab(nullptr); addDeckEditorTab(nullptr);
checkAndTrigger(aTabVisualDeckStorage, SettingsCache::instance().getTabVisualDeckStorageOpen()); if (SettingsCache::instance().getTabVisualDeckStorageOpen()) {
checkAndTrigger(aTabDeckStorage, SettingsCache::instance().getTabDeckStorageOpen()); openTabVisualDeckStorage();
checkAndTrigger(aTabReplays, SettingsCache::instance().getTabReplaysOpen()); }
if (SettingsCache::instance().getTabDeckStorageOpen()) {
openTabDeckStorage();
}
if (SettingsCache::instance().getTabReplaysOpen()) {
openTabReplays();
}
} }
/** /**
@ -360,8 +366,12 @@ void TabSupervisor::start(const ServerInfo_User &_userInfo)
tabsMenu->addAction(aTabServer); tabsMenu->addAction(aTabServer);
tabsMenu->addAction(aTabAccount); tabsMenu->addAction(aTabAccount);
checkAndTrigger(aTabServer, SettingsCache::instance().getTabServerOpen()); if (SettingsCache::instance().getTabServerOpen()) {
checkAndTrigger(aTabAccount, SettingsCache::instance().getTabAccountOpen()); openTabServer();
}
if (SettingsCache::instance().getTabAccountOpen()) {
openTabAccount();
}
updatePingTime(0, -1); updatePingTime(0, -1);
@ -370,8 +380,12 @@ void TabSupervisor::start(const ServerInfo_User &_userInfo)
tabsMenu->addAction(aTabAdmin); tabsMenu->addAction(aTabAdmin);
tabsMenu->addAction(aTabLog); tabsMenu->addAction(aTabLog);
checkAndTrigger(aTabAdmin, SettingsCache::instance().getTabAdminOpen()); if (SettingsCache::instance().getTabAdminOpen()) {
checkAndTrigger(aTabLog, SettingsCache::instance().getTabLogOpen()); openTabAdmin();
}
if (SettingsCache::instance().getTabLogOpen()) {
openTabLog();
}
} }
retranslateUi(); retranslateUi();
@ -453,114 +467,163 @@ void TabSupervisor::actTabVisualDeckStorage(bool checked)
{ {
SettingsCache::instance().setTabVisualDeckStorageOpen(checked); SettingsCache::instance().setTabVisualDeckStorageOpen(checked);
if (checked && !tabVisualDeckStorage) { if (checked && !tabVisualDeckStorage) {
tabVisualDeckStorage = new TabDeckStorageVisual(this); openTabVisualDeckStorage();
myAddTab(tabVisualDeckStorage, aTabVisualDeckStorage); setCurrentWidget(tabVisualDeckStorage);
connect(tabVisualDeckStorage, &Tab::closed, this, [this] {
tabVisualDeckStorage = nullptr;
aTabVisualDeckStorage->setChecked(false);
});
} else if (!checked && tabVisualDeckStorage) { } else if (!checked && tabVisualDeckStorage) {
tabVisualDeckStorage->closeRequest(); tabVisualDeckStorage->closeRequest();
} }
} }
void TabSupervisor::openTabVisualDeckStorage()
{
tabVisualDeckStorage = new TabDeckStorageVisual(this);
myAddTab(tabVisualDeckStorage, aTabVisualDeckStorage);
connect(tabVisualDeckStorage, &Tab::closed, this, [this] {
tabVisualDeckStorage = nullptr;
aTabVisualDeckStorage->setChecked(false);
});
aTabVisualDeckStorage->setChecked(true);
}
void TabSupervisor::actTabServer(bool checked) void TabSupervisor::actTabServer(bool checked)
{ {
SettingsCache::instance().setTabServerOpen(checked); SettingsCache::instance().setTabServerOpen(checked);
if (checked && !tabServer) { if (checked && !tabServer) {
tabServer = new TabServer(this, client); openTabServer();
connect(tabServer, &TabServer::roomJoined, this, &TabSupervisor::addRoomTab); setCurrentWidget(tabServer);
myAddTab(tabServer, aTabServer);
connect(tabServer, &Tab::closed, this, [this] {
tabServer = nullptr;
aTabServer->setChecked(false);
});
} else if (!checked && tabServer) { } else if (!checked && tabServer) {
tabServer->closeRequest(); tabServer->closeRequest();
} }
} }
void TabSupervisor::openTabServer()
{
tabServer = new TabServer(this, client);
connect(tabServer, &TabServer::roomJoined, this, &TabSupervisor::addRoomTab);
myAddTab(tabServer, aTabServer);
connect(tabServer, &Tab::closed, this, [this] {
tabServer = nullptr;
aTabServer->setChecked(false);
});
aTabServer->setChecked(true);
}
void TabSupervisor::actTabAccount(bool checked) void TabSupervisor::actTabAccount(bool checked)
{ {
SettingsCache::instance().setTabAccountOpen(checked); SettingsCache::instance().setTabAccountOpen(checked);
if (checked && !tabAccount) { if (checked && !tabAccount) {
tabAccount = new TabAccount(this, client, *userInfo); openTabAccount();
connect(tabAccount, &TabAccount::openMessageDialog, this, &TabSupervisor::addMessageTab); setCurrentWidget(tabAccount);
connect(tabAccount, &TabAccount::userJoined, this, &TabSupervisor::processUserJoined);
connect(tabAccount, &TabAccount::userLeft, this, &TabSupervisor::processUserLeft);
myAddTab(tabAccount, aTabAccount);
connect(tabAccount, &Tab::closed, this, [this] {
tabAccount = nullptr;
aTabAccount->setChecked(false);
});
} else if (!checked && tabAccount) { } else if (!checked && tabAccount) {
tabAccount->closeRequest(); tabAccount->closeRequest();
} }
} }
void TabSupervisor::openTabAccount()
{
tabAccount = new TabAccount(this, client, *userInfo);
connect(tabAccount, &TabAccount::openMessageDialog, this, &TabSupervisor::addMessageTab);
connect(tabAccount, &TabAccount::userJoined, this, &TabSupervisor::processUserJoined);
connect(tabAccount, &TabAccount::userLeft, this, &TabSupervisor::processUserLeft);
myAddTab(tabAccount, aTabAccount);
connect(tabAccount, &Tab::closed, this, [this] {
tabAccount = nullptr;
aTabAccount->setChecked(false);
});
aTabAccount->setChecked(true);
}
void TabSupervisor::actTabDeckStorage(bool checked) void TabSupervisor::actTabDeckStorage(bool checked)
{ {
SettingsCache::instance().setTabDeckStorageOpen(checked); SettingsCache::instance().setTabDeckStorageOpen(checked);
if (checked && !tabDeckStorage) { if (checked && !tabDeckStorage) {
tabDeckStorage = new TabDeckStorage(this, client, userInfo); openTabDeckStorage();
connect(tabDeckStorage, &TabDeckStorage::openDeckEditor, this, &TabSupervisor::addDeckEditorTab); setCurrentWidget(tabDeckStorage);
myAddTab(tabDeckStorage, aTabDeckStorage);
connect(tabDeckStorage, &Tab::closed, this, [this] {
tabDeckStorage = nullptr;
aTabDeckStorage->setChecked(false);
});
} else if (!checked && tabDeckStorage) { } else if (!checked && tabDeckStorage) {
tabDeckStorage->closeRequest(); tabDeckStorage->closeRequest();
} }
} }
void TabSupervisor::openTabDeckStorage()
{
tabDeckStorage = new TabDeckStorage(this, client, userInfo);
connect(tabDeckStorage, &TabDeckStorage::openDeckEditor, this, &TabSupervisor::addDeckEditorTab);
myAddTab(tabDeckStorage, aTabDeckStorage);
connect(tabDeckStorage, &Tab::closed, this, [this] {
tabDeckStorage = nullptr;
aTabDeckStorage->setChecked(false);
});
aTabDeckStorage->setChecked(true);
}
void TabSupervisor::actTabReplays(bool checked) void TabSupervisor::actTabReplays(bool checked)
{ {
SettingsCache::instance().setTabReplaysOpen(checked); SettingsCache::instance().setTabReplaysOpen(checked);
if (checked && !tabReplays) { if (checked && !tabReplays) {
tabReplays = new TabReplays(this, client, userInfo); openTabReplays();
connect(tabReplays, &TabReplays::openReplay, this, &TabSupervisor::openReplay); setCurrentWidget(tabReplays);
myAddTab(tabReplays, aTabReplays);
connect(tabReplays, &Tab::closed, this, [this] {
tabReplays = nullptr;
aTabReplays->setChecked(false);
});
} else if (!checked && tabReplays) { } else if (!checked && tabReplays) {
tabReplays->closeRequest(); tabReplays->closeRequest();
} }
} }
void TabSupervisor::openTabReplays()
{
tabReplays = new TabReplays(this, client, userInfo);
connect(tabReplays, &TabReplays::openReplay, this, &TabSupervisor::openReplay);
myAddTab(tabReplays, aTabReplays);
connect(tabReplays, &Tab::closed, this, [this] {
tabReplays = nullptr;
aTabReplays->setChecked(false);
});
aTabReplays->setChecked(true);
}
void TabSupervisor::actTabAdmin(bool checked) void TabSupervisor::actTabAdmin(bool checked)
{ {
SettingsCache::instance().setTabAdminOpen(checked); SettingsCache::instance().setTabAdminOpen(checked);
if (checked && !tabAdmin) { if (checked && !tabAdmin) {
tabAdmin = new TabAdmin(this, client, (userInfo->user_level() & ServerInfo_User::IsAdmin)); openTabAdmin();
connect(tabAdmin, &TabAdmin::adminLockChanged, this, &TabSupervisor::adminLockChanged); setCurrentWidget(tabAdmin);
myAddTab(tabAdmin, aTabAdmin);
connect(tabAdmin, &Tab::closed, this, [this] {
tabAdmin = nullptr;
aTabAdmin->setChecked(false);
});
} else if (!checked && tabAdmin) { } else if (!checked && tabAdmin) {
tabAdmin->closeRequest(); tabAdmin->closeRequest();
} }
} }
void TabSupervisor::openTabAdmin()
{
tabAdmin = new TabAdmin(this, client, (userInfo->user_level() & ServerInfo_User::IsAdmin));
connect(tabAdmin, &TabAdmin::adminLockChanged, this, &TabSupervisor::adminLockChanged);
myAddTab(tabAdmin, aTabAdmin);
connect(tabAdmin, &Tab::closed, this, [this] {
tabAdmin = nullptr;
aTabAdmin->setChecked(false);
});
aTabAdmin->setChecked(true);
}
void TabSupervisor::actTabLog(bool checked) void TabSupervisor::actTabLog(bool checked)
{ {
SettingsCache::instance().setTabLogOpen(checked); SettingsCache::instance().setTabLogOpen(checked);
if (checked && !tabLog) { if (checked && !tabLog) {
tabLog = new TabLog(this, client); openTabLog();
myAddTab(tabLog, aTabLog); setCurrentWidget(tabLog);
connect(tabLog, &Tab::closed, this, [this] {
tabLog = nullptr;
aTabAdmin->setChecked(false);
});
} else if (!checked && tabLog) { } else if (!checked && tabLog) {
tabLog->closeRequest(); tabLog->closeRequest();
} }
} }
void TabSupervisor::openTabLog()
{
tabLog = new TabLog(this, client);
myAddTab(tabLog, aTabLog);
connect(tabLog, &Tab::closed, this, [this] {
tabLog = nullptr;
aTabAdmin->setChecked(false);
});
aTabAdmin->setChecked(true);
}
void TabSupervisor::updatePingTime(int value, int max) void TabSupervisor::updatePingTime(int value, int max)
{ {
if (!tabServer) if (!tabServer)

View file

@ -163,6 +163,14 @@ private slots:
void actTabAdmin(bool checked); void actTabAdmin(bool checked);
void actTabLog(bool checked); void actTabLog(bool checked);
void openTabVisualDeckStorage();
void openTabServer();
void openTabAccount();
void openTabDeckStorage();
void openTabReplays();
void openTabAdmin();
void openTabLog();
void updateCurrent(int index); void updateCurrent(int index);
void updatePingTime(int value, int max); void updatePingTime(int value, int max);
void gameJoined(const Event_GameJoined &event); void gameJoined(const Event_GameJoined &event);