projects
/
quassel.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Add 16x16 icons for context menu actions
[quassel.git]
/
src
/
uisupport
/
nickview.cpp
diff --git
a/src/uisupport/nickview.cpp
b/src/uisupport/nickview.cpp
index
98fbee3
..
e27640e
100644
(file)
--- a/
src/uisupport/nickview.cpp
+++ b/
src/uisupport/nickview.cpp
@@
-48,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();
@@
-75,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();
}
@@
-95,18
+100,23
@@
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);
+ if(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);
- GraphicalUi::contextMenuActionProvider()->addActions(&contextMenu,
indexList
);
+ GraphicalUi::contextMenuActionProvider()->addActions(&contextMenu,
selectedIndexes()
);
contextMenu.exec(QCursor::pos());
}
contextMenu.exec(QCursor::pos());
}