MessageTray: don't close the tray when interacting with the right click menu
If the chosen action is not open, the tray should not be closed, to let the user further interact with it (for example to mute or remove more sources) https://bugzilla.gnome.org/show_bug.cgi?id=689296
This commit is contained in:
parent
41f933b89e
commit
961dba7faa
@ -478,7 +478,7 @@ const ChatSource = new Lang.Class({
|
|||||||
}));
|
}));
|
||||||
item.connect('activate', Lang.bind(this, function() {
|
item.connect('activate', Lang.bind(this, function() {
|
||||||
this.setMuted(!this.isMuted);
|
this.setMuted(!this.isMuted);
|
||||||
this.emit('done-displaying-content');
|
this.emit('done-displaying-content', false);
|
||||||
}));
|
}));
|
||||||
rightClickMenu.add(item.actor);
|
rightClickMenu.add(item.actor);
|
||||||
return rightClickMenu;
|
return rightClickMenu;
|
||||||
|
@ -1088,14 +1088,14 @@ const Source = new Lang.Class({
|
|||||||
item = new PopupMenu.PopupMenuItem(_("Open"));
|
item = new PopupMenu.PopupMenuItem(_("Open"));
|
||||||
item.connect('activate', Lang.bind(this, function() {
|
item.connect('activate', Lang.bind(this, function() {
|
||||||
this.open();
|
this.open();
|
||||||
this.emit('done-displaying-content');
|
this.emit('done-displaying-content', true);
|
||||||
}));
|
}));
|
||||||
rightClickMenu.add(item.actor);
|
rightClickMenu.add(item.actor);
|
||||||
|
|
||||||
item = new PopupMenu.PopupMenuItem(_("Remove"));
|
item = new PopupMenu.PopupMenuItem(_("Remove"));
|
||||||
item.connect('activate', Lang.bind(this, function() {
|
item.connect('activate', Lang.bind(this, function() {
|
||||||
this.destroy();
|
this.destroy();
|
||||||
this.emit('done-displaying-content');
|
this.emit('done-displaying-content', false);
|
||||||
}));
|
}));
|
||||||
rightClickMenu.add(item.actor);
|
rightClickMenu.add(item.actor);
|
||||||
return rightClickMenu;
|
return rightClickMenu;
|
||||||
@ -1341,7 +1341,7 @@ const SummaryItem = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_notificationDoneDisplaying: function() {
|
_notificationDoneDisplaying: function() {
|
||||||
this.source.emit('done-displaying-content');
|
this.source.emit('done-displaying-content', true);
|
||||||
},
|
},
|
||||||
|
|
||||||
_notificationDestroyed: function(notification) {
|
_notificationDestroyed: function(notification) {
|
||||||
@ -2454,12 +2454,21 @@ const MessageTray = new Lang.Class({
|
|||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_onSourceDoneDisplayingContent: function(source, closeTray) {
|
||||||
|
if (closeTray) {
|
||||||
|
this._escapeTray();
|
||||||
|
} else {
|
||||||
|
this._setClickedSummaryItem(null);
|
||||||
|
this._updateState();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
_showSummaryBoxPointer: function() {
|
_showSummaryBoxPointer: function() {
|
||||||
this._summaryBoxPointerItem = this._clickedSummaryItem;
|
this._summaryBoxPointerItem = this._clickedSummaryItem;
|
||||||
this._summaryBoxPointerContentUpdatedId = this._summaryBoxPointerItem.connect('content-updated',
|
this._summaryBoxPointerContentUpdatedId = this._summaryBoxPointerItem.connect('content-updated',
|
||||||
Lang.bind(this, this._onSummaryBoxPointerContentUpdated));
|
Lang.bind(this, this._onSummaryBoxPointerContentUpdated));
|
||||||
this._sourceDoneDisplayingId = this._summaryBoxPointerItem.source.connect('done-displaying-content',
|
this._sourceDoneDisplayingId = this._summaryBoxPointerItem.source.connect('done-displaying-content',
|
||||||
Lang.bind(this, this._escapeTray));
|
Lang.bind(this, this._onSourceDoneDisplayingContent));
|
||||||
|
|
||||||
let hasRightClickMenu = this._summaryBoxPointerItem.rightClickMenu != null;
|
let hasRightClickMenu = this._summaryBoxPointerItem.rightClickMenu != null;
|
||||||
if (this._clickedSummaryItemMouseButton == 1 || !hasRightClickMenu) {
|
if (this._clickedSummaryItemMouseButton == 1 || !hasRightClickMenu) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user