67d1820e0e3124fc7c9cae4540bdd29c6bf0f640
[toast/confclerk.git] / src / mvc / eventmodel.h
1 #ifndef EVENTMODEL_H
2 #define EVENTMODEL_H
3
4 #include <QAbstractItemModel>
5
6 #include "event.h"
7
8 class EventModel : public QAbstractItemModel
9 {
10 public:
11     static const QString COMMA_SEPARATOR;
12 public:
13     EventModel();
14     QVariant data(const QModelIndex& index, int role) const;
15     QModelIndex index(int row, int column, const QModelIndex & parent = QModelIndex()) const;
16     QModelIndex parent ( const QModelIndex & index ) const;
17     int columnCount ( const QModelIndex & parent = QModelIndex() ) const;
18     int rowCount ( const QModelIndex & parent = QModelIndex() ) const;
19     void loadEvents(const QDate &aDate, int aConferenceId); // loads Events from the DB
20     void loadFavEvents(const QDate &aDate, int aConferenceId); // loads Favourite events from the DB
21     void loadEventsByTrack(const QDate &aDate, int aConferenceId); // loads Events sorted by Track id and Event start from the DB
22     int loadSearchResultEvents(const QDate &aDate, int aConferenceId);
23     void loadNowEvents(int aConferenceId); // loads Now events from the DB
24     void loadEventsByRoom(const QDate &aDate, int aConferenceId);
25
26 private:
27     struct Group
28     {
29         Group(const QString & title,
30               int firstEventIndex) :
31
32             mTitle(title),
33             mFirstEventIndex(firstEventIndex),
34             mChildCount(0)
35         {}
36
37         QString mTitle;
38         int mFirstEventIndex;
39         int mChildCount;
40     };
41
42 private:
43     void createTimeGroups();
44     void createTrackGroups();
45     void createTrackGroupsNew();
46     void clearModel();
47     void createRoomGroups();
48
49 public slots:
50     void updateModel(int aEventId);
51
52 private:
53     QList<Event> mEvents;
54     QList<Group> mGroups;
55     QHash<int, int> mParents;
56 };
57
58 #endif // EVENTMODEL_H
59