Cancel Destroy effect of modal windows when the parent has gone away
Modal dialogs slide back into the titlebar of the parent window when destroyed. This looks weird if the parent window itself has been destroyed, so cancel the effect in this case. https://bugzilla.gnome.org/show_bug.cgi?id=629560
This commit is contained in:
parent
652ce3ce8c
commit
5ccc763385
@ -334,15 +334,10 @@ WindowManager.prototype = {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_destroyWindowOverwrite : function(shellwm, actor) {
|
|
||||||
if (this._removeEffect(this._mapping, actor)) {
|
|
||||||
shellwm.completed_destroy(actor);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_destroyWindow : function(shellwm, actor) {
|
_destroyWindow : function(shellwm, actor) {
|
||||||
|
let parent = actor.get_meta_window().get_transient_for();
|
||||||
while (actor.get_window_type() == Meta.CompWindowType.MODAL_DIALOG
|
while (actor.get_window_type() == Meta.CompWindowType.MODAL_DIALOG
|
||||||
&& actor.get_meta_window().get_transient_for()) {
|
&& parent) {
|
||||||
if (!Main.overview.visible)
|
if (!Main.overview.visible)
|
||||||
this._undimParentWindow(actor, true);
|
this._undimParentWindow(actor, true);
|
||||||
this._dimmedWindows = this._dimmedWindows.filter(function(win) {
|
this._dimmedWindows = this._dimmedWindows.filter(function(win) {
|
||||||
@ -353,7 +348,12 @@ WindowManager.prototype = {
|
|||||||
break;
|
break;
|
||||||
actor.set_scale(1.0, 1.0);
|
actor.set_scale(1.0, 1.0);
|
||||||
actor.show();
|
actor.show();
|
||||||
this._mapping.push(actor);
|
this._destroying.push(actor);
|
||||||
|
|
||||||
|
actor._parentDestroyId = parent.connect('unmanaged', Lang.bind(this, function () {
|
||||||
|
Tweener.removeTweens(actor);
|
||||||
|
this._destroyWindowDone(shellwm, actor);
|
||||||
|
}));
|
||||||
|
|
||||||
Tweener.addTween(actor,
|
Tweener.addTween(actor,
|
||||||
{ scale_y: 0,
|
{ scale_y: 0,
|
||||||
@ -362,7 +362,7 @@ WindowManager.prototype = {
|
|||||||
onComplete: this._destroyWindowDone,
|
onComplete: this._destroyWindowDone,
|
||||||
onCompleteScope: this,
|
onCompleteScope: this,
|
||||||
onCompleteParams: [shellwm, actor],
|
onCompleteParams: [shellwm, actor],
|
||||||
onOverwrite: this._destroyWindowOverwrite,
|
onOverwrite: this._destroyWindowDone,
|
||||||
onOverwriteScope: this,
|
onOverwriteScope: this,
|
||||||
onOverwriteParams: [shellwm, actor]
|
onOverwriteParams: [shellwm, actor]
|
||||||
});
|
});
|
||||||
@ -372,11 +372,13 @@ WindowManager.prototype = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
_destroyWindowDone : function(shellwm, actor) {
|
_destroyWindowDone : function(shellwm, actor) {
|
||||||
if (actor && actor.get_window_type() == Meta.CompWindowType.MODAL_DIALOG &&
|
if (this._removeEffect(this._destroying, actor)) {
|
||||||
actor.get_meta_window().get_transient_for()) {
|
let parent = actor.get_meta_window().get_transient_for();
|
||||||
if (this._removeEffect(this._mapping, actor)) {
|
if (parent && actor._parentDestroyId) {
|
||||||
shellwm.completed_destroy(actor);
|
parent.disconnect(actor._parentDestroyId);
|
||||||
|
actor._parentDestroyId = 0;
|
||||||
}
|
}
|
||||||
|
shellwm.completed_destroy(actor);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user