From afa7cdd59fe9a80479812eaad73a1eeea58bd5de Mon Sep 17 00:00:00 2001 From: Andrei Karas Date: Wed, 14 Jan 2015 17:50:47 +0300 Subject: By requesting open #trade channel, really open trade tab. --- src/gui/windows/chatwindow.cpp | 29 ++++++++++++++++++++++++++--- src/gui/windows/chatwindow.h | 7 +++++-- 2 files changed, 31 insertions(+), 5 deletions(-) (limited to 'src/gui/windows') diff --git a/src/gui/windows/chatwindow.cpp b/src/gui/windows/chatwindow.cpp index 4799f65f4..1f3b165c5 100644 --- a/src/gui/windows/chatwindow.cpp +++ b/src/gui/windows/chatwindow.cpp @@ -1194,12 +1194,35 @@ WhisperTab *ChatWindow::getWhisperTab(const std::string &nick) const return ret; } -ChannelTab *ChatWindow::addChannelTab(const std::string &name, - const bool switchTo) +ChatTab *ChatWindow::addSpecialChannelTab(const std::string &name, + const bool switchTo) +{ + ChatTab *ret = nullptr; + if (name == TRADE_CHANNEL) + { + if (!tradeChatTab) + { + tradeChatTab = new TradeTab(chatWindow); + tradeChatTab->setAllowHighlight(false); + } + ret = tradeChatTab; + } + if (switchTo) + mChatTabs->setSelectedTab(ret); + + return ret; +} + +ChatTab *ChatWindow::addChannelTab(const std::string &name, + const bool switchTo) { std::string tempName = name; toLower(tempName); + ChatTab *const tab = addSpecialChannelTab(name, switchTo); + if (tab) + return tab; + const ChannelMap::const_iterator i = mChannels.find(tempName); ChannelTab *ret = nullptr; @@ -1656,7 +1679,7 @@ void ChatWindow::channelChatLog(const std::string &channel, std::string tempChannel = channel; toLower(tempChannel); - ChannelTab *tab = nullptr; + ChatTab *tab = nullptr; const ChannelMap::const_iterator i = mChannels.find(tempChannel); if (i != mChannels.end()) diff --git a/src/gui/windows/chatwindow.h b/src/gui/windows/chatwindow.h index d0af5a74c..1da6c6016 100644 --- a/src/gui/windows/chatwindow.h +++ b/src/gui/windows/chatwindow.h @@ -202,8 +202,11 @@ class ChatWindow final : public Window, WhisperTab *getWhisperTab(const std::string &nick) const A_WARN_UNUSED; - ChannelTab *addChannelTab(const std::string &name, - const bool switchTo = false); + ChatTab *addChannelTab(const std::string &name, + const bool switchTo = false); + + ChatTab *addSpecialChannelTab(const std::string &name, + const bool switchTo = false); ChatTab *addChatTab(const std::string &name, const bool switchTo, -- cgit v1.2.3-60-g2f50