+/*
+ * Copyright (C) 2010 Ixonos Plc.
+ * Copyright (C) 2011-2024 Philipp Spitzer, gregor herrmann, Stefan Stahl
+ *
+ * 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 <QMouseEvent>
#include "treeview.h"
#include "delegate.h"
#include "event.h"
+#include "conference.h"
#include "eventmodel.h"
#ifdef MAEMO
-#include <alarm.h>
+#include "alarm.h"
+#include "appsettings.h"
#endif
#include <QDebug>
TreeView::TreeView(QWidget *aParent)
: QTreeView(aParent)
{
+ connect(this, SIGNAL(clicked(QModelIndex)), SLOT(handleItemClicked(QModelIndex)));
}
void TreeView::mouseReleaseEvent(QMouseEvent *aEvent)
QPoint point = aEvent->pos();
// test whether we have handled the mouse event
- if(!testForControlClicked(index,point))
+ if(!testForControlClicked(index, point, aEvent->button()))
{
// pass the event to the Base class, so item clicks/events are handled correctly
QTreeView::mouseReleaseEvent(aEvent);
}
// returns bool if some Control was clicked
-bool TreeView::testForControlClicked(const QModelIndex &aIndex, const QPoint &aPoint)
+bool TreeView::testForControlClicked(const QModelIndex &aIndex, const QPoint &aPoint, Qt::MouseButton button)
{
bool handled = false;
if(!aIndex.isValid())
return handled;
- QRect rect = visualRect(aIndex); // visual QRect of selected/clicked item in the list
+ int confId = Conference::activeConference();
+ // QRect rect = visualRect(aIndex); // visual QRect of selected/clicked item in the list
Delegate *delegate = static_cast<Delegate*>(itemDelegate(aIndex));
switch(delegate->whichControlClicked(aIndex,aPoint))
{
- case Delegate::FavouriteControlOn:
- case Delegate::FavouriteControlOff:
+ case Delegate::FavouriteControlStrong:
+ case Delegate::FavouriteControlWeak:
+ case Delegate::FavouriteControlNo:
{
// handle Favourite Control clicked
- Event event = Event::getById(aIndex.data().toInt(),1);
- if(event.isFavourite())
- {
- static_cast<Event*>(aIndex.internalPointer())->setFavourite(false); // list of events
- event.setFavourite(false); // update DB
- }
- else
- {
- static_cast<Event*>(aIndex.internalPointer())->setFavourite(true); // list of events
- event.setFavourite(true);
- }
- qDebug() << " FAVOURITE [" << qVariantValue<QString>(aIndex.data()) << "] -> " << event.isFavourite();
+ Event event = Event::getById(aIndex.data().toInt(),confId);
+
+ QList<Event> conflicts = Event::conflictEvents(event.id(),Conference::activeConference());
+ event.cycleFavourite(button == Qt::RightButton);
event.update("favourite");
- // since the Favourite icon has changed, update TreeView accordingly
- static_cast<EventModel*>(model())->emitDataChangedSignal(aIndex,aIndex);
+
+ // event has became 'favourite' and so 'conflicts' list may have changed
+ conflicts = Event::conflictEvents(event.id(),Conference::activeConference());
+
+ // have to emit 'eventChanged' signal on all events in conflict
+ for(int i=0; i<conflicts.count(); i++)
+ emit eventChanged(conflicts[i].id(), false);
+
+ // since the Favourite icon has changed, update TreeViews accordingly
+ // all TreeViews have to listen on this signal
+ emit eventChanged(event.id(), true);
+
handled = true;
}
break;
case Delegate::AlarmControlOff:
{
// handle Alarm Control clicked
- Event event = Event::getById(aIndex.data().toInt(),1);
+ Event event = Event::getById(aIndex.data().toInt(),confId);
if(event.hasAlarm())
{
- static_cast<Event*>(aIndex.internalPointer())->setHasAlarm(false); // list of events
event.setHasAlarm(false); // update DB
#ifdef MAEMO
- // remove alarm from the 'alarmd' alrms list
+ // remove alarm from the 'alarmd' alarms list
Alarm alarm;
- alarm.deleteAlarm(event.id());
- // TODO: test if removing was successfull
+ alarm.deleteAlarm(event.conferenceId(), event.id());
#endif /* MAEMO */
}
else
{
- static_cast<Event*>(aIndex.internalPointer())->setHasAlarm(true); // list of events
event.setHasAlarm(true);
#ifdef MAEMO
// add alarm to the 'alarmd'
Alarm alarm;
- int cookie = alarm.addAlarm(event.id(),QDateTime::currentDateTime().addSecs(10));
- qDebug() << "cookie: " << cookie;
+ alarm.addAlarm(event.conferenceId(), event.id(), event.title(),event.start().addSecs(-AppSettings::preEventAlarmSec()));
#endif /* MAEMO */
}
- qDebug() << " ALARM [" << qVariantValue<QString>(aIndex.data()) << "] -> " << event.hasAlarm();
event.update("alarm");
// since the Alarm icon has changed, update TreeView accordingly
- static_cast<EventModel*>(model())->emitDataChangedSignal(aIndex,aIndex);
+ // all TreeViews have to listen on this signal
+ emit eventChanged(event.id(), false);
handled = true;
}
break;
- case Delegate::MapControl:
- {
- // handle Alarm Control clicked
- qDebug() << "MAP CLICKED: " << qVariantValue<QString>(aIndex.data());
- emit(requestForMap(aIndex));
- handled = true;
- }
+ case Delegate::WarningControl:
+ {
+
+ emit(requestForConflicts(aIndex));
+ handled = true;
+ }
break;
case Delegate::ControlNone:
default:
return handled;
}
+void TreeView::handleItemClicked(const QModelIndex &index)
+{
+ if(!index.parent().isValid()) // time-group
+ {
+ if(isExpanded(index))
+ setExpanded(index, false);
+ else
+ setExpanded(index, true);
+ }
+}
+
+void TreeView::setAllExpanded(bool aExpanded)
+{
+ for(int i=0; i<model()->rowCount(QModelIndex()); i++)
+ {
+ setExpanded(model()->index(i,0,QModelIndex()),aExpanded);
+ }
+}
+