[gnome-shell/wip/fmuellner/notification-redux+sass: 130/141] dateMenu: Block notification banners while the calendar is open
- From: Florian Müllner <fmuellner src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-shell/wip/fmuellner/notification-redux+sass: 130/141] dateMenu: Block notification banners while the calendar is open
- Date: Thu, 19 Feb 2015 21:05:47 +0000 (UTC)
commit 719453f8c8a5c3e91b8b5fb21f2216ddfae3ebbb
Author: Florian Müllner <fmuellner gnome org>
Date: Fri Feb 13 23:53:18 2015 +0100
dateMenu: Block notification banners while the calendar is open
The new banner position interferes with the calendar drop-down. Resolve
this by blocking banners while the calendar is shown.
js/ui/dateMenu.js | 4 +++-
js/ui/messageTray.js | 12 ++++++++++++
2 files changed, 15 insertions(+), 1 deletions(-)
---
diff --git a/js/ui/dateMenu.js b/js/ui/dateMenu.js
index 7e2cb5c..55b360b 100644
--- a/js/ui/dateMenu.js
+++ b/js/ui/dateMenu.js
@@ -358,13 +358,15 @@ const DateMenuButton = new Lang.Class({
this._messageList.setDate(date);
}));
- // Whenever the menu is opened, select today
this.menu.connect('open-state-changed', Lang.bind(this, function(menu, isOpen) {
+ // Whenever the menu is opened, select today
if (isOpen) {
let now = new Date();
this._calendar.setDate(now);
this._date.setDate(now);
}
+ // Block notification banners while the menu is open
+ Main.messageTray.bannerBlocked = isOpen;
}));
// Fill up the first column
diff --git a/js/ui/messageTray.js b/js/ui/messageTray.js
index 27ae6f4..4a1b056 100644
--- a/js/ui/messageTray.js
+++ b/js/ui/messageTray.js
@@ -1365,6 +1365,7 @@ const MessageTray = new Lang.Class({
this._onStatusChanged(proxy.status);
}));
this._busy = false;
+ this._bannerBlocked = false;
this._presence.connectSignal('StatusChanged', Lang.bind(this, function(proxy, senderName, [status]) {
this._onStatusChanged(status);
}));
@@ -1477,6 +1478,13 @@ const MessageTray = new Lang.Class({
return this._notificationQueue.length;
},
+ set bannerBlocked(v) {
+ if (this._bannerBlocked == v)
+ return;
+ this._bannerBlocked = v;
+ this._updateState();
+ },
+
contains: function(source) {
return this._sources.has(source);
},
@@ -1688,6 +1696,10 @@ const MessageTray = new Lang.Class({
// _updateState() figures out what (if anything) needs to be done
// at the present time.
_updateState: function() {
+ this.actor.visible = !this._bannerBlocked;
+ if (this._bannerBlocked)
+ return;
+
// If our state changes caused _updateState to be called,
// just exit now to prevent reentrancy issues.
if (this._updatingState)
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]