-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathIQExtraNotifications.qml
115 lines (108 loc) · 3.85 KB
/
IQExtraNotifications.qml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
/*
* This file is part of IQ Notifier.
*
* IQ Notifier 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 3 of the License, or
* any later version.
*
* IQ Notifier 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 IQ Notifier. If not, see <http://www.gnu.org/licenses/>.
*/
import QtQuick 2.5
import QtQuick.Window 2.1
import IQNotifier 1.0
IQPopup {
id: root
visible: IQNotifications.extraNotifications > 0
x: IQNotifications.extraWindowPos.x
y: IQNotifications.extraWindowPos.y
width: IQNotifications.extraWindowSize.width
height: IQNotifications.extraWindowSize.height
property real buttonImageScale: IQThemes.notificationsTheme.extraButtonImageScale
property real unreadCircleScale: 0.6
property color bgColor: IQThemes.notificationsTheme.extraBgColor
IQFancyContainer {
id: iQFancyContainer
anchors.fill: parent
Rectangle {
id: bg
color: bgColor
anchors.fill: parent
}
Rectangle {
id: circle
scale: unreadCircleScale
color: IQThemes.notificationsTheme.extraUreadCircleColor
height: parent.height
width: height
radius: width
anchors.verticalCenter: parent.verticalCenter
anchors.left: parent.left
Text {
id: count
color: IQThemes.notificationsTheme.extraUreadTextColor
font.pointSize: parent.height/2.5
text: IQNotifications.extraNotifications
verticalAlignment: Text.AlignVCenter
horizontalAlignment: Text.AlignHCenter
anchors.horizontalCenter: parent.horizontalCenter
anchors.verticalCenter: parent.verticalCenter
}
}
MouseArea {
id: closeVisible
anchors.top: parent.top
anchors.bottom: parent.bottom
anchors.right: closeExtra.left
height: root.height
anchors.rightMargin: 0
width: height
hoverEnabled: true
Image {
scale: buttonImageScale
anchors.fill: parent
source: IQThemes.notificationsTheme.extraCloseVisibleButtonImage
opacity: parent.containsMouse ? 0.85 : 1
}
onClicked: IQNotifications.onDropVisible()
}
MouseArea {
id: closeExtra
anchors.top: parent.top
anchors.bottom: parent.bottom
anchors.right: closeAll.left
height: root.height
anchors.rightMargin: 0
width: height
hoverEnabled: true
Image {
scale: buttonImageScale
anchors.fill: parent
source: IQThemes.notificationsTheme.extraCloseButtonImage
opacity: parent.containsMouse ? 0.85 : 1
}
onClicked: IQNotifications.onDropStacked()
}
MouseArea {
id: closeAll
anchors.top: parent.top
anchors.bottom: parent.bottom
anchors.right: parent.right
width: height
hoverEnabled: true
Image {
scale: buttonImageScale
anchors.fill: parent
source: IQThemes.notificationsTheme.extraCloseAllButtonImage
opacity: parent.containsMouse ? 0.85 : 1
}
onClicked: IQNotifications.onDropAll()
}
}
}