X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fuisupport%2Fbufferview.h;h=82db16d0b6a5723858531d98b791ff0f4c0e5f85;hp=4a752c7058708e098bb3290a1e678b00afaf6cc3;hb=4fdf00a414eba03fb95cade3aca3ba53705c7b97;hpb=8699dd758516d0ded076811e8ea656adc95e69d0 diff --git a/src/uisupport/bufferview.h b/src/uisupport/bufferview.h index 4a752c70..82db16d0 100644 --- a/src/uisupport/bufferview.h +++ b/src/uisupport/bufferview.h @@ -18,13 +18,20 @@ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ -#ifndef _BUFFERVIEW_H_ -#define _BUFFERVIEW_H_ +#ifndef BUFFERVIEW_H_ +#define BUFFERVIEW_H_ -#include -#include +#include +#include +#include +#include +#include +#include -#include "bufferviewfilter.h" +#include "bufferviewconfig.h" +#include "networkmodel.h" + +#include "types.h" /***************************************** * The TreeView showing the Buffers @@ -35,19 +42,84 @@ class BufferView : public QTreeView { public: BufferView(QWidget *parent = 0); void init(); + void setModel(QAbstractItemModel *model); - void setFilteredModel(QAbstractItemModel *model, BufferViewFilter::Modes mode, QList nets); + void setFilteredModel(QAbstractItemModel *model, BufferViewConfig *config); + virtual void setSelectionModel(QItemSelectionModel *selectionModel); + + void setConfig(BufferViewConfig *config); + inline BufferViewConfig *config() { return _config; } + +public slots: + void setRootIndexForNetworkId(const NetworkId &networkId); + void removeSelectedBuffers(); signals: void removeBuffer(const QModelIndex &); - + +protected: + virtual void keyPressEvent(QKeyEvent *); + virtual void rowsInserted (const QModelIndex & parent, int start, int end); + virtual void dataChanged(const QModelIndex &topLeft, const QModelIndex &bottomRight); + virtual void wheelEvent(QWheelEvent *); + virtual QSize sizeHint() const; + virtual void focusInEvent(QFocusEvent *event) { QAbstractScrollArea::focusInEvent(event); } + virtual void contextMenuEvent(QContextMenuEvent *event); + private slots: void joinChannel(const QModelIndex &index); - void keyPressEvent(QKeyEvent *); - void rowsInserted (const QModelIndex & parent, int start, int end); void toggleHeader(bool checked); + // void showContextMenu(const QPoint &); + void layoutChanged(); + +private: + enum itemActiveState { + inactiveState = 0x01, + activeState = 0x02 + }; + Q_DECLARE_FLAGS(itemActiveStates, itemActiveState); + + QPointer _config; + + QAction _connectNetAction; + QAction _disconnectNetAction; + QAction _joinChannelAction; + + QAction _joinBufferAction; + QAction _partBufferAction; + QAction _hideBufferAction; + QAction _removeBufferAction; + QAction _ignoreListAction; + + QAction _hideJoinAction; + QAction _hidePartAction; + QAction _hideKillAction; + QAction _hideQuitAction; + QAction _hideModeAction; + + bool checkRequirements(const QModelIndex &index, itemActiveStates requiredActiveState = activeState | inactiveState); + void addItemToMenu(QAction &action, QMenu &menu, const QModelIndex &index, itemActiveStates requiredActiveState = activeState | inactiveState); + void addItemToMenu(QAction &action, QMenu &menu, bool condition = true); + void addItemToMenu(QMenu &subMenu, QMenu &menu, const QModelIndex &index, itemActiveStates requiredActiveState = activeState | inactiveState); + void addSeparatorToMenu(QMenu &menu, const QModelIndex &index, itemActiveStates requiredActiveState = activeState | inactiveState); + QMenu *createHideEventsSubMenu(QMenu &menu); }; +Q_DECLARE_OPERATORS_FOR_FLAGS(BufferView::itemActiveStates); + + +// ============================== +// BufferView Dock +// ============================== +class BufferViewDock : public QDockWidget { + Q_OBJECT + +public: + BufferViewDock(BufferViewConfig *config, QWidget *parent); + BufferViewDock(QWidget *parent); +public slots: + void bufferViewRenamed(const QString &newName); +}; #endif