diff options
| author | Tobias Markmann <tm@ayena.de> | 2013-03-08 15:17:30 (GMT) | 
|---|---|---|
| committer | Tobias Markmann <tm@ayena.de> | 2013-03-27 14:12:26 (GMT) | 
| commit | 497b647fe034a3d2cdc6d75ce0ff70e3df3aaf04 (patch) | |
| tree | dc81e56199f54cf20f834c78bda7fc26ffbc38f9 /Swift/QtUI/Roster/QtRosterWidget.cpp | |
| parent | 20ead0a84fdd8c9e870e98ee6a2712bfa263d7fb (diff) | |
| download | swift-contrib-497b647fe034a3d2cdc6d75ce0ff70e3df3aaf04.zip swift-contrib-497b647fe034a3d2cdc6d75ce0ff70e3df3aaf04.tar.bz2 | |
Adding support for Blocking Command (XEP-0191) to Swift(-en).
Change-Id: I7c92518dc389474d520d4cf96f96a11459f73d26
License: This patch is BSD-licensed, see Documentation/Licenses/BSD-simplified.txt for details.
Diffstat (limited to 'Swift/QtUI/Roster/QtRosterWidget.cpp')
| -rw-r--r-- | Swift/QtUI/Roster/QtRosterWidget.cpp | 43 | 
1 files changed, 31 insertions, 12 deletions
| diff --git a/Swift/QtUI/Roster/QtRosterWidget.cpp b/Swift/QtUI/Roster/QtRosterWidget.cpp index b783ff6..6bf3989 100644 --- a/Swift/QtUI/Roster/QtRosterWidget.cpp +++ b/Swift/QtUI/Roster/QtRosterWidget.cpp @@ -4,24 +4,25 @@   * See Documentation/Licenses/GPLv3.txt for more information.   */ -#include "Roster/QtRosterWidget.h" +#include <Swift/QtUI/Roster/QtRosterWidget.h>  #include <QContextMenuEvent>  #include <QMenu>  #include <QInputDialog>  #include <QFileDialog> -#include "Swift/Controllers/UIEvents/RequestContactEditorUIEvent.h" -#include "Swift/Controllers/UIEvents/RemoveRosterItemUIEvent.h" -#include "Swift/Controllers/UIEvents/RenameGroupUIEvent.h" -#include "Swift/Controllers/UIEvents/SendFileUIEvent.h" -#include "Swift/Controllers/UIEvents/RequestWhiteboardUIEvent.h" -#include "Swift/Controllers/UIEvents/ShowProfileForRosterItemUIEvent.h" -#include "QtContactEditWindow.h" -#include "Swift/Controllers/Roster/ContactRosterItem.h" -#include "Swift/Controllers/Roster/GroupRosterItem.h" -#include "Swift/Controllers/UIEvents/UIEventStream.h" -#include "QtSwiftUtil.h" +#include <Swift/Controllers/UIEvents/RequestContactEditorUIEvent.h> +#include <Swift/Controllers/UIEvents/RemoveRosterItemUIEvent.h> +#include <Swift/Controllers/UIEvents/RenameGroupUIEvent.h> +#include <Swift/Controllers/UIEvents/SendFileUIEvent.h> +#include <Swift/Controllers/UIEvents/RequestWhiteboardUIEvent.h> +#include <Swift/Controllers/UIEvents/ShowProfileForRosterItemUIEvent.h> +#include <Swift/Controllers/UIEvents/RequestChangeBlockStateUIEvent.h> +#include <Swift/QtUI/QtContactEditWindow.h> +#include <Swift/Controllers/Roster/ContactRosterItem.h> +#include <Swift/Controllers/Roster/GroupRosterItem.h> +#include <Swift/Controllers/UIEvents/UIEventStream.h> +#include <Swift/QtUI/QtSwiftUtil.h>  namespace Swift { @@ -59,6 +60,17 @@ void QtRosterWidget::contextMenuEvent(QContextMenuEvent* event) {  		QAction* editContact = contextMenu.addAction(tr("Edit…"));  		QAction* removeContact = contextMenu.addAction(tr("Remove"));  		QAction* showProfileForContact = contextMenu.addAction(tr("Show Profile")); + +		QAction* unblockContact = NULL; +		if (contact->blockState() == ContactRosterItem::IsBlocked) { +			unblockContact = contextMenu.addAction(tr("Unblock")); +		} + +		QAction* blockContact = NULL; +		if (contact->blockState() == ContactRosterItem::IsUnblocked) { +			blockContact = contextMenu.addAction(tr("Block")); +		} +  #ifdef SWIFT_EXPERIMENTAL_FT  		QAction* sendFile = NULL;  		if (contact->supportsFeature(ContactRosterItem::FileTransferFeature)) { @@ -71,6 +83,7 @@ void QtRosterWidget::contextMenuEvent(QContextMenuEvent* event) {  			startWhiteboardChat = contextMenu.addAction(tr("Start Whiteboard Chat"));  		}  #endif +  		QAction* result = contextMenu.exec(event->globalPos());  		if (result == editContact) {  			eventStream_->send(boost::make_shared<RequestContactEditorUIEvent>(contact->getJID())); @@ -83,6 +96,12 @@ void QtRosterWidget::contextMenuEvent(QContextMenuEvent* event) {  		else if (result == showProfileForContact) {  			eventStream_->send(boost::make_shared<ShowProfileForRosterItemUIEvent>(contact->getJID()));  		} +		else if (unblockContact && result == unblockContact) { +			eventStream_->send(boost::make_shared<RequestChangeBlockStateUIEvent>(RequestChangeBlockStateUIEvent::Unblocked, contact->getJID())); +		} +		else if (blockContact && result == blockContact) { +			eventStream_->send(boost::make_shared<RequestChangeBlockStateUIEvent>(RequestChangeBlockStateUIEvent::Blocked, contact->getJID())); +		}  #ifdef SWIFT_EXPERIMENTAL_FT  		else if (sendFile && result == sendFile) {  			QString fileName = QFileDialog::getOpenFileName(this, tr("Send File"), "", tr("All Files (*);;")); | 
 Swift
 Swift