/*
* Copyright (C) 2010 Ixonos Plc.
- * Copyright (C) 2011-2015 Philipp Spitzer, gregor herrmann, Stefan Stahl
+ * Copyright (C) 2011-2017 Philipp Spitzer, gregor herrmann, Stefan Stahl
*
* This file is part of ConfClerk.
*
QString info;
// title
- info.append(QString("<h1>%1</h1>\n").arg(Qt::escape(event.title())));
+ info.append(QString("<h1>%1</h1>\n").arg(event.title().toHtmlEscaped()));
// persons
info += QString("<h2>%1</h2>\n").arg(tr("Persons"));
QStringList persons = event.persons();
- for (int i = 0; i != persons.size(); ++i) persons[i] = Qt::escape(persons[i]);
+ for (int i = 0; i != persons.size(); ++i) persons[i] = persons[i].toHtmlEscaped();
info += QString("<p>%1</p>\n").arg(persons.join(", "));
// abstract
info += QString("<h2>%1</h2>\n").arg(tr("Abstract"));
- info += Qt::convertFromPlainText(event.abstract(), Qt::WhiteSpaceNormal);
+ if (Qt::mightBeRichText(event.abstract())) {
+ info += event.abstract();
+ } else {
+ info += Qt::convertFromPlainText(event.abstract(), Qt::WhiteSpaceNormal);
+ }
// description
info += QString("<h2>%1</h2>\n").arg(tr("Description"));
- info += Qt::convertFromPlainText(event.description(), Qt::WhiteSpaceNormal);
+ if (Qt::mightBeRichText(event.description())) {
+ info += event.description();
+ } else {
+ info += Qt::convertFromPlainText(event.description(), Qt::WhiteSpaceNormal);
+ }
// links
info += QString("<h2>%1</h2>\n<ul>\n").arg(tr("Links"));
QString name(i.key());
if (url.isEmpty() || url == "http://") continue;
if (name.isEmpty()) name = url;
- info += QString("<li><a href=\"%1\">%2</a></li>\n").arg(Qt::escape(url), Qt::escape(name));
+ info += QString("<li><a href=\"%1\">%2</a></li>\n").arg(url.toHtmlEscaped(), name.toHtmlEscaped());
}
info += QString("</ul>\n");
eventInfoTextBrowser->setHtml(info);
connect(favouriteButton, SIGNAL(clicked()), SLOT(favouriteClicked()));
connect(alarmButton, SIGNAL(clicked()), SLOT(alarmClicked()));
- if(event.isFavourite())
- {
- favouriteButton->setIcon(QIcon(":/icons/favourite-on.png"));
- }
+ updateFavouriteButton(event);
if(event.hasAlarm())
{
void EventDialog::favouriteClicked()
{
Event event = Event::getById(mEventId, mConferenceId);
-
- QList<Event> conflicts = Event::conflictEvents(event.id(), mConferenceId);
- if(event.isFavourite())
- {
- event.setFavourite(false);
- favouriteButton->setIcon(QIcon(":/icons/favourite-off.png"));
- }
- else
- {
- event.setFavourite(true);
- favouriteButton->setIcon(QIcon(":/icons/favourite-on.png"));
- }
+ event.cycleFavourite();
event.update("favourite");
+ updateFavouriteButton(event);
- if(event.isFavourite())
- {
- // event has became 'favourite' and so 'conflicts' list may have changed
- conflicts = Event::conflictEvents(event.id(), mConferenceId);
- }
+ // 'conflicts' list may have changed
+ QList<Event> conflicts = Event::conflictEvents(event.id(), mConferenceId);
// have to emit 'eventChanged' signal on all events in conflict
for(int i=0; i<conflicts.count(); i++)
emit eventChanged(event.id(), false);
}
+
+ void EventDialog::updateFavouriteButton(const Event& event) {
+ switch (event.favourite()) {
+ case Favourite_no: favouriteButton->setIcon(QIcon(":/icons/favourite-no.png")); break;
+ case Favourite_weak: favouriteButton->setIcon(QIcon(":/icons/favourite-weak.png")); break;
+ case Favourite_strong: favouriteButton->setIcon(QIcon(":/icons/favourite-strong.png")); break;
+ }
+ }
+
/*
* Copyright (C) 2010 Ixonos Plc.
- * Copyright (C) 2011-2015 Philipp Spitzer, gregor herrmann, Stefan Stahl
+ * Copyright (C) 2011-2017 Philipp Spitzer, gregor herrmann, Stefan Stahl
*
* This file is part of ConfClerk.
*
#ifndef MAINWINDOW_H
#define MAINWINDOW_H
-#include <QtGui/QMainWindow>
+#include <QtWidgets>
+ #include <QSslError>
#include "ui_mainwindow.h"
void onEventChanged(int aEventId, bool favouriteChanged);
void onSearchResultChanged();
+ void sslErrors(QNetworkReply*,const QList<QSslError> &errors);
void networkQueryFinished(QNetworkReply*);
void importFromNetwork(const QString&, int conferenceId);
void importFromFile(const QString&, int conferenceId);
/*
* Copyright (C) 2010 Ixonos Plc.
- * Copyright (C) 2011-2015 Philipp Spitzer, gregor herrmann, Stefan Stahl
+ * Copyright (C) 2011-2017 Philipp Spitzer, gregor herrmann, Stefan Stahl
*
* This file is part of ConfClerk.
*
#ifndef SEARCHHEAD_H
#define SEARCHHEAD_H
-#include <QtGui/QWidget>
+#include <QtWidgets>
#include <QDebug>
#include "ui_searchhead.h"
/*
* Copyright (C) 2010 Ixonos Plc.
- * Copyright (C) 2011-2015 Philipp Spitzer, gregor herrmann, Stefan Stahl
+ * Copyright (C) 2011-2017 Philipp Spitzer, gregor herrmann, Stefan Stahl
*
* This file is part of ConfClerk.
*
// reinitialize list from database
void reinit()
{
+ beginResetModel();
conferences = Conference::getAll();
- reset();
+ endResetModel();
}
QList<Conference> conferences;
/*
* Copyright (C) 2010 Ixonos Plc.
- * Copyright (C) 2011-2015 Philipp Spitzer, gregor herrmann, Stefan Stahl
+ * Copyright (C) 2011-2017 Philipp Spitzer, gregor herrmann, Stefan Stahl
*
* This file is part of ConfClerk.
*
if(hasParent(index))
{
+ Event *event = static_cast<Event*>(index.internalPointer());
+
+ // determine severity of conflict
+ Favourite eventTimeConflict = event->timeConflict(); // cache value as event->timeConflict is expensive
+ enum ConflictSeverity {csNone, csWeak, csStrong} conflictSeverity = csNone;
+ switch (event->favourite()) {
+ case Favourite_strong:
+ conflictSeverity = (eventTimeConflict == Favourite_strong) ? csStrong : csNone;
+ break;
+ case Favourite_weak:
+ conflictSeverity = (eventTimeConflict == Favourite_no) ? csNone : csWeak;
+ break;
+ case Favourite_no:
+ conflictSeverity = csNone;
+ break;
+ }
+
// entry horizontal layout:
// * spacer (aka y position of image)
// * image
// * rest is text, which is 1 line of title with big letters and 2 lines of Presenter and Track
- int aux = option.rect.height() - SPACER - mControls[FavouriteControlOn]->image()->height();
- Event *event = static_cast<Event*>(index.internalPointer());
+ int aux = option.rect.height() - SPACER - mControls[FavouriteControlStrong]->image()->height();
// font SMALL
QFont fontSmall = option.font;
QFontMetrics fmBigB(fontBigB);
// background (in case of time conflicts)
- if(event->hasTimeConflict()) {
- painter->setBrush(Qt::yellow);
+ if (conflictSeverity != csNone) {
+ painter->setBrush(conflictSeverity == csStrong ? Qt::yellow : QColor("lightyellow"));
painter->setPen(Qt::NoPen);
painter->drawRect(option.rect);
}
foreach(Control* c, mControls.values()) {
c->setEnabled(false);
}
- if(event->isFavourite())
- mControls[FavouriteControlOn]->paint(painter, option.rect);
- else
- mControls[FavouriteControlOff]->paint(painter, option.rect);
+ switch (event->favourite()) {
+ case Favourite_strong:
+ mControls[FavouriteControlStrong]->paint(painter, option.rect);
+ break;
+ case Favourite_weak:
+ mControls[FavouriteControlWeak]->paint(painter, option.rect);
+ break;
+ case Favourite_no:
+ mControls[FavouriteControlNo]->paint(painter, option.rect);
+ break;
+ }
if(event->hasAlarm())
mControls[AlarmControlOn]->paint(painter, option.rect);
else
mControls[AlarmControlOff]->paint(painter, option.rect);
- if(event->hasTimeConflict())
+ if(eventTimeConflict != Favourite_no)
mControls[WarningControl]->paint(painter, option.rect);
// draw texts
// it starts just below the image
// ("position of text" is lower-left angle of the first letter,
// so the first line is actually at the same height as the image)
- painter->setPen(QPen(event->hasTimeConflict() ? Qt::black : textColor));
+ painter->setPen(QPen(conflictSeverity != csNone ? Qt::black : textColor));
QPointF titlePointF(option.rect.x() + SPACER,
- option.rect.y() + SPACER + mControls[FavouriteControlOn]->image()->height());
+ option.rect.y() + SPACER + mControls[FavouriteControlStrong]->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->roomName());
// draw icons
painter->setPen(QPen(textColor));
painter->setFont(fontSmall);
- QImage *image = mControls[numFav ? FavouriteControlOn : FavouriteControlOff]->image();
+ QImage *image = mControls[numFav ? FavouriteControlStrong : FavouriteControlNo]->image();
QPoint drawPoint =
option.rect.topRight()
- QPoint(
option.rect.x()+SPACER,
option.rect.y()+option.rect.height()-fmBig.descent());
painter->setFont(fontBig);
- painter->drawText(titlePointF,qVariantValue<QString>(index.data()));
+ painter->drawText(titlePointF,index.data().value<QString>());
}
painter->restore();
void Delegate::defineControls()
{
// FAVOURITE ICONs
- // on
- mControls.insert(FavouriteControlOn, new Control(FavouriteControlOn, QString(":icons/favourite-on.png"), NULL));
- // off
- mControls.insert(FavouriteControlOff, new Control(FavouriteControlOff, QString(":icons/favourite-off.png"), NULL));
+ // strong
+ mControls.insert(FavouriteControlStrong, new Control(FavouriteControlStrong, QString(":icons/favourite-strong.png"), NULL));
+ // weak
+ mControls.insert(FavouriteControlWeak, new Control(FavouriteControlWeak, QString(":icons/favourite-weak.png"), NULL));
+ // no
+ mControls.insert(FavouriteControlNo, new Control(FavouriteControlNo, QString(":icons/favourite-no.png"), NULL));
// ALARM ICONs
// on
mControls.insert(AlarmControlOn,
- new Control(AlarmControlOn, QString(":icons/alarm-on.png"), mControls[FavouriteControlOn]));
+ new Control(AlarmControlOn, QString(":icons/alarm-on.png"), mControls[FavouriteControlStrong]));
// off
mControls.insert(AlarmControlOff,
- new Control(AlarmControlOff, QString(":icons/alarm-off.png"), mControls[FavouriteControlOff]));
+ new Control(AlarmControlOff, QString(":icons/alarm-off.png"), mControls[FavouriteControlNo]));
// WARNING ICON
mControls.insert(WarningControl,
new Control(WarningControl, QString(":icons/dialog-warning.png"), mControls[AlarmControlOff]));
int nrofFavs = 0;
for(int i=0; i<index.model()->rowCount(index); i++)
- if(static_cast<Event*>(index.child(i,0).internalPointer())->isFavourite())
+ if(static_cast<Event*>(index.child(i,0).internalPointer())->favourite() != Favourite_no)
nrofFavs++;
return nrofFavs;
/*
* Copyright (C) 2010 Ixonos Plc.
- * Copyright (C) 2011-2015 Philipp Spitzer, gregor herrmann, Stefan Stahl
+ * Copyright (C) 2011-2017 Philipp Spitzer, gregor herrmann, Stefan Stahl
*
* This file is part of ConfClerk.
*
#ifndef DELEGATE_H
#define DELEGATE_H
-#include <QtGui>
+#include <QtWidgets>
class Delegate : public QItemDelegate
{
enum ControlId
{
ControlNone = 0,
- FavouriteControlOn,
- FavouriteControlOff,
+ FavouriteControlStrong,
+ FavouriteControlWeak,
+ FavouriteControlNo,
AlarmControlOn,
AlarmControlOff,
WarningControl
/*
* Copyright (C) 2010 Ixonos Plc.
- * Copyright (C) 2011-2015 Philipp Spitzer, gregor herrmann, Stefan Stahl
+ * Copyright (C) 2011-2017 Philipp Spitzer, gregor herrmann, Stefan Stahl
*
* This file is part of ConfClerk.
*
// multiple of one hour.
void EventModel::createTimeGroups()
{
+ beginResetModel();
+
mGroups.clear();
mParents.clear();
if (mEvents.empty()) return;
// the last group needs a title as well
mGroups.last().setTitle(mEvents);
- reset();
+ endResetModel();
}
void EventModel::createTrackGroups() {
if (!parent.isValid())
{
- return createIndex(row, column, 0);
+ return createIndex(row, column, (quintptr) 0);
}
else if (parent.internalId() == 0)
{
Event * event = static_cast<Event*>(index.internalPointer());
- return createIndex(mParents[event->id()], 0, 0);
+ return createIndex(mParents[event->id()], 0, (quintptr) 0);
}
return QModelIndex();
void EventModel::clearModel()
{
+ beginResetModel();
mGroups.clear();
mEvents.clear();
mParents.clear();
-
- reset();
+ endResetModel();
}
/*
* Copyright (C) 2010 Ixonos Plc.
- * Copyright (C) 2011-2015 Philipp Spitzer, gregor herrmann, Stefan Stahl
+ * Copyright (C) 2011-2017 Philipp Spitzer, gregor herrmann, Stefan Stahl
*
* This file is part of ConfClerk.
*
#include <QSqlRecord>
#include <QVariant>
#include <QDateTime>
+#include <QStandardPaths>
#include <QDir>
-#include <QDesktopServices>
#include "sqlengine.h"
#include "track.h"
#include "conference.h"
const QString TIME_FORMAT ("hh:mm");
SqlEngine::SqlEngine(QObject *aParent): QObject(aParent) {
- QDir dbPath(QDesktopServices::storageLocation(QDesktopServices::DataLocation));
+ QDir dbPath(QStandardPaths::writableLocation(QStandardPaths::DataLocation));
dbFilename = dbPath.absoluteFilePath("ConfClerk.sqlite");
}
Track track;
int trackId;
QString trackName = aEvent["track"];
+ if (trackName.isEmpty()) trackName = tr("No track");
try
{
track = Track::retrieveByName(conferenceId, trackName);