We finally got a nice solution to synchronize multiple views or whatevers[tm] even...
[quassel.git] / src / client / buffertreemodel.h
index 602cf57..f300d98 100644 (file)
 #include <QtCore>
 
 #include "treemodel.h"
 #include <QtCore>
 
 #include "treemodel.h"
-class BufferInfo;
 #include "buffer.h"
 
 #include "buffer.h"
 
+#include <QItemSelectionModel>
+
+class BufferInfo;
+class SelectionModelSynchronizer;
+
+
 /*****************************************
  *  Fancy Buffer Items
  *****************************************/
 /*****************************************
  *  Fancy Buffer Items
  *****************************************/
@@ -84,17 +89,18 @@ public:
   
   BufferTreeModel(QObject *parent = 0);
   static QList<QVariant> defaultHeader();
   
   BufferTreeModel(QObject *parent = 0);
   static QList<QVariant> defaultHeader();
-  
+
+  inline SelectionModelSynchronizer *selectionModelSynchronizer() { return _selectionModelSynchronizer; }
+
 public slots:
 public slots:
-  void bufferUpdated(Buffer *);    
-  void changeCurrent(const QModelIndex &, const QModelIndex &);
+  void bufferUpdated(Buffer *);
+  void setCurrentIndex(const QModelIndex &index, QItemSelectionModel::SelectionFlags command);
   void selectBuffer(Buffer *buffer);
   void bufferActivity(Buffer::ActivityLevel, Buffer *buffer);
   
 signals:
   void bufferSelected(Buffer *);
   void invalidateFilter();
   void selectBuffer(Buffer *buffer);
   void bufferActivity(Buffer::ActivityLevel, Buffer *buffer);
   
 signals:
   void bufferSelected(Buffer *);
   void invalidateFilter();
-  void fakeUserInput(BufferInfo, QString);
   void selectionChanged(const QModelIndex &);
     
 private:
   void selectionChanged(const QModelIndex &);
     
 private:
@@ -106,7 +112,8 @@ private:
   QStringList mimeTypes() const;
   QMimeData *mimeData(const QModelIndexList &) const;
   bool dropMimeData(const QMimeData *, Qt::DropAction, int, int, const QModelIndex &);
   QStringList mimeTypes() const;
   QMimeData *mimeData(const QModelIndexList &) const;
   bool dropMimeData(const QMimeData *, Qt::DropAction, int, int, const QModelIndex &);
-  
+
+  SelectionModelSynchronizer *_selectionModelSynchronizer;
   Buffer *currentBuffer;
 };
 
   Buffer *currentBuffer;
 };