X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;ds=sidebyside;f=src%2Fclient%2Fnetworkmodel.h;h=c3dbaf472480208f9c80277524240c1cbe9dedaa;hb=d3ea803d8977692f95bbe31fbaba3686fc2ce5a9;hp=b1cc15f0511c1af29a4f5fe75b367629d8b27647;hpb=d1b6499b0b848d4287efae89107576548533502c;p=quassel.git diff --git a/src/client/networkmodel.h b/src/client/networkmodel.h index b1cc15f0..c3dbaf47 100644 --- a/src/client/networkmodel.h +++ b/src/client/networkmodel.h @@ -32,6 +32,8 @@ class BufferInfo; #include "selectionmodelsynchronizer.h" #include "modelpropertymapper.h" +#include "clientsettings.h" + class MappedSelectionModel; class QAbstractItemView; class Network; @@ -53,6 +55,7 @@ public: const BufferInfo &bufferInfo() const; virtual quint64 id() const; virtual QVariant data(int column, int role) const; + virtual bool setData(int column, const QVariant &value, int role); void attachIrcChannel(IrcChannel *ircChannel); @@ -80,8 +83,12 @@ public: Q_DECLARE_FLAGS(ActivityLevel, Activity) ActivityLevel activity() const; - void setActivity(const ActivityLevel &level); - void addActivity(const ActivityLevel &level); + bool setActivity(const ActivityLevel &level); + void updateActivity(const ActivityLevel &level); + + void setLastMsgInsert(QDateTime msgDate); + bool setLastSeen(); + QDateTime lastSeen(); public slots: void setTopic(const QString &topic); @@ -94,11 +101,14 @@ public slots: private slots: void ircChannelDestroyed(); + void ircUserDestroyed(); private: BufferInfo _bufferInfo; ActivityLevel _activity; Type _type; + QDateTime _lastMsgInsert; + QDateTime _lastSeen; QPointer _ircChannel; }; @@ -116,8 +126,8 @@ class NetworkItem : public PropertyMapItem { public: NetworkItem(const NetworkId &netid, AbstractTreeItem *parent = 0); - virtual QVariant data(int column, int row) const; virtual quint64 id() const; + virtual QVariant data(int column, int row) const; bool isActive() const; @@ -131,6 +141,8 @@ public slots: void attachNetwork(Network *network); void attachIrcChannel(const QString &channelName); + + void setActive(bool connected); private: NetworkId _networkId; @@ -150,14 +162,13 @@ public: QString categoryId(); virtual quint64 id() const; - + virtual QVariant data(int column, int role) const; + void addUser(IrcUser *ircUser); + bool removeUser(IrcUser *ircUser); static int categoryFromModes(const QString &modes); -private slots: - void checkNoChilds(); - private: int _category; @@ -180,16 +191,20 @@ class IrcUserItem : public PropertyMapItem { public: IrcUserItem(IrcUser *ircUser, AbstractTreeItem *parent); - QString nickName(); + QString nickName() const; + bool isActive() const; + IrcUser *ircUser(); virtual quint64 id() const; - + virtual QVariant data(int column, int role) const; + virtual QString toolTip(int column) const; + private slots: void setNick(QString newNick); - void ircUserDestroyed(); private: - IrcUser *_ircUser; + QPointer _ircUser; + quint64 _id; }; @@ -203,17 +218,19 @@ public: enum myRoles { BufferTypeRole = Qt::UserRole, ItemActiveRole, + BufferActivityRole, BufferIdRole, NetworkIdRole, - ItemTypeRole + BufferInfoRole, + ItemTypeRole, + LastSeenRole }; enum itemTypes { - AbstractItemType, - SimpleItemType, NetworkItemType, BufferItemType, - NickItemType + UserCategoryItemType, + IrcUserItemType }; NetworkModel(QObject *parent = 0); @@ -232,10 +249,13 @@ public: //Buffer *getBufferByIndex(const QModelIndex &) const; QModelIndex bufferIndex(BufferId bufferId); + const Network *networkByIndex(const QModelIndex &index) const; + public slots: void bufferUpdated(BufferInfo bufferInfo); - void bufferActivity(BufferItem::ActivityLevel, BufferInfo bufferInfo); - + void updateBufferActivity(const Message &msg); + void networkRemoved(const NetworkId &networkId); + private: QModelIndex networkIndex(NetworkId networkId); NetworkItem *networkItem(NetworkId networkId);