X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fmainwin.cpp;h=8220669f0462ba34f340c9fd7a32478abab67477;hp=c24120b94a90af6fdb5aab2a3e202f53c3a4a3a1;hb=a634acadbcf6017474f68a3eaf7cb632660e9e49;hpb=9fd4619e9aca7d53d7c5df156a0b25956a1bf682 diff --git a/src/qtui/mainwin.cpp b/src/qtui/mainwin.cpp index c24120b9..8220669f 100644 --- a/src/qtui/mainwin.cpp +++ b/src/qtui/mainwin.cpp @@ -31,6 +31,9 @@ #include "topicwidget.h" +#include "selectionmodelsynchronizer.h" +#include "mappedselectionmodel.h" + MainWin::MainWin(QtUi *_gui, QWidget *parent) : QMainWindow(parent), gui(_gui) { ui.setupUi(this); setWindowTitle("Quassel IRC"); @@ -39,7 +42,9 @@ MainWin::MainWin(QtUi *_gui, QWidget *parent) : QMainWindow(parent), gui(_gui) { setWindowIconText("Quassel IRC"); statusBar()->showMessage(tr("Waiting for core...")); - + serverListDlg = new ServerListDlg(this); + settingsDlg = new SettingsDlg(this); + } void MainWin::init() { @@ -79,27 +84,32 @@ void MainWin::init() { showCoreConnectionDlg(true); // autoconnect if appropriate //ui.actionConnectCore->activate(QAction::Trigger); - serverListDlg = new ServerListDlg(this); if(serverListDlg->showOnStartup()) { showServerList(); } - + + setDockNestingEnabled(true); + + // TESTING -// setCorner(Qt::TopLeftCorner, Qt::LeftDockWidgetArea); -// setCorner(Qt::BottomLeftCorner, Qt::LeftDockWidgetArea); + setCorner(Qt::TopLeftCorner, Qt::LeftDockWidgetArea); + setCorner(Qt::BottomLeftCorner, Qt::LeftDockWidgetArea); -// setCorner(Qt::TopRightCorner, Qt::RightDockWidgetArea); -// setCorner(Qt::BottomRightCorner, Qt::RightDockWidgetArea); - -// QDockWidget *dock = new QDockWidget("Topic Dock", this); -// dock->setAllowedAreas(Qt::TopDockWidgetArea | Qt::BottomDockWidgetArea); + setCorner(Qt::TopRightCorner, Qt::RightDockWidgetArea); + setCorner(Qt::BottomRightCorner, Qt::RightDockWidgetArea); -// TopicWidget *topicwidget = new TopicWidget(dock); -// dock->setWidget(topicwidget); - -// addDockWidget(Qt::TopDockWidgetArea, dock); -// ui.menuViews->addAction(dock->toggleViewAction()); + QDockWidget *dock = new QDockWidget("Topic Dock", this); + dock->setAllowedAreas(Qt::TopDockWidgetArea | Qt::BottomDockWidgetArea); + + TopicWidget *topicwidget = new TopicWidget(dock); + dock->setWidget(topicwidget); + + Client::bufferModel()->mapProperty(0, Qt::DisplayRole, topicwidget, "topic"); + + addDockWidget(Qt::TopDockWidgetArea, dock); + + ui.menuViews->addAction(dock->toggleViewAction()); } @@ -156,6 +166,7 @@ void MainWin::addBufferView(const QString &viewname, QAbstractItemModel *model, //create the view and initialize it's filter BufferView *view = new BufferView(dock); view->setFilteredModel(model, mode, nets); + Client::bufferModel()->synchronizeView(view); dock->setWidget(view); addDockWidget(Qt::LeftDockWidgetArea, dock);