2014-02-27 14:25:03 +00:00
|
|
|
/*
|
2020-08-02 22:22:19 +00:00
|
|
|
SPDX-FileCopyrightText: 2014 Martin Gräßlin <mgraesslin@kde.org>
|
|
|
|
SPDX-FileCopyrightText: 2017 Kai Uwe Broulik <kde@privat.broulik.de>
|
|
|
|
|
|
|
|
SPDX-License-Identifier: GPL-2.0-only OR GPL-3.0-only OR LicenseRef-KDE-Accepted-GPL
|
2014-02-27 14:25:03 +00:00
|
|
|
*/
|
2017-04-25 14:38:52 +00:00
|
|
|
import QtQuick 2.1
|
|
|
|
import QtQuick.Window 2.1
|
|
|
|
import org.kde.plasma.core 2.0 as PlasmaCore
|
2014-02-27 14:25:03 +00:00
|
|
|
|
|
|
|
Window {
|
|
|
|
id: window
|
2017-04-25 14:38:52 +00:00
|
|
|
|
|
|
|
readonly property int animationDuration: units.longDuration
|
|
|
|
property bool animationEnabled: false
|
|
|
|
|
2016-08-09 14:38:19 +00:00
|
|
|
flags: Qt.BypassWindowManagerHint | Qt.FramelessWindowHint
|
2014-02-27 14:25:03 +00:00
|
|
|
color: "transparent"
|
|
|
|
|
|
|
|
// outline is a context property
|
2017-04-25 14:38:52 +00:00
|
|
|
x: outline.unifiedGeometry.x
|
|
|
|
y: outline.unifiedGeometry.y
|
|
|
|
width: outline.unifiedGeometry.width
|
|
|
|
height: outline.unifiedGeometry.height
|
|
|
|
|
2014-02-27 14:25:03 +00:00
|
|
|
visible: outline.active
|
|
|
|
|
2017-04-25 14:38:52 +00:00
|
|
|
onVisibleChanged: {
|
|
|
|
if (visible) {
|
|
|
|
if (outline.visualParentGeometry.width > 0 && outline.visualParentGeometry.height > 0) {
|
|
|
|
window.animationEnabled = false
|
|
|
|
// move our frame to the visual parent geometry
|
|
|
|
svg.setGeometry(outline.visualParentGeometry)
|
|
|
|
window.animationEnabled = true
|
|
|
|
// and then animate it nicely to its destination
|
|
|
|
svg.setGeometry(outline.geometry)
|
|
|
|
} else {
|
|
|
|
// no visual parent? just move it to its destination right away
|
|
|
|
window.animationEnabled = false
|
|
|
|
svg.setGeometry(outline.geometry)
|
|
|
|
window.animationEnabled = true
|
2014-02-27 14:25:03 +00:00
|
|
|
}
|
2017-04-25 14:38:52 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Connections {
|
|
|
|
target: outline
|
|
|
|
// when unified geometry changes, this means our window position changed and any
|
|
|
|
// animation will potentially be offset and/or cut off, skip the animation in this case
|
2020-11-11 16:44:38 +00:00
|
|
|
function onUnifiedGeometryChanged() {
|
2017-04-25 14:38:52 +00:00
|
|
|
if (window.visible) {
|
|
|
|
window.animationEnabled = false
|
|
|
|
svg.setGeometry(outline.geometry)
|
|
|
|
window.animationEnabled = true
|
2014-02-27 14:25:03 +00:00
|
|
|
}
|
2017-04-25 14:38:52 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
PlasmaCore.FrameSvgItem {
|
|
|
|
id: svg
|
|
|
|
|
|
|
|
// takes into account the offset inside unified geometry
|
|
|
|
function setGeometry(geometry) {
|
|
|
|
x = geometry.x - outline.unifiedGeometry.x
|
|
|
|
y = geometry.y - outline.unifiedGeometry.y
|
|
|
|
width = geometry.width
|
|
|
|
height = geometry.height
|
|
|
|
}
|
|
|
|
|
|
|
|
imagePath: "widgets/translucentbackground"
|
|
|
|
|
|
|
|
x: 0
|
|
|
|
y: 0
|
|
|
|
width: 0
|
|
|
|
height: 0
|
|
|
|
|
|
|
|
enabledBorders: {
|
|
|
|
var maximizedArea = workspace.clientArea(workspace.MaximizeArea, Qt.point(outline.geometry.x, outline.geometry.y), workspace.currentDesktop);
|
|
|
|
|
|
|
|
var left = outline.geometry.x === maximizedArea.x;
|
|
|
|
var right = outline.geometry.x + outline.geometry.width === maximizedArea.x + maximizedArea.width;
|
|
|
|
var top = outline.geometry.y === maximizedArea.y;
|
|
|
|
var bottom = outline.geometry.y + outline.geometry.height === maximizedArea.y + maximizedArea.height;
|
|
|
|
|
2014-02-27 14:25:03 +00:00
|
|
|
var borders = PlasmaCore.FrameSvgItem.AllBorders;
|
|
|
|
if (left) {
|
|
|
|
borders = borders & ~PlasmaCore.FrameSvgItem.LeftBorder;
|
|
|
|
}
|
|
|
|
if (right) {
|
|
|
|
borders = borders & ~PlasmaCore.FrameSvgItem.RightBorder;
|
|
|
|
}
|
|
|
|
if (top) {
|
|
|
|
borders = borders & ~PlasmaCore.FrameSvgItem.TopBorder;
|
|
|
|
}
|
|
|
|
if (bottom) {
|
|
|
|
borders = borders & ~PlasmaCore.FrameSvgItem.BottomBorder;
|
|
|
|
}
|
|
|
|
if (left && right && bottom && top) {
|
|
|
|
borders = PlasmaCore.FrameSvgItem.AllBorders;
|
|
|
|
}
|
2017-04-25 14:38:52 +00:00
|
|
|
return borders;
|
2014-02-27 14:25:03 +00:00
|
|
|
}
|
2017-04-25 14:38:52 +00:00
|
|
|
|
|
|
|
Behavior on x {
|
2020-03-04 10:51:25 +00:00
|
|
|
NumberAnimation { duration: window.animationDuration; easing.type: Easing.InOutCubic; }
|
2017-04-25 14:38:52 +00:00
|
|
|
enabled: window.animationEnabled
|
|
|
|
}
|
|
|
|
Behavior on y {
|
2020-03-04 10:51:25 +00:00
|
|
|
NumberAnimation { duration: window.animationDuration; easing.type: Easing.InOutCubic; }
|
2017-04-25 14:38:52 +00:00
|
|
|
enabled: window.animationEnabled
|
|
|
|
}
|
|
|
|
Behavior on width {
|
2020-03-04 10:51:25 +00:00
|
|
|
NumberAnimation { duration: window.animationDuration; easing.type: Easing.InOutCubic; }
|
2017-04-25 14:38:52 +00:00
|
|
|
enabled: window.animationEnabled
|
|
|
|
}
|
|
|
|
Behavior on height {
|
2020-03-04 10:51:25 +00:00
|
|
|
NumberAnimation { duration: window.animationDuration; easing.type: Easing.InOutCubic; }
|
2017-04-25 14:38:52 +00:00
|
|
|
enabled: window.animationEnabled
|
2014-02-27 14:25:03 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|