diff --git a/effects/logout/package/contents/code/main.js b/effects/logout/package/contents/code/main.js index b31a9355a..1e28841d7 100644 --- a/effects/logout/package/contents/code/main.js +++ b/effects/logout/package/contents/code/main.js @@ -1,58 +1,85 @@ /******************************************************************** KWin - the KDE window manager This file is part of the KDE project. Copyright (C) 2007 Lubos Lunak Copyright (C) 2013 Martin Gräßlin Copyright (C) 2017 Marco Martin This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . *********************************************************************/ /*global effect, effects, animate, animationTime, Effect*/ var logoutEffect = { - duration: animationTime(800), + inDuration: animationTime(800), + outDuration: animationTime(400), loadConfig: function () { "use strict"; - logoutEffect.duration = animationTime(800); + logoutEffect.inDuration = animationTime(800); + logoutEffect.outDuration = animationTime(400); }, isLogoutWindow: function (window) { "use strict"; var windowClass = window.windowClass; if (windowClass === "ksmserver ksmserver") { return true; } return false; }, opened: function (window) { "use strict"; if (!logoutEffect.isLogoutWindow(window)) { return; } - animate({ + // If the Out animation is still active, kill it. + if (window.outAnimation !== undefined) { + cancel(window.outAnimation); + delete window.outAnimation; + } + window.inAnimation = animate({ window: window, - duration: logoutEffect.duration, + duration: logoutEffect.inDuration, type: Effect.Opacity, from: 0.0, to: 1.0 }); }, + closed: function (window) { + "use strict"; + if (!logoutEffect.isLogoutWindow(window)) { + return; + } + // If the In animation is still active, kill it. + if (window.inAnimation !== undefined) { + cancel(window.inAnimation); + delete window.inAnimation; + } + window.outAnimation = animate({ + window: window, + duration: logoutEffect.outDuration, + type: Effect.Opacity, + from: 1.0, + to: 0.0 + }); + }, init: function () { "use strict"; logoutEffect.loadConfig(); effects.windowAdded.connect(logoutEffect.opened); effects.windowShown.connect(logoutEffect.opened); + effects.windowClosed.connect(logoutEffect.closed); + effects.windowHidden.connect(logoutEffect.closed); } }; logoutEffect.init();