X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtopia%2Fmainwidget.cpp;h=520ba7667de195ba92b74dff2c85d44f1990c190;hp=9ab5b620ff7db981b9986203462824731cb46b63;hb=adc222822ec7d872f2bcc0ca384e6ec5fd777287;hpb=4e9a619ab2a22ce3c933fbb36122632debfd415a diff --git a/src/qtopia/mainwidget.cpp b/src/qtopia/mainwidget.cpp index 9ab5b620..520ba766 100644 --- a/src/qtopia/mainwidget.cpp +++ b/src/qtopia/mainwidget.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-07 by The Quassel IRC Development Team * + * Copyright (C) 2005-07 by the Quassel IRC Team * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -21,16 +21,12 @@ #include "mainwidget.h" #include "buffer.h" +#include "chatwidget.h" MainWidget::MainWidget(QWidget *parent) : QWidget(parent) { ui.setupUi(this); - -// ui.bufferLeft->setIcon(QIcon(":icon/left")); -// ui.bufferRight->setIcon(QIcon(":icon/right")); - //ui.bufferLeft->setIconSize(QSize(10, 10)); - //ui.bufferRight->setIconSize(QSize(10, 10)); - //ui.bufferLeft->setMaximumSize(QSize(10,10)); - //ui.bufferRight->setMaximumSize(QSize(10,10)); + connect(ui.inputLine, SIGNAL(returnPressed()), this, SLOT(enterPressed())); + currentBuffer = 0; } MainWidget::~MainWidget() { @@ -39,9 +35,44 @@ MainWidget::~MainWidget() { } -void MainWidget::setBuffer(Buffer *b) { +void MainWidget::setBuffer(Buffer *buf) { // TODO update topic if changed; handle status buffer display - QString title = QString("%1 (%2): \"%3\"").arg(b->displayName()).arg(b->networkName()).arg(b->topic()); + QString title = QString("%1 (%2): \"%3\"").arg(buf->name()).arg(buf->networkName()).arg(buf->topic()); ui.topicBar->setContents(title); + //ui.chatWidget->setStyleSheet("div { color: #777777; }"); + //ui.chatWidget->setHtml("" + // "
foo
bar
baz"); + //ui.chatWidget->moveCursor(QTextCursor::End); + //ui.chatWidget->insertHtml("
brumm
"); + + ChatWidget *chatWidget; + if(!chatWidgets.contains(buf)) { + chatWidget = new ChatWidget(this); + QList lines; + QList msgs = buf->contents(); + foreach(AbstractUiMsg *msg, msgs) { + lines.append((ChatLine*)(msg)); + } + chatWidget->setContents(lines); + connect(buf, SIGNAL(msgAppended(AbstractUiMsg *)), chatWidget, SLOT(appendMsg(AbstractUiMsg *))); + connect(buf, SIGNAL(msgPrepended(AbstractUiMsg *)), chatWidget, SLOT(prependMsg(AbstractUiMsg *))); + //connect(buf, SIGNAL(topicSet(QString)), this, SLOT(setTopic(QString))); + //connect(buf, SIGNAL(ownNickSet(QString)), this, SLOT(setOwnNick(QString))); + ui.stack->addWidget(chatWidget); + chatWidgets.insert(buf, chatWidget); + chatWidget->setFocusProxy(ui.inputLine); + } else chatWidget = chatWidgets[buf]; + ui.stack->setCurrentWidget(chatWidget); + ui.inputLine->setFocus(); + currentBuffer = buf; +} + +void MainWidget::enterPressed() { + QStringList lines = ui.inputLine->text().split('\n', QString::SkipEmptyParts); + foreach(QString msg, lines) { + if(msg.isEmpty()) continue; + if(currentBuffer) currentBuffer->processUserInput(msg); + } + ui.inputLine->clear(); }