/*
* Copyright (C) 2010 Ixonos Plc.
- * Copyright (C) 2011 Philipp Spitzer, gregor herrmann
+ * Copyright (C) 2011-2024 Philipp Spitzer, gregor herrmann, Stefan Stahl
*
* This file is part of ConfClerk.
*
#include "eventmodel.h"
#ifdef MAEMO
-#include <alarm.h>
+#include "alarm.h"
+#include "appsettings.h"
#endif
#include <QDebug>
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;
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(),confId);
QList<Event> conflicts = Event::conflictEvents(event.id(),Conference::activeConference());
- if(event.isFavourite())
- event.setFavourite(false);
- else
- event.setFavourite(true);
+ event.cycleFavourite(button == Qt::RightButton);
event.update("favourite");
- qDebug() << " FAVOURITE [" << qVariantValue<QString>(aIndex.data()) << "] -> " << event.isFavourite();
+ // event has became 'favourite' and so 'conflicts' list may have changed
+ conflicts = Event::conflictEvents(event.id(),Conference::activeConference());
- if(event.isFavourite())
- {
- // event has became 'favourite' and so 'conflicts' list may have changed
- conflicts = Event::conflictEvents(event.id(),Conference::activeConference());
- }
-
- // have to emit 'eventHasChanged' signal on all events in conflict
+ // have to emit 'eventChanged' signal on all events in conflict
for(int i=0; i<conflicts.count(); i++)
- emit(eventHasChanged(conflicts[i].id()));
+ emit eventChanged(conflicts[i].id(), false);
// since the Favourite icon has changed, update TreeViews accordingly
// all TreeViews have to listen on this signal
- emit(eventHasChanged(event.id(),true));
+ emit eventChanged(event.id(), true);
handled = true;
}
{
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
#ifdef MAEMO
// add alarm to the 'alarmd'
Alarm alarm;
- //int cookie = alarm.addAlarm(event.id(),QDateTime::currentDateTime().addSecs(10)); // testing
- int cookie = alarm.addAlarm(event.id(),event.start().addSecs(-15*60)); // 15 minutes before real start
- qDebug() << "cookie: " << cookie;
+ alarm.addAlarm(event.conferenceId(), event.id(), event.title(),event.start().addSecs(-AppSettings::preEventAlarmSec()));
#endif /* MAEMO */
}
event.update("alarm");
- qDebug() << " ALARM [" << qVariantValue<QString>(aIndex.data()) << "] -> " << event.hasAlarm();
// since the Alarm icon has changed, update TreeView accordingly
// all TreeViews have to listen on this signal
- emit(eventHasChanged(event.id()));
+ 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;
- }
- break;
case Delegate::WarningControl:
{
- qDebug() << "WARNING CLICKED: " << qVariantValue<QString>(aIndex.data());
emit(requestForConflicts(aIndex));
handled = true;
}