diff --git a/effects/morphingpopups/package/contents/code/morphingpopups.js b/effects/morphingpopups/package/contents/code/morphingpopups.js index 16040dc2b..4413f9136 100644 --- a/effects/morphingpopups/package/contents/code/morphingpopups.js +++ b/effects/morphingpopups/package/contents/code/morphingpopups.js @@ -1,140 +1,138 @@ /******************************************************************** This file is part of the KDE project. Copyright (C) 2012 Martin Gräßlin Copyright (C) 2016 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 morphingEffect = { duration: animationTime(150), loadConfig: function () { "use strict"; morphingEffect.duration = animationTime(150); }, geometryChange: function (window, oldGeometry) { "use strict"; //only tooltips and notifications if (!window.tooltip && !window.notification) { return; } var newGeometry = window.geometry; //only do the transition for near enough tooltips, //don't cross the whole screen: ugly var distance = Math.abs(oldGeometry.x - newGeometry.x) + Math.abs(oldGeometry.y - newGeometry.y); if (distance > (newGeometry.width + newGeometry.height) * 2) { if (window.moveAnimation) { delete window.moveAnimation; } if (window.fadeAnimation) { delete window.fadeAnimation; } return; } //don't resize it "too much", set as four times if ((newGeometry.width / oldGeometry.width) > 4 || (oldGeometry.width / newGeometry.width) > 4 || (newGeometry.height / oldGeometry.height) > 4 || (oldGeometry.height / newGeometry.height) > 4) { return; } - //WindowForceBackgroundContrastRole - window.setData(7, true); - //WindowForceBlurRole - window.setData(5, true); + window.setData(Effect.WindowForceBackgroundContrastRole, true); + window.setData(Effect.WindowForceBlurRole, true); var couldRetarget = false; if (window.moveAnimation) { if (window.moveAnimation[0]) { couldRetarget = retarget(window.moveAnimation[0], { value1: newGeometry.width, value2: newGeometry.height }, morphingEffect.duration); } if (couldRetarget && window.moveAnimation[1]) { couldRetarget = retarget(window.moveAnimation[1], { value1: newGeometry.x + newGeometry.width/2, value2: newGeometry.y + newGeometry.height / 2 }, morphingEffect.duration); } if (!couldRetarget) { cancel(window.moveAnimation[0]); } } if (!couldRetarget) { window.moveAnimation = animate({ window: window, duration: morphingEffect.duration, animations: [{ type: Effect.Size, to: { value1: newGeometry.width, value2: newGeometry.height }, from: { value1: oldGeometry.width, value2: oldGeometry.height } }, { type: Effect.Position, to: { value1: newGeometry.x + newGeometry.width / 2, value2: newGeometry.y + newGeometry.height / 2 }, from: { value1: oldGeometry.x + oldGeometry.width / 2, value2: oldGeometry.y + oldGeometry.height / 2 } }] }); } couldRetarget = false; if (window.fadeAnimation) { couldRetarget = retarget(window.fadeAnimation[0], 1.0, morphingEffect.duration); } if (!couldRetarget) { window.fadeAnimation = animate({ window: window, duration: morphingEffect.duration, animations: [{ type: Effect.CrossFadePrevious, to: 1.0, from: 0.0 }] }); } }, init: function () { "use strict"; effect.configChanged.connect(morphingEffect.loadConfig); effects.windowGeometryShapeChanged.connect(morphingEffect.geometryChange); } }; morphingEffect.init();