_hideModeAction(tr("Mode Events"), this)
{
- // currently no events can be hidden -> disable actions
_hideJoinAction.setCheckable(true);
_hidePartAction.setCheckable(true);
_hideKillAction.setCheckable(true);
_hideQuitAction.setEnabled(false);
_hideModeAction.setEnabled(false);
+ showChannelList.setIcon(QIcon(":/16x16/actions/oxygen/16x16/actions/format-list-unordered.png"));
+
+ connect(this, SIGNAL(collapsed(const QModelIndex &)), this, SLOT(on_collapse(const QModelIndex &)));
+ connect(this, SIGNAL(expanded(const QModelIndex &)), this, SLOT(on_expand(const QModelIndex &)));
+
setSelectionMode(QAbstractItemView::ExtendedSelection);
}
void BufferView::setModel(QAbstractItemModel *model) {
delete selectionModel();
- if(QTreeView::model()) {
- disconnect(QTreeView::model(), SIGNAL(layoutChanged()), this, SLOT(layoutChanged()));
- }
QTreeView::setModel(model);
init();
if(!model)
return;
- connect(model, SIGNAL(layoutChanged()), this, SLOT(layoutChanged()));
-
QString sectionName;
QAction *showSection;
for(int i = 1; i < model->columnCount(); i++) {
if(model()) {
disconnect(this, 0, model(), 0);
+ disconnect(model(), 0, this, 0);
}
if(!model_) {
} else {
BufferViewFilter *filter = new BufferViewFilter(model_, config);
setModel(filter);
+ connect(filter, SIGNAL(configChanged()), this, SLOT(on_configChanged()));
}
setConfig(config);
}
}
}
-void BufferView::layoutChanged() {
+void BufferView::on_configChanged() {
Q_ASSERT(model());
- // expand all active networks
+ // expand all active networks... collapse inactive ones... unless manually changed
QModelIndex networkIdx;
+ NetworkId networkId;
for(int row = 0; row < model()->rowCount(); row++) {
networkIdx = model()->index(row, 0);
+ if(model()->rowCount(networkIdx) == 0)
+ continue;
+
+ networkId = model()->data(networkIdx, NetworkModel::NetworkIdRole).value<NetworkId>();
+ if(!networkId.isValid())
+ continue;
+
update(networkIdx);
- if(model()->rowCount(networkIdx) > 0 && model()->data(networkIdx, NetworkModel::ItemActiveRole) == true) {
+
+ bool expandNetwork = false;
+ if(_expandedState.contains(networkId))
+ expandNetwork = _expandedState[networkId];
+ else
+ expandNetwork = model()->data(networkIdx, NetworkModel::ItemActiveRole).toBool();
+
+ if(expandNetwork)
expand(networkIdx);
- } else {
+ else
collapse(networkIdx);
- }
}
// update selection to current one
mappedSelectionModel->mappedSelect(Client::bufferModel()->standardSelectionModel()->selection(), QItemSelectionModel::ClearAndSelect | QItemSelectionModel::Rows);
}
+void BufferView::on_collapse(const QModelIndex &index) {
+ storeExpandedState(index.data(NetworkModel::NetworkIdRole).value<NetworkId>(), false);
+}
+
+void BufferView::on_expand(const QModelIndex &index) {
+ storeExpandedState(index.data(NetworkModel::NetworkIdRole).value<NetworkId>(), true);
+}
+
+void BufferView::storeExpandedState(NetworkId networkId, bool expanded) {
+ _expandedState[networkId] = expanded;
+}
+
void BufferView::dataChanged(const QModelIndex &topLeft, const QModelIndex &bottomRight) {
QTreeView::dataChanged(topLeft, bottomRight);
return;
for(int i = topLeft.row(); i <= bottomRight.row(); i++) {
- QModelIndex networkIdx = topLeft.sibling(topLeft.row(), 0);
+ QModelIndex networkIdx = topLeft.sibling(i, 0);
if(model()->rowCount(networkIdx) == 0)
continue;
}
}
-
void BufferView::toggleHeader(bool checked) {
QAction *action = qobject_cast<QAction *>(sender());
header()->setSectionHidden((action->property("column")).toInt(), !checked);
if(!index.isValid())
return false;
-// NetworkModel::itemTypes itemType = static_cast<NetworkModel::itemTypes>(index.data(NetworkModel::ItemTypeRole).toInt());
-// if(!(itemType & validItemTypes))
-// return false;
-
ItemActiveStates isActive = index.data(NetworkModel::ItemActiveRole).toBool()
? ActiveState
: InactiveState;
return hideEventsMenu;
}
-//void BufferView::showContextMenu(const QPoint &pos) {
void BufferView::contextMenuEvent(QContextMenuEvent *event) {
QModelIndex index = indexAt(event->pos());
+ if(!index.isValid())
+ index = rootIndex();
if(!index.isValid())
return;
_disconnectNetAction.setIcon(connectionStateIcon);
_connectNetAction.setIcon(connectionStateIcon);
addItemToMenu(showChannelList, contextMenu, index, ActiveState);
- addItemToMenu(_disconnectNetAction, contextMenu, index, ActiveState);
- addItemToMenu(_connectNetAction, contextMenu, index, InactiveState);
+ addItemToMenu(_disconnectNetAction, contextMenu, network->connectionState() != Network::Disconnected);
+ addItemToMenu(_connectNetAction, contextMenu, network->connectionState() == Network::Disconnected);
addSeparatorToMenu(contextMenu, index, ActiveState);
addItemToMenu(_joinChannelAction, contextMenu, index, ActiveState);
break;
QString channelName = QInputDialog::getText(this, tr("Join Channel"), tr("Input channel name:"), QLineEdit::Normal, QString(), &ok);
if(ok && !channelName.isEmpty()) {
Client::instance()->userInput(BufferInfo::fakeStatusBuffer(index.data(NetworkModel::NetworkIdRole).value<NetworkId>()), QString("/J %1").arg(channelName));
-// BufferInfo bufferInfo = index.child(0,0).data(NetworkModel::BufferInfoRole).value<BufferInfo>();
-// if(bufferInfo.isValid()) {
-// Client::instance()->userInput(bufferInfo, QString("/J %1").arg(channelName));
-// }
}
#endif
return;