mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-13 15:55:18 +00:00
bf14b06d55
This adds the UI plus all necessary models and signal handling to render discord import progress in the desktop application. It also introduces message handling for discord chat message types. Requires status-im/status-go#2826 to function Co-authored with @caybro
135 lines
4.0 KiB
QML
135 lines
4.0 KiB
QML
import QtQuick 2.13
|
|
import QtQuick.Controls 2.13
|
|
import QtQuick.Layouts 1.13
|
|
|
|
import StatusQ.Core 0.1
|
|
import StatusQ.Core.Theme 0.1
|
|
import StatusQ.Controls 0.1
|
|
import StatusQ.Popups 0.1
|
|
|
|
StatusModal {
|
|
id: confirmationDialog
|
|
anchors.centerIn: parent
|
|
|
|
property var parentPopup
|
|
property var value
|
|
property var executeConfirm
|
|
property var executeReject
|
|
property var executeCancel
|
|
property string confirmButtonObjectName: ""
|
|
property string btnType: "warn"
|
|
property string cancelBtnType: "warn"
|
|
property string confirmButtonLabel: qsTr("Confirm")
|
|
property string rejectButtonLabel: qsTr("Reject")
|
|
property string cancelButtonLabel: qsTr("Cancel")
|
|
property string confirmationText: qsTr("Are you sure you want to do this?")
|
|
property bool showRejectButton: false
|
|
property bool showCancelButton: false
|
|
property alias checkbox: checkbox
|
|
|
|
|
|
header.title: qsTr("Confirm your action")
|
|
focus: visible
|
|
|
|
signal confirmButtonClicked()
|
|
signal rejectButtonClicked()
|
|
signal cancelButtonClicked()
|
|
|
|
|
|
contentItem: Item {
|
|
width: confirmationDialog.width
|
|
implicitHeight: childrenRect.height
|
|
Column {
|
|
width: parent.width - 32
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
Item {
|
|
width: parent.width
|
|
height: 16
|
|
}
|
|
|
|
StatusBaseText {
|
|
text: confirmationDialog.confirmationText
|
|
font.pixelSize: 15
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
wrapMode: Text.WordWrap
|
|
color: Theme.palette.directColor1
|
|
}
|
|
|
|
Item {
|
|
width: parent.width
|
|
height: 16
|
|
}
|
|
|
|
StatusCheckBox {
|
|
id: checkbox
|
|
visible: false
|
|
Layout.preferredWidth: parent.width
|
|
text: qsTr("Do not show this again")
|
|
}
|
|
|
|
Item {
|
|
width: parent.width
|
|
height: visible ? 16 : 0
|
|
visible: checkbox.visible
|
|
}
|
|
}
|
|
}
|
|
|
|
rightButtons: [
|
|
StatusFlatButton {
|
|
id: cancelButton
|
|
visible: showCancelButton
|
|
text: confirmationDialog.cancelButtonLabel
|
|
type: {
|
|
switch (confirmationDialog.cancelBtnType) {
|
|
case "warn":
|
|
return StatusBaseButton.Type.Danger
|
|
default:
|
|
return StatusBaseButton.Type.Normal
|
|
}
|
|
}
|
|
onClicked: {
|
|
if (executeCancel && typeof executeCancel === "function") {
|
|
executeCancel()
|
|
}
|
|
confirmationDialog.cancelButtonClicked()
|
|
}
|
|
},
|
|
StatusFlatButton {
|
|
visible: showRejectButton
|
|
text: confirmationDialog.rejectButtonLabel
|
|
onClicked: {
|
|
if (executeReject && typeof executeReject === "function") {
|
|
executeReject()
|
|
}
|
|
confirmationDialog.rejectButtonClicked()
|
|
}
|
|
},
|
|
StatusButton {
|
|
id: confirmButton
|
|
objectName: confirmationDialog.confirmButtonObjectName
|
|
type: {
|
|
switch (confirmationDialog.btnType) {
|
|
case "warn":
|
|
return StatusBaseButton.Type.Danger
|
|
default:
|
|
return StatusBaseButton.Type.Normal
|
|
}
|
|
}
|
|
text: confirmationDialog.confirmButtonLabel
|
|
focus: true
|
|
Keys.onReturnPressed: function(event) {
|
|
confirmButton.clicked()
|
|
}
|
|
onClicked: {
|
|
if (executeConfirm && typeof executeConfirm === "function") {
|
|
executeConfirm()
|
|
}
|
|
confirmationDialog.confirmButtonClicked()
|
|
}
|
|
}
|
|
]
|
|
}
|