X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Fmainwin.cpp;h=e81eb889510e71f57982676775f4901afcf75b17;hb=76a276c472cb99032e2407d8e4bc2f2d693e8e67;hp=5c3e73f139abb625aa99653c30bc22d32718f69b;hpb=d298e7275374e2da41b0ed9ef1080464a77c8cf1;p=quassel.git diff --git a/src/qtui/mainwin.cpp b/src/qtui/mainwin.cpp index 5c3e73f1..e81eb889 100644 --- a/src/qtui/mainwin.cpp +++ b/src/qtui/mainwin.cpp @@ -25,6 +25,7 @@ #include "chatline.h" #include "chatline-old.h" #include "client.h" +#include "clientbacklogmanager.h" #include "coreconnectdlg.h" #include "networkmodel.h" #include "buffermodel.h" @@ -55,12 +56,16 @@ MainWin::MainWin(QtUi *_gui, QWidget *parent) : QMainWindow(parent), gui(_gui), + activeTrayIcon(":/icons/quassel-icon-active.png"), + inactiveTrayIcon(":/icons/quassel-icon.png"), + trayIconActive(false), + timer(new QTimer(this)), settingsDlg(new SettingsDlg(this)), debugConsole(new DebugConsole(this)) { ui.setupUi(this); setWindowTitle("Quassel IRC"); - setWindowIcon(QIcon(":icons/quassel-icon.png")); + setWindowIcon(inactiveTrayIcon); setWindowIconText("Quassel IRC"); statusBar()->showMessage(tr("Waiting for core...")); @@ -80,7 +85,7 @@ void MainWin::init() { connect(Client::instance(), SIGNAL(networkCreated(NetworkId)), this, SLOT(clientNetworkCreated(NetworkId))); connect(Client::instance(), SIGNAL(networkRemoved(NetworkId)), this, SLOT(clientNetworkRemoved(NetworkId))); ui.bufferWidget->init(); - + show(); statusBar()->showMessage(tr("Not connected to core.")); @@ -102,7 +107,6 @@ void MainWin::init() { setupInputWidget(); setupSystray(); - setupSettingsDlg(); // restore mainwin state @@ -114,7 +118,7 @@ void MainWin::init() { // attach the BufferWidget to the BufferModel and the default selection ui.bufferWidget->setModel(Client::bufferModel()); ui.bufferWidget->setSelectionModel(Client::bufferModel()->standardSelectionModel()); - + if(Global::SPUTDEV) { //showSettingsDlg(); //showAboutDlg(); @@ -199,15 +203,15 @@ void MainWin::setupNickWidget() { nickListWidget = new NickListWidget(nickDock); nickDock->setWidget(nickListWidget); + nickListWidget->setShowDockAction(nickDock->toggleViewAction()); + connect(nickDock->toggleViewAction(), SIGNAL(toggled(bool)), nickListWidget, SLOT(changedVisibility(bool))); addDockWidget(Qt::RightDockWidgetArea, nickDock); - ui.menuViews->addAction(nickDock->toggleViewAction()); + ui.menuViews->addAction(nickListWidget->showNickListAction()); // attach the NickListWidget to the BufferModel and the default selection nickListWidget->setModel(Client::bufferModel()); nickListWidget->setSelectionModel(Client::bufferModel()->standardSelectionModel()); - - Client::bufferModel()->mapProperty(0, NetworkModel::BufferIdRole, nickListWidget, "currentBuffer"); } void MainWin::setupChatMonitor() { @@ -262,7 +266,8 @@ void MainWin::setupTopicWidget() { dock->setWidget(topicwidget); - Client::bufferModel()->mapProperty(1, Qt::DisplayRole, topicwidget, "topic"); + topicwidget->setModel(Client::bufferModel()); + topicwidget->setSelectionModel(Client::bufferModel()->standardSelectionModel()); addDockWidget(Qt::TopDockWidgetArea, dock); @@ -270,8 +275,11 @@ void MainWin::setupTopicWidget() { } void MainWin::setupSystray() { + connect(timer, SIGNAL(timeout()), this, SLOT(makeTrayIconBlink())); + connect(Client::instance(), SIGNAL(messageReceived(const Message &)), this, SLOT(receiveMessage(const Message &))); + systray = new QSystemTrayIcon(this); - systray->setIcon(QIcon(":/icons/quassel-icon.png")); + systray->setIcon(inactiveTrayIcon); // systray->setToolTip("left click to minimize the quassel client to tray"); // systray->setToolTip(toolTip); @@ -319,7 +327,7 @@ void MainWin::changeTopic(const QString &topic) { void MainWin::connectedToCore() { foreach(BufferInfo id, Client::allBufferInfos()) { - emit requestBacklog(id, 1000, -1); + Client::backlogManager()->requestBacklog(id.bufferId(), 500, -1); } ui.menuViews->setEnabled(true); @@ -398,8 +406,9 @@ void MainWin::toggleVisibility() { showNormal(); raise(); - setFocus(Qt::ActiveWindowFocusReason); - // activateWindow(); + activateWindow(); + // setFocus(); //Qt::ActiveWindowFocusReason + } else { if(systray->isSystemTrayAvailable ()) { clearFocus(); @@ -413,6 +422,57 @@ void MainWin::toggleVisibility() { } } +void MainWin::receiveMessage(const Message &msg) { + if(QApplication::activeWindow() != 0) + return; + + if(msg.flags() & Message::Highlight || msg.bufferInfo().type() == BufferInfo::QueryBuffer) { + QString title = msg.bufferInfo().bufferName();; + if(msg.bufferInfo().type() != BufferInfo::QueryBuffer) { + QString sender = msg.sender(); + int i = sender.indexOf("!"); + if(i != -1) + sender = sender.left(i); + title += QString(" - %1").arg(sender); + } + QString text = QtUi::style()->styleString(Message::mircToInternal(msg.text())).text; + displayTrayIconMessage(title, text); + QApplication::alert(this); + setTrayIconActivity(true); + } +} + +bool MainWin::event(QEvent *event) { + if(event->type() == QEvent::WindowActivate) + setTrayIconActivity(false); + return QMainWindow::event(event); +} + +void MainWin::displayTrayIconMessage(const QString &title, const QString &message) { + systray->showMessage(title, message); +} + +void MainWin::setTrayIconActivity(bool active) { + if(active) { + if(!timer->isActive()) + timer->start(500); + } else { + timer->stop(); + systray->setIcon(inactiveTrayIcon); + } +} + +void MainWin::makeTrayIconBlink() { + if(trayIconActive) { + systray->setIcon(inactiveTrayIcon); + trayIconActive = false; + } else { + systray->setIcon(activeTrayIcon); + trayIconActive = true; + } +} + + void MainWin::showNetworkDlg() { SettingsPageDlg dlg(new NetworksSettingsPage(this), this); dlg.exec();