diff options
Diffstat (limited to 'Swift/Controllers/Chat/ChatController.cpp')
| -rw-r--r-- | Swift/Controllers/Chat/ChatController.cpp | 37 | 
1 files changed, 14 insertions, 23 deletions
| diff --git a/Swift/Controllers/Chat/ChatController.cpp b/Swift/Controllers/Chat/ChatController.cpp index 9b65c9f..786b4e9 100644 --- a/Swift/Controllers/Chat/ChatController.cpp +++ b/Swift/Controllers/Chat/ChatController.cpp @@ -137,72 +137,72 @@ void ChatController::handleBareJIDCapsChanged(const JID& /*jid*/) {  		} else {  			contactSupportsReceipts_ = ChatWindow::No;  		}  		if (FileTransferManager::isSupportedBy(disco)) {  			chatWindow_->setFileTransferEnabled(ChatWindow::Yes);  		} else {  			chatWindow_->setFileTransferEnabled(ChatWindow::No);  		}  	} else {  		SWIFT_LOG(debug) << "No disco info :(" << std::endl;  		chatWindow_->setCorrectionEnabled(ChatWindow::Maybe);  		contactSupportsReceipts_ = ChatWindow::Maybe;  	}  	checkForDisplayingDisplayReceiptsAlert();  }  void ChatController::setToJID(const JID& jid) {  	chatStateNotifier_->setContact(jid);  	ChatControllerBase::setToJID(jid);  	Presence::ref presence;  	if (isInMUC_) {  		presence = presenceOracle_->getLastPresence(jid);  	} else {  		presence = jid.isBare() ? presenceOracle_->getHighestPriorityPresence(jid.toBare()) : presenceOracle_->getLastPresence(jid);  	}  	chatStateNotifier_->setContactIsOnline(presence && presence->getType() == Presence::Available);  	handleBareJIDCapsChanged(toJID_);  }  void ChatController::setAvailableServerFeatures(boost::shared_ptr<DiscoInfo> info) {  	ChatControllerBase::setAvailableServerFeatures(info);  	if (iqRouter_->isAvailable() && info->hasFeature(DiscoInfo::BlockingCommandFeature)) {  		boost::shared_ptr<BlockList> blockList = clientBlockListManager_->getBlockList();  		blockingOnStateChangedConnection_ = blockList->onStateChanged.connect(boost::bind(&ChatController::handleBlockingStateChanged, this)); -		blockingOnItemAddedConnection_ = blockList->onItemAdded.connect(boost::bind(&ChatController::handleBlockingItemAdded, this, _1)); -		blockingOnItemRemovedConnection_ = blockList->onItemRemoved.connect(boost::bind(&ChatController::handleBlockingItemRemoved, this, _1)); +		blockingOnItemAddedConnection_ = blockList->onItemAdded.connect(boost::bind(&ChatController::handleBlockingStateChanged, this)); +		blockingOnItemRemovedConnection_ = blockList->onItemRemoved.connect(boost::bind(&ChatController::handleBlockingStateChanged, this));  		handleBlockingStateChanged();  	}  }  bool ChatController::isIncomingMessageFromMe(boost::shared_ptr<Message>) {  	return false;  }  void ChatController::preHandleIncomingMessage(boost::shared_ptr<MessageEvent> messageEvent) {  	if (messageEvent->isReadable()) {  		chatWindow_->flash();  		lastWasPresence_ = false;  	}  	boost::shared_ptr<Message> message = messageEvent->getStanza();  	JID from = message->getFrom();  	if (!from.equals(toJID_, JID::WithResource)) {  		if (toJID_.equals(from, JID::WithoutResource)  && toJID_.isBare()){  			setToJID(from);  		}  	}  	chatStateTracker_->handleMessageReceived(message);  	chatStateNotifier_->receivedMessageFromContact(!!message->getPayload<ChatState>());  	// handle XEP-0184 Message Receipts  	// incomming receipts  	if (boost::shared_ptr<DeliveryReceipt> receipt = message->getPayload<DeliveryReceipt>()) {  		SWIFT_LOG(debug) << "received receipt for id: " << receipt->getReceivedID() << std::endl;  		if (requestedReceipts_.find(receipt->getReceivedID()) != requestedReceipts_.end()) {  			chatWindow_->setMessageReceiptState(requestedReceipts_[receipt->getReceivedID()], ChatWindow::ReceiptReceived);  			requestedReceipts_.erase(receipt->getReceivedID());  		}  	// incomming errors in response to send out receipts  	} else if (message->getPayload<DeliveryReceiptRequest>() && (message->getType() == Message::Error)) {  		if (requestedReceipts_.find(message->getID()) != requestedReceipts_.end()) { @@ -216,108 +216,99 @@ void ChatController::preHandleIncomingMessage(boost::shared_ptr<MessageEvent> me  			receiptMessage->setTo(toJID_);  			receiptMessage->addPayload(boost::make_shared<DeliveryReceipt>(message->getID()));  			stanzaChannel_->sendMessage(receiptMessage);  		}  	}  }  void ChatController::postHandleIncomingMessage(boost::shared_ptr<MessageEvent> messageEvent, const HighlightAction& highlight) {  	eventController_->handleIncomingEvent(messageEvent);  	if (!messageEvent->getConcluded()) {  		highlighter_->handleHighlightAction(highlight);  	}  }  void ChatController::preSendMessageRequest(boost::shared_ptr<Message> message) {  	chatStateNotifier_->addChatStateRequest(message);  	if (userWantsReceipts_ && (contactSupportsReceipts_ != ChatWindow::No) && message) {  		message->addPayload(boost::make_shared<DeliveryReceiptRequest>());  	}  }  void ChatController::setContactIsReceivingPresence(bool isReceivingPresence) {  	receivingPresenceFromUs_ = isReceivingPresence;  }  void ChatController::handleSettingChanged(const std::string& settingPath) {  	if (settingPath == SettingConstants::REQUEST_DELIVERYRECEIPTS.getKey()) {  		userWantsReceipts_ = settings_->getSetting(SettingConstants::REQUEST_DELIVERYRECEIPTS);  		checkForDisplayingDisplayReceiptsAlert();  	}  }  void ChatController::checkForDisplayingDisplayReceiptsAlert() {  	if (userWantsReceipts_ && (contactSupportsReceipts_ == ChatWindow::No)) { -		chatWindow_->setAlert(QT_TRANSLATE_NOOP("", "This chat doesn't support delivery receipts.")); +		deliveryReceiptAlert_ = chatWindow_->addAlert(QT_TRANSLATE_NOOP("", "This chat doesn't support delivery receipts."));  	} else if (userWantsReceipts_ && (contactSupportsReceipts_ == ChatWindow::Maybe)) { -		chatWindow_->setAlert(QT_TRANSLATE_NOOP("", "This chat may not support delivery receipts. You might not receive delivery receipts for the messages you sent.")); +		deliveryReceiptAlert_ = chatWindow_->addAlert(QT_TRANSLATE_NOOP("", "This chat may not support delivery receipts. You might not receive delivery receipts for the messages you sent."));  	} else { -		chatWindow_->cancelAlert(); +		if (deliveryReceiptAlert_) { +			chatWindow_->removeAlert(*deliveryReceiptAlert_); +			deliveryReceiptAlert_.reset(); +		}  	}  }  void ChatController::handleBlockingStateChanged() {  	boost::shared_ptr<BlockList> blockList = clientBlockListManager_->getBlockList();  	if (blockList->getState() == BlockList::Available) {  		if (isInMUC_ ? blockList->isBlocked(toJID_) : blockList->isBlocked(toJID_.toBare())) { -			chatWindow_->setAlert(QT_TRANSLATE_NOOP("", "You've currently blocked this contact. To continue your conversation you have to unblock the contact first.")); +			blockedContactAlert_ = chatWindow_->addAlert(QT_TRANSLATE_NOOP("", "You've currently blocked this contact. To continue your conversation you have to unblock the contact first."));  			chatWindow_->setInputEnabled(false);  			chatWindow_->setBlockingState(ChatWindow::IsBlocked);  		} else { +			if (blockedContactAlert_) { +				chatWindow_->removeAlert(*blockedContactAlert_); +				blockedContactAlert_.reset(); +			} +			chatWindow_->setInputEnabled(true);  			chatWindow_->setBlockingState(ChatWindow::IsUnblocked);  		}  	}  } -void ChatController::handleBlockingItemAdded(const JID& jid) { -	if (toJID_ == (isInMUC_ ? jid: jid.toBare())) { -		chatWindow_->setAlert(QT_TRANSLATE_NOOP("", "You've currently blocked this contact. To continue your conversation you have to unblock the contact first.")); -		chatWindow_->setInputEnabled(false); -		chatWindow_->setBlockingState(ChatWindow::IsBlocked); -	} -} - -void ChatController::handleBlockingItemRemoved(const JID& jid) { -	if (toJID_ == (isInMUC_ ? jid: jid.toBare())) { -		// FIXME: Support for different types of alerts. -		chatWindow_->cancelAlert(); -		chatWindow_->setInputEnabled(true); -		chatWindow_->setBlockingState(ChatWindow::IsUnblocked); -	} -} -  void ChatController::handleBlockUserRequest() {  	if (isInMUC_) {  		eventStream_->send(boost::make_shared<RequestChangeBlockStateUIEvent>(RequestChangeBlockStateUIEvent::Blocked, toJID_));  	} else {  		eventStream_->send(boost::make_shared<RequestChangeBlockStateUIEvent>(RequestChangeBlockStateUIEvent::Blocked, toJID_.toBare()));  	}  }  void ChatController::handleUnblockUserRequest() {  	if (isInMUC_) {  		eventStream_->send(boost::make_shared<RequestChangeBlockStateUIEvent>(RequestChangeBlockStateUIEvent::Unblocked, toJID_));  	} else {  		eventStream_->send(boost::make_shared<RequestChangeBlockStateUIEvent>(RequestChangeBlockStateUIEvent::Unblocked, toJID_.toBare()));  	}  }  void ChatController::handleInviteToChat(const std::vector<JID>& droppedJIDs) {  	boost::shared_ptr<UIEvent> event(new RequestInviteToMUCUIEvent(toJID_.toBare(), droppedJIDs, RequestInviteToMUCUIEvent::Impromptu));  	eventStream_->send(event);  }  void ChatController::handleWindowClosed() {  	onWindowClosed();  }  void ChatController::handleUIEvent(boost::shared_ptr<UIEvent> event) {  	boost::shared_ptr<InviteToMUCUIEvent> inviteEvent = boost::dynamic_pointer_cast<InviteToMUCUIEvent>(event);  	if (inviteEvent && inviteEvent->getRoom() == toJID_.toBare()) {  		onConvertToMUC(detachChatWindow(), inviteEvent->getInvites(), inviteEvent->getReason());  	}  }  void ChatController::postSendMessage(const std::string& body, boost::shared_ptr<Stanza> sentStanza) {  	boost::shared_ptr<Replace> replace = sentStanza->getPayload<Replace>(); | 
 Swift
 Swift