projects
/
quassel.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Emit signal on selection change, ensure currentIndex is first item in selectedItems()
[quassel.git]
/
src
/
uisupport
/
nickview.cpp
diff --git
a/src/uisupport/nickview.cpp
b/src/uisupport/nickview.cpp
index
fd86abd
..
1a1c4bb
100644
(file)
--- a/
src/uisupport/nickview.cpp
+++ b/
src/uisupport/nickview.cpp
@@
-27,9
+27,11
@@
#include "buffermodel.h"
#include "client.h"
#include "buffermodel.h"
#include "client.h"
+#include "contextmenuactionprovider.h"
+#include "graphicalui.h"
+#include "nickview.h"
#include "nickviewfilter.h"
#include "networkmodel.h"
#include "nickviewfilter.h"
#include "networkmodel.h"
-#include "quasselui.h"
#include "types.h"
#include "uisettings.h"
#include "types.h"
#include "uisettings.h"
@@
-46,7
+48,6
@@
NickView::NickView(QWidget *parent)
setItemDelegate(newDelegate);
delete oldDelegate;
setItemDelegate(newDelegate);
delete oldDelegate;
-
setIndentation(10);
setAnimated(true);
header()->hide();
setIndentation(10);
setAnimated(true);
header()->hide();
@@
-73,10
+74,16
@@
void NickView::init() {
for(int i = 1; i < model()->columnCount(); i++)
setColumnHidden(i, true);
for(int i = 1; i < model()->columnCount(); i++)
setColumnHidden(i, true);
+
+ connect(selectionModel(), SIGNAL(currentChanged(QModelIndex, QModelIndex)), SIGNAL(selectionUpdated()));
+ connect(selectionModel(), SIGNAL(selectionChanged(QItemSelection, QItemSelection)), SIGNAL(selectionUpdated()));
}
}
-void NickView::setModel(QAbstractItemModel *model) {
- QTreeView::setModel(model);
+void NickView::setModel(QAbstractItemModel *model_) {
+ if(model())
+ disconnect(model(), 0, this, 0);
+
+ QTreeView::setModel(model_);
init();
}
init();
}
@@
-93,18
+100,22
@@
void NickView::setRootIndex(const QModelIndex &index) {
QCoreApplication::postEvent(this, new ExpandAllEvent);
}
QCoreApplication::postEvent(this, new ExpandAllEvent);
}
-void NickView::showContextMenu(const QPoint & pos ) {
- QModelIndex index = indexAt(pos);
- if(index.data(NetworkModel::ItemTypeRole) != NetworkModel::IrcUserItemType)
- return;
+QModelIndexList NickView::selectedIndexes() const {
+ QModelIndexList indexList = QTreeView::selectedIndexes();
- QModelIndexList indexList = selectedIndexes();
// make sure the item we clicked on is first
// make sure the item we clicked on is first
- indexList.removeAll(index);
- indexList.prepend(index);
+ Q_ASSERT(indexList.contains(currentIndex()));
+ indexList.removeAll(currentIndex());
+ indexList.prepend(currentIndex());
+
+ return indexList;
+}
+
+void NickView::showContextMenu(const QPoint &pos ) {
+ Q_UNUSED(pos);
QMenu contextMenu(this);
QMenu contextMenu(this);
-
Client::mainUi()->actionProvider()->addActions(&contextMenu, indexList
);
+
GraphicalUi::contextMenuActionProvider()->addActions(&contextMenu, selectedIndexes()
);
contextMenu.exec(QCursor::pos());
}
contextMenu.exec(QCursor::pos());
}
@@
-167,6
+178,9
@@
NickViewDelegate::NickViewDelegate(QObject *parent)
void NickViewDelegate::initStyleOption(QStyleOptionViewItem *option, const QModelIndex &index) const {
QStyledItemDelegate::initStyleOption(option, index);
void NickViewDelegate::initStyleOption(QStyleOptionViewItem *option, const QModelIndex &index) const {
QStyledItemDelegate::initStyleOption(option, index);
+ if(!index.isValid())
+ return;
+
QColor fgColor = _FgOnlineStatus;
if(!index.data(NetworkModel::ItemActiveRole).toBool())
fgColor = _FgAwayStatus;
QColor fgColor = _FgOnlineStatus;
if(!index.data(NetworkModel::ItemActiveRole).toBool())
fgColor = _FgAwayStatus;