// This file is part of RSS Guard. // // Copyright (C) 2011-2016 by Martin Rotter // // RSS Guard is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // RSS Guard is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with RSS Guard. If not, see . #ifndef MESSAGESMODEL_H #define MESSAGESMODEL_H #include #include "definitions/definitions.h" #include "core/message.h" #include "services/abstract/rootitem.h" #include #include class MessagesModel : public QSqlTableModel { Q_OBJECT public: // Enum which describes basic filtering schemes // for messages. enum MessageHighlighter { NoHighlighting = 100, HighlightUnread = 101, HighlightImportant = 102 }; // Constructors and destructors. explicit MessagesModel(QObject *parent = 0); virtual ~MessagesModel(); // Model implementation. QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const; QVariant data(int row, int column, int role = Qt::DisplayRole) const; QVariant headerData(int section, Qt::Orientation orientation, int role) const; Qt::ItemFlags flags(const QModelIndex &index) const; // Returns message at given index. Message messageAt(int row_index) const; int messageId(int row_index) const; RootItem::Importance messageImportance(int row_index) const; RootItem *loadedItem() const; void updateDateFormat(); void reloadWholeLayout(); // CORE messages manipulators. // NOTE: These are used to change properties of one message. // NOTE: Model is NOT reset after one of these methods are applied // but changes ARE written to the database. bool switchMessageImportance(int row_index); bool setMessageRead(int row_index, RootItem::ReadStatus read); // BATCH messages manipulators. // NOTE: These methods are used for changing of attributes of // many messages via DIRECT SQL calls. // NOTE: Model is reset after one of these methods is applied and // changes ARE written to the database. bool switchBatchMessageImportance(const QModelIndexList &messages); bool setBatchMessagesDeleted(const QModelIndexList &messages); bool setBatchMessagesRead(const QModelIndexList &messages, RootItem::ReadStatus read); bool setBatchMessagesRestored(const QModelIndexList &messages); // Fetches ALL available data to the model. void fetchAllData(); // Filters messages void highlightMessages(MessageHighlighter highlight); // Loads messages of given feeds. void loadMessages(RootItem *item); public slots: // NOTE: These methods DO NOT actually change data in the DB, just in the model. // These are particularly used by msg browser. bool setMessageImportantById(int id, RootItem::Importance important); bool setMessageReadById(int id, RootItem::ReadStatus read); private slots: // To disable persistent changes submissions. bool submitAll(); private: void setupHeaderData(); void setupFonts(); void setupIcons(); MessageHighlighter m_messageHighlighter; QString m_customDateFormat; RootItem *m_selectedItem; QList m_headerData; QList m_tooltipData; QFont m_normalFont; QFont m_boldFont; QIcon m_favoriteIcon; QIcon m_readIcon; QIcon m_unreadIcon; }; Q_DECLARE_METATYPE(MessagesModel::MessageHighlighter) #endif // MESSAGESMODEL_H