diff options
| author | Richard Maudsley <richard.maudsley@isode.com> | 2014-06-30 12:30:28 (GMT) | 
|---|---|---|
| committer | Swift Review <review@swift.im> | 2014-07-09 13:04:52 (GMT) | 
| commit | 16b1f85c1a7a0310b0a722c853e5fc8dd799570b (patch) | |
| tree | a52e93753da58e6b9f3c039c6ae4b886ee30f83e /Swift/QtUI/UserSearch/QtUserSearchWindow.cpp | |
| parent | 1edfc36235cc67d303ceb2bcf0630affc509f2f7 (diff) | |
| download | swift-contrib-16b1f85c1a7a0310b0a722c853e5fc8dd799570b.zip swift-contrib-16b1f85c1a7a0310b0a722c853e5fc8dd799570b.tar.bz2 | |
Reset QtSuggestingJIDInput when a contact has been selected.
Test-Information:
Verified that the selected contact is added to the contact list when selecting from the drop-down list or by pressing the 'Add' button and that the JID field is reset after this happens.
Change-Id: I7ef047ec9dbacf1af8635849320371f082bb3d0d
Diffstat (limited to 'Swift/QtUI/UserSearch/QtUserSearchWindow.cpp')
| -rw-r--r-- | Swift/QtUI/UserSearch/QtUserSearchWindow.cpp | 2 | 
1 files changed, 2 insertions, 0 deletions
| diff --git a/Swift/QtUI/UserSearch/QtUserSearchWindow.cpp b/Swift/QtUI/UserSearch/QtUserSearchWindow.cpp index 260ccfe..ca84759 100644 --- a/Swift/QtUI/UserSearch/QtUserSearchWindow.cpp +++ b/Swift/QtUI/UserSearch/QtUserSearchWindow.cpp @@ -126,70 +126,71 @@ void QtUserSearchWindow::handleAccepted() {  	switch(type_) {  		case AddContact:  			jid = getContactJID();  			eventStream_->send(boost::make_shared<AddContactUIEvent>(jid, detailsPage_->getName(), detailsPage_->getSelectedGroups()));  			break;  		case ChatToContact:  			if (contactVector_.size() == 1) {  				boost::shared_ptr<UIEvent> event(new RequestChatUIEvent(contactVector_[0]->jid));  				eventStream_->send(event);  				break;  			}  			foreach(Contact::ref contact, contactVector_) {  				jids.push_back(contact->jid);  			}  			eventStream_->send(boost::make_shared<CreateImpromptuMUCUIEvent>(jids, JID(), Q2PSTRING(firstMultiJIDPage_->reason_->text())));  			break;  		case InviteToChat:  			foreach(Contact::ref contact, contactVector_) {  				jids.push_back(contact->jid);  			}  			eventStream_->send(boost::make_shared<InviteToMUCUIEvent>(roomJID_, jids, Q2PSTRING(firstMultiJIDPage_->reason_->text())));  			break;  	}  }  void QtUserSearchWindow::handleContactSuggestionRequested(const QString& text) {  	std::string stdText = Q2PSTRING(text);  	onContactSuggestionsRequested(stdText);  }  void QtUserSearchWindow::addContact() {  	if (!!firstMultiJIDPage_->jid_->getContact()) {  		contactVector_.push_back(firstMultiJIDPage_->jid_->getContact()); +		firstMultiJIDPage_->jid_->clear();  	}  	firstMultiJIDPage_->contactList_->setList(contactVector_);  	firstMultiJIDPage_->emitCompletenessCheck();  	if (type_ == ChatToContact) {  		firstMultiJIDPage_->groupBox->setEnabled(supportsImpromptu_ ? 1 : (contactVector_.size() < 1));  	}  }  int QtUserSearchWindow::nextId() const {  	if (type_ == AddContact) {  		switch (currentId()) {  			case 1: return firstPage_->byJID_->isChecked() ? (type_ == AddContact ? 4 : -1) : 2;  			case 2: return 3;  			case 3: return type_ == AddContact ? 4 : -1;  			case 4: return -1;  			default: return -1;  		}  	} else {  		switch (currentId()) {  			case 1: return searchNext_ ? 2 : -1;  			case 2: return 3;  			case 3: return 1;  			case 4: return -1;  			default: return -1;  		}  	}  }  void QtUserSearchWindow::handleFirstPageRadioChange() {  	if (firstPage_->byJID_->isChecked()) {  		firstPage_->jid_->setText("");  		firstPage_->jid_->setEnabled(true);  		firstPage_->service_->setEnabled(false);  		restart();  	} @@ -241,70 +242,71 @@ JID QtUserSearchWindow::getContactJID() const {  	if (useSearchResult) {  		if (dynamic_cast<UserSearchModel*>(model_)) {  			UserSearchResult* userItem = static_cast<UserSearchResult*>(resultsPage_->results_->currentIndex().internalPointer());  			if (userItem) { /* Remember to leave this if we change to dynamic cast */  				jid = userItem->getJID();  			}  		} else {  			int row = resultsPage_->results_->currentIndex().row();  			Form::FormItem item = dynamic_cast<QtFormResultItemModel*>(model_)->getForm()->getItems().at(row);  			JID fallbackJid;  			foreach(FormField::ref field, item) {  				if (field->getType() == FormField::JIDSingleType) {  					jid = JID(field->getJIDSingleValue());  					break;  				}  				if (field->getName() == "jid") {  					fallbackJid = field->getValues()[0];  				}  			}  			if (!jid.isValid()) {  				jid = fallbackJid;  			}  		}  	}  	else {  		jid = JID(Q2PSTRING(firstPage_->jid_->text().trimmed()));  	}  	return jid;  }  void QtUserSearchWindow::addSearchedJIDToList(const JID& jid) {  	std::vector<JID> jids;  	jids.push_back(jid);  	handleJIDsAdded(jids); +	firstMultiJIDPage_->jid_->clear();  }  void QtUserSearchWindow::show() {  	clear();  	QWidget::show();  }  void QtUserSearchWindow::addSavedServices(const std::vector<JID>& services) {  	if (type_ == AddContact) {  		firstPage_->service_->clear();  		foreach (JID jid, services) {  			firstPage_->service_->addItem(P2QSTRING(jid.toString()));  		}  		firstPage_->service_->clearEditText();  	} else {  		firstMultiJIDPage_->service_->clear();  		foreach (JID jid, services) {  			firstMultiJIDPage_->service_->addItem(P2QSTRING(jid.toString()));  		}  		firstMultiJIDPage_->service_->clearEditText();  	}  }  void QtUserSearchWindow::setSearchFields(boost::shared_ptr<SearchPayload> fields) {  	fieldsPage_->fetchingThrobber_->hide();  	fieldsPage_->fetchingThrobber_->movie()->stop();  	fieldsPage_->fetchingLabel_->hide();  	fieldsPage_->instructionsLabel_->setText(fields->getInstructions() ? P2QSTRING(fields->getInstructions().get()) : "Enter search terms");  	if (fields->getForm()) {  		fieldsPage_->setFormWidget(new QtFormWidget(fields->getForm(), fieldsPage_));  	} else {  		fieldsPage_->setFormWidget(NULL);  		bool enabled[8] = {fields->getNick(), fields->getNick(), fields->getFirst(), fields->getFirst(), fields->getLast(), fields->getLast(), fields->getEMail(), fields->getEMail()};  		QWidget* legacySearchWidgets[8] = {fieldsPage_->nickInputLabel_, fieldsPage_->nickInput_, fieldsPage_->firstInputLabel_, fieldsPage_->firstInput_, fieldsPage_->lastInputLabel_, fieldsPage_->lastInput_, fieldsPage_->emailInputLabel_, fieldsPage_->emailInput_}; | 
 Swift
 Swift