2024-07-08 22:14:30 +02:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQuick.Controls 2.15
|
|
|
|
import QtQuick.Layouts 1.15
|
|
|
|
import QtQml.Models 2.15
|
|
|
|
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Popups.Dialog 0.1
|
|
|
|
|
|
|
|
import utils 1.0
|
2024-10-28 12:23:46 +01:00
|
|
|
import shared.panels 1.0
|
2024-07-08 22:14:30 +02:00
|
|
|
|
|
|
|
StatusDialogFooter {
|
|
|
|
id: root
|
|
|
|
|
2024-10-28 12:23:46 +01:00
|
|
|
property string maxFiatFees: d.emptyValue
|
2024-07-08 22:14:30 +02:00
|
|
|
property string totalTimeEstimate
|
|
|
|
property bool pending: true
|
|
|
|
property string nextButtonText: qsTr("Next")
|
|
|
|
property string nextButtonIconName: "password"
|
|
|
|
|
|
|
|
signal nextButtonClicked()
|
|
|
|
|
|
|
|
implicitHeight: 82
|
2024-10-15 21:26:12 +02:00
|
|
|
spacing: Theme.halfPadding
|
2024-07-08 22:14:30 +02:00
|
|
|
color: Theme.palette.baseColor3
|
|
|
|
dropShadowEnabled: true
|
|
|
|
|
2024-10-28 12:23:46 +01:00
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
|
|
|
|
readonly property string emptyValue: "..."
|
|
|
|
}
|
|
|
|
|
2024-07-08 22:14:30 +02:00
|
|
|
leftButtons: ObjectModel {
|
|
|
|
ColumnLayout {
|
2024-10-15 21:26:12 +02:00
|
|
|
Layout.leftMargin: Theme.padding
|
2024-07-08 22:14:30 +02:00
|
|
|
StatusBaseText {
|
|
|
|
color: Theme.palette.directColor5
|
|
|
|
text: qsTr("Estimated time:")
|
|
|
|
}
|
|
|
|
StatusBaseText {
|
2024-10-28 12:23:46 +01:00
|
|
|
id: estimatedTime
|
2024-07-08 22:14:30 +02:00
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
text: root.totalTimeEstimate
|
2024-10-28 12:23:46 +01:00
|
|
|
|
|
|
|
onTextChanged: {
|
|
|
|
if (text === "" || text === d.emptyValue) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
estimatedTimeAnimation.restart()
|
|
|
|
}
|
|
|
|
|
|
|
|
AnimatedText {
|
|
|
|
id: estimatedTimeAnimation
|
|
|
|
target: estimatedTime
|
|
|
|
}
|
2024-07-08 22:14:30 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
rightButtons: ObjectModel {
|
|
|
|
RowLayout {
|
2024-10-15 21:26:12 +02:00
|
|
|
spacing: Theme.padding
|
2024-07-08 22:14:30 +02:00
|
|
|
ColumnLayout {
|
|
|
|
StatusBaseText {
|
|
|
|
color: Theme.palette.directColor5
|
|
|
|
text: qsTr("Max fees:")
|
|
|
|
}
|
|
|
|
StatusBaseText {
|
2024-10-28 12:23:46 +01:00
|
|
|
id: fees
|
2024-07-08 22:14:30 +02:00
|
|
|
text: maxFiatFees
|
|
|
|
wrapMode: Text.WordWrap
|
2024-10-28 12:23:46 +01:00
|
|
|
|
|
|
|
onTextChanged: {
|
|
|
|
if (text === "" || text === d.emptyValue) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
feesAnimation.restart()
|
|
|
|
}
|
|
|
|
|
|
|
|
AnimatedText {
|
|
|
|
id: feesAnimation
|
|
|
|
target: fees
|
|
|
|
}
|
2024-07-08 22:14:30 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
StatusButton {
|
2024-10-15 21:26:12 +02:00
|
|
|
Layout.rightMargin: Theme.padding
|
2024-07-08 22:14:30 +02:00
|
|
|
text: root.nextButtonText
|
|
|
|
objectName: "transactionModalFooterButton"
|
|
|
|
enabled: !root.pending
|
|
|
|
loading: root.pending
|
|
|
|
onClicked: nextButtonClicked()
|
|
|
|
icon.name: root.nextButtonIconName
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|