X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fnicklistwidget.cpp;h=20051512c92e776c343050187a14eaf5cd61a691;hp=42cc3507c57840dd9df435e307ed998a77844a10;hb=b4f1d778d8ea3bf86ddf1764314132e5eb9ef296;hpb=7f8acf4ede38a0178a97eb701a9382e455ca7c2d diff --git a/src/qtui/nicklistwidget.cpp b/src/qtui/nicklistwidget.cpp index 42cc3507..20051512 100644 --- a/src/qtui/nicklistwidget.cpp +++ b/src/qtui/nicklistwidget.cpp @@ -20,58 +20,177 @@ #include "nicklistwidget.h" -#include "buffer.h" #include "nickview.h" #include "client.h" #include "networkmodel.h" +#include "buffermodel.h" #include "nickviewfilter.h" +#include "qtuisettings.h" + +#include +#include +#include +#include NickListWidget::NickListWidget(QWidget *parent) - : QWidget(parent), - _currentBuffer(0) + : AbstractItemView(parent) { ui.setupUi(this); } +QDockWidget *NickListWidget::dock() const { + QDockWidget *dock = qobject_cast(parent()); + if(dock) + return dock; + else + return 0; +} + +void NickListWidget::showWidget(bool visible) { + if(!selectionModel()) + return; -BufferId NickListWidget::currentBuffer() const { - return _currentBuffer; + QModelIndex currentIndex = selectionModel()->currentIndex(); + if(currentIndex.data(NetworkModel::BufferTypeRole) == BufferInfo::ChannelBuffer) { + QDockWidget *dock_ = dock(); + if(!dock_) + return; + + if(visible) + dock_->show(); + else + dock_->close(); + } } -void NickListWidget::setCurrentBuffer(BufferId bufferId) { - QModelIndex bufferIdx = Client::networkModel()->bufferIndex(bufferId); - - if(bufferIdx.data(NetworkModel::BufferTypeRole) != BufferItem::ChannelType) { +void NickListWidget::currentChanged(const QModelIndex ¤t, const QModelIndex &previous) { + BufferInfo::Type bufferType = (BufferInfo::Type)current.data(NetworkModel::BufferTypeRole).toInt(); + BufferId newBufferId = current.data(NetworkModel::BufferIdRole).value(); + BufferId oldBufferId = previous.data(NetworkModel::BufferIdRole).value(); + + if(bufferType != BufferInfo::ChannelBuffer) { ui.stackedWidget->setCurrentWidget(ui.emptyPage); return; } - if(nickViews.contains(bufferId)) { - ui.stackedWidget->setCurrentWidget(nickViews.value(bufferId)); + // See NickListDock::NickListDock() below +// if(bufferType != BufferInfo::ChannelBuffer) { +// ui.stackedWidget->setCurrentWidget(ui.emptyPage); +// QDockWidget *dock_ = dock(); +// if(dock_) { +// dock_->close(); +// } +// return; +// } else { +// QDockWidget *dock_ = dock(); +// if(dock_ && dock_->toggleViewAction()->isChecked()) { +// dock_->show(); +// } +// } + + if(newBufferId == oldBufferId) + return; + + if(nickViews.contains(newBufferId)) { + ui.stackedWidget->setCurrentWidget(nickViews.value(newBufferId)); } else { NickView *view = new NickView(this); - NickViewFilter *filter = new NickViewFilter(Client::networkModel()); + NickViewFilter *filter = new NickViewFilter(newBufferId, Client::networkModel()); view->setModel(filter); - view->setRootIndex(filter->mapFromSource(bufferIdx)); - nickViews[bufferId] = view; + QModelIndex source_current = Client::bufferModel()->mapToSource(current); + view->setRootIndex(filter->mapFromSource(source_current)); + nickViews[newBufferId] = view; ui.stackedWidget->addWidget(view); ui.stackedWidget->setCurrentWidget(view); } } -void NickListWidget::reset() { - foreach(NickView *view, nickViews.values()) { - ui.stackedWidget->removeWidget(view); - view->deleteLater(); +void NickListWidget::rowsAboutToBeRemoved(const QModelIndex &parent, int start, int end) { + Q_ASSERT(model()); + if(!parent.isValid()) { + // ok this means that whole networks are about to be removed + // we can't determine which buffers are affect, so we hope that all nets are removed + // this is the most common case (for example disconnecting from the core or terminating the clint) + NickView *nickView; + QHash::iterator iter = nickViews.begin(); + while(iter != nickViews.end()) { + nickView = *iter; + iter = nickViews.erase(iter); + ui.stackedWidget->removeWidget(nickView); + QAbstractItemModel *model = nickView->model(); + nickView->setModel(0); + if(QSortFilterProxyModel *filter = qobject_cast(model)) + filter->setSourceModel(0); + model->deleteLater(); + nickView->deleteLater(); + } + } else { + // check if there are explicitly buffers removed + for(int i = start; i <= end; i++) { + QVariant variant = parent.child(i,0).data(NetworkModel::BufferIdRole); + if(!variant.isValid()) + continue; + + BufferId bufferId = qVariantValue(variant); + removeBuffer(bufferId); + } } - nickViews.clear(); } void NickListWidget::removeBuffer(BufferId bufferId) { if(!nickViews.contains(bufferId)) return; - + NickView *view = nickViews.take(bufferId); ui.stackedWidget->removeWidget(view); + QAbstractItemModel *model = view->model(); + view->setModel(0); + if(QSortFilterProxyModel *filter = qobject_cast(model)) + filter->setSourceModel(0); + model->deleteLater(); view->deleteLater(); } + +QSize NickListWidget::sizeHint() const { + QWidget *currentWidget = ui.stackedWidget->currentWidget(); + if(!currentWidget || currentWidget == ui.emptyPage) + return QSize(100, height()); + else + return currentWidget->sizeHint(); +} + + +// ============================== +// NickList Dock +// ============================== +NickListDock::NickListDock(const QString &title, QWidget *parent) + : QDockWidget(title, parent) +{ + // THIS STUFF IS NEEDED FOR NICKLIST AUTOHIDE... + // AS THIS BRINGS LOTS OF FUCKUPS WITH IT IT'S DEACTIVATED FOR NOW... + +// QAction *toggleView = toggleViewAction(); +// disconnect(toggleView, SIGNAL(triggered(bool)), this, 0); +// toggleView->setChecked(QtUiSettings().value("ShowNickList", QVariant(true)).toBool()); + +// // reconnecting the closebuttons clicked signal to the action +// foreach(QAbstractButton *button, findChildren()) { +// if(disconnect(button, SIGNAL(clicked()), this, SLOT(close()))) +// connect(button, SIGNAL(clicked()), toggleView, SLOT(trigger())); +// } +} + +// NickListDock::~NickListDock() { +// QtUiSettings().setValue("ShowNickList", toggleViewAction()->isChecked()); +// } + +// bool NickListDock::event(QEvent *event) { +// switch (event->type()) { +// case QEvent::Hide: +// case QEvent::Show: +// emit visibilityChanged(event->type() == QEvent::Show); +// return QWidget::event(event); +// default: +// return QDockWidget::event(event); +// } +// }