X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fuisupport%2Ftoolbaractionprovider.cpp;h=c65a62dd26931b4e730f95ab9263e57c50cf0b4b;hp=0ae1078d9f91a57b4bd00822ea4341416f579e75;hb=45645a28bdc5b6c1052b3e4cebf8cc80832d205a;hpb=b7447afe8e836376776dac26704e227a678d2913 diff --git a/src/uisupport/toolbaractionprovider.cpp b/src/uisupport/toolbaractionprovider.cpp index 0ae1078d..c65a62dd 100644 --- a/src/uisupport/toolbaractionprovider.cpp +++ b/src/uisupport/toolbaractionprovider.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2018 by the Quassel Project * + * Copyright (C) 2005-2019 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -25,7 +25,7 @@ #include "icon.h" -ToolBarActionProvider::ToolBarActionProvider(QObject *parent) +ToolBarActionProvider::ToolBarActionProvider(QObject* parent) : NetworkModelController(parent) { registerAction(NetworkConnectAllWithDropdown, icon::get("network-connect"), tr("Connect"))->setToolTip(tr("Connect to IRC")); @@ -36,8 +36,8 @@ ToolBarActionProvider::ToolBarActionProvider(QObject *parent) registerAction(BufferPart, icon::get("irc-close-channel"), tr("Part"))->setToolTip(tr("Leave currently selected channel")); registerAction(JoinChannel, icon::get("irc-join-channel"), tr("Join"))->setToolTip(tr("Join a channel")); - registerAction(NickQuery, icon::get("mail-message-new"), tr("Query"))->setToolTip(tr("Start a private conversation")); // fix icon - registerAction(NickWhois, icon::get("im-user"), tr("Whois"))->setToolTip(tr("Request user information")); // fix icon + registerAction(NickQuery, icon::get("mail-message-new"), tr("Query"))->setToolTip(tr("Start a private conversation")); // fix icon + registerAction(NickWhois, icon::get("im-user"), tr("Whois"))->setToolTip(tr("Request user information")); // fix icon registerAction(NickOp, icon::get("irc-operator"), tr("Op"))->setToolTip(tr("Give operator privileges to user")); registerAction(NickDeop, icon::get("irc-remove-operator"), tr("Deop"))->setToolTip(tr("Take operator privileges from user")); @@ -61,18 +61,12 @@ ToolBarActionProvider::ToolBarActionProvider(QObject *parent) action(NetworkDisconnectAllWithDropdown)->setMenu(_networksDisconnectMenu); action(NetworkDisconnectAllWithDropdown)->setEnabled(false); - connect(Client::instance(), SIGNAL(networkCreated(NetworkId)), SLOT(networkCreated(NetworkId))); - connect(Client::instance(), SIGNAL(networkRemoved(NetworkId)), SLOT(networkRemoved(NetworkId))); + connect(Client::instance(), &Client::networkCreated, this, &ToolBarActionProvider::networkCreated); + connect(Client::instance(), &Client::networkRemoved, this, &ToolBarActionProvider::networkRemoved); updateStates(); } - -ToolBarActionProvider::~ToolBarActionProvider() -{ -} - - void ToolBarActionProvider::disconnectedFromCore() { _currentBuffer = QModelIndex(); @@ -80,16 +74,14 @@ void ToolBarActionProvider::disconnectedFromCore() NetworkModelController::disconnectedFromCore(); } - void ToolBarActionProvider::updateStates() { - action(BufferPart)->setEnabled(_currentBuffer.isValid() - && _currentBuffer.data(NetworkModel::BufferTypeRole) == BufferInfo::ChannelBuffer - && _currentBuffer.data(NetworkModel::ItemActiveRole).toBool()); + action(BufferPart) + ->setEnabled(_currentBuffer.isValid() && _currentBuffer.data(NetworkModel::BufferTypeRole) == BufferInfo::ChannelBuffer + && _currentBuffer.data(NetworkModel::ItemActiveRole).toBool()); } - -void ToolBarActionProvider::addActions(QToolBar *bar, ToolBarType type) +void ToolBarActionProvider::addActions(QToolBar* bar, ToolBarType type) { switch (type) { case MainToolBar: @@ -115,91 +107,82 @@ void ToolBarActionProvider::addActions(QToolBar *bar, ToolBarType type) } } - -void ToolBarActionProvider::currentBufferChanged(const QModelIndex &index) +void ToolBarActionProvider::onCurrentBufferChanged(const QModelIndex& index) { _currentBuffer = index; updateStates(); } - -void ToolBarActionProvider::nickSelectionChanged(const QModelIndexList &indexList) +void ToolBarActionProvider::onNickSelectionChanged(const QModelIndexList& indexList) { _selectedNicks = indexList; updateStates(); } - // override those to set indexes right -void ToolBarActionProvider::handleNetworkAction(ActionType type, QAction *action) +void ToolBarActionProvider::handleNetworkAction(ActionType type, QAction* action) { setIndexList(_currentBuffer); NetworkModelController::handleNetworkAction(type, action); } - -void ToolBarActionProvider::handleBufferAction(ActionType type, QAction *action) +void ToolBarActionProvider::handleBufferAction(ActionType type, QAction* action) { setIndexList(_currentBuffer); NetworkModelController::handleBufferAction(type, action); } - -void ToolBarActionProvider::handleNickAction(ActionType type, QAction *action) +void ToolBarActionProvider::handleNickAction(ActionType type, QAction* action) { setIndexList(_selectedNicks); NetworkModelController::handleNickAction(type, action); } - -void ToolBarActionProvider::handleGeneralAction(ActionType type, QAction *action) +void ToolBarActionProvider::handleGeneralAction(ActionType type, QAction* action) { setIndexList(_currentBuffer); NetworkModelController::handleGeneralAction(type, action); } - void ToolBarActionProvider::networkCreated(NetworkId id) { - const Network *net = Client::network(id); - Action *act = new Action(net->networkName(), this); + const Network* net = Client::network(id); + Action* act = new Action(net->networkName(), this); _networkActions[id] = act; act->setObjectName(QString("NetworkAction-%1").arg(id.toInt())); act->setData(QVariant::fromValue(id)); - connect(net, SIGNAL(updatedRemotely()), SLOT(networkUpdated())); - connect(act, SIGNAL(triggered()), SLOT(connectOrDisconnectNet())); + connect(net, &Network::updatedRemotely, this, [this]() { networkUpdated(); }); + connect(act, &QAction::triggered, this, &ToolBarActionProvider::connectOrDisconnectNet); networkUpdated(net); } - void ToolBarActionProvider::networkRemoved(NetworkId id) { - Action *act = _networkActions.take(id); + Action* act = _networkActions.take(id); if (act) act->deleteLater(); } - -void ToolBarActionProvider::networkUpdated(const Network *net) +void ToolBarActionProvider::networkUpdated(const Network* net) { if (!net) - net = qobject_cast(sender()); + net = qobject_cast(sender()); if (!net) return; - Action *act = _networkActions.value(net->networkId()); + Action* act = _networkActions.value(net->networkId()); if (!act) return; _networksConnectMenu->removeAction(act); _networksDisconnectMenu->removeAction(act); - QMenu *newMenu = net->connectionState() != Network::Disconnected ? _networksDisconnectMenu : _networksConnectMenu; + QMenu* newMenu = net->connectionState() != Network::Disconnected ? _networksDisconnectMenu : _networksConnectMenu; act->setText(net->networkName()); const int lastidx = newMenu->actions().count() - 2; - QAction *beforeAction = newMenu->actions().at(lastidx); + QAction* beforeAction = newMenu->actions().at(lastidx); for (int i = 0; i < newMenu->actions().count() - 2; i++) { - QAction *action = newMenu->actions().at(i); + QAction* action = newMenu->actions().at(i); if (net->networkName().localeAwareCompare(action->text()) < 0) { beforeAction = action; break; @@ -212,19 +195,19 @@ void ToolBarActionProvider::networkUpdated(const Network *net) action(JoinChannel)->setEnabled(_networksDisconnectMenu->actions().count() > 2); } - void ToolBarActionProvider::connectOrDisconnectNet() { - QAction *act = qobject_cast(sender()); + auto* act = qobject_cast(sender()); if (!act) return; - const Network *net = Client::network(act->data().value()); + const Network* net = Client::network(act->data().value()); if (!net) return; - if (net->connectionState() == Network::Disconnected) net->requestConnect(); - else net->requestDisconnect(); + if (net->connectionState() == Network::Disconnected) + net->requestConnect(); + else + net->requestDisconnect(); } - -//void ToolBarActionProvider:: +// void ToolBarActionProvider::