diff options
| author | Remko Tronçon <git@el-tramo.be> | 2009-06-10 17:23:57 (GMT) | 
|---|---|---|
| committer | Remko Tronçon <git@el-tramo.be> | 2009-06-10 17:38:05 (GMT) | 
| commit | e2f5588d089e4d2148762ea092e032976254a467 (patch) | |
| tree | 851946c7a36ffa96e0f3ab54bc72f233f8b2c746 /Swift/Controllers/RosterController.cpp | |
| parent | 7214d768dca85a6d43892169d5008898249dce73 (diff) | |
| download | swift-e2f5588d089e4d2148762ea092e032976254a467.zip swift-e2f5588d089e4d2148762ea092e032976254a467.tar.bz2 | |
Moved Swiften/Controllers to Swift/Controllers.
Diffstat (limited to 'Swift/Controllers/RosterController.cpp')
| -rw-r--r-- | Swift/Controllers/RosterController.cpp | 83 | 
1 files changed, 83 insertions, 0 deletions
| diff --git a/Swift/Controllers/RosterController.cpp b/Swift/Controllers/RosterController.cpp new file mode 100644 index 0000000..c447602 --- /dev/null +++ b/Swift/Controllers/RosterController.cpp @@ -0,0 +1,83 @@ +#include "Swift/Controllers/RosterController.h" + +#include <boost/bind.hpp> + +#include "Swiften/Base/foreach.h" +#include "Swift/Controllers/MainWindow.h" +#include "Swift/Controllers/MainWindowFactory.h" +#include "Swiften/Queries/Requests/GetRosterRequest.h" +#include "Swiften/EventLoop/MainEventLoop.h" +#include "Swiften/Roster/Roster.h" +#include "Swiften/Roster/SetPresence.h" +#include "Swiften/Roster/OfflineRosterFilter.h" +#include "Swiften/Roster/OpenChatRosterAction.h" +#include "Swiften/Roster/TreeWidgetFactory.h" +#include "Swiften/Roster/XMPPRoster.h" + +namespace Swift { +	 +/** + * The controller does not gain ownership of these parameters. + */ +RosterController::RosterController(boost::shared_ptr<XMPPRoster> xmppRoster, MainWindowFactory* mainWindowFactory, TreeWidgetFactory* treeWidgetFactory) + : xmppRoster_(xmppRoster), mainWindowFactory_(mainWindowFactory), treeWidgetFactory_(treeWidgetFactory), mainWindow_(mainWindowFactory_->createMainWindow()), roster_(new Roster(mainWindow_->getTreeWidget(), treeWidgetFactory_)), offlineFilter_(new OfflineRosterFilter()) { +	roster_->addFilter(offlineFilter_); +	mainWindow_->onStartChatRequest.connect(boost::bind(&RosterController::handleStartChatRequest, this, _1)); +	mainWindow_->onJoinMUCRequest.connect(boost::bind(&RosterController::handleJoinMUCRequest, this, _1, _2)); +	mainWindow_->onChangeStatusRequest.connect(boost::bind(&RosterController::handleChangeStatusRequest, this, _1, _2)); +	mainWindow_->onShowOfflineToggled.connect(boost::bind(&RosterController::handleShowOfflineToggled, this, _1)); +	roster_->onUserAction.connect(boost::bind(&RosterController::handleUserAction, this, _1)); +	xmppRoster_->onJIDAdded.connect(boost::bind(&RosterController::handleOnJIDAdded, this, _1)); +} + +RosterController::~RosterController() { +	delete offlineFilter_; + +} + +void RosterController::handleShowOfflineToggled(bool state) { +	if (state) { +		roster_->removeFilter(offlineFilter_); +	} else { +		roster_->addFilter(offlineFilter_); +	} +} + +void RosterController::handleChangeStatusRequest(StatusShow::Type show, const String &statusText) { +	onChangeStatusRequest(show, statusText); +} + +void RosterController::handleUserAction(boost::shared_ptr<UserRosterAction> action) { +	boost::shared_ptr<OpenChatRosterAction> chatAction = boost::dynamic_pointer_cast<OpenChatRosterAction>(action); +	if (chatAction.get() != NULL) { +		ContactRosterItem *contactItem = dynamic_cast<ContactRosterItem*>(chatAction->getRosterItem()); +		assert(contactItem); +		onStartChatRequest(contactItem->getJID().toBare()); +	} +} + +void RosterController::handleOnJIDAdded(const JID& jid) { +	std::vector<String> groups = xmppRoster_->getGroupsForJID(jid); +	String name = xmppRoster_->getNameForJID(jid); +	if (!groups.empty()) { +		foreach(const String& group, groups) { +			roster_->addContact(jid, name, group); +		} +	} else { +		roster_->addContact(jid, name, "Contacts"); +	} +} + +void RosterController::handleIncomingPresence(boost::shared_ptr<Presence> presence) { +	roster_->applyOnItems(SetPresence(presence)); +} + +void RosterController::handleStartChatRequest(const JID& contact) { +	onStartChatRequest(contact); +} + +void RosterController::handleJoinMUCRequest(const JID &muc, const String &nick) { +	onJoinMUCRequest(JID(muc), nick); +} + +} | 
 Swift
 Swift