X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fuisupport%2Fnetworkmodelcontroller.cpp;h=be1db922a9fd58a04d17fa5b975c6dd9045ba9cb;hp=cb882f81b1dd3df5c0ce8f5f02d1c19deafc642f;hb=86bd6b1ffb870e65af6d830a2ea16471c348ed5a;hpb=f19fea582ace1d8f3dfe29c1096c48758079e56e diff --git a/src/uisupport/networkmodelcontroller.cpp b/src/uisupport/networkmodelcontroller.cpp index cb882f81..be1db922 100644 --- a/src/uisupport/networkmodelcontroller.cpp +++ b/src/uisupport/networkmodelcontroller.cpp @@ -267,11 +267,11 @@ void NetworkModelController::handleHideAction(ActionType type, QAction *action) int filter = 0; if(NetworkModelController::action(HideJoin)->isChecked()) - filter |= Message::Join; + filter |= Message::Join | Message::NetsplitJoin; if(NetworkModelController::action(HidePart)->isChecked()) filter |= Message::Part; if(NetworkModelController::action(HideQuit)->isChecked()) - filter |= Message::Quit; + filter |= Message::Quit | Message::NetsplitQuit; if(NetworkModelController::action(HideNick)->isChecked()) filter |= Message::Nick; if(NetworkModelController::action(HideMode)->isChecked()) @@ -366,9 +366,6 @@ void NetworkModelController::handleNickAction(ActionType type, QAction *action) if(!bufferInfo.isValid()) continue; - // the validity of that cast is checked on contextmenu creation, take care - IrcUser *ircUser = qobject_cast(index.data(NetworkModel::IrcUserRole).value()); - switch(type) { case NickWhois: Client::userInput(bufferInfo, QString("/WHOIS %1 %1").arg(nick)); @@ -408,42 +405,55 @@ void NetworkModelController::handleNickAction(ActionType type, QAction *action) Client::userInput(bufferInfo, QString("/KICK %1").arg(nick)); break; case NickSwitchTo: - Client::bufferModel()->switchToBuffer(findQueryBuffer(networkId, nick)); - break; case NickQuery: - Client::userInput(bufferInfo, QString("/QUERY %1").arg(nick)); + Client::bufferModel()->switchToOrStartQuery(networkId, nick); break; case NickIgnoreUser: + { + IrcUser *ircUser = qobject_cast(index.data(NetworkModel::IrcUserRole).value()); + if(!ircUser) + break; Client::ignoreListManager()->requestAddIgnoreListItem(IgnoreListManager::SenderIgnore, - action->text(), + action->property("ignoreRule").toString(), false, IgnoreListManager::SoftStrictness, IgnoreListManager::NetworkScope, ircUser->network()->networkName(), true); break; + } case NickIgnoreHost: + { + IrcUser *ircUser = qobject_cast(index.data(NetworkModel::IrcUserRole).value()); + if(!ircUser) + break; Client::ignoreListManager()->requestAddIgnoreListItem(IgnoreListManager::SenderIgnore, - action->text(), + action->property("ignoreRule").toString(), false, IgnoreListManager::SoftStrictness, IgnoreListManager::NetworkScope, ircUser->network()->networkName(), true); break; + } case NickIgnoreDomain: + { + IrcUser *ircUser = qobject_cast(index.data(NetworkModel::IrcUserRole).value()); + if(!ircUser) + break; Client::ignoreListManager()->requestAddIgnoreListItem(IgnoreListManager::SenderIgnore, - action->text(), + action->property("ignoreRule").toString(), false, IgnoreListManager::SoftStrictness, IgnoreListManager::NetworkScope, ircUser->network()->networkName(), true); break; + } case NickIgnoreCustom: // forward that to mainwin since we can access the settingspage only from there - emit showIgnoreList(ircUser->hostmask()); + emit showIgnoreList(action->property("ignoreRule").toString()); break; case NickIgnoreToggleEnabled0: case NickIgnoreToggleEnabled1: case NickIgnoreToggleEnabled2: case NickIgnoreToggleEnabled3: case NickIgnoreToggleEnabled4: - Client::ignoreListManager()->requestToggleIgnoreRule(action->text()); + Client::ignoreListManager()->requestToggleIgnoreRule(action->property("ignoreRule").toString()); break; default: qWarning() << "Unhandled nick action";