You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
103 lines
3.0 KiB
QML
103 lines
3.0 KiB
QML
/*
|
|
SPDX-FileCopyrightText: 2016 Smith AR <audoban@openmailbox.org>
|
|
SPDX-FileCopyrightText: 2016 Michail Vourlakos <mvourlakos@gmail.com>
|
|
SPDX-License-Identifier: GPL-2.0-or-later
|
|
*/
|
|
|
|
import QtQuick 2.0
|
|
|
|
import org.kde.plasma.plasmoid 2.0
|
|
|
|
import org.kde.plasma.core 2.0 as PlasmaCore
|
|
|
|
////////////////// new window and needs attention animation
|
|
Item{
|
|
id:newWindowAnimation
|
|
|
|
property int speed: 1.2 * taskItem.abilities.animations.speedFactor.normal * taskItem.abilities.animations.duration.large
|
|
property bool isDemandingAttention: taskItem.inAttention
|
|
property bool containsMouse: taskItem.containsMouse
|
|
|
|
property bool inDelayedStartup: false
|
|
|
|
readonly property bool running: newWindowAnimationLoader.active ? newWindowAnimationLoader.item.running : false
|
|
readonly property string needThicknessEvent: newWindowAnimation + "_newwindow"
|
|
|
|
Loader {
|
|
id: newWindowAnimationLoader
|
|
source: "newwindow/BounceAnimation.qml"
|
|
}
|
|
|
|
Connections {
|
|
target: newWindowAnimationLoader.item
|
|
|
|
onStopped: {
|
|
taskItem.abilities.animations.needThickness.removeEvent(needThicknessEvent);
|
|
newWindowAnimation.clear();
|
|
}
|
|
}
|
|
|
|
function clear(){
|
|
newWindowAnimationLoader.item.stop();
|
|
|
|
taskItem.parabolicItem.zoomLength = 1.0;
|
|
taskItem.parabolicItem.zoomThickness = 1.0;
|
|
|
|
taskItem.setBlockingAnimation(false);
|
|
taskItem.inAttentionAnimation = false;
|
|
taskItem.inNewWindowAnimation = false;
|
|
}
|
|
|
|
function pause() {
|
|
if (running) {
|
|
newWindowAnimationLoader.item.pause();
|
|
}
|
|
}
|
|
|
|
function stop() {
|
|
if (running) {
|
|
clear();
|
|
}
|
|
}
|
|
|
|
onIsDemandingAttentionChanged: {
|
|
if(isDemandingAttention){
|
|
startNewWindowAnimation();
|
|
}
|
|
}
|
|
|
|
function init(){
|
|
taskItem.setBlockingAnimation(true);
|
|
taskItem.inNewWindowAnimation = true;
|
|
|
|
taskItem.parabolicItem.zoomLength = taskItem.parabolicItem.zoom;
|
|
taskItem.parabolicItem.zoomThickness = taskItem.parabolicItem.zoom;
|
|
|
|
taskItem.inAttentionAnimation = isDemandingAttention;
|
|
|
|
taskItem.abilities.animations.needThickness.addEvent(needThicknessEvent);
|
|
}
|
|
|
|
function startNewWindowAnimation(){
|
|
if (!taskItem.abilities.myView.isHidden
|
|
&& ((root.windowInAttentionEnabled && isDemandingAttention)
|
|
|| root.windowAddedInGroupEnabled)){
|
|
if (newWindowAnimationLoader.status !== Loader.Ready) {
|
|
inDelayedStartup = true;
|
|
} else {
|
|
newWindowAnimation.init();
|
|
newWindowAnimationLoader.item.start();
|
|
}
|
|
}
|
|
}
|
|
|
|
Component.onCompleted: {
|
|
taskItem.groupWindowAdded.connect(startNewWindowAnimation);
|
|
}
|
|
|
|
Component.onDestruction: {
|
|
taskItem.groupWindowAdded.disconnect(startNewWindowAnimation);
|
|
taskItem.abilities.animations.needThickness.removeEvent(needThicknessEvent);
|
|
}
|
|
}
|