2023-02-21 23:48:49 +01:00
|
|
|
// SPDX-FileCopyrightText: Nheko Contributors
|
2021-03-07 05:57:56 +01:00
|
|
|
//
|
2021-03-05 00:35:15 +01:00
|
|
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
|
2021-01-26 05:46:55 +01:00
|
|
|
import QtGraphicalEffects 1.0
|
2021-01-26 06:03:09 +01:00
|
|
|
import QtQuick 2.12
|
2022-01-12 19:09:46 +01:00
|
|
|
import QtQuick.Window 2.2
|
2021-01-26 23:23:28 +01:00
|
|
|
import im.nheko 1.0
|
2021-01-26 05:46:55 +01:00
|
|
|
|
|
|
|
Item {
|
2021-01-26 23:23:28 +01:00
|
|
|
id: privacyScreen
|
|
|
|
|
2021-01-26 05:46:55 +01:00
|
|
|
property var timelineRoot
|
|
|
|
property int screenTimeout
|
2021-01-26 06:03:09 +01:00
|
|
|
|
2022-05-12 20:56:22 +02:00
|
|
|
required property var windowTarget
|
|
|
|
|
2021-01-26 23:23:28 +01:00
|
|
|
Connections {
|
2022-05-12 18:48:12 +02:00
|
|
|
function onActiveChanged() {
|
2022-05-12 20:56:22 +02:00
|
|
|
if (windowTarget.active) {
|
2021-01-26 23:23:28 +01:00
|
|
|
screenSaverTimer.stop();
|
|
|
|
screenSaver.state = "Invisible";
|
|
|
|
} else {
|
2021-02-02 17:37:10 +01:00
|
|
|
if (timelineRoot.visible)
|
2021-02-02 00:57:59 +01:00
|
|
|
screenSaverTimer.start();
|
2021-02-02 17:37:10 +01:00
|
|
|
|
2021-01-26 23:23:28 +01:00
|
|
|
}
|
|
|
|
}
|
2021-07-27 22:35:38 +02:00
|
|
|
|
2022-05-12 20:56:22 +02:00
|
|
|
target: windowTarget
|
2021-01-26 23:23:28 +01:00
|
|
|
}
|
|
|
|
|
2021-01-26 05:46:55 +01:00
|
|
|
Timer {
|
|
|
|
id: screenSaverTimer
|
2021-01-26 06:03:09 +01:00
|
|
|
|
2021-01-26 05:46:55 +01:00
|
|
|
interval: screenTimeout * 1000
|
2022-05-12 20:56:22 +02:00
|
|
|
running: !windowTarget.active
|
2021-01-26 05:46:55 +01:00
|
|
|
onTriggered: {
|
2021-02-03 03:12:08 +01:00
|
|
|
screenSaver.state = "Visible";
|
2021-01-26 05:46:55 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-03 03:12:08 +01:00
|
|
|
Item {
|
2021-01-26 05:46:55 +01:00
|
|
|
id: screenSaver
|
2021-01-26 06:03:09 +01:00
|
|
|
|
2021-01-26 23:23:28 +01:00
|
|
|
state: "Invisible"
|
2021-01-26 05:46:55 +01:00
|
|
|
anchors.fill: parent
|
|
|
|
visible: false
|
2021-01-26 23:23:28 +01:00
|
|
|
states: [
|
|
|
|
State {
|
|
|
|
name: "Visible"
|
|
|
|
|
|
|
|
PropertyChanges {
|
|
|
|
target: screenSaver
|
|
|
|
visible: true
|
|
|
|
}
|
|
|
|
|
|
|
|
PropertyChanges {
|
|
|
|
target: screenSaver
|
|
|
|
opacity: 1
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
State {
|
|
|
|
name: "Invisible"
|
|
|
|
|
|
|
|
PropertyChanges {
|
|
|
|
target: screenSaver
|
|
|
|
opacity: 0
|
|
|
|
}
|
|
|
|
|
|
|
|
PropertyChanges {
|
|
|
|
target: screenSaver
|
|
|
|
visible: false
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
]
|
|
|
|
transitions: [
|
|
|
|
Transition {
|
|
|
|
from: "Visible"
|
|
|
|
to: "Invisible"
|
|
|
|
|
|
|
|
SequentialAnimation {
|
|
|
|
NumberAnimation {
|
|
|
|
target: screenSaver
|
|
|
|
property: "opacity"
|
|
|
|
duration: 250
|
|
|
|
easing.type: Easing.InQuad
|
|
|
|
}
|
|
|
|
|
|
|
|
NumberAnimation {
|
|
|
|
target: screenSaver
|
|
|
|
property: "visible"
|
|
|
|
duration: 0
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
Transition {
|
|
|
|
from: "Invisible"
|
|
|
|
to: "Visible"
|
|
|
|
|
|
|
|
SequentialAnimation {
|
|
|
|
NumberAnimation {
|
|
|
|
target: screenSaver
|
|
|
|
property: "visible"
|
|
|
|
duration: 0
|
|
|
|
}
|
|
|
|
|
|
|
|
NumberAnimation {
|
|
|
|
target: screenSaver
|
|
|
|
property: "opacity"
|
|
|
|
duration: 500
|
|
|
|
easing.type: Easing.InQuad
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
]
|
2021-01-26 05:46:55 +01:00
|
|
|
|
2021-01-26 06:03:09 +01:00
|
|
|
FastBlur {
|
2021-01-26 05:46:55 +01:00
|
|
|
id: blur
|
2021-01-26 06:03:09 +01:00
|
|
|
|
2021-02-03 03:12:08 +01:00
|
|
|
anchors.fill: parent
|
|
|
|
source: timelineRoot
|
2021-01-26 05:46:55 +01:00
|
|
|
radius: 50
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2021-01-26 06:03:09 +01:00
|
|
|
|
|
|
|
}
|