Sander van Grieken 3 years ago
parent
commit
7e6991c097
  1. 29
      electrum/gui/qml/components/BalanceSummary.qml
  2. 4
      electrum/gui/qml/components/Constants.qml
  3. 12
      electrum/gui/qml/components/NetworkStats.qml
  4. 23
      electrum/gui/qml/components/Receive.qml
  5. 65
      electrum/gui/qml/components/Send.qml
  6. 90
      electrum/gui/qml/components/Wallets.qml
  7. 48
      electrum/gui/qml/components/main.qml
  8. 9
      electrum/gui/qml/components/wizard/Wizard.qml

29
electrum/gui/qml/components/BalanceSummary.qml

@ -1,6 +1,7 @@
import QtQuick 2.6 import QtQuick 2.6
import QtQuick.Layouts 1.0 import QtQuick.Layouts 1.0
import QtQuick.Controls 2.0 import QtQuick.Controls 2.0
import QtQuick.Controls.Material 2.0
Frame { Frame {
id: root id: root
@ -17,27 +18,33 @@ Frame {
GridLayout { GridLayout {
id: layout id: layout
columns: 3 columns: 2
Label { Label {
id: balance
Layout.columnSpan: 3
font.pixelSize: constants.fontSizeLarge font.pixelSize: constants.fontSizeLarge
text: 'Balance: ' + formattedBalance text: qsTr('Balance: ')
}
Label {
font.pixelSize: constants.fontSizeLarge
color: Material.accentColor
text: formattedBalance
} }
Label { Label {
id: confirmed
font.pixelSize: constants.fontSizeMedium font.pixelSize: constants.fontSizeMedium
text: 'Confirmed: ' + formattedBalance text: qsTr('Confirmed: ')
} }
Label { Label {
id: unconfirmed
font.pixelSize: constants.fontSizeMedium font.pixelSize: constants.fontSizeMedium
text: 'Unconfirmed: ' + formattedUnconfirmed color: Material.accentColor
text: formattedBalance
} }
Label { Label {
id: lightning font.pixelSize: constants.fontSizeMedium
font.pixelSize: constants.fontSizeSmall text: qsTr('Unconfirmed: ')
text: 'Lightning: ?' }
Label {
font.pixelSize: constants.fontSizeMedium
color: Material.accentColor
text: formattedUnconfirmed
} }
} }

4
electrum/gui/qml/components/Constants.qml

@ -15,4 +15,8 @@ QtObject {
readonly property int fontSizeLarge: 18 readonly property int fontSizeLarge: 18
readonly property int fontSizeXLarge: 22 readonly property int fontSizeXLarge: 22
readonly property int fontSizeXXLarge: 28 readonly property int fontSizeXXLarge: 28
readonly property int iconSizeSmall: 16
readonly property int iconSizeMedium: 24
readonly property int iconSizeLarge: 32
} }

12
electrum/gui/qml/components/NetworkStats.qml

@ -46,11 +46,13 @@ Pane {
font.bold: true font.bold: true
} }
Image { Image {
Layout.preferredWidth: 16 Layout.preferredWidth: constants.iconSizeSmall
Layout.preferredHeight: 16 Layout.preferredHeight: constants.iconSizeSmall
source: Daemon.currentWallet.isUptodate source: Network.status == 'connecting' || Network.status == 'disconnected'
? "../../icons/status_connected.png" ? '../../icons/status_disconnected.png' :
: "../../icons/status_lagging.png" Daemon.currentWallet.isUptodate
? '../../icons/status_connected.png'
: '../../icons/status_lagging.png'
} }
Label { Label {
text: Network.status text: Network.status

23
electrum/gui/qml/components/Receive.qml

@ -156,9 +156,7 @@ Pane {
bottom: parent.bottom bottom: parent.bottom
} }
background: Rectangle { background: PaneInsetBackground {}
color: Qt.darker(Material.background, 1.25)
}
ColumnLayout { ColumnLayout {
spacing: 0 spacing: 0
@ -223,6 +221,7 @@ Pane {
Layout.fillWidth: true Layout.fillWidth: true
Layout.columnSpan: 2 Layout.columnSpan: 2
text: model.message text: model.message
elide: Text.ElideRight
font.pixelSize: constants.fontSizeLarge font.pixelSize: constants.fontSizeLarge
} }
@ -233,6 +232,7 @@ Pane {
Label { Label {
id: amount id: amount
text: Config.formatSats(model.amount, true) text: Config.formatSats(model.amount, true)
font.family: FixedFont
font.pixelSize: constants.fontSizeSmall font.pixelSize: constants.fontSizeSmall
} }
@ -282,17 +282,20 @@ Pane {
NumberAnimation { properties: 'opacity'; to: 1.0; duration: 700 * (1-from) } NumberAnimation { properties: 'opacity'; to: 1.0; duration: 700 * (1-from) }
} }
ScrollBar.vertical: ScrollBar { ScrollIndicator.vertical: ScrollIndicator { }
parent: parent.parent
anchors.top: parent.top
anchors.left: parent.right
anchors.bottom: parent.bottom
}
} }
} }
} }
// make clicking the dialog background move the scope away from textedit fields
// so the keyboard goes away
MouseArea {
anchors.fill: parent
z: -1000
onClicked: parkFocus.focus = true
FocusScope { id: parkFocus }
}
function createRequest(ignoreGaplimit = false) { function createRequest(ignoreGaplimit = false) {
var a = Config.unitsToSats(amount.text) var a = Config.unitsToSats(amount.text)
Daemon.currentWallet.create_invoice(a, message.text, expires.currentValue, false, ignoreGaplimit) Daemon.currentWallet.create_invoice(a, message.text, expires.currentValue, false, ignoreGaplimit)

65
electrum/gui/qml/components/Send.qml

@ -16,14 +16,14 @@ Pane {
} }
Label { Label {
text: "Recipient" text: qsTr('Recipient')
} }
TextField { TextField {
id: address id: address
Layout.columnSpan: 2 Layout.columnSpan: 2
placeholderText: 'Paste address or invoice'
Layout.fillWidth: true Layout.fillWidth: true
placeholderText: qsTr('Paste address or invoice')
} }
ToolButton { ToolButton {
@ -34,57 +34,64 @@ Pane {
} }
Label { Label {
text: "Amount" text: qsTr('Amount')
} }
TextField { TextField {
id: amount id: amount
placeholderText: 'Amount' placeholderText: qsTr('Amount')
} }
Label { Label {
text: Config.baseUnit text: Config.baseUnit
color: Material.accentColor color: Material.accentColor
Layout.columnSpan: 2 Layout.fillWidth: true
} }
Item { width: 1; height: 1 } // workaround colspan on baseunit messing up row above
Label { Label {
text: "Fee" text: qsTr('Fee')
} }
TextField { TextField {
id: fee id: fee
placeholderText: 'sat/vB' placeholderText: qsTr('sat/vB')
Layout.columnSpan: 2 Layout.columnSpan: 3
} }
Item { RowLayout {
Layout.fillWidth: true
Layout.columnSpan: 4 Layout.columnSpan: 4
Layout.alignment: Qt.AlignHCenter
spacing: 10
Row { Button {
spacing: 10 text: qsTr('Pay')
anchors.horizontalCenter: parent.horizontalCenter enabled: false // TODO proper validation
Button { onClicked: {
text: 'Pay' var i_amount = parseInt(amount.text)
enabled: address.text != '' && amount.text != '' && fee.text != '' // TODO proper validation if (isNaN(i_amount))
onClicked: { return
var i_amount = parseInt(amount.text) var result = Daemon.currentWallet.send_onchain(address.text, i_amount, undefined, false)
if (isNaN(i_amount)) if (result)
return app.stack.pop()
var result = Daemon.currentWallet.send_onchain(address.text, i_amount, undefined, false)
if (result)
app.stack.pop()
}
} }
}
Button { Button {
text: 'Scan QR Code' text: qsTr('Scan QR Code')
Layout.alignment: Qt.AlignHCenter onClicked: app.stack.push(Qt.resolvedUrl('Scan.qml'))
onClicked: app.stack.push(Qt.resolvedUrl('Scan.qml'))
}
} }
} }
} }
// make clicking the dialog background move the scope away from textedit fields
// so the keyboard goes away
MouseArea {
anchors.fill: parent
z: -1000
onClicked: parkFocus.focus = true
FocusScope { id: parkFocus }
}
} }

90
electrum/gui/qml/components/Wallets.qml

@ -49,59 +49,61 @@ Pane {
} }
// } // }
Item {
width: parent.width
// height: detailsFrame.height
Layout.fillHeight: true
Frame { Frame {
id: detailsFrame id: detailsFrame
width: parent.width Layout.preferredWidth: parent.width
height: parent.height Layout.fillHeight: true
verticalPadding: 0
ListView { horizontalPadding: 0
id: listview background: PaneInsetBackground {}
width: parent.width
// Layout.fillHeight: true ListView {
height: parent.height id: listview
clip: true width: parent.width
model: Daemon.availableWallets height: parent.height
clip: true
// header: sadly seems to be buggy model: Daemon.availableWallets
delegate: AbstractButton { delegate: AbstractButton {
width: ListView.view.width width: ListView.view.width
height: 50 height: row.height
onClicked: { onClicked: {
wallet_db.path = model.path wallet_db.path = model.path
}
RowLayout {
spacing: 10
width: parent.width
Image {
id: walleticon
source: "../../icons/wallet.png"
fillMode: Image.PreserveAspectFit
Layout.preferredWidth: 32
Layout.preferredHeight: 32
} }
Label { RowLayout {
font.pixelSize: 18 id: row
text: model.name spacing: 10
Layout.fillWidth: true x: constants.paddingSmall
} width: parent.width - 2 * constants.paddingSmall
Image {
id: walleticon
source: "../../icons/wallet.png"
fillMode: Image.PreserveAspectFit
Layout.preferredWidth: 32
Layout.preferredHeight: 32
}
Button { Label {
text: 'Open' font.pixelSize: 18
onClicked: { text: model.name
Daemon.load_wallet(model.path) Layout.fillWidth: true
}
Button {
text: 'Open'
onClicked: {
Daemon.load_wallet(model.path)
}
} }
} }
} }
ScrollIndicator.vertical: ScrollIndicator { }
} }
}}}
}
Button { Button {
Layout.alignment: Qt.AlignHCenter Layout.alignment: Qt.AlignHCenter

48
electrum/gui/qml/components/main.qml

@ -27,11 +27,23 @@ ApplicationWindow
id: toolbar id: toolbar
RowLayout { RowLayout {
anchors.fill: parent anchors.fill: parent
ToolButton { ToolButton {
text: qsTr("‹") text: qsTr("‹")
enabled: stack.depth > 1 enabled: stack.depth > 1
onClicked: stack.pop() onClicked: stack.pop()
} }
Label {
text: stack.currentItem.title
elide: Label.ElideRight
horizontalAlignment: Qt.AlignHCenter
verticalAlignment: Qt.AlignVCenter
Layout.fillWidth: true
font.pixelSize: constants.fontSizeMedium
font.bold: true
}
Item { Item {
visible: Network.isTestNet visible: Network.isTestNet
width: column.width width: column.width
@ -47,12 +59,13 @@ ApplicationWindow
} }
Column { ColumnLayout {
id: column id: column
spacing: 0
Image { Image {
anchors.horizontalCenter: parent.horizontalCenter Layout.alignment: Qt.AlignHCenter
width: 16 Layout.preferredWidth: constants.iconSizeSmall
height: 16 Layout.preferredHeight: constants.iconSizeSmall
source: "../../icons/info.png" source: "../../icons/info.png"
} }
@ -60,28 +73,31 @@ ApplicationWindow
id: networkNameLabel id: networkNameLabel
text: Network.networkName text: Network.networkName
color: Material.accentColor color: Material.accentColor
font.pointSize: 5 font.pixelSize: constants.fontSizeXSmall
} }
} }
} }
Image { Image {
Layout.preferredWidth: 16 Layout.preferredWidth: constants.iconSizeSmall
Layout.preferredHeight: 16 Layout.preferredHeight: constants.iconSizeSmall
source: Daemon.currentWallet.isUptodate ? "../../icons/status_connected.png" : "../../icons/status_lagging.png" source: Network.status == 'connecting' || Network.status == 'disconnected'
? '../../icons/status_disconnected.png' :
Daemon.currentWallet.isUptodate
? '../../icons/status_connected.png'
: '../../icons/status_lagging.png'
} }
Label { Rectangle {
text: stack.currentItem.title color: 'transparent'
elide: Label.ElideRight Layout.preferredWidth: constants.paddingSmall
horizontalAlignment: Qt.AlignHCenter height: 1
verticalAlignment: Qt.AlignVCenter visible: !menuButton.visible
Layout.fillWidth: true
font.pixelSize: 14
font.bold: true
} }
ToolButton { ToolButton {
id: menuButton
visible: stack.currentItem.menu !== undefined && stack.currentItem.menu.count > 0
text: qsTr("⋮") text: qsTr("⋮")
onClicked: { onClicked: {
stack.currentItem.menu.open() stack.currentItem.menu.open()

9
electrum/gui/qml/components/wizard/Wizard.qml

@ -162,5 +162,14 @@ Dialog {
} }
} }
// make clicking the dialog background move the scope away from textedit fields
// so the keyboard goes away
// TODO: here it works on desktop, but not android. hmm.
MouseArea {
anchors.fill: wizard
z: -1000
onClicked: { parkFocus.focus = true }
FocusScope { id: parkFocus }
}
} }

Loading…
Cancel
Save