+/*
+ * Copyright (C) 2010 Ixonos Plc.
+ * Copyright (C) 2011 Philipp Spitzer, gregor herrmann
+ *
+ * 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 <delegate.h>
#include "eventdialog.h"
-#include "mapwindow.h"
+#include "room.h"
+#include "errormessage.h"
#include "conflictsdialog.h"
treeView->setModel(new EventModel());
treeView->setItemDelegate(new Delegate(treeView));
- connect(dayNavigator, SIGNAL(dateChanged(const QDate &)), SLOT(updateTreeView(const QDate &)));
-
- connect(treeView, SIGNAL(eventHasChanged(int,bool)), SIGNAL(eventHasChanged(int,bool)));
+ connect(treeView, SIGNAL(eventChanged(int,bool)), SIGNAL(eventChanged(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(requestForConflicts(const QModelIndex &)), SLOT(displayConflicts(const QModelIndex &)));
-
- // day navigator is hidden by default
- dayNavigator->hide();
}
void TabContainer::updateTreeView(const QDate &aDate)
{
- dayNavigator->show();
- loadEvents( aDate, Conference::activeConference() );
- treeView->reset();
+ int active_id = Conference::activeConference();
+ if (active_id > 0) {
+ loadEvents(aDate, active_id);
+ } else {
+ static_cast<EventModel*>(treeView->model())->clearModel();
+ }
}
void TabContainer::itemClicked(const QModelIndex &aIndex)
#ifdef N810
dialog.setFixedWidth(static_cast<QWidget*>(parent())->width());
#endif
- connect(&dialog, SIGNAL(eventHasChanged(int,bool)), this, SIGNAL(eventHasChanged(int,bool)));
+ connect(&dialog, SIGNAL(eventChanged(int,bool)), this, SIGNAL(eventChanged(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();
-
- QPixmap map(mapPath);
- MapWindow window(map,roomName,this);
- window.exec();
+ disconnect(&dialog, SIGNAL(eventChanged(int,bool)), this, SIGNAL(eventChanged(int,bool)));
}
void TabContainer::displayConflicts(const QModelIndex &aIndex)
#ifdef N810
dialog.setFixedWidth(static_cast<QWidget*>(parent())->width());
#endif
- connect(&dialog, SIGNAL(eventHasChanged(int,bool)), this, SIGNAL(eventHasChanged(int,bool)));
+ connect(&dialog, SIGNAL(eventChanged(int,bool)), this, SIGNAL(eventChanged(int,bool)));
dialog.exec();
- disconnect(&dialog, SIGNAL(eventHasChanged(int,bool)), this, SIGNAL(eventHasChanged(int,bool)));
+ disconnect(&dialog, SIGNAL(eventChanged(int,bool)), this, SIGNAL(eventChanged(int,bool)));
}
-void TabContainer::updateTreeViewModel(int aEventId, bool aReloadModel)
-{
- if(aReloadModel)
- {
- // 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() );
- }
- else
- {
- // just update event in the question
- static_cast<EventModel*>(treeView->model())->updateModel(aEventId);
- }
+
+void TabContainer::redisplayEvent(int aEventId) {
+ static_cast<EventModel*>(treeView->model())->updateModel(aEventId);
}
-void TabContainer::setDates(const QDate &aStart, const QDate &aEnd)
+
+void TabContainer::redisplayDate(const QDate& curDate) {
+ updateTreeView(curDate);
+}
+
+
+void TabContainer::clearModel()
{
- dayNavigator->setDates(aStart, aEnd);
+ static_cast<EventModel*>(treeView->model())->clearModel();
}