2022-06-06 18:23:24 +03:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtGraphicalEffects 1.13
|
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
2022-08-18 16:25:06 +02:00
|
|
|
import StatusQ.Components 0.1
|
2022-06-06 18:23:24 +03:00
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Controls 0.1 as StatusQControls
|
|
|
|
|
|
|
|
import shared.panels 1.0
|
|
|
|
import shared.status 1.0
|
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
property alias text: bannerText.text
|
|
|
|
property alias buttonText: bannerButton.text
|
2022-08-11 14:55:08 +03:00
|
|
|
property alias icon: bannerIcon.asset
|
2022-09-15 09:31:38 +02:00
|
|
|
property string buttonTooltipText: ""
|
|
|
|
property bool buttonLoading: false
|
2022-06-06 18:23:24 +03:00
|
|
|
|
|
|
|
implicitWidth: 272
|
2022-08-18 16:25:06 +02:00
|
|
|
implicitHeight: 168
|
2022-06-06 18:23:24 +03:00
|
|
|
border.color: Style.current.border
|
|
|
|
radius: 16
|
|
|
|
color: Style.current.transparent
|
|
|
|
|
|
|
|
signal buttonClicked()
|
|
|
|
|
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
|
|
|
acceptedButtons: Qt.RightButton
|
|
|
|
propagateComposedEvents: true
|
|
|
|
onClicked: {
|
|
|
|
/* Prevents sending events to the component beneath
|
|
|
|
if Right Mouse Button is clicked. */
|
|
|
|
mouse.accepted = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
width: 70
|
|
|
|
height: 4
|
|
|
|
color: Style.current.background
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin: -2
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
}
|
|
|
|
|
2022-08-18 16:25:06 +02:00
|
|
|
StatusRoundIcon {
|
2022-06-06 18:23:24 +03:00
|
|
|
id: bannerIcon
|
|
|
|
anchors.top: parent.top
|
2022-08-18 16:25:06 +02:00
|
|
|
anchors.topMargin: -8
|
2022-06-06 18:23:24 +03:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusBaseText {
|
|
|
|
id: bannerText
|
|
|
|
anchors.top: parent.top
|
2022-08-18 16:25:06 +02:00
|
|
|
anchors.topMargin: 48
|
2022-06-06 18:23:24 +03:00
|
|
|
horizontalAlignment: Text.AlignHCenter
|
|
|
|
font.pixelSize: 15
|
|
|
|
color: Theme.palette.directColor1
|
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: Style.current.xlPadding
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: Style.current.xlPadding
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusQControls.StatusButton {
|
|
|
|
id: bannerButton
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
anchors.bottom: parent.bottom
|
2022-08-18 16:25:06 +02:00
|
|
|
anchors.bottomMargin: 16
|
|
|
|
font.weight: Font.Medium
|
2022-09-15 09:31:38 +02:00
|
|
|
onClicked: {
|
|
|
|
if (!root.buttonLoading) {
|
|
|
|
root.buttonClicked()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
loading: root.buttonLoading
|
|
|
|
|
|
|
|
StatusQControls.StatusToolTip {
|
|
|
|
text: root.buttonTooltipText
|
|
|
|
visible: !!root.buttonTooltipText && bannerButton.loading && bannerButton.hovered
|
|
|
|
}
|
2022-06-06 18:23:24 +03:00
|
|
|
}
|
|
|
|
}
|
2022-08-25 13:18:51 +02:00
|
|
|
|