+/*
+ * Copyright (C) 2010 Ixonos Plc.
+ *
+ * This file is part of fosdem-schedule.
+ *
+ * fosdem-schedule 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.
+ *
+ * fosdem-schedule 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
+ * fosdem-schedule. If not, see <http://www.gnu.org/licenses/>.
+ */
#include "delegate.h"
#include "eventmodel.h"
#include <track.h>
#include <QDebug>
#include <QPainter>
+#include "room.h"
+
const int RADIUS = 10;
const int SPACER = 10;
painter->save();
QColor bkgrColor = Qt::cyan;
+ //QColor bkgrColor = QColor(0xAA,0xAA,0xAA);
+ QColor conflictColor = Qt::yellow;
QPen borderPen(bkgrColor.darker());
- //QColor bkgrColor = QColor(0,0,113);
- //QPen borderPen(Qt::cyan);
if(hasParent(index))
{
int aux = option.rect.height() - mControls[FavouriteControlOn]->drawPoint().y() - mControls[FavouriteControlOn]->image()->height();
+ Event *event = static_cast<Event*>(index.internalPointer());
// font SMALL
QFont fontSmall = option.font;
fontSmall.setBold(false);
//int spacer = (fmSmall.boundingRect("999").width() < SPACER) ? SPACER : fmSmall.boundingRect("999").width();
//Time conflicts are colored differently
- if ((static_cast<Event*>(index.internalPointer())->isFavourite())
- && (hasTimeConflict(index, index.parent())))
- {
- bkgrColor = Qt::yellow;
- }
+ if(event->hasTimeConflict())
+ bkgrColor = conflictColor;
+
+ QLinearGradient itemGradient(option.rect.topLeft(), option.rect.bottomLeft());
+ itemGradient.setColorAt(0.0, Qt::white);
+ itemGradient.setColorAt(0.25, bkgrColor);
+ itemGradient.setColorAt(0.5, bkgrColor);
+ itemGradient.setColorAt(0.75, bkgrColor);
+ itemGradient.setColorAt(1.0, Qt::white);
if(isLast(index))
{
- QLinearGradient lastGradient(option.rect.topLeft(), option.rect.bottomLeft());
- lastGradient.setColorAt(0.0, Qt::white);
- lastGradient.setColorAt(0.5, bkgrColor);
- lastGradient.setColorAt(1.0, Qt::white);
-
QPainterPath endPath;
endPath.moveTo(option.rect.topLeft());
endPath.lineTo(option.rect.bottomLeft()-QPoint(0, RADIUS));
endPath.arcTo(option.rect.right()-2*RADIUS, option.rect.bottom()-2*RADIUS, 2*RADIUS, 2*RADIUS, 270, 90);
endPath.lineTo(option.rect.topRight());
- painter->setBrush( bkgrColor );
- //painter->setBrush(lastGradient);
+ //painter->setBrush( bkgrColor );
+ painter->setBrush(itemGradient);
painter->setPen(borderPen);
painter->drawPath(endPath);
}
else // middle elements
{
- QLinearGradient middleGradient(option.rect.topLeft(), option.rect.bottomLeft());
- middleGradient.setColorAt(0.0, Qt::white);
- middleGradient.setColorAt(0.25, bkgrColor);
- middleGradient.setColorAt(0.5, Qt::white);
- middleGradient.setColorAt(0.75, bkgrColor);
- middleGradient.setColorAt(1.0, Qt::white);
-
- painter->setBrush( bkgrColor );
- //painter->setBrush(middleGradient);
+ //painter->setBrush( bkgrColor );
+ painter->setBrush(itemGradient);
painter->setPen(Qt::NoPen);
painter->drawRect(option.rect);
// draw Controls
// favourite
- if(static_cast<Event*>(index.internalPointer())->isFavourite())
+ if(event->isFavourite())
painter->drawImage(mControls[FavouriteControlOn]->drawPoint(option.rect),*mControls[FavouriteControlOn]->image());
else
painter->drawImage(mControls[FavouriteControlOff]->drawPoint(option.rect),*mControls[FavouriteControlOff]->image());
#ifdef MAEMO
// alarm
- if(static_cast<Event*>(index.internalPointer())->hasAlarm())
+ if(event->hasAlarm())
painter->drawImage(mControls[AlarmControlOn]->drawPoint(option.rect),*mControls[AlarmControlOn]->image());
else
painter->drawImage(mControls[AlarmControlOff]->drawPoint(option.rect),*mControls[AlarmControlOff]->image());
#endif
// map
- painter->drawImage(mControls[MapControl]->drawPoint(option.rect),*mControls[MapControl]->image());
- // Time conflict
- //if(static_cast<Event*>(index.internalPointer())->hasTimeConflict())
- if(bkgrColor == Qt::yellow)
- {
- painter->drawImage(mControls[WarningControlOn]->drawPoint(option.rect),*mControls[WarningControlOn]->image());
- mControls[WarningControlOn]->hasConflict=true;
- }
- else
- {
- painter->drawImage(mControls[WarningControlOff]->drawPoint(option.rect),*mControls[WarningControlOff]->image());
- mControls[WarningControlOn]->hasConflict=false;
+ if (event->room()->hasMap()) {
+ painter->drawImage(mControls[MapControl]->drawPoint(option.rect),*mControls[MapControl]->image());
}
+ // Time conflict
+ if(event->hasTimeConflict())
+ painter->drawImage(mControls[WarningControl]->drawPoint(option.rect),*mControls[WarningControl]->image());
// draw texts
- Event *event = static_cast<Event*>(index.internalPointer());
QPointF titlePointF(mControls[FavouriteControlOn]->drawPoint(option.rect));
titlePointF.setX(option.rect.x()+SPACER);
titlePointF.setY(titlePointF.y()+mControls[FavouriteControlOn]->image()->height());
QTime start = event->start().time();
painter->setFont(fontBig);
- painter->drawText(titlePointF,start.toString("hh:mm") + "-" + start.addSecs(event->duration()).toString("hh:mm") + ", " + event->room());
+ painter->drawText(titlePointF,start.toString("hh:mm") + "-" + start.addSecs(event->duration()).toString("hh:mm") + ", " + event->roomName());
// title
titlePointF.setY(titlePointF.y()+fmBig.height()-fmBig.descent());
painter->setFont(fontBigB);
// draw icons
painter->setFont(fontSmall);
+ QImage *image = mControls[FavouriteControlOn]->image();
QPoint drawPoint =
option.rect.topRight()
- QPoint(
- spacer + mControls[FavouriteControlOn]->image()->width(),
- - option.rect.height()/2 + mControls[FavouriteControlOn]->image()->height()/2);
- painter->drawImage(drawPoint,*mControls[FavouriteControlOn]->image());
- painter->drawText(drawPoint+QPoint(mControls[FavouriteControlOn]->image()->width()+2, option.rect.height()/2),
+ spacer + image->width(),
+ - option.rect.height()/2 + image->height()/2);
+ painter->drawImage(drawPoint,*image);
+ painter->drawText(drawPoint+QPoint(image->width()+2, image->height() - 2),
QString::number(numberOfFavourities(index)));
#ifdef MAEMO
- drawPoint.setX(drawPoint.x() - spacer - mControls[FavouriteControlOn]->image()->width());
+ drawPoint.setX(drawPoint.x() - spacer - image->width());
painter->drawImage(drawPoint,*mControls[AlarmControlOn]->image());
- painter->drawText(drawPoint+QPoint(mControls[FavouriteControlOn]->image()->width()+2, option.rect.height()/2),
+ painter->drawText(drawPoint+QPoint(image->width()+2, image->height() - 2),
QString::number(numberOfAlarms(index)));
#endif
// draw texts
QString numEvents = QString::number(index.model()->rowCount(index)).append("/");
drawPoint.setX(drawPoint.x() - spacer - fmSmall.boundingRect(numEvents).width());
- drawPoint.setY(drawPoint.y() + option.rect.height()/2);
+ drawPoint.setY(drawPoint.y()+image->height() - 2);
painter->drawText(drawPoint,numEvents);
QPointF titlePointF = QPoint(
while (i.hasNext())
{
ControlId id = i.next();
- if((mControls[id]->drawRect(static_cast<QTreeView*>(parent())->visualRect(aIndex)).contains(aPoint))
- && (id != WarningControlOn) && (id != WarningControlOff))
- {
- return id;
- }
- else if ((mControls[id]->drawRect(static_cast<QTreeView*>(parent())->visualRect(aIndex)).contains(aPoint))
- && (mControls[id]->hasConflict))
+ if(mControls[id]->drawRect(static_cast<QTreeView*>(parent())->visualRect(aIndex)).contains(aPoint))
{
- qDebug() << "tengo conflicto";
- return id;
+ if(id == WarningControl)
+ {
+ if(static_cast<Event*>(aIndex.internalPointer())->hasTimeConflict())
+ return id;
+ }
+ else
+ return id;
}
-
}
return ControlNone;
mControls.insert(MapControl,control);
#endif
- // WARNING ICONs
- // on
- control = new Control(WarningControlOn,QString(":icons/exclamation-iconOn.png"));
- p = mControls[MapControl]->drawPoint();
- control->hasConflict = false;
- p.setX(p.x()-control->image()->width()-SPACER);
- control->setDrawPoint(p);
- mControls.insert(WarningControlOn,control);
- // off
- control = new Control(WarningControlOff,QString(":icons/exclamation-iconOff.png"));
+ // WARNING ICON
+ control = new Control(WarningControl,QString(":icons/exclamation.png"));
p = mControls[MapControl]->drawPoint();
- control->hasConflict = false;
p.setX(p.x()-control->image()->width()-SPACER);
control->setDrawPoint(p);
- mControls.insert(WarningControlOff,control);
+ mControls.insert(WarningControl,control);
}
bool Delegate::isPointFromRect(const QPoint &aPoint, const QRect &aRect) const
return nrofAlarms;
}
-bool Delegate::hasTimeConflict(const QModelIndex &index, const QModelIndex &parent) const
-{
- Event *event = static_cast<Event*>(index.internalPointer());
- QTime start = event->start().time();
- QTime end = start.addSecs(event->duration());
- for(int i=0; i<parent.model()->rowCount(parent); i++)
- {
- if((event->id()!=static_cast<Event*>(parent.child(i,0).internalPointer())->id())
- &&
- (static_cast<Event*>(parent.child(i,0).internalPointer())->isFavourite()))
- {
- if (((start >= static_cast<Event*>(parent.child(i,0).internalPointer())->start().time())
- &&
- (start < static_cast<Event*>(parent.child(i,0).internalPointer())->start().time().addSecs(static_cast<Event*>(parent.child(i,0).internalPointer())->duration())))
- ||
- ((end > static_cast<Event*>(parent.child(i,0).internalPointer())->start().time())
- &&
- (end <= static_cast<Event*>(parent.child(i,0).internalPointer())->start().time().addSecs(static_cast<Event*>(parent.child(i,0).internalPointer())->duration()))))
- {
- return true;
- }
- }
- }
- return false;
-}