X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fbufferwidget.h;h=089d498afce2ac00b234e51a9bc6247b12669d51;hp=72ece0dc0559a4cc69de57fb0d741cbc9bbd2a0e;hb=1b2d3ea62867220d7bffc3b23dda1dc14d429007;hpb=8699dd758516d0ded076811e8ea656adc95e69d0 diff --git a/src/qtui/bufferwidget.h b/src/qtui/bufferwidget.h index 72ece0dc..089d498a 100644 --- a/src/qtui/bufferwidget.h +++ b/src/qtui/bufferwidget.h @@ -23,18 +23,20 @@ #include "ui_bufferwidget.h" +#include "abstractitemview.h" #include "chatview.h" #include "types.h" -class Buffer; +class Network; class ChatView; class ChatWidget; -class LayoutThread; + +#include "buffermodel.h" //! Displays the contents of a Buffer. /** */ -class BufferWidget : public QWidget { +class BufferWidget : public AbstractItemView { Q_OBJECT public: @@ -42,31 +44,22 @@ public: virtual ~BufferWidget(); void init(); - QSize sizeHint() const; - -signals: - void userInput(QString msg); - void aboutToClose(); - -public slots: - void setBuffer(Buffer *); - void saveState(); + inline BufferId currentBuffer() const { return _currentBuffer; } + +protected slots: + virtual void currentChanged(const QModelIndex ¤t, const QModelIndex &previous); + virtual void rowsAboutToBeRemoved(const QModelIndex &parent, int start, int end); private slots: - void enterPressed(); - void setActive(bool act = true); - void bufferDestroyed(QObject *); - + void removeBuffer(BufferId bufferId); + void setCurrentBuffer(BufferId bufferId); private: Ui::BufferWidget ui; - //QHash _chatViews; - QHash _chatWidgets; - bool active; + QHash _chatWidgets; + QHash _chatViews; - QString _networkName; - QString _bufferName; + BufferId _currentBuffer; }; - #endif