2023-04-23 07:05:43 -04:00
|
|
|
import QtCore
|
|
|
|
import QtQuick
|
|
|
|
import QtQuick.Controls
|
2023-04-23 23:56:33 -04:00
|
|
|
import QtQuick.Controls.Basic
|
2023-04-23 07:05:43 -04:00
|
|
|
import QtQuick.Layouts
|
|
|
|
|
|
|
|
Dialog {
|
2023-04-23 07:35:38 -04:00
|
|
|
id: popupDialog
|
2023-04-23 07:05:43 -04:00
|
|
|
anchors.centerIn: parent
|
|
|
|
opacity: 0.9
|
|
|
|
padding: 20
|
|
|
|
property alias text: textField.text
|
2023-04-25 11:20:51 -04:00
|
|
|
property bool shouldTimeOut: true
|
|
|
|
property bool shouldShowBusy: false
|
|
|
|
modal: shouldShowBusy
|
|
|
|
closePolicy: shouldShowBusy ? Popup.NoAutoClose : (Popup.CloseOnEscape | Popup.CloseOnPressOutside)
|
2023-04-23 09:42:35 -04:00
|
|
|
|
|
|
|
Theme {
|
|
|
|
id: theme
|
|
|
|
}
|
|
|
|
|
2023-04-25 11:20:51 -04:00
|
|
|
Row {
|
|
|
|
anchors.centerIn: parent
|
|
|
|
width: childrenRect.width
|
|
|
|
height: childrenRect.height
|
|
|
|
spacing: 20
|
|
|
|
|
|
|
|
Text {
|
|
|
|
id: textField
|
|
|
|
anchors.verticalCenter: busyIndicator.verticalCenter
|
|
|
|
horizontalAlignment: Text.AlignJustify
|
|
|
|
color: theme.textColor
|
|
|
|
Accessible.role: Accessible.HelpBalloon
|
|
|
|
Accessible.name: text
|
|
|
|
Accessible.description: qsTr("Reveals a shortlived help balloon")
|
|
|
|
}
|
|
|
|
|
|
|
|
BusyIndicator {
|
|
|
|
id: busyIndicator
|
|
|
|
visible: shouldShowBusy
|
|
|
|
running: shouldShowBusy
|
|
|
|
|
|
|
|
Accessible.role: Accessible.Animation
|
|
|
|
Accessible.name: qsTr("Busy indicator")
|
|
|
|
Accessible.description: qsTr("Displayed when the popup is showing busy")
|
|
|
|
}
|
2023-04-23 07:05:43 -04:00
|
|
|
}
|
2023-04-25 11:20:51 -04:00
|
|
|
|
2023-04-23 07:05:43 -04:00
|
|
|
background: Rectangle {
|
|
|
|
anchors.fill: parent
|
2023-04-23 09:42:35 -04:00
|
|
|
color: theme.backgroundDarkest
|
2023-04-23 07:05:43 -04:00
|
|
|
border.width: 1
|
2023-04-23 09:42:35 -04:00
|
|
|
border.color: theme.dialogBorder
|
2023-04-23 07:05:43 -04:00
|
|
|
radius: 10
|
|
|
|
}
|
|
|
|
|
|
|
|
exit: Transition {
|
|
|
|
NumberAnimation { duration: 500; property: "opacity"; from: 1.0; to: 0.0 }
|
|
|
|
}
|
2023-04-23 07:35:38 -04:00
|
|
|
|
|
|
|
onOpened: {
|
2023-04-25 11:20:51 -04:00
|
|
|
if (shouldTimeOut)
|
|
|
|
timer.start()
|
2023-04-23 07:35:38 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
Timer {
|
|
|
|
id: timer
|
|
|
|
interval: 500; running: false; repeat: false
|
|
|
|
onTriggered: popupDialog.close()
|
|
|
|
}
|
2023-04-23 07:05:43 -04:00
|
|
|
}
|