2022-09-15 09:31:38 +02:00
|
|
|
import QtQuick 2.14
|
|
|
|
import QtQuick.Controls 2.14
|
2020-11-27 13:32:48 -04:00
|
|
|
import QtQuick.Layouts 1.13
|
2021-04-21 17:39:05 +10:00
|
|
|
import QtGraphicalEffects 1.13
|
2021-09-28 18:04:06 +03:00
|
|
|
|
2022-09-02 17:56:14 +03:00
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
|
2021-09-28 18:04:06 +03:00
|
|
|
import utils 1.0
|
2022-09-15 09:31:38 +02:00
|
|
|
|
2022-09-02 17:56:14 +03:00
|
|
|
Item {
|
2021-04-21 17:39:05 +10:00
|
|
|
id: root
|
2022-02-09 10:43:23 +01:00
|
|
|
|
2022-09-02 17:56:14 +03:00
|
|
|
enum Type {
|
|
|
|
Danger,
|
2023-01-18 20:37:36 +04:00
|
|
|
Warning,
|
2022-09-02 17:56:14 +03:00
|
|
|
Success
|
|
|
|
}
|
|
|
|
|
2023-01-30 11:42:26 +01:00
|
|
|
property bool active
|
2022-09-02 17:56:14 +03:00
|
|
|
property int type: ModuleWarning.Danger
|
2022-09-15 09:31:38 +02:00
|
|
|
property int progressValue: -1 // 0..100, -1 not visible
|
2021-06-17 14:41:11 -04:00
|
|
|
property string text: ""
|
2022-09-02 17:56:14 +03:00
|
|
|
property alias buttonText: button.text
|
2022-09-15 09:31:38 +02:00
|
|
|
property alias closeBtnVisible: closeImg.visible
|
2022-09-02 17:56:14 +03:00
|
|
|
|
|
|
|
signal clicked()
|
|
|
|
signal closeClicked()
|
|
|
|
signal showStarted()
|
2022-09-27 23:26:26 +02:00
|
|
|
signal showFinished()
|
2022-09-02 17:56:14 +03:00
|
|
|
signal hideStarted()
|
|
|
|
signal hideFinished()
|
2022-02-09 10:43:23 +01:00
|
|
|
|
2022-09-02 17:56:14 +03:00
|
|
|
function show() {
|
|
|
|
hideTimer.stop()
|
2023-01-30 11:42:26 +01:00
|
|
|
active = true;
|
2022-09-02 17:56:14 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function showFor(duration = 5000) {
|
|
|
|
show();
|
|
|
|
hide(duration);
|
|
|
|
}
|
2021-04-21 17:39:05 +10:00
|
|
|
|
2022-09-02 17:56:14 +03:00
|
|
|
function hide(timeout = 0) {
|
|
|
|
hideTimer.interval = timeout
|
|
|
|
hideTimer.start()
|
|
|
|
}
|
2022-03-03 17:00:52 -04:00
|
|
|
|
2022-03-17 12:15:38 -04:00
|
|
|
function close() {
|
2022-09-02 17:56:14 +03:00
|
|
|
closeButtonMouseArea.clicked(null)
|
2022-03-17 12:15:38 -04:00
|
|
|
}
|
|
|
|
|
2022-09-15 09:31:38 +02:00
|
|
|
signal linkActivated(string link)
|
|
|
|
|
2023-01-30 11:42:26 +01:00
|
|
|
implicitHeight: active ? content.implicitHeight : 0
|
2022-09-02 17:56:14 +03:00
|
|
|
visible: implicitHeight > 0
|
2020-11-27 13:32:48 -04:00
|
|
|
|
2022-09-02 17:56:14 +03:00
|
|
|
onActiveChanged: {
|
|
|
|
active ? showAnimation.start() : hideAnimation.start()
|
|
|
|
}
|
|
|
|
|
|
|
|
NumberAnimation {
|
|
|
|
id: showAnimation
|
|
|
|
target: root
|
|
|
|
property: "implicitHeight"
|
|
|
|
from: 0
|
|
|
|
to: content.implicitHeight
|
|
|
|
duration: 500
|
|
|
|
easing.type: Easing.OutCubic
|
|
|
|
onStarted: {
|
|
|
|
root.showStarted()
|
2020-11-27 13:32:48 -04:00
|
|
|
}
|
2022-09-02 17:56:14 +03:00
|
|
|
onFinished: {
|
2022-09-27 23:26:26 +02:00
|
|
|
root.showFinished()
|
2022-09-02 17:56:14 +03:00
|
|
|
}
|
|
|
|
}
|
2020-11-27 13:32:48 -04:00
|
|
|
|
2022-09-02 17:56:14 +03:00
|
|
|
NumberAnimation {
|
|
|
|
id: hideAnimation
|
|
|
|
target: root
|
|
|
|
property: "implicitHeight"
|
|
|
|
to: 0
|
|
|
|
from: content.implicitHeight
|
|
|
|
duration: 500
|
|
|
|
easing.type: Easing.OutCubic
|
|
|
|
onStarted: {
|
|
|
|
root.hideStarted()
|
|
|
|
}
|
|
|
|
onFinished: {
|
|
|
|
root.hideFinished()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Timer {
|
|
|
|
id: hideTimer
|
|
|
|
repeat: false
|
|
|
|
running: false
|
|
|
|
onTriggered: {
|
2023-01-30 11:42:26 +01:00
|
|
|
root.active = false
|
2022-09-02 17:56:14 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
id: content
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
width: parent.width
|
|
|
|
implicitHeight: 32
|
|
|
|
|
|
|
|
readonly property color baseColor: {
|
|
|
|
switch (root.type) {
|
|
|
|
case ModuleWarning.Danger: return Theme.palette.dangerColor1
|
|
|
|
case ModuleWarning.Success: return Theme.palette.successColor1
|
2023-01-18 20:37:36 +04:00
|
|
|
case ModuleWarning.Warning: return Theme.palette.warningColor1
|
2022-09-02 17:56:14 +03:00
|
|
|
default: return Theme.palette.baseColor1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
color: baseColor
|
|
|
|
|
|
|
|
Behavior on color {
|
|
|
|
ColorAnimation {
|
|
|
|
duration: 150
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
RowLayout {
|
|
|
|
id: layout
|
|
|
|
|
|
|
|
spacing: 12
|
2022-09-15 09:31:38 +02:00
|
|
|
anchors.centerIn: parent
|
2022-09-02 17:56:14 +03:00
|
|
|
|
|
|
|
StatusBaseText {
|
|
|
|
text: root.text
|
|
|
|
font.pixelSize: 13
|
2022-09-15 09:31:38 +02:00
|
|
|
font.weight: Font.Medium
|
2022-09-02 17:56:14 +03:00
|
|
|
color: Theme.palette.indirectColor1
|
2022-09-15 09:31:38 +02:00
|
|
|
linkColor: color
|
|
|
|
onLinkActivated: root.linkActivated(link)
|
|
|
|
HoverHandler {
|
|
|
|
id: handler1
|
|
|
|
}
|
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
|
|
|
acceptedButtons: Qt.NoButton
|
|
|
|
cursorShape: handler1.hovered && parent.hoveredLink ? Qt.PointingHandCursor : Qt.ArrowCursor
|
|
|
|
}
|
2022-09-02 17:56:14 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
Button {
|
|
|
|
id: button
|
|
|
|
visible: text != ""
|
2023-04-05 15:25:21 +02:00
|
|
|
focusPolicy: Qt.NoFocus
|
2022-09-02 17:56:14 +03:00
|
|
|
padding: 5
|
|
|
|
onClicked: {
|
|
|
|
root.clicked()
|
|
|
|
}
|
2022-09-15 09:31:38 +02:00
|
|
|
contentItem: StatusBaseText {
|
2022-09-02 17:56:14 +03:00
|
|
|
text: button.text
|
2022-09-15 09:31:38 +02:00
|
|
|
font.pixelSize: 13
|
2020-11-27 13:32:48 -04:00
|
|
|
font.weight: Font.Medium
|
2022-09-15 17:23:51 +02:00
|
|
|
font.family: Style.current.baseFont.name
|
2020-11-27 13:32:48 -04:00
|
|
|
horizontalAlignment: Text.AlignHCenter
|
|
|
|
verticalAlignment: Text.AlignVCenter
|
2022-09-02 17:56:14 +03:00
|
|
|
color: Theme.palette.indirectColor1
|
|
|
|
}
|
|
|
|
background: Rectangle {
|
|
|
|
radius: 4
|
|
|
|
border.width: 1
|
|
|
|
border.color: Theme.palette.indirectColor3
|
|
|
|
color: Theme.palette.getColor("white", button.hovered ? 0.4 : 0.1)
|
|
|
|
}
|
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
|
|
|
acceptedButtons: Qt.NoButton
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
2020-11-27 13:32:48 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-15 09:31:38 +02:00
|
|
|
StatusBaseText {
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
anchors.right: progressBar.left
|
|
|
|
anchors.rightMargin: Style.current.halfPadding
|
|
|
|
text: qsTr("%1%").arg(progressBar.value)
|
|
|
|
visible: progressBar.visible
|
|
|
|
font.pixelSize: 12
|
|
|
|
verticalAlignment: Text.AlignVCenter
|
|
|
|
color: Theme.palette.white
|
|
|
|
}
|
|
|
|
|
|
|
|
ProgressBar {
|
|
|
|
id: progressBar
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
anchors.right: closeImg.left
|
|
|
|
anchors.rightMargin: Style.current.bigPadding
|
|
|
|
from: 0
|
|
|
|
to: 100
|
|
|
|
visible: root.progressValue > -1
|
|
|
|
value: root.progressValue
|
|
|
|
background: Rectangle {
|
|
|
|
implicitWidth: 64
|
|
|
|
implicitHeight: 8
|
|
|
|
radius: 8
|
|
|
|
color: "transparent"
|
|
|
|
border.width: 1
|
|
|
|
border.color: Theme.palette.white
|
|
|
|
}
|
|
|
|
contentItem: Rectangle {
|
|
|
|
width: progressBar.width*progressBar.position
|
|
|
|
implicitHeight: 8
|
|
|
|
radius: 8
|
|
|
|
color: Theme.palette.white
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-02 17:56:14 +03:00
|
|
|
StatusIcon {
|
|
|
|
id: closeImg
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: 18
|
|
|
|
height: 20
|
|
|
|
width: 20
|
|
|
|
icon: "close-circle"
|
|
|
|
color: Theme.palette.indirectColor1
|
|
|
|
opacity: closeButtonMouseArea.containsMouse ? 1 : 0.7
|
2022-03-03 17:00:52 -04:00
|
|
|
|
2022-09-02 17:56:14 +03:00
|
|
|
MouseArea {
|
|
|
|
id: closeButtonMouseArea
|
|
|
|
anchors.fill: parent
|
|
|
|
hoverEnabled: true
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
onClicked: {
|
|
|
|
root.closeClicked()
|
|
|
|
}
|
2022-03-03 17:00:52 -04:00
|
|
|
}
|
2021-04-21 17:39:05 +10:00
|
|
|
}
|
|
|
|
}
|
2021-06-11 15:57:43 +02:00
|
|
|
}
|