diff --git a/components/HistoryTable.qml b/components/HistoryTable.qml deleted file mode 100644 index 1f9178e2..00000000 --- a/components/HistoryTable.qml +++ /dev/null @@ -1,506 +0,0 @@ -// Copyright (c) 2014-2019, The Monero Project -// -// All rights reserved. -// -// Redistribution and use in source and binary forms, with or without modification, are -// permitted provided that the following conditions are met: -// -// 1. Redistributions of source code must retain the above copyright notice, this list of -// conditions and the following disclaimer. -// -// 2. Redistributions in binary form must reproduce the above copyright notice, this list -// of conditions and the following disclaimer in the documentation and/or other -// materials provided with the distribution. -// -// 3. Neither the name of the copyright holder nor the names of its contributors may be -// used to endorse or promote products derived from this software without specific -// prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY -// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF -// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL -// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, -// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, -// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF -// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -import QtQuick 2.9 -import moneroComponents.Clipboard 1.0 -import moneroComponents.AddressBookModel 1.0 - -import "../components" as MoneroComponents -import "../js/TxUtils.js" as TxUtils - -ListView { - id: listView - clip: true - boundsBehavior: ListView.StopAtBounds - property var previousItem - property int rowSpacing: 12 - property var addressBookModel: null - - function buildTxDetailsString(tx_id, paymentId, tx_key,tx_note, destinations, rings, address, address_label) { - var trStart = '', - trMiddle = '', - trEnd = ""; - - return '' - + (tx_id ? trStart + qsTr("Tx ID:") + trMiddle + tx_id + trEnd : "") - + (address_label ? trStart + qsTr("Address label:") + trMiddle + address_label + trEnd : "") - + (address ? trStart + qsTr("Address:") + trMiddle + address + trEnd : "") - + (paymentId ? trStart + qsTr("Payment ID:") + trMiddle + paymentId + trEnd : "") - + (tx_key ? trStart + qsTr("Tx key:") + trMiddle + tx_key + trEnd : "") - + (tx_note ? trStart + qsTr("Tx note:") + trMiddle + tx_note + trEnd : "") - + (destinations ? trStart + qsTr("Destinations:") + trMiddle + destinations + trEnd : "") - + (rings ? trStart + qsTr("Rings:") + trMiddle + rings + trEnd : "") - + "
" - + translationManager.emptyString; - } - - function lookupPaymentID(paymentId) { - if (!addressBookModel) - return "" - var idx = addressBookModel.lookupPaymentID(paymentId) - if (idx < 0) - return "" - idx = addressBookModel.index(idx, 0) - return addressBookModel.data(idx, AddressBookModel.AddressBookDescriptionRole) - } - - footer: Rectangle { - height: 127 - width: listView.width - color: "transparent" - - MoneroComponents.TextPlain { - anchors.centerIn: parent - font.family: "Arial" - font.pixelSize: 14 - color: "#545454" - text: qsTr("No more results") + translationManager.emptyString - } - } - - delegate: Rectangle { - id: delegate - property bool collapsed: index ? false : true - height: collapsed ? 180 : 70 - width: listView.width - color: "transparent" - - function collapse(){ - delegate.height = 180; - } - - // borders - Rectangle{ - anchors.right: parent.right - anchors.top: parent.top - anchors.bottom: parent.bottom - width: 1 - color: "#404040" - } - - Rectangle{ - anchors.left: parent.left - anchors.top: parent.top - anchors.bottom: parent.bottom - width: collapsed ? 2 : 1 - color: collapsed ? "#BBBBBB" : "#404040" - } - - Rectangle{ - anchors.right: parent.right - anchors.bottom: parent.top - anchors.left: parent.left - height: 1 - color: "#404040" - } - - Rectangle{ - anchors.right: parent.right - anchors.bottom: parent.bottom - anchors.left: parent.left - height: 1 - color: "#404040" - } - - Rectangle { - id: row1 - anchors.left: parent.left - anchors.leftMargin: 20 - anchors.right: parent.right - anchors.rightMargin: 20 - anchors.top: parent.top - anchors.topMargin: 15 - height: 40 - color: "transparent" - - Image { - id: arrowImage - source: isOut ? "qrc:///images/downArrow.png" : confirmationsRequired === 60 ? "qrc:///images/miningxmr.png" : "qrc:///images/upArrow-green.png" - height: 18 - width: (confirmationsRequired === 60 ? 18 : 12) - anchors.top: parent.top - anchors.topMargin: 12 - } - - MoneroComponents.TextPlain { - id: txrxLabel - anchors.left: arrowImage.right - anchors.leftMargin: 18 - font.family: MoneroComponents.Style.fontLight.name - font.pixelSize: 14 - text: isOut ? qsTr("Sent") + translationManager.emptyString : qsTr("Received") + translationManager.emptyString - color: "#808080" - } - - MoneroComponents.TextPlain { - id: amountLabel - anchors.left: arrowImage.right - anchors.leftMargin: 18 - anchors.top: txrxLabel.bottom - anchors.topMargin: 0 - font.family: MoneroComponents.Style.fontBold.name - font.pixelSize: 18 - font.bold: true - text: { - var _amount = amount; - if(_amount === 0){ - // *sometimes* amount is 0, while the 'destinations string' - // has the correct amount, so we try to fetch it from that instead. - _amount = TxUtils.destinationsToAmount(destinations); - _amount = (_amount *1); - } - - return _amount + " XMR"; - } - color: isOut ? MoneroComponents.Style.white : MoneroComponents.Style.green - - MouseArea { - hoverEnabled: true - anchors.fill: parent - cursorShape: Qt.PointingHandCursor - onEntered: { - parent.color = MoneroComponents.Style.orange - } - onExited: { - parent.color = isOut ? MoneroComponents.Style.white : MoneroComponents.Style.green } - onClicked: { - console.log("Copied to clipboard"); - clipboard.setText(parent.text.split(" ")[0]); - appWindow.showStatusMessage(qsTr("Copied to clipboard"),3) - } - } - } - - Rectangle { - anchors.right: parent.right - width: 300 - height: parent.height - color: "transparent" - - MoneroComponents.TextPlain { - id: dateLabel - anchors.left: parent.left - font.family: MoneroComponents.Style.fontRegular.name - font.pixelSize: 14 - text: date - color: "#808080" - } - - MoneroComponents.TextPlain { - id: timeLabel - anchors.left: dateLabel.right - anchors.leftMargin: 7 - anchors.top: parent.top - anchors.topMargin: 1 - font.pixelSize: 12 - text: time - color: "#808080" - } - - MoneroComponents.TextPlain { - id: toLabel - property string address: "" - color: "#BBBBBB" - anchors.left: parent.left - anchors.top: dateLabel.bottom - anchors.topMargin: 0 - font.family: MoneroComponents.Style.fontRegular.name - font.pixelSize: 16 - text: { - if(isOut){ - address = TxUtils.destinationsToAddress(destinations); - if(address){ - var truncated = TxUtils.addressTruncate(address); - return qsTr("To ") + translationManager.emptyString + truncated; - } else { - return "Unknown recipient"; - } - } - return ""; - } - - MouseArea{ - visible: parent.address !== undefined - hoverEnabled: true - anchors.fill: parent - cursorShape: Qt.PointingHandCursor - onEntered: { - toLabel.color = "white"; - } - onExited: { - toLabel.color = "#BBBBBB"; - } - onClicked: { - if(parent.address){ - console.log("Address copied to clipboard"); - clipboard.setText(parent.address); - appWindow.showStatusMessage(qsTr("Address copied to clipboard"),3) - } - } - } - } - - Rectangle { - height: 24 - width: 24 - color: "transparent" - anchors.right: parent.right - anchors.verticalCenter: parent.verticalCenter - - Image { - id: dropdownImage - height: 8 - width: 12 - source: "qrc:///images/whiteDropIndicator.png" - rotation: delegate.collapsed ? 180 : 0 - anchors.horizontalCenter: parent.horizontalCenter - anchors.verticalCenter: parent.verticalCenter - } - - MouseArea{ - anchors.fill: parent - hoverEnabled: true - cursorShape: Qt.PointingHandCursor - onClicked: { - delegate.collapsed = !delegate.collapsed; - } - } - } - } - } - - Rectangle { - id: row2 - anchors.left: parent.left - anchors.leftMargin: 20 - anchors.right: parent.right - anchors.rightMargin: 20 - anchors.top: row1.bottom - anchors.topMargin: 15 - height: 40 - color: "transparent" - visible: delegate.collapsed - - // left column - MoneroComponents.HistoryTableInnerColumn{ - anchors.left: parent.left - anchors.leftMargin: 30 - - labelHeader: qsTr("Transaction ID") + translationManager.emptyString - labelValue: hash.substring(0, 18) + "..." - copyValue: hash - } - - // right column - MoneroComponents.HistoryTableInnerColumn{ - anchors.right: parent.right - anchors.rightMargin: 100 - width: 200 - height: parent.height - color: "transparent" - - labelHeader: qsTr("Fee") - labelValue: { - if(!isOut && !fee){ - return "-"; - } else if(isOut && fee){ - return fee + " XMR"; - } else { - return "Unknown" - } - } - copyValue: { - if(isOut && fee){ return fee } - else { return "" } - } - } - - } - - Rectangle { - id: row3 - anchors.left: parent.left - anchors.leftMargin: 20 - anchors.right: parent.right - anchors.rightMargin: 20 - anchors.top: row2.bottom - anchors.topMargin: 15 - height: 40 - color: "transparent" - visible: delegate.collapsed - - // left column - MoneroComponents.HistoryTableInnerColumn{ - anchors.left: parent.left - anchors.leftMargin: 30 - labelHeader: qsTr("Blockheight") - labelValue: { - if (!isPending) - if(confirmations < confirmationsRequired) - return blockHeight + " " + qsTr("(%1/%2 confirmations)").arg(confirmations).arg(confirmationsRequired); - else - return blockHeight; - if (!isOut) - return qsTr("UNCONFIRMED") + translationManager.emptyString - if (isFailed) - return qsTr("FAILED") + translationManager.emptyString - return qsTr("PENDING") + translationManager.emptyString - } - copyValue: labelValue.indexOf(" ") > 0 ? labelValue.slice(0, labelValue.indexOf(" ")) : labelValue - } - - // right column - MoneroComponents.HistoryTableInnerColumn { - anchors.right: parent.right - anchors.rightMargin: 80 - width: 220 - height: parent.height - color: "transparent" - hashValue: hash - labelHeader: qsTr("Description") + translationManager.emptyString - labelHeaderIconImageSource: "qrc:///images/editIcon.png" - - labelValue: { - var note = currentWallet.getUserNote(hash); - if(note){ - if(note.length > 28) { - return note.substring(0, 28) + "..."; - } else { - return note; - } - } else { - return qsTr("None") + translationManager.emptyString; - } - } - - copyValue: { - return currentWallet.getUserNote(hash); - } - } - - Rectangle { - id: proofButton - visible: isOut - color: "#404040" - height: 24 - width: 24 - anchors.right: parent.right - anchors.bottom: parent.bottom - anchors.bottomMargin: 36 - radius: 20 - - MouseArea { - id: proofButtonMouseArea - anchors.fill: parent - hoverEnabled: true - cursorShape: Qt.PointingHandCursor - onClicked: { - var address = TxUtils.destinationsToAddress(destinations); - if(address === undefined){ - console.log('getProof: Error fetching address') - return; - } - - var checked = (TxUtils.checkTxID(hash) && TxUtils.checkAddress(address, appWindow.persistentSettings.nettype)); - if(!checked){ - console.log('getProof: Error checking TxId and/or address'); - } - - console.log("getProof: Generate clicked: txid " + hash + ", address " + address); - root.getProofClicked(hash, address, ''); - } - - onEntered: { - proofButton.color = "#656565"; - } - - onExited: { - proofButton.color = "#404040"; - } - } - - MoneroComponents.TextPlain { - color: MoneroComponents.Style.defaultFontColor - text: "P" - anchors.horizontalCenter: parent.horizontalCenter - anchors.verticalCenter: parent.verticalCenter - font.pixelSize: 14 - } - } - - Rectangle { - id: detailsButton - color: "#404040" - height: 24 - width: 24 - anchors.right: parent.right - anchors.bottom: parent.bottom - anchors.bottomMargin: 6 - radius: 20 - - MouseArea { - id: detailsButtonMouseArea - anchors.fill: parent - hoverEnabled: true - cursorShape: Qt.PointingHandCursor - onClicked: { - var tx_key = currentWallet.getTxKey(hash) - var tx_note = currentWallet.getUserNote(hash) - var rings = currentWallet.getRings(hash) - var address_label = subaddrIndex == 0 ? qsTr("Primary address") : currentWallet.getSubaddressLabel(subaddrAccount, subaddrIndex) - var address = currentWallet.address(subaddrAccount, subaddrIndex) - if (rings) - rings = rings.replace(/\|/g, '\n') - informationPopup.title = "Transaction details"; - informationPopup.content = buildTxDetailsString(hash,paymentId,tx_key,tx_note,destinations, rings, address, address_label); - informationPopup.onCloseCallback = null - informationPopup.open(); - } - - onEntered: { - detailsButton.color = "#656565"; - } - - onExited: { - detailsButton.color = "#404040"; - } - } - - MoneroComponents.TextPlain { - color: MoneroComponents.Style.defaultFontColor - text: "?" - anchors.horizontalCenter: parent.horizontalCenter - anchors.verticalCenter: parent.verticalCenter - font.pixelSize: 14 - } - } - } - } - - Clipboard { id: clipboard } -} diff --git a/components/TableDropdown.qml b/components/TableDropdown.qml deleted file mode 100644 index 50a296a7..00000000 --- a/components/TableDropdown.qml +++ /dev/null @@ -1,237 +0,0 @@ -// Copyright (c) 2014-2018, The Monero Project -// -// All rights reserved. -// -// Redistribution and use in source and binary forms, with or without modification, are -// permitted provided that the following conditions are met: -// -// 1. Redistributions of source code must retain the above copyright notice, this list of -// conditions and the following disclaimer. -// -// 2. Redistributions in binary form must reproduce the above copyright notice, this list -// of conditions and the following disclaimer in the documentation and/or other -// materials provided with the distribution. -// -// 3. Neither the name of the copyright holder nor the names of its contributors may be -// used to endorse or promote products derived from this software without specific -// prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY -// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF -// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL -// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, -// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, -// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF -// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -import QtQuick 2.9 - -Item { - id: dropdown - property bool expanded: false - property alias dataModel: repeater.model - signal collapsed() - signal optionClicked(int option) - width: 72 - height: 37 - - onExpandedChanged: if(expanded) appWindow.currentItem = dropdown - function hide() { dropdown.expanded = false } - function containsPoint(px, py) { - if(px < 0) - return false - if(px > width) - return false - if(py < 0) - return false - if(py > height + dropArea.height) - return false - return true - } - - Item { - id: head - anchors.fill: parent - - Rectangle { - anchors.left: parent.left - anchors.right: parent.right - height: parent.height - 1 - y: dropdown.expanded || dropArea.height > 0 ? 0 : 1 - //radius: 3 - color: dropdown.expanded || dropArea.height > 0 ? "#888888" : "#DBDBDB" - } - - Rectangle { - anchors.left: parent.left - anchors.right: parent.right - height: parent.height - 1 - y: dropdown.expanded || dropArea.height > 0 ? 1 : 0 - //radius: 3 - color: dropdown.expanded || dropArea.height > 0 ? "#DBDBDB" : "#F0EEEE" - } - - Rectangle { - anchors.left: parent.left - anchors.bottom: parent.bottom - height: 3 - width: 3 - color: "#DBDBDB" - visible: dropdown.expanded || dropArea.height > 0 - } - - Rectangle { - anchors.right: parent.right - anchors.bottom: parent.bottom - height: 3 - width: 3 - color: "#DBDBDB" - visible: dropdown.expanded || dropArea.height > 0 - } - - Image { - anchors.verticalCenter: parent.verticalCenter - anchors.left: parent.left - anchors.leftMargin: 10 - source: "qrc:///images/tableOptions.png" - } - - Rectangle { - anchors.centerIn: parent - anchors.horizontalCenterOffset: 1 - height: 23 - width: 1 - color: dropdown.expanded || dropArea.height > 0 ? "#FFFFFF" : "#DBDBDB" - } - - Image { - anchors.verticalCenter: parent.verticalCenter - anchors.right: parent.right - anchors.rightMargin: 10 - source: "qrc:///images/dropIndicator.png" - } - } - - Timer { - id: timer - interval: 50 - repeat: true - running: false - onTriggered: { - if(((appWindow.toolTip.visible && !appWindow.toolTip.containsMouse) || !appWindow.toolTip.visible) && !mouseArea.containsMouse) { - appWindow.toolTip.visible = false - dropdown.expanded = false - currentIndex = -1 - timer.stop() - } - } - } - - MouseArea { - id: mouseArea - anchors.left: head.left - anchors.right: head.right - anchors.top: head.top - height: head.height + dropArea.height - hoverEnabled: true - onEntered: dropdown.expanded = true - - property int currentIndex: -1 - onMouseYChanged: { - if(mouseY > head.height) { - var posY = parseInt((mouseY - head.height) / 30) - currentIndex = posY - } else { - currentIndex = -1 - } - } - - onClicked: { - optionClicked(currentIndex) - } - - onExited: timer.start() - preventStealing: true - z: 1 - - Item { - id: dropArea - anchors.left: parent.left - anchors.right: parent.right - y: head.height - height: dropdown.expanded ? column.height : 0 - onHeightChanged: if(height === 0) dropdown.collapsed() - clip: true - - Behavior on height { - NumberAnimation { duration: 100; easing.type: Easing.InQuad } - } - - Column { - id: column - anchors.left: parent.left - anchors.right: parent.right - anchors.top: parent.top - - Repeater { - id: repeater - - // Workaround for translations in listElements. All translated strings needs to be listed in this file. - property string stringCopy: qsTr("Copy address to clipboard") + translationManager.emptyString - property string stringSend: qsTr("Send to this address") + translationManager.emptyString - property string stringFind: qsTr("Find similar transactions") + translationManager.emptyString - property string stringRemove: qsTr("Remove from address book") + translationManager.emptyString - - delegate: Rectangle { - id: delegate - property bool containsMouse: index === mouseArea.currentIndex - anchors.left: parent.left - anchors.right: parent.right - height: 30 - color: containsMouse ? "#F0EEEE" : "#DBDBDB" - //radius: index === repeater.count - 1 ? 5 : 0 - Rectangle { - anchors.left: parent.left - anchors.top: parent.top - width: 5 - height: 5 - color: delegate.color - } - - Rectangle { - anchors.right: parent.right - anchors.top: parent.top - width: 5 - height: 5 - color: delegate.color - } - - Image { - anchors.verticalCenter: parent.verticalCenter - anchors.left: parent.left - anchors.leftMargin: 10 - source: icon - } - - onContainsMouseChanged: { - if(containsMouse) { - var pos = rootItem.mapFromItem(delegate, 30, -25) - appWindow.toolTip.text = qsTr(name) + translationManager.emptyString - appWindow.toolTip.x = pos.x - appWindow.toolTip.width -// if(appWindow.toolTip.height > 30) -// pos.y -= appWindow.toolTip.height - 30 - appWindow.toolTip.y = pos.y - appWindow.toolTip.visible = true - appWindow.toolTip.z = 3 - - } - } - - } - } - } - } - } -}