diff options
Diffstat (limited to 'kopete/protocols/jabber/ui/dlgjabberchatjoin.cpp')
-rw-r--r-- | kopete/protocols/jabber/ui/dlgjabberchatjoin.cpp | 129 |
1 files changed, 129 insertions, 0 deletions
diff --git a/kopete/protocols/jabber/ui/dlgjabberchatjoin.cpp b/kopete/protocols/jabber/ui/dlgjabberchatjoin.cpp new file mode 100644 index 00000000..620bff03 --- /dev/null +++ b/kopete/protocols/jabber/ui/dlgjabberchatjoin.cpp @@ -0,0 +1,129 @@ + +/*************************************************************************** + dlgjabberchatjoin.cpp - description + ------------------- + begin : Fri Dec 13 2002 + copyright : (C) 2002-2003 by Till Gerken <till@tantalo.net> + email : kopete-devel@kde.org + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#include <kdebug.h> +#include <klocale.h> +#include <qlineedit.h> +#include <qpushbutton.h> + +#include "jabberaccount.h" +#include "jabberclient.h" +#include "dlgjabberchatroomslist.h" + +#include "dlgjabberchatjoin.h" + +dlgJabberChatJoin::dlgJabberChatJoin(JabberAccount *account, QWidget* parent, const char* name) : +dlgChatJoin(parent, name), +m_account(account) +{ + setCaption(i18n("Join Jabber Groupchat")); + leNick->setText(m_account->client()->client()->user()); + checkDefaultChatroomServer(); +} + +dlgJabberChatJoin::~dlgJabberChatJoin() +{ +} + +/*$SPECIALIZATION$*/ +void dlgJabberChatJoin::slotJoin() +{ + if(!m_account->isConnected()) + { + m_account->errorConnectFirst(); + return; + } + + m_account->client()->joinGroupChat(leServer->text(), leRoom->text(), leNick->text()); + accept(); +} + +void dlgJabberChatJoin::slotBowse() +{ + if(!m_account->isConnected()) + { + m_account->errorConnectFirst(); + return; + } + + dlgJabberChatRoomsList *crl = new dlgJabberChatRoomsList(m_account, leServer->text() , leNick->text()); + crl->show(); + accept(); +} + +/* + TODO : Used to look for the default chat server, + this is duplicate with dlgjabberservices.cpp + should be merged elsewhere ! +*/ +// JabberAccount *m_account; +// XMPP::JT_GetServices * serviceTask; + +void dlgJabberChatJoin::checkDefaultChatroomServer() +{ + XMPP::JT_GetServices *serviceTask = new XMPP::JT_GetServices(m_account->client()->rootTask()); + connect(serviceTask, SIGNAL (finished()), this, SLOT (slotQueryFinished())); + + serviceTask->get(m_account->server()); + serviceTask->go(true); +} + +void dlgJabberChatJoin::slotQueryFinished() +{ + XMPP::JT_GetServices *task = (XMPP::JT_GetServices*)sender(); + if (!task->success ()) + return; + + if(!leServer->text().isEmpty()) + { //the user already started to type the server manyally. abort auto-detect + return; + } + + for (XMPP::AgentList::const_iterator it = task->agents().begin(); it != task->agents().end(); ++it) + { + XMPP::JT_DiscoInfo *discoTask = new XMPP::JT_DiscoInfo(m_account->client()->rootTask()); + connect(discoTask, SIGNAL (finished()), this, SLOT (slotDiscoFinished())); + + discoTask->get((*it).jid().full()); + discoTask->go(true); + } +} + +void dlgJabberChatJoin::slotDiscoFinished() +{ + XMPP::JT_DiscoInfo *task = (XMPP::JT_DiscoInfo*)sender(); + + if (!task->success()) + return; + + if(!leServer->text().isEmpty()) + { //the user already started to type the server manyally. abort auto-detect + return; + } + + + if (task->item().features().canGroupchat() && !task->item().features().isGateway()) + { + leServer->setText(task->item().jid().full()); + } +} + +// end todo + +#include "dlgjabberchatjoin.moc" + |