diff options
author | Kevin Smith <git@kismith.co.uk> | 2010-09-24 16:58:30 (GMT) |
---|---|---|
committer | Kevin Smith <git@kismith.co.uk> | 2010-09-24 16:58:30 (GMT) |
commit | 245185ca3133fd496b90c5c9973713e8aa02f0ef (patch) | |
tree | d67354fa0f96f78bfcf6ec9969b436e9f29ee234 | |
parent | ecc4dc5633b6d3b46ff2ef24d7d976172b9c01ae (diff) | |
download | swift-245185ca3133fd496b90c5c9973713e8aa02f0ef.zip swift-245185ca3133fd496b90c5c9973713e8aa02f0ef.tar.bz2 |
Rename contacts in the QtUI.
Resolves: #575
-rw-r--r-- | Swift/QtUI/ContextMenus/QtRosterContextMenu.cpp | 18 | ||||
-rw-r--r-- | Swift/QtUI/ContextMenus/QtRosterContextMenu.h | 3 |
2 files changed, 18 insertions, 3 deletions
diff --git a/Swift/QtUI/ContextMenus/QtRosterContextMenu.cpp b/Swift/QtUI/ContextMenus/QtRosterContextMenu.cpp index e6b5ae5..59c3b78 100644 --- a/Swift/QtUI/ContextMenus/QtRosterContextMenu.cpp +++ b/Swift/QtUI/ContextMenus/QtRosterContextMenu.cpp @@ -6,6 +6,8 @@ #include "Swift/QtUI/ContextMenus/QtRosterContextMenu.h" +#include <QInputDialog> +#include <QLineEdit> #include <QMenu> #include <QDebug> @@ -15,6 +17,7 @@ #include "Swiften/Base/String.h" #include "Swift/Controllers/UIEvents/UIEvent.h" #include "Swift/Controllers/UIEvents/RemoveRosterItemUIEvent.h" +#include "Swift/Controllers/UIEvents/RenameRosterItemUIEvent.h" #include "Swift/QtUI/QtSwiftUtil.h" namespace Swift { @@ -30,14 +33,25 @@ void QtRosterContextMenu::show(RosterItem* item) { } item_ = item; QMenu* contextMenu = new QMenu(); - contextMenu->addAction("Remove", this, SLOT(handleRemove())); + contextMenu->addAction("Remove", this, SLOT(handleRemoveContact())); + contextMenu->addAction("Rename", this, SLOT(handleRenameContact())); contextMenu->exec(QCursor::pos()); } -void QtRosterContextMenu::handleRemove() { +void QtRosterContextMenu::handleRemoveContact() { ContactRosterItem* contact = dynamic_cast<ContactRosterItem*>(item_); assert(contact); eventStream_->send(boost::shared_ptr<UIEvent>(new RemoveRosterItemUIEvent(contact->getJID()))); } +void QtRosterContextMenu::handleRenameContact() { + ContactRosterItem* contact = dynamic_cast<ContactRosterItem*>(item_); + assert(contact); + bool ok; + QString newName = QInputDialog::getText(NULL, "Rename contact", "New name for " + P2QSTRING(item_->getDisplayName()), QLineEdit::Normal, P2QSTRING(item_->getDisplayName()), &ok); + if (ok) { + eventStream_->send(boost::shared_ptr<UIEvent>(new RenameRosterItemUIEvent(contact->getJID(), Q2PSTRING(newName)))); + } +} + } diff --git a/Swift/QtUI/ContextMenus/QtRosterContextMenu.h b/Swift/QtUI/ContextMenus/QtRosterContextMenu.h index 51556e4..44f3314 100644 --- a/Swift/QtUI/ContextMenus/QtRosterContextMenu.h +++ b/Swift/QtUI/ContextMenus/QtRosterContextMenu.h @@ -20,7 +20,8 @@ namespace Swift { void show(RosterItem* item); private slots: - void handleRemove(); + void handleRemoveContact(); + void handleRenameContact(); private: RosterItem* item_; |