Update GPL blurb in source files.
[toast/confclerk.git] / src / gui / tabcontainer.cpp
index 993b9a2..945db73 100644 (file)
@@ -1,30 +1,42 @@
+/*
+ * Copyright (C) 2010 Ixonos Plc.
+ *
+ * This file is part of ConfClerk.
+ *
+ * ConfClerk 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 2 of the License, or (at your option)
+ * any later version.
+ *
+ * ConfClerk 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
+ * ConfClerk.  If not, see <http://www.gnu.org/licenses/>.
+ */
 #include "tabcontainer.h"
 
 #include <QFile>
 #include <QMessageBox>
 #include <QTimer>
 
-#include <sqlengine.h>
-#include <appsettings.h>
-
-#include <conference.h>
-
 #include <treeview.h>
-#include <eventmodel.h>
 #include <delegate.h>
 
 #include "eventdialog.h"
 #include "mapwindow.h"
+#include "room.h"
+#include "errormessage.h"
+
+#include "conflictsdialog.h"
 
 TabContainer::TabContainer(QWidget *aParent)
     : QWidget(aParent)
-    , mType(EContainerTypeNone)
 {
     setupUi(this);
 
-    searchAgainButton->hide();
-    searchHead->hide();
-
     treeView->setHeaderHidden(true);
     treeView->setRootIsDecorated(false);
     treeView->setIndentation(0);
@@ -34,99 +46,24 @@ TabContainer::TabContainer(QWidget *aParent)
 
     connect(dayNavigator, SIGNAL(dateChanged(const QDate &)), SLOT(updateTreeView(const QDate &)));
 
-    connect(treeView, SIGNAL(eventHasChanged(int)), SIGNAL(eventHasChanged(int)));
+    connect(treeView, SIGNAL(eventHasChanged(int,bool)), SIGNAL(eventHasChanged(int,bool)));
     connect(treeView, SIGNAL(clicked(const QModelIndex &)), SLOT(itemClicked(const QModelIndex &)));
     connect(treeView, SIGNAL(requestForMap(const QModelIndex &)), SLOT(displayMap(const QModelIndex &)));
-    connect(treeView, SIGNAL(requestForWarning(const QModelIndex &)), SLOT(displayWarning(const QModelIndex &)));
-
-    connect(searchButton, SIGNAL(clicked()), SLOT(searchClicked()));
-    connect(searchAgainButton, SIGNAL(clicked()), SLOT(searchAgainClicked()));
-
-    if(!Conference::getAll().count()) // no conference(s) in the DB
-    {
-        dayNavigator->hide(); // hide DayNavigatorWidget
-    }
-    else
-    {
-        QDate aStartDate = Conference::getById(AppSettings::confId()).start();
-        QDate aEndDate = Conference::getById(AppSettings::confId()).end();
-        dayNavigator->setDates(aStartDate, aEndDate);
-    }
-}
-
-void TabContainer::setType(TabContainer::Type aType)
-{
-    mType = aType;
+    connect(treeView, SIGNAL(requestForConflicts(const QModelIndex &)), SLOT(displayConflicts(const QModelIndex &)));
 
-    if(aType == EContainerTypeNow)
-    {
-        QTimer *timer = new QTimer( this );
-        connect( timer, SIGNAL(timeout()), SLOT(timerUpdateTreeView()) );
-        timer->start( 30000); // 30 seconds timer
-    }
-    if(aType == EContainerTypeSearch)
-    {
-        searchHead->show();
-    }
+    // day navigator is hidden by default
+    dayNavigator->hide();
 }
 
 void TabContainer::updateTreeView(const QDate &aDate)
 {
-    switch(mType)
-    {
-        case EContainerTypeDay:
-            {
-                static_cast<EventModel*>(treeView->model())->loadEvents(aDate,AppSettings::confId());
-            }
-            break;
-        case EContainerTypeFavs:
-            {
-                static_cast<EventModel*>(treeView->model())->loadFavEvents(aDate,AppSettings::confId());
-            }
-            break;
-        case EContainerTypeTracks:
-            {
-                static_cast<EventModel*>(treeView->model())->loadEventsByTrack(aDate, AppSettings::confId());
-            }
-            break;
-        case EContainerTypeRooms:
-            {
-                static_cast<EventModel*>(treeView->model())->loadEventsByRoom(aDate, AppSettings::confId());
-            }
-            break;
-        case EContainerTypeNow:
-            {
-                static_cast<EventModel*>(treeView->model())->loadNowEvents(AppSettings::confId());
-                treeView->setAllExpanded(true);
-            }
-            break;
-        case EContainerTypeSearch:
-            {
-                treeView->reset();
-                int eventsCount = static_cast<EventModel*>(treeView->model())->loadSearchResultEvents(aDate,AppSettings::confId());
-                if( eventsCount ||
-                        dayNavigator->getCurrentDate() != Conference::getById(AppSettings::confId()).start() ){
-                    searchAgainButton->show();
-                    dayNavigator->show();
-                    treeView->show();
-                    searchHead->hide();
-                }
-                else{
-                    treeView->hide();
-                    searchAgainButton->hide();
-                    dayNavigator->hide();
-                    searchHead->show();
-                }
-            }
-            break;
-        case EContainerTypeNone:
-        default:
-            {
-                qDebug() << "Container type not specified";
-            }
-    }
-    treeView->reset();
+    int active_id = Conference::activeConference();
     dayNavigator->show();
+    if (active_id > 0) {
+        loadEvents(aDate, active_id);
+    } else {
+        static_cast<EventModel*>(treeView->model())->clearModel();
+    }
 }
 
 void TabContainer::itemClicked(const QModelIndex &aIndex)
@@ -136,113 +73,74 @@ void TabContainer::itemClicked(const QModelIndex &aIndex)
         return;
 
     EventDialog dialog(static_cast<Event*>(aIndex.internalPointer())->id(),this);
+#ifdef N810
+    dialog.setFixedWidth(static_cast<QWidget*>(parent())->width());
+#endif
+    connect(&dialog, SIGNAL(eventHasChanged(int,bool)), this, SIGNAL(eventHasChanged(int,bool)));
     dialog.exec();
+    disconnect(&dialog, SIGNAL(eventHasChanged(int,bool)), this, SIGNAL(eventHasChanged(int,bool)));
 }
 
 void TabContainer::displayMap(const QModelIndex &aIndex)
 {
     Event *event = static_cast<Event*>(aIndex.internalPointer());
 
-    // room names are stored in lower-case format
-    // room names are stored without dots in the name, eg. "aw.1124.png" -> "aw1124.png"
-    QString mapPath = QString(":/maps/rooms/%1.png").arg(event->room().toLower().remove("."));
-    if(!QFile::exists(mapPath))
-        mapPath = QString(":/maps/rooms/not-available.png");
-
-    QString roomName;
-    if(mapPath.contains("not-available", Qt::CaseInsensitive))
-        roomName = QString("Map is not available: %1").arg(event->room());
-    else
-        roomName = event->room();
+    QVariant mapPathV = event->room()->map();
+    QString mapPath;
+    if (!mapPathV.isValid()) {
+        error_message("No map for this room");
+        return;
+    } else {
+        mapPath = mapPathV.toString();
+        if (!QFile::exists(mapPath)) {
+            error_message("Map for this room not found: " + mapPath);
+            return;
+        }
+    }
 
     QPixmap map(mapPath);
-    MapWindow window(map,roomName,this);
+    MapWindow window(map, event->room()->name(),this);
     window.exec();
 }
 
-void TabContainer::displayWarning(const QModelIndex &aIndex)
+void TabContainer::displayConflicts(const QModelIndex &aIndex)
 {
-    Q_UNUSED(aIndex);
-
-    QMessageBox::warning(
-        this,
-        tr("Time Conflict Warning"),
-        tr("This event happens at the same time than another one of your favourites.") );
+    ConflictsDialog dialog(static_cast<Event*>(aIndex.internalPointer())->id(),this);
+#ifdef N810
+    dialog.setFixedWidth(static_cast<QWidget*>(parent())->width());
+#endif
+    connect(&dialog, SIGNAL(eventHasChanged(int,bool)), this, SIGNAL(eventHasChanged(int,bool)));
+    dialog.exec();
+    disconnect(&dialog, SIGNAL(eventHasChanged(int,bool)), this, SIGNAL(eventHasChanged(int,bool)));
 }
 
-void TabContainer::updateTreeViewModel(int aEventId)
+void TabContainer::updateTreeViewModel(int aEventId, bool aReloadModel)
 {
-    switch(mType)
+    if(aReloadModel)
     {
-        case EContainerTypeFavs:
-            {
-                // requires special handling
-                // we need to reload favourites, because some favourite could be deleted
-                //static_cast<EventModel*>(favTreeView->model())->updateModel(aEventId);
-                QDate aStartDate = Conference::getById(AppSettings::confId()).start();
-                QDate aEndDate = Conference::getById(AppSettings::confId()).end();
-                dayNavigator->setDates(aStartDate, aEndDate);
-                updateTreeView( Conference::getById(AppSettings::confId()).start() );
-            }
-            break;
-        case EContainerTypeDay:
-        case EContainerTypeNone:
-        default:
-            {
-                static_cast<EventModel*>(treeView->model())->updateModel(aEventId);
-            }
+        // requires special handling
+        // eg. in case of favourities - some favourities may have changed
+        // and so we need to reload them
+        int confId = Conference::activeConference();
+        QDate startDate = Conference::getById(confId).start();
+        QDate endDate = Conference::getById(confId).end();
+        dayNavigator->setDates(startDate, endDate);
+        updateTreeView( Conference::getById(confId).start() );
     }
-}
-
-void TabContainer::setDates(const QDate &aStart, const QDate &aEnd)
-{
-    dayNavigator->setDates(aStart, aEnd);
-}
-
-void TabContainer::timerUpdateTreeView()
-{
-    if(mType == EContainerTypeNow)
+    else
     {
-        updateTreeView(QDate());
+        // just update event in the question
+        static_cast<EventModel*>(treeView->model())->updateModel(aEventId);
     }
 }
 
-void TabContainer::searchClicked()
+void TabContainer::setDates(const QDate &aStart, const QDate &aEnd)
 {
-    if(mType == EContainerTypeSearch)
-    {
-        QHash<QString,QString> columns;
-
-        if( searchTitle->isChecked() )
-            columns.insertMulti("EVENT", "title");
-        if( searchAbstract->isChecked() )
-            columns.insertMulti("EVENT", "abstract");
-        if( searchTag->isChecked() )
-            columns.insertMulti("EVENT", "tag");
-        if( searchSpeaker->isChecked() )
-            columns["PERSON"] = "name";
-        if( searchRoom->isChecked() )
-            columns["ROOM"] = "name";
-
-        QString keyword = searchEdit->text().replace( QString("%"), QString("\\%") );
-        qDebug() << "\nKeyword to search: " << keyword;
-        SqlEngine::searchEvent( AppSettings::confId(), columns, keyword );
-
-        QDate startDate = Conference::getById(AppSettings::confId()).start();
-        QDate endDate = Conference::getById(AppSettings::confId()).end();
-        dayNavigator->setDates(startDate, endDate);
-        updateTreeView( Conference::getById(AppSettings::confId()).start() );
-    }
+    dayNavigator->setDates(aStart, aEnd);
 }
 
-void TabContainer::searchAgainClicked()
+void TabContainer::clearModel()
 {
-    if(mType == EContainerTypeSearch)
-    {
-        searchHead->show();
-        searchAgainButton->hide();
-        dayNavigator->hide();
-        treeView->hide();
-    }
+    static_cast<EventModel*>(treeView->model())->clearModel();
 }