1 /***************************************************************************
2 * Copyright (C) 2005-2016 by the Quassel Project *
3 * devel@quassel-irc.org *
5 * This program is free software; you can redistribute it and/or modify *
6 * it under the terms of the GNU General Public License as published by *
7 * the Free Software Foundation; either version 2 of the License, or *
8 * (at your option) version 3. *
10 * This program is distributed in the hope that it will be useful, *
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13 * GNU General Public License for more details. *
15 * You should have received a copy of the GNU General Public License *
16 * along with this program; if not, write to the *
17 * Free Software Foundation, Inc., *
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
19 ***************************************************************************/
26 #include <QDockWidget>
27 #include <QModelIndex>
28 #include <QStyledItemDelegate>
31 #include "actioncollection.h"
32 #include "bufferviewconfig.h"
33 #include "networkmodel.h"
34 #include "treeviewtouch.h"
37 /*****************************************
38 * The TreeView showing the Buffers
39 *****************************************/
40 class BufferView : public TreeViewTouch
50 BufferView(QWidget *parent = 0);
53 void setModel(QAbstractItemModel *model);
54 void setFilteredModel(QAbstractItemModel *model, BufferViewConfig *config);
56 void setConfig(BufferViewConfig *config);
57 inline BufferViewConfig *config() { return _config; }
59 void addActionsToMenu(QMenu *menu, const QModelIndex &index);
60 void addFilterActions(QMenu *contextMenu, const QModelIndex &index);
62 void selectFirstBuffer();
65 void setRootIndexForNetworkId(const NetworkId &networkId);
66 void removeSelectedBuffers(bool permanently = false);
67 void menuActionTriggered(QAction *);
69 void previousBuffer();
70 void hideCurrentBuffer();
71 void filterTextChanged(QString filterString);
74 void removeBuffer(const QModelIndex &);
75 void removeBufferPermanently(const QModelIndex &);
78 virtual void keyPressEvent(QKeyEvent *);
79 virtual void dropEvent(QDropEvent *event);
80 virtual void rowsInserted(const QModelIndex &parent, int start, int end);
81 virtual void wheelEvent(QWheelEvent *);
82 virtual QSize sizeHint() const;
83 virtual void focusInEvent(QFocusEvent *event) { QAbstractScrollArea::focusInEvent(event); }
84 virtual void contextMenuEvent(QContextMenuEvent *event);
86 #if QT_VERSION < 0x050000
87 virtual void dataChanged(const QModelIndex &topLeft, const QModelIndex &bottomRight);
89 virtual void dataChanged(const QModelIndex &topLeft, const QModelIndex &bottomRight, const QVector<int> &roles);
93 void joinChannel(const QModelIndex &index);
94 void toggleHeader(bool checked);
97 * Expand all active networks and collapse inactive ones unless manually changed
99 * Applies to all networks. Shouldn't need called except during initialization.
101 void setExpandedState();
104 * Save the current display state of the given network
106 * Tracks expanded or collapsed and active or inactive.
108 * @see setExpandedState()
109 * @param[in] networkIdx QModelIndex of the root network to store
111 void storeExpandedState(const QModelIndex &networkIdx);
114 * Set the display state of the given network according to network status and manual changes
116 * Expands if active or previously expanded, collapses if inactive or previously collapsed.
118 * @see storeExpandedState()
119 * @param[in] networkIdx QModelIndex of the root network to update
121 void setExpandedState(const QModelIndex &networkIdx);
123 void on_configChanged();
124 void on_layoutChanged();
126 void changeBuffer(Direction direction);
129 QPointer<BufferViewConfig> _config;
135 QHash<NetworkId, short> _expandedState;
139 // ******************************
141 // ******************************
143 class BufferViewDelegate : public QStyledItemDelegate
148 BufferViewDelegate(QObject *parent = 0);
149 bool editorEvent(QEvent *event, QAbstractItemModel *model, const QStyleOptionViewItem &option, const QModelIndex &index);
152 virtual void customEvent(QEvent *event);
156 // ==============================
158 // ==============================
159 class BufferViewDock : public QDockWidget
162 Q_PROPERTY(bool active READ isActive WRITE setActive STORED true)
165 BufferViewDock(BufferViewConfig *config, QWidget *parent);
167 int bufferViewId() const;
168 BufferViewConfig *config() const;
169 inline BufferView *bufferView() const { return qobject_cast<BufferView *>(widget()); }
170 inline bool isActive() const { return _active; }
171 void setWidget(QWidget *newWidget);
172 QWidget *widget() const { return _childWidget; }
174 void activateFilter();
177 void setActive(bool active = true);
180 virtual bool eventFilter(QObject *object, QEvent *event);
181 virtual void focusInEvent(QFocusEvent*event) { qDebug() << event; }
184 void bufferViewRenamed(const QString &newName);
186 void configChanged();
187 void onFilterReturnPressed();
190 QWidget *_childWidget;
192 QPointer<QWidget> _oldFocusItem; // QPointer in case the old item gets deleted
193 QLineEdit *_filterEdit;