qml: forgot WalletDetails.qml
This commit is contained in:
306
electrum/gui/qml/components/WalletDetails.qml
Normal file
306
electrum/gui/qml/components/WalletDetails.qml
Normal file
@@ -0,0 +1,306 @@
|
||||
import QtQuick 2.6
|
||||
import QtQuick.Layouts 1.0
|
||||
import QtQuick.Controls 2.3
|
||||
import QtQuick.Controls.Material 2.0
|
||||
|
||||
import org.electrum 1.0
|
||||
|
||||
import "controls"
|
||||
|
||||
Pane {
|
||||
id: rootItem
|
||||
objectName: 'WalletDetails'
|
||||
|
||||
padding: 0
|
||||
|
||||
function enableLightning() {
|
||||
var dialog = app.messageDialog.createObject(rootItem,
|
||||
{'text': qsTr('Enable Lightning for this wallet?'), 'yesno': true})
|
||||
dialog.yesClicked.connect(function() {
|
||||
Daemon.currentWallet.enableLightning()
|
||||
})
|
||||
dialog.open()
|
||||
}
|
||||
|
||||
function deleteWallet() {
|
||||
var dialog = app.messageDialog.createObject(rootItem,
|
||||
{'text': qsTr('Really delete this wallet?'), 'yesno': true})
|
||||
dialog.yesClicked.connect(function() {
|
||||
Daemon.check_then_delete_wallet(Daemon.currentWallet)
|
||||
})
|
||||
dialog.open()
|
||||
}
|
||||
|
||||
function changePassword() {
|
||||
// trigger dialog via wallet (auth then signal)
|
||||
Daemon.start_change_password()
|
||||
}
|
||||
|
||||
|
||||
ColumnLayout {
|
||||
id: rootLayout
|
||||
width: parent.width
|
||||
height: parent.height
|
||||
spacing: 0
|
||||
|
||||
Flickable {
|
||||
Layout.fillWidth: true
|
||||
Layout.fillHeight: true
|
||||
Layout.margins: constants.paddingLarge
|
||||
|
||||
contentHeight: flickableLayout.height
|
||||
clip:true
|
||||
interactive: height < contentHeight
|
||||
|
||||
ColumnLayout {
|
||||
id: flickableLayout
|
||||
width: parent.width
|
||||
spacing: constants.paddingLarge
|
||||
|
||||
RowLayout {
|
||||
Label {
|
||||
text: qsTr('Wallet:')
|
||||
font.pixelSize: constants.fontSizeLarge
|
||||
color: Material.accentColor
|
||||
}
|
||||
|
||||
Label {
|
||||
text: Daemon.currentWallet.name;
|
||||
font.bold: true
|
||||
font.pixelSize: constants.fontSizeLarge
|
||||
Layout.fillWidth: true
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
Layout.fillWidth: true
|
||||
height: 1
|
||||
color: Material.accentColor
|
||||
}
|
||||
|
||||
GridLayout {
|
||||
columns: 3
|
||||
Layout.alignment: Qt.AlignHCenter
|
||||
|
||||
Tag {
|
||||
Layout.alignment: Qt.AlignHCenter
|
||||
text: Daemon.currentWallet.walletType
|
||||
font.pixelSize: constants.fontSizeSmall
|
||||
font.bold: true
|
||||
iconSource: '../../../icons/wallet.png'
|
||||
}
|
||||
Tag {
|
||||
Layout.alignment: Qt.AlignHCenter
|
||||
text: Daemon.currentWallet.txinType
|
||||
font.pixelSize: constants.fontSizeSmall
|
||||
font.bold: true
|
||||
}
|
||||
Tag {
|
||||
Layout.alignment: Qt.AlignHCenter
|
||||
text: qsTr('HD')
|
||||
visible: Daemon.currentWallet.isDeterministic
|
||||
font.pixelSize: constants.fontSizeSmall
|
||||
font.bold: true
|
||||
}
|
||||
Tag {
|
||||
Layout.alignment: Qt.AlignHCenter
|
||||
text: qsTr('Watch only')
|
||||
visible: Daemon.currentWallet.isWatchOnly
|
||||
font.pixelSize: constants.fontSizeSmall
|
||||
font.bold: true
|
||||
iconSource: '../../../icons/eye1.png'
|
||||
}
|
||||
Tag {
|
||||
Layout.alignment: Qt.AlignHCenter
|
||||
text: qsTr('Encrypted')
|
||||
visible: Daemon.currentWallet.isEncrypted
|
||||
font.pixelSize: constants.fontSizeSmall
|
||||
font.bold: true
|
||||
iconSource: '../../../icons/key.png'
|
||||
}
|
||||
Tag {
|
||||
Layout.alignment: Qt.AlignHCenter
|
||||
text: qsTr('HW')
|
||||
visible: Daemon.currentWallet.isHardware
|
||||
font.pixelSize: constants.fontSizeSmall
|
||||
font.bold: true
|
||||
iconSource: '../../../icons/seed.png'
|
||||
}
|
||||
Tag {
|
||||
Layout.alignment: Qt.AlignHCenter
|
||||
text: qsTr('Lightning')
|
||||
visible: Daemon.currentWallet.isLightning
|
||||
font.pixelSize: constants.fontSizeSmall
|
||||
font.bold: true
|
||||
iconSource: '../../../icons/lightning.png'
|
||||
}
|
||||
Tag {
|
||||
Layout.alignment: Qt.AlignHCenter
|
||||
text: qsTr('Seed')
|
||||
visible: Daemon.currentWallet.hasSeed
|
||||
font.pixelSize: constants.fontSizeSmall
|
||||
font.bold: true
|
||||
iconSource: '../../../icons/seed.png'
|
||||
}
|
||||
}
|
||||
|
||||
Piechart {
|
||||
id: piechart
|
||||
visible: Daemon.currentWallet.totalBalance.satsInt > 0
|
||||
Layout.preferredWidth: parent.width
|
||||
implicitHeight: 200 // TODO: sane value dependent on screen
|
||||
innerOffset: 6
|
||||
function updateSlices() {
|
||||
var totalB = Daemon.currentWallet.totalBalance.satsInt
|
||||
var onchainB = Daemon.currentWallet.confirmedBalance.satsInt
|
||||
var frozenB = Daemon.currentWallet.frozenBalance.satsInt
|
||||
var lnB = Daemon.currentWallet.lightningBalance.satsInt
|
||||
piechart.slices = [
|
||||
{ v: (onchainB-frozenB)/totalB, color: constants.colorPiechartOnchain, text: 'On-chain' },
|
||||
{ v: frozenB/totalB, color: constants.colorPiechartFrozen, text: 'On-chain (frozen)' },
|
||||
{ v: lnB/totalB, color: constants.colorPiechartLightning, text: 'Lightning' }
|
||||
]
|
||||
}
|
||||
}
|
||||
|
||||
GridLayout {
|
||||
id: detailsLayout
|
||||
visible: Daemon.currentWallet
|
||||
Layout.preferredWidth: parent.width
|
||||
|
||||
columns: 2
|
||||
|
||||
Label {
|
||||
text: qsTr('Derivation prefix')
|
||||
visible: Daemon.currentWallet.isDeterministic
|
||||
color: Material.accentColor
|
||||
}
|
||||
Label {
|
||||
text: Daemon.currentWallet.derivationPrefix
|
||||
visible: Daemon.currentWallet.isDeterministic
|
||||
}
|
||||
|
||||
Label {
|
||||
visible: Daemon.currentWallet.masterPubkey
|
||||
Layout.columnSpan:2; text: qsTr('Master Public Key'); color: Material.accentColor
|
||||
}
|
||||
|
||||
TextHighlightPane {
|
||||
visible: Daemon.currentWallet.masterPubkey
|
||||
|
||||
Layout.columnSpan: 2
|
||||
Layout.fillWidth: true
|
||||
padding: 0
|
||||
leftPadding: constants.paddingSmall
|
||||
|
||||
RowLayout {
|
||||
width: parent.width
|
||||
Label {
|
||||
text: Daemon.currentWallet.masterPubkey
|
||||
wrapMode: Text.Wrap
|
||||
Layout.fillWidth: true
|
||||
font.family: FixedFont
|
||||
font.pixelSize: constants.fontSizeMedium
|
||||
}
|
||||
ToolButton {
|
||||
icon.source: '../../icons/share.png'
|
||||
icon.color: 'transparent'
|
||||
onClicked: {
|
||||
var dialog = app.genericShareDialog.createObject(rootItem, {
|
||||
title: qsTr('Master Public Key'),
|
||||
text: Daemon.currentWallet.masterPubkey
|
||||
})
|
||||
dialog.open()
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
FlatButton {
|
||||
Layout.fillWidth: true
|
||||
text: qsTr('Change Password');
|
||||
onClicked: rootItem.changePassword()
|
||||
icon.source: '../../icons/lock.png'
|
||||
}
|
||||
FlatButton {
|
||||
Layout.fillWidth: true
|
||||
text: qsTr('Delete Wallet');
|
||||
onClicked: rootItem.deleteWallet()
|
||||
icon.source: '../../icons/delete.png'
|
||||
}
|
||||
FlatButton {
|
||||
Layout.fillWidth: true
|
||||
text: qsTr('Enable Lightning');
|
||||
onClicked: rootItem.enableLightning()
|
||||
visible: Daemon.currentWallet && Daemon.currentWallet.canHaveLightning && !Daemon.currentWallet.isLightning
|
||||
icon.source: '../../icons/lightning.png'
|
||||
}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: Daemon
|
||||
function onWalletLoaded() {
|
||||
Daemon.availableWallets.reload()
|
||||
app.stack.pop()
|
||||
}
|
||||
function onRequestNewPassword() { // new unified password (all wallets)
|
||||
var dialog = app.passwordDialog.createObject(app,
|
||||
{
|
||||
'confirmPassword': true,
|
||||
'title': qsTr('Enter new password'),
|
||||
'infotext': qsTr('If you forget your password, you\'ll need to\
|
||||
restore from seed. Please make sure you have your seed stored safely')
|
||||
} )
|
||||
dialog.accepted.connect(function() {
|
||||
Daemon.set_password(dialog.password)
|
||||
})
|
||||
dialog.open()
|
||||
}
|
||||
function onWalletDeleteError(code, message) {
|
||||
if (code == 'unpaid_requests') {
|
||||
var dialog = app.messageDialog.createObject(app, {text: message, yesno: true })
|
||||
dialog.yesClicked.connect(function() {
|
||||
Daemon.check_then_delete_wallet(Daemon.currentWallet, true)
|
||||
})
|
||||
dialog.open()
|
||||
} else if (code == 'balance') {
|
||||
var dialog = app.messageDialog.createObject(app, {text: message, yesno: true })
|
||||
dialog.yesClicked.connect(function() {
|
||||
Daemon.check_then_delete_wallet(Daemon.currentWallet, true, true)
|
||||
})
|
||||
dialog.open()
|
||||
} else {
|
||||
var dialog = app.messageDialog.createObject(app, {text: message })
|
||||
dialog.open()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: Daemon.currentWallet
|
||||
function onRequestNewPassword() { // new wallet password
|
||||
var dialog = app.passwordDialog.createObject(app,
|
||||
{
|
||||
'confirmPassword': true,
|
||||
'title': qsTr('Enter new password'),
|
||||
'infotext': qsTr('If you forget your password, you\'ll need to\
|
||||
restore from seed. Please make sure you have your seed stored safely')
|
||||
} )
|
||||
dialog.accepted.connect(function() {
|
||||
Daemon.currentWallet.set_password(dialog.password)
|
||||
})
|
||||
dialog.open()
|
||||
}
|
||||
function onBalanceChanged() {
|
||||
piechart.updateSlices()
|
||||
}
|
||||
}
|
||||
|
||||
Component.onCompleted: {
|
||||
piechart.updateSlices()
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user