mirror of
https://github.com/monero-project/monero-gui.git
synced 2025-01-25 12:05:54 +00:00
First iteration of the subaddress table restyle
This commit is contained in:
parent
cb94523747
commit
6ff273fd32
1 changed files with 118 additions and 70 deletions
|
@ -40,12 +40,14 @@ import moneroComponents.TransactionHistory 1.0
|
||||||
import moneroComponents.TransactionHistoryModel 1.0
|
import moneroComponents.TransactionHistoryModel 1.0
|
||||||
import moneroComponents.Subaddress 1.0
|
import moneroComponents.Subaddress 1.0
|
||||||
import moneroComponents.SubaddressModel 1.0
|
import moneroComponents.SubaddressModel 1.0
|
||||||
|
import "../js/TxUtils.js" as TxUtils
|
||||||
|
|
||||||
Rectangle {
|
Rectangle {
|
||||||
id: pageReceive
|
id: pageReceive
|
||||||
color: "transparent"
|
color: "transparent"
|
||||||
property var model
|
property var model
|
||||||
property var current_address
|
property var current_address
|
||||||
|
property var current_subaddress_table_index: 0
|
||||||
property alias addressText : pageReceive.current_address
|
property alias addressText : pageReceive.current_address
|
||||||
|
|
||||||
function makeQRCodeString() {
|
function makeQRCodeString() {
|
||||||
|
@ -82,7 +84,7 @@ Rectangle {
|
||||||
var isout = model.data(idx, TransactionHistoryModel.TransactionIsOutRole);
|
var isout = model.data(idx, TransactionHistoryModel.TransactionIsOutRole);
|
||||||
var subaddrAccount = model.data(idx, TransactionHistoryModel.TransactionSubaddrAccountRole);
|
var subaddrAccount = model.data(idx, TransactionHistoryModel.TransactionSubaddrAccountRole);
|
||||||
var subaddrIndex = model.data(idx, TransactionHistoryModel.TransactionSubaddrIndexRole);
|
var subaddrIndex = model.data(idx, TransactionHistoryModel.TransactionSubaddrIndexRole);
|
||||||
if (!isout && subaddrAccount == appWindow.currentWallet.currentSubaddressAccount && subaddrIndex == table.currentIndex) {
|
if (!isout && subaddrAccount == appWindow.currentWallet.currentSubaddressAccount && subaddrIndex == current_subaddress_table_index) {
|
||||||
var amount = model.data(idx, TransactionHistoryModel.TransactionAtomicAmountRole);
|
var amount = model.data(idx, TransactionHistoryModel.TransactionAtomicAmountRole);
|
||||||
totalAmount = walletManager.addi(totalAmount, amount)
|
totalAmount = walletManager.addi(totalAmount, amount)
|
||||||
nTransactions += 1
|
nTransactions += 1
|
||||||
|
@ -177,75 +179,120 @@ Rectangle {
|
||||||
ColumnLayout {
|
ColumnLayout {
|
||||||
id: addressRow
|
id: addressRow
|
||||||
spacing: 0
|
spacing: 0
|
||||||
Label {
|
|
||||||
id: addressLabel
|
LabelSubheader {
|
||||||
text: qsTr("Addresses") + translationManager.emptyString
|
Layout.fillWidth: true
|
||||||
width: mainLayout.labelWidth
|
textFormat: Text.RichText
|
||||||
|
text: "<style type='text/css'>a {text-decoration: none; color: #FF6C3C; font-size: 14px;}</style>" +
|
||||||
|
qsTr("Addresses") +
|
||||||
|
"<font size='2'> </font><a href='#'>" +
|
||||||
|
qsTr("Help") + "</a>" +
|
||||||
|
translationManager.emptyString
|
||||||
|
onLinkActivated: {
|
||||||
|
trackingHowToUseDialog.title = qsTr("Tracking payments") + translationManager.emptyString;
|
||||||
|
trackingHowToUseDialog.text = qsTr(
|
||||||
|
"<p>This QR code includes the address you selected above and" +
|
||||||
|
"the amount you entered below. Share it with others (right-click->Save) " +
|
||||||
|
"so they can more easily send you exact amounts.</p>"
|
||||||
|
)
|
||||||
|
trackingHowToUseDialog.icon = StandardIcon.Information
|
||||||
|
trackingHowToUseDialog.open()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Rectangle {
|
ColumnLayout {
|
||||||
id: header
|
id: trackingTableRow2
|
||||||
|
visible: subaddressListView.count >= 1
|
||||||
|
Layout.topMargin: 22 * scaleRatio
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.topMargin: 10
|
Layout.minimumWidth: 240
|
||||||
visible: table.count > 0
|
Layout.preferredHeight: 32 * subaddressListView.count
|
||||||
|
|
||||||
height: 10
|
ListView {
|
||||||
|
id: subaddressListView
|
||||||
|
Layout.fillWidth: true
|
||||||
|
anchors.fill: parent
|
||||||
|
clip: true
|
||||||
|
boundsBehavior: ListView.StopAtBounds
|
||||||
|
delegate: Rectangle {
|
||||||
|
id: tableItem2
|
||||||
|
height: 32
|
||||||
|
width: parent.width
|
||||||
|
Layout.fillWidth: true
|
||||||
color: "transparent"
|
color: "transparent"
|
||||||
|
|
||||||
Rectangle {
|
Rectangle{
|
||||||
anchors.top: parent.top
|
|
||||||
anchors.left: parent.left
|
|
||||||
anchors.right: parent.right
|
anchors.right: parent.right
|
||||||
anchors.rightMargin: 10
|
anchors.left: parent.left
|
||||||
anchors.leftMargin: 10
|
anchors.top: parent.top
|
||||||
|
|
||||||
height: 1
|
height: 1
|
||||||
color: "#404040"
|
color: "#404040"
|
||||||
}
|
visible: index !== 0
|
||||||
|
|
||||||
Image {
|
|
||||||
anchors.top: parent.top
|
|
||||||
anchors.left: parent.left
|
|
||||||
|
|
||||||
width: 10
|
|
||||||
height: 10
|
|
||||||
|
|
||||||
source: "../images/historyBorderRadius.png"
|
|
||||||
}
|
|
||||||
|
|
||||||
Image {
|
|
||||||
anchors.top: parent.top
|
|
||||||
anchors.right: parent.right
|
|
||||||
|
|
||||||
width: 10
|
|
||||||
height: 10
|
|
||||||
|
|
||||||
source: "../images/historyBorderRadius.png"
|
|
||||||
rotation: 90
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Rectangle {
|
Rectangle {
|
||||||
id: tableRect
|
anchors.fill: parent
|
||||||
property int table_max_height: 260
|
anchors.rightMargin: 80
|
||||||
Layout.fillWidth: true
|
|
||||||
Layout.preferredHeight: table.contentHeight < table_max_height ? table.contentHeight : table_max_height
|
|
||||||
color: "transparent"
|
color: "transparent"
|
||||||
|
|
||||||
Scroll {
|
Label {
|
||||||
id: flickableScroll
|
id: idLabel
|
||||||
anchors.right: table.right
|
color: index === current_subaddress_table_index ? "white" : "#757575"
|
||||||
anchors.top: table.top
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
anchors.bottom: table.bottom
|
anchors.left: parent.left
|
||||||
flickable: table
|
anchors.leftMargin: 6
|
||||||
|
fontSize: 14 * scaleRatio
|
||||||
|
fontBold: true
|
||||||
|
text: "#" + index
|
||||||
}
|
}
|
||||||
|
|
||||||
SubaddressTable {
|
Label {
|
||||||
id: table
|
id: nameLabel
|
||||||
|
color: "#a5a5a5"
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
anchors.left: idLabel.right
|
||||||
|
anchors.leftMargin: 6
|
||||||
|
fontSize: 14 * scaleRatio
|
||||||
|
fontBold: true
|
||||||
|
text: label
|
||||||
|
}
|
||||||
|
|
||||||
|
Label {
|
||||||
|
color: "white"
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
anchors.left: nameLabel.right
|
||||||
|
anchors.leftMargin: 6
|
||||||
|
fontSize: 14 * scaleRatio
|
||||||
|
fontBold: true
|
||||||
|
text: TxUtils.addressTruncate(address)
|
||||||
|
}
|
||||||
|
|
||||||
|
MouseArea{
|
||||||
|
cursorShape: Qt.PointingHandCursor
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
onContentYChanged: flickableScroll.flickableContentYChanged()
|
hoverEnabled: true
|
||||||
|
onEntered: {
|
||||||
|
tableItem2.color = "#26FFFFFF"
|
||||||
|
}
|
||||||
|
onExited: {
|
||||||
|
tableItem2.color = "transparent"
|
||||||
|
}
|
||||||
|
onClicked: {
|
||||||
|
subaddressListView.currentIndex = index;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
onCurrentItemChanged: {
|
onCurrentItemChanged: {
|
||||||
current_address = appWindow.currentWallet.address(appWindow.currentWallet.currentSubaddressAccount, table.currentIndex);
|
// reset global vars
|
||||||
|
current_subaddress_table_index = subaddressListView.currentIndex;
|
||||||
|
current_address = appWindow.currentWallet.address(
|
||||||
|
appWindow.currentWallet.currentSubaddressAccount,
|
||||||
|
subaddressListView.currentIndex
|
||||||
|
);
|
||||||
|
|
||||||
|
// reset tracking table
|
||||||
|
trackingModel.clear();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -262,7 +309,7 @@ Rectangle {
|
||||||
inputDialog.inputText = qsTr("(Untitled)")
|
inputDialog.inputText = qsTr("(Untitled)")
|
||||||
inputDialog.onAcceptedCallback = function() {
|
inputDialog.onAcceptedCallback = function() {
|
||||||
appWindow.currentWallet.subaddress.addRow(appWindow.currentWallet.currentSubaddressAccount, inputDialog.inputText)
|
appWindow.currentWallet.subaddress.addRow(appWindow.currentWallet.currentSubaddressAccount, inputDialog.inputText)
|
||||||
table.currentIndex = appWindow.currentWallet.numSubaddresses() - 1
|
current_subaddress_table_index = appWindow.currentWallet.numSubaddresses() - 1
|
||||||
}
|
}
|
||||||
inputDialog.onRejectedCallback = null;
|
inputDialog.onRejectedCallback = null;
|
||||||
inputDialog.open()
|
inputDialog.open()
|
||||||
|
@ -271,13 +318,13 @@ Rectangle {
|
||||||
|
|
||||||
StandardButton {
|
StandardButton {
|
||||||
small: true
|
small: true
|
||||||
enabled: table.currentIndex > 0
|
enabled: current_subaddress_table_index > 0
|
||||||
text: qsTr("Rename") + translationManager.emptyString;
|
text: qsTr("Rename") + translationManager.emptyString;
|
||||||
onClicked: {
|
onClicked: {
|
||||||
inputDialog.labelText = qsTr("Set the label of the selected address:") + translationManager.emptyString
|
inputDialog.labelText = qsTr("Set the label of the selected address:") + translationManager.emptyString
|
||||||
inputDialog.inputText = appWindow.currentWallet.getSubaddressLabel(appWindow.currentWallet.currentSubaddressAccount, table.currentIndex)
|
inputDialog.inputText = appWindow.currentWallet.getSubaddressLabel(appWindow.currentWallet.currentSubaddressAccount, current_subaddress_table_index)
|
||||||
inputDialog.onAcceptedCallback = function() {
|
inputDialog.onAcceptedCallback = function() {
|
||||||
appWindow.currentWallet.subaddress.setLabel(appWindow.currentWallet.currentSubaddressAccount, table.currentIndex, inputDialog.inputText)
|
appWindow.currentWallet.subaddress.setLabel(appWindow.currentWallet.currentSubaddressAccount, current_subaddress_table_index, inputDialog.inputText)
|
||||||
}
|
}
|
||||||
inputDialog.onRejectedCallback = null;
|
inputDialog.onRejectedCallback = null;
|
||||||
inputDialog.open()
|
inputDialog.open()
|
||||||
|
@ -432,13 +479,13 @@ Rectangle {
|
||||||
|
|
||||||
ColumnLayout {
|
ColumnLayout {
|
||||||
id: trackingTableRow
|
id: trackingTableRow
|
||||||
visible: vv.count >= 1
|
visible: trackingListView.count >= 1
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.minimumWidth: 240
|
Layout.minimumWidth: 240
|
||||||
Layout.preferredHeight: 46 * vv.count
|
Layout.preferredHeight: 46 * trackingListView.count
|
||||||
|
|
||||||
ListView {
|
ListView {
|
||||||
id: vv
|
id: trackingListView
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
clip: true
|
clip: true
|
||||||
|
@ -567,12 +614,13 @@ Rectangle {
|
||||||
|
|
||||||
function onPageCompleted() {
|
function onPageCompleted() {
|
||||||
console.log("Receive page loaded");
|
console.log("Receive page loaded");
|
||||||
table.model = currentWallet.subaddressModel;
|
subaddressListView.model = appWindow.currentWallet.subaddressModel;
|
||||||
|
|
||||||
if (appWindow.currentWallet) {
|
if (appWindow.currentWallet) {
|
||||||
current_address = appWindow.currentWallet.address(appWindow.currentWallet.currentSubaddressAccount, 0)
|
current_address = appWindow.currentWallet.address(appWindow.currentWallet.currentSubaddressAccount, 0)
|
||||||
appWindow.currentWallet.subaddress.refresh(appWindow.currentWallet.currentSubaddressAccount)
|
appWindow.currentWallet.subaddress.refresh(appWindow.currentWallet.currentSubaddressAccount)
|
||||||
table.currentIndex = 0
|
current_subaddress_table_index = 0;
|
||||||
|
subaddressListView.currentIndex = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
update()
|
update()
|
||||||
|
|
Loading…
Reference in a new issue