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:
parent
d7ad949ecb
commit
0a87e28d1a
@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user