X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=gui%2Fchannelwidget.cpp;h=5053654b4dfe2d115b5915c30bb9d64de1d4284d;hp=b271ec404deca4dd0315d476856e52d95aa01618;hb=057883f768f86257c9dbefeb5ef12403b207b773;hpb=bcd7397f34626cf64f263f8779036b3c5d0767e9 diff --git a/gui/channelwidget.cpp b/gui/channelwidget.cpp index b271ec40..5053654b 100644 --- a/gui/channelwidget.cpp +++ b/gui/channelwidget.cpp @@ -24,44 +24,226 @@ #include #include -ChannelWidget::ChannelWidget(QWidget *parent) : QWidget(parent) { +ChannelWidget::ChannelWidget(QString netname, QString bufname, QString own, QWidget *parent) : QWidget(parent) { ui.setupUi(this); - ui.inputEdit->grabKeyboard(); - ui.inputEdit->setFocus(); - -/* //ui.splitter-> - ui.textBrowser->setHtml("[17:21] --> Dante has joined #quassel (~hurz@p1af2242.dip.t-dialin.net)
" - "[17:21] --> Sput has joined #quassel (~Sput42@vincent.mindpool.net)
" - "[17:23] <Dante> Das sieht ja soweit schonmal Klasse aus!
" - "[17:23] <Sput> Find ich auch... schade dass es noch nix tut :p
" - "[17:24] <Dante> Das wird sich ja gottseidank bald ändern.
" - "[17:24] <Sput> Wollen wir's hoffen :D" - ); - ui.listWidget->addItem("@Dante"); - ui.listWidget->addItem("@Sput"); - */ - //connect(&core, SIGNAL(outputLine( const QString& )), ui.textBrowser, SLOT(insertPlainText(const QString &))); - //connect(ui.lineEdit, SIGNAL( - //connect(&core, SIGNAL(outputLine( const QString& )), this, SLOT(lineReceived(const QString &))); + _networkName = netname; + _bufferName = bufname; + ui.ownNick->clear(); + ui.ownNick->addItem(own); + if(bufname.isEmpty()) { + // Server Buffer + ui.nickTree->hide(); + ui.topicEdit->hide(); + ui.chanSettingsButton->hide(); + } connect(ui.inputEdit, SIGNAL(returnPressed()), this, SLOT(enterPressed())); - //connect(this, SIGNAL(inputLine( const QString& )), &core, SLOT(inputLine( const QString& ))); + //ui.inputEdit->setFocus(); - connect(this, SIGNAL(inputLine(QString)), guiProxy, SLOT(gsUserInput(QString))); - connect(this, SIGNAL(requestConnect(QString, quint16)), guiProxy, SLOT(gsRequestConnect(QString, quint16))); - connect(guiProxy, SIGNAL(csCoreMessage(QString)), this, SLOT(lineReceived(QString))); - - //emit requestConnect("irc.scortum.moep.net", 6668); - //emit requestConnect("irc.quakenet.org", 6668); + // Define standard colors + stdCol = QColor("black"); + noticeCol = QColor("darkblue"); + serverCol = QColor("darkblue"); + errorCol = QColor("red"); + joinCol = QColor("green"); + quitCol = QColor("firebrick"); + partCol = QColor("firebrick"); + } void ChannelWidget::enterPressed() { - QString l = ui.inputEdit->text(); - if(l == "/c") emit requestConnect("irc.quakenet.org", 6668); - else emit inputLine(ui.inputEdit->text()); + emit sendInput(networkName(), bufferName(), ui.inputEdit->text()); ui.inputEdit->clear(); } -void ChannelWidget::lineReceived(QString s) { - ui.chatWidget->insertPlainText(s + "\n"); +void ChannelWidget::recvMessage(Message msg) { + QString s; + QColor c = stdCol; + switch(msg.type) { + case Message::Msg: + c = stdCol; s = QString("<%1> %2").arg(msg.sender).arg(msg.msg); + break; + case Message::Server: + c = serverCol; s = msg.msg; + break; + case Message::Error: + c = errorCol; s = msg.msg; + break; + case Message::Join: + c = joinCol; s = msg.msg; + break; + default: + c = stdCol; s = QString("[%1] %2").arg(msg.sender).arg(msg.msg); + break; + } + ui.chatWidget->setTextColor(c); + ui.chatWidget->insertPlainText(QString("[%2] %1\n").arg(s).arg(msg.timeStamp.toLocalTime().toString("hh:mm:ss"))); + //ui.chatWidget->insertHtml(QString("" + // "" + // "" + // "
[12:13]
[nickname]
This is the Message!
[12:13]
[nick]
This is the Message!
[12:13]
[looongnickname]
This is the Message!
[12:13]
[nickname]
This is the Message!
" + // )); + ui.chatWidget->ensureCursorVisible(); +} + +void ChannelWidget::recvStatusMsg(QString msg) { + ui.chatWidget->insertPlainText(QString("[STATUS] %1").arg(msg)); ui.chatWidget->ensureCursorVisible(); } + +void ChannelWidget::setTopic(QString topic) { + ui.topicEdit->setText(topic); +} + +void ChannelWidget::setNicks(QStringList nicks) { + + +} + +void ChannelWidget::addNick(QString nick, VarMap props) { + nicks[nick] = props; + updateNickList(); +} + +void ChannelWidget::updateNick(QString nick, VarMap props) { + nicks[nick] = props; + updateNickList(); +} + +void ChannelWidget::removeNick(QString nick) { + nicks[nick].toMap().remove(nick); + updateNickList(); +} + +void ChannelWidget::setOwnNick(QString nick) { + ui.ownNick->clear(); + ui.ownNick->addItem(nick); +} + +void ChannelWidget::updateNickList() { + ui.nickTree->clear(); + if(nicks.count() != 1) ui.nickTree->setHeaderLabel(tr("%1 Users").arg(nicks.count())); + else ui.nickTree->setHeaderLabel(tr("1 User")); + QTreeWidgetItem *ops = new QTreeWidgetItem(); + QTreeWidgetItem *voiced = new QTreeWidgetItem(); + QTreeWidgetItem *users = new QTreeWidgetItem(); + // To sort case-insensitive, we have to put all nicks in a map which is sorted by (lowercase) key... + QMap sorted; + foreach(QString n, nicks.keys()) { sorted[n.toLower()] = n; } + foreach(QString n, sorted.keys()) { + QString nick = sorted[n]; + QString mode = nicks[nick].toMap()["Channels"].toMap()[bufferName()].toMap()["Mode"].toString(); + if(mode.contains('o')) { new QTreeWidgetItem(ops, QStringList(QString("@%1").arg(nick))); } + else if(mode.contains('v')) { new QTreeWidgetItem(voiced, QStringList(QString("+%1").arg(nick))); } + else new QTreeWidgetItem(users, QStringList(nick)); + } + if(ops->childCount()) { + ops->setText(0, tr("%1 Operators").arg(ops->childCount())); + ui.nickTree->addTopLevelItem(ops); + ops->setExpanded(true); + } else delete ops; + if(voiced->childCount()) { + voiced->setText(0, tr("%1 Voiced").arg(voiced->childCount())); + ui.nickTree->addTopLevelItem(voiced); + voiced->setExpanded(true); + } else delete voiced; + if(users->childCount()) { + users->setText(0, tr("%1 Users").arg(users->childCount())); + ui.nickTree->addTopLevelItem(users); + users->setExpanded(true); + } else delete users; +} +/**********************************************************************************************/ + + +IrcWidget::IrcWidget(QWidget *parent) : QWidget(parent) { + ui.setupUi(this); + ui.tabWidget->removeTab(0); + + connect(guiProxy, SIGNAL(csDisplayMsg(QString, QString, Message)), this, SLOT(recvMessage(QString, QString, Message))); + connect(guiProxy, SIGNAL(csDisplayStatusMsg(QString, QString)), this, SLOT(recvStatusMsg(QString, QString))); + connect(guiProxy, SIGNAL(csTopicSet(QString, QString, QString)), this, SLOT(setTopic(QString, QString, QString))); + connect(guiProxy, SIGNAL(csSetNicks(QString, QString, QStringList)), this, SLOT(setNicks(QString, QString, QStringList))); + connect(guiProxy, SIGNAL(csNickAdded(QString, QString, VarMap)), this, SLOT(addNick(QString, QString, VarMap))); + connect(guiProxy, SIGNAL(csNickRemoved(QString, QString)), this, SLOT(removeNick(QString, QString))); + connect(guiProxy, SIGNAL(csNickUpdated(QString, QString, VarMap)), this, SLOT(updateNick(QString, QString, VarMap))); + connect(guiProxy, SIGNAL(csOwnNickSet(QString, QString)), this, SLOT(setOwnNick(QString, QString))); + connect(this, SIGNAL(sendInput( QString, QString, QString )), guiProxy, SLOT(gsUserInput(QString, QString, QString))); +} + +ChannelWidget * IrcWidget::getBuffer(QString net, QString buf) { + QString key = net + buf; + if(!buffers.contains(key)) { + ChannelWidget *cw = new ChannelWidget(net, buf, ownNick); + connect(cw, SIGNAL(sendInput(QString, QString, QString)), this, SLOT(userInput(QString, QString, QString))); + ui.tabWidget->addTab(cw, net+buf); + ui.tabWidget->setCurrentWidget(cw); + //cw->setFocus(); + buffers[key] = cw; + } + return buffers[key]; +} + + +void IrcWidget::recvMessage(QString net, QString buf, Message msg) { + ChannelWidget *cw = getBuffer(net, buf); + cw->recvMessage(msg); +} + +void IrcWidget::recvStatusMsg(QString net, QString msg) { + recvMessage(net, "", QString("[STATUS] %1").arg(msg)); + +} + +void IrcWidget::userInput(QString net, QString buf, QString msg) { + emit sendInput(net, buf, msg); +} + +void IrcWidget::setTopic(QString net, QString buf, QString topic) { + ChannelWidget *cw = getBuffer(net, buf); + cw->setTopic(topic); +} + +void IrcWidget::setNicks(QString net, QString buf, QStringList nicks) { + ChannelWidget *cw = getBuffer(net, buf); + cw->setNicks(nicks); +} + +void IrcWidget::addNick(QString net, QString nick, VarMap props) { + nicks[net].toMap()[nick] = props; + VarMap chans = props["Channels"].toMap(); + QStringList c = chans.keys(); + foreach(QString bufname, c) { + getBuffer(net, bufname)->addNick(nick, props); + } +} + +void IrcWidget::updateNick(QString net, QString nick, VarMap props) { + QStringList oldchans = nicks[net].toMap()[nick].toMap()["Channels"].toMap().keys(); + QStringList newchans = props["Channels"].toMap().keys(); + foreach(QString c, newchans) { + if(oldchans.contains(c)) getBuffer(net, c)->updateNick(nick, props); + else getBuffer(net, c)->addNick(nick, props); + } + foreach(QString c, oldchans) { + if(!newchans.contains(c)) getBuffer(net, c)->removeNick(nick); + } + nicks[net].toMap()[nick] = props; +} + +void IrcWidget::removeNick(QString net, QString nick) { + VarMap chans = nicks[net].toMap()[nick].toMap()["Channels"].toMap(); + foreach(QString bufname, chans.keys()) { + getBuffer(net, bufname)->removeNick(nick); + } + qDebug() << nicks; + nicks[net].toMap().remove(nick); + qDebug() << nicks; +} + +void IrcWidget::setOwnNick(QString net, QString nick) { + ownNick = nick; + foreach(ChannelWidget *cw, buffers.values()) { + if(cw->networkName() == net) cw->setOwnNick(nick); + } +} +