Rework interaction between Calendar, EventList and EventSource abstractions

As proposed by Florian in the review.

Signed-off-by: David Zeuthen <davidz@redhat.com>
This commit is contained in:
David Zeuthen 2011-01-19 13:55:04 -05:00
parent d7ad949ecb
commit 0a87e28d1a
2 changed files with 32 additions and 19 deletions

View File

@ -248,15 +248,13 @@ Signals.addSignalMethods(FakeEventSource.prototype);
// Calendar: // Calendar:
// @eventSource: is an object implementing the EventSource API, e.g. the // @eventSource: is an object implementing the EventSource API, e.g. the
// getTasks(), hasTasks() methods and the ::changed signal. // getTasks(), hasTasks() methods and the ::changed signal.
// @eventList: is the EventList object to control function Calendar(eventSource) {
function Calendar(eventSource, eventList) { this._init(eventSource);
this._init(eventSource, eventList);
} }
Calendar.prototype = { Calendar.prototype = {
_init: function(eventSource, eventList) { _init: function(eventSource) {
this._eventSource = eventSource; this._eventSource = eventSource;
this._eventList = eventList;
this._eventSource.connect('changed', Lang.bind(this, this._update)); this._eventSource.connect('changed', Lang.bind(this, this._update));
@ -487,17 +485,6 @@ Calendar.prototype = {
row++; row++;
} }
} }
// update the event list widget
if (now.getDate() == this.selectedDate.getDate() &&
now.getMonth() == this.selectedDate.getMonth() &&
now.getFullYear() == this.selectedDate.getFullYear()) {
// Today - show: Today, Tomorrow and This Week
this._eventList.showToday();
} else {
// Not Today - show only events from that day
this._eventList.showOtherDay(this.selectedDate);
}
} }
}; };
@ -510,7 +497,10 @@ function EventsList(eventSource) {
EventsList.prototype = { EventsList.prototype = {
_init: function(eventSource) { _init: function(eventSource) {
this.actor = new St.BoxLayout({ vertical: true, style_class: 'events-header-vbox'}); this.actor = new St.BoxLayout({ vertical: true, style_class: 'events-header-vbox'});
this._date = new Date();
this._eventSource = eventSource; this._eventSource = eventSource;
this._eventSource.connect('changed', Lang.bind(this, this._update));
this._update();
}, },
_addEvent: function(dayNameBox, timeBox, eventTitleBox, includeDayName, day, time, desc) { _addEvent: function(dayNameBox, timeBox, eventTitleBox, includeDayName, day, time, desc) {
@ -554,7 +544,7 @@ EventsList.prototype = {
} }
}, },
showOtherDay: function(day) { _showOtherDay: function(day) {
this.actor.destroy_children(); this.actor.destroy_children();
let dayBegin = new Date(day.getTime()); let dayBegin = new Date(day.getTime());
@ -566,7 +556,7 @@ EventsList.prototype = {
this._addPeriod(day.toLocaleFormat('%A, %B %d, %Y'), dayBegin, dayEnd, false); this._addPeriod(day.toLocaleFormat('%A, %B %d, %Y'), dayBegin, dayEnd, false);
}, },
showToday: function() { _showToday: function() {
this.actor.destroy_children(); this.actor.destroy_children();
let dayBegin = new Date(); let dayBegin = new Date();
@ -592,5 +582,22 @@ EventsList.prototype = {
dayBegin.setDate(dayBegin.getDate() + 1); dayBegin.setDate(dayBegin.getDate() + 1);
dayEnd.setDate(dayEnd.getDate() + 1 + d); dayEnd.setDate(dayEnd.getDate() + 1 + d);
this._addPeriod(_("This week"), dayBegin, dayEnd, true); this._addPeriod(_("This week"), dayBegin, dayEnd, true);
},
// Sets the event list to show events from a specific date
setDate: function(date) {
if (!_sameDay(date, this._date)) {
this._date = date;
this._update();
}
},
_update: function() {
let today = new Date();
if (_sameDay (this._date, today)) {
this._showToday();
} else {
this._showOtherDay(this._date);
}
} }
}; };

View File

@ -85,7 +85,11 @@ DateMenuButton.prototype = {
this._eventList = new Calendar.EventsList(this._eventSource); this._eventList = new Calendar.EventsList(this._eventSource);
// Calendar // Calendar
this._calendar = new Calendar.Calendar(this._eventSource, this._eventList); this._calendar = new Calendar.Calendar(this._eventSource);
this._calendar.connect('selected-date-changed',
Lang.bind(this, function(calendar, date) {
this._eventList.setDate(date);
}));
vbox.add(this._calendar.actor); vbox.add(this._calendar.actor);
// Add vertical separator // Add vertical separator
@ -106,6 +110,8 @@ DateMenuButton.prototype = {
if (isOpen) { if (isOpen) {
let now = new Date(); let now = new Date();
this._calendar.setDate(now); this._calendar.setDate(now);
// No need to update this._eventList as ::selected-date-changed
// signal will fire
} }
})); }));