From: Bas Pape Date: Sat, 6 Aug 2011 22:50:33 +0000 (+0200) Subject: Unhide buffer when joining or querying and it was temporarily hidden. fixes #866 X-Git-Tag: 0.8-beta1~61 X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=commitdiff_plain;h=ed178d5c517ad031444fc64f1f85f9ea7a926e15;ds=sidebyside Unhide buffer when joining or querying and it was temporarily hidden. fixes #866 --- diff --git a/src/client/clientuserinputhandler.cpp b/src/client/clientuserinputhandler.cpp index 3e7ece3c..aa614f2a 100644 --- a/src/client/clientuserinputhandler.cpp +++ b/src/client/clientuserinputhandler.cpp @@ -29,6 +29,8 @@ #include "network.h" #include "types.h" #include "bufferinfo.h" +#include "clientbufferviewconfig.h" +#include "clientbufferviewmanager.h" #include "messagemodel.h" #include @@ -108,5 +110,18 @@ void ClientUserInputHandler::switchBuffer(const NetworkId &networkId, const QStr } else { Client::bufferModel()->switchToBuffer(newBufId); + // unhide the buffer + ClientBufferViewManager *clientBufferViewManager = Client::bufferViewManager(); + QList bufferViewConfigList = clientBufferViewManager->clientBufferViewConfigs(); + foreach (ClientBufferViewConfig *bufferViewConfig, bufferViewConfigList) { + if (bufferViewConfig->temporarilyRemovedBuffers().contains(newBufId)) { + bufferViewConfig->addBuffer(newBufId, bufferViewConfig->bufferList().length()); + //if (bufferViewConfig->sortAlphabetically()) { + // TODO we need to trigger a sort here, but can't reach the model required + // to get a bufferviewfilter, as the bufferviewmanager only managers configs + //BufferViewFilter *filter = qobject_cast(model()); + //} + } + } } }