From 0a87e28d1a14d5b18bba994cd7e035360938b09d Mon Sep 17 00:00:00 2001 From: David Zeuthen Date: Wed, 19 Jan 2011 13:55:04 -0500 Subject: [PATCH] Rework interaction between Calendar, EventList and EventSource abstractions As proposed by Florian in the review. Signed-off-by: David Zeuthen --- js/ui/calendar.js | 43 +++++++++++++++++++++++++------------------ js/ui/dateMenu.js | 8 +++++++- 2 files changed, 32 insertions(+), 19 deletions(-) diff --git a/js/ui/calendar.js b/js/ui/calendar.js index 4c34aa007..16c0961e7 100644 --- a/js/ui/calendar.js +++ b/js/ui/calendar.js @@ -248,15 +248,13 @@ Signals.addSignalMethods(FakeEventSource.prototype); // Calendar: // @eventSource: is an object implementing the EventSource API, e.g. the // getTasks(), hasTasks() methods and the ::changed signal. -// @eventList: is the EventList object to control -function Calendar(eventSource, eventList) { - this._init(eventSource, eventList); +function Calendar(eventSource) { + this._init(eventSource); } Calendar.prototype = { - _init: function(eventSource, eventList) { + _init: function(eventSource) { this._eventSource = eventSource; - this._eventList = eventList; this._eventSource.connect('changed', Lang.bind(this, this._update)); @@ -487,17 +485,6 @@ Calendar.prototype = { 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 = { _init: function(eventSource) { this.actor = new St.BoxLayout({ vertical: true, style_class: 'events-header-vbox'}); + this._date = new Date(); this._eventSource = eventSource; + this._eventSource.connect('changed', Lang.bind(this, this._update)); + this._update(); }, _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(); let dayBegin = new Date(day.getTime()); @@ -566,7 +556,7 @@ EventsList.prototype = { this._addPeriod(day.toLocaleFormat('%A, %B %d, %Y'), dayBegin, dayEnd, false); }, - showToday: function() { + _showToday: function() { this.actor.destroy_children(); let dayBegin = new Date(); @@ -592,5 +582,22 @@ EventsList.prototype = { dayBegin.setDate(dayBegin.getDate() + 1); dayEnd.setDate(dayEnd.getDate() + 1 + d); 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); + } } }; diff --git a/js/ui/dateMenu.js b/js/ui/dateMenu.js index 44f860c86..6cf4c7014 100644 --- a/js/ui/dateMenu.js +++ b/js/ui/dateMenu.js @@ -85,7 +85,11 @@ DateMenuButton.prototype = { this._eventList = new Calendar.EventsList(this._eventSource); // 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); // Add vertical separator @@ -106,6 +110,8 @@ DateMenuButton.prototype = { if (isOpen) { let now = new Date(); this._calendar.setDate(now); + // No need to update this._eventList as ::selected-date-changed + // signal will fire } }));