environment: Don't use actor if an ease callback destroys it
An actor ease callback could destroy the actor, in such case we should do not touch the actor anymore. So, before calling the callback, reset restore the easing state and don't perform any further action with it. Fixes https://gitlab.gnome.org/GNOME/gnome-shell/issues/1507
This commit is contained in:
parent
9b7f228f8e
commit
826ac95726
@ -117,6 +117,7 @@ function _easeActor(actor, params) {
|
|||||||
animatedProps.forEach(p => actor.remove_transition(p));
|
animatedProps.forEach(p => actor.remove_transition(p));
|
||||||
|
|
||||||
actor.set(params);
|
actor.set(params);
|
||||||
|
actor.restore_easing_state();
|
||||||
|
|
||||||
if (callback) {
|
if (callback) {
|
||||||
let transition = actor.get_transition(animatedProps[0]);
|
let transition = actor.get_transition(animatedProps[0]);
|
||||||
@ -126,8 +127,6 @@ function _easeActor(actor, params) {
|
|||||||
else
|
else
|
||||||
callback(true);
|
callback(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
actor.restore_easing_state();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function _easeActorProperty(actor, propName, target, params) {
|
function _easeActorProperty(actor, propName, target, params) {
|
||||||
|
Loading…
Reference in New Issue
Block a user