implemented JOINing two tables
[toast/confclerk.git] / src / mvc / event.h
index 76216e7..4089f4f 100644 (file)
@@ -18,13 +18,18 @@ class Event : public OrmRecord<Event>
 {
 public:
     static QSqlRecord const sColumns;
-    static QString const sTableName;
+    //static QString const sTableName;
+    static QString const sTable1Name;
+    static QString const sTable2Name;
+    static int const sTable1ColCount;
+    static int const sTable2ColCount;
 
 public:
     static Event getById(int id, int conferenceId);
     static QList<Event> getByDate(const QDate& date, int conferenceId);
 
 public:
+    // Table 1
     int id() const { return value("id").toInt(); }
     int conferenceId() const { return value("xid_conference").toInt(); }
     QDateTime start() const { return value("start").toDateTime(); }
@@ -33,7 +38,14 @@ public:
     QString type() const { return value("type").toString(); }
     QString language() const { return value("language").toString(); }
     bool isFavourite() const { return value("favourite").toBool(); }
+    // Table 2 : virtual table for FTS (Full Text Search)
+    QString tag() const { return value("tag").toString(); }
+    QString title() const { return value("title").toString(); }
+    QString subtitle() const { return value("subtitle").toString(); }
+    QString abstract() const { return value("abstract").toString(); }
+    QString description() const { return value("description").toString(); }
 
+    // Table 1
     void setId(int id) { setValue("id", id); }
     void setConferenceId(int conferenceId) { setValue("xid_conference", conferenceId); }
     void setStart(const QDateTime& start) { setValue("start", start); }
@@ -42,6 +54,12 @@ public:
     void setType(const QString& type) { setValue("type", type); }
     void setLanguage(const QString& language) { setValue("language", language); }
     void setFavourite(bool favourite) { setValue("favourite", favourite); }
+    // Table 2 : virtual table for FTS (Full Text Search)
+    void setTag(const QString& tag) { setValue("tag", tag); }
+    void setTitle(const QString& title) { setValue("title", title); }
+    void setSubtitle(const QString& subtitle) { setValue("subtitle", subtitle); }
+    void setAbstract(const QString& abstract) { setValue("abstract", abstract); }
+    void setDescription(const QString& description) { setValue("description", description); }
 
 friend class EventTest;
 };