CREATE TABLE EVENT ( xid_conference INTEGER NOT NULL
, id INTEGER NOT NULL
, start INTEGER NOT NULL
- , duration INTEGER NOT NULL
+ , duration INTEGER NOT NULL -- duration of the event in seconds
, xid_track INTEGER NOT NULL REFERENCES TRACK(id)
, type VARCHAR
, language VARCHAR
connect(prevDayButton, SIGNAL(clicked()), SLOT(prevDayButtonClicked()));
connect(nextDayButton, SIGNAL(clicked()), SLOT(nextDayButtonClicked()));
- connect(todayButton, SIGNAL(clicked()), SLOT(todayButtonClicked()));
configureNavigation();
}
}
-void DayNavigatorWidget::todayButtonClicked() {
- setCurDate(QDate::currentDate());
-}
-
-
void DayNavigatorWidget::paintEvent(QPaintEvent *aEvent)
{
Q_UNUSED(aEvent);
void paintEvent(QPaintEvent *);
void configureNavigation();
private slots:
- void todayButtonClicked();
void prevDayButtonClicked();
void nextDayButtonClicked();
signals:
</property>
</widget>
</item>
- <item>
- <widget class="QToolButton" name="todayButton">
- <property name="text">
- <string>...</string>
- </property>
- <property name="icon">
- <iconset resource="../icons.qrc">
- <normaloff>:/icons/today.png</normaloff>:/icons/today.png</iconset>
- </property>
- <property name="autoRaise">
- <bool>true</bool>
- </property>
- </widget>
- </item>
</layout>
</item>
</layout>
</widget>
- <resources>
- <include location="../icons.qrc"/>
- </resources>
+ <resources/>
<connections/>
<slots>
<slot>prevDayButtonClicked()</slot>
#include "dayviewtabcontainer.h"
-DayViewTabContainer::DayViewTabContainer(QWidget *aParent) : TabContainer( aParent )
-{
+DayViewTabContainer::DayViewTabContainer(QWidget *aParent): TabContainer(aParent) {
}
-DayViewTabContainer::~DayViewTabContainer()
-{
+
+void DayViewTabContainer::expandTimeGroup(QTime time, int conferenceId) {
+ EventModel* eventModel = static_cast<EventModel*>(treeView->model());
+
+ // iterate over the time groups
+ for (int g = 0; g != eventModel->rowCount(); ++g) {
+ QModelIndex groupIdx = eventModel->index(g, 0);
+ // iterate over the events in the group
+ for (int e = 0; e != eventModel->rowCount(groupIdx); ++e) {
+ QModelIndex eventIdx = eventModel->index(e, 0, groupIdx);
+ int eventId = eventIdx.data().toInt();
+ Event event = Event::getById(eventId, conferenceId);
+ if (time < event.start().time().addSecs(event.duration())) { // if time < end
+ // expand this group
+ treeView->expand(groupIdx);
+ treeView->scrollTo(eventIdx, QAbstractItemView::PositionAtTop);
+ return;
+ }
+ }
+ }
}
-void DayViewTabContainer::loadEvents( const QDate &aDate, const int aConferenceId )
-{
+
+void DayViewTabContainer::loadEvents( const QDate &aDate, const int aConferenceId ) {
static_cast<EventModel*>(treeView->model())->loadEvents( aDate, aConferenceId );
}
Q_OBJECT
public:
DayViewTabContainer(QWidget *aParent);
- virtual ~DayViewTabContainer();
+ virtual ~DayViewTabContainer() {}
+
+public slots:
+ void expandTimeGroup(QTime time, int conferenceId);
+
protected:
virtual void loadEvents(const QDate &aDate, const int aConferenceId );
};
void MainWindow::on_nowAction_triggered() {
-
+ int confId = Conference::activeConference();
+ if (confId== -1) return;
+ dayNavigator->setCurDate(QDate::currentDate());
+ dayTabContainer->expandTimeGroup(QTime::currentTime(), confId);
}
int id() const { return value("id").toInt(); }
int conferenceId() const { return value("xid_conference").toInt(); }
QDateTime start() const { return value("start").toDateTime(); }
+ /// duration of the event in seconds
int duration() const { return value("duration").toInt(); }
int trackId() const { return value("xid_track").toInt(); }
QString type() const { return value("type").toString(); }