mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-27 14:55:44 +00:00
fa4755ce9e
+ store the card state in user settings + amend the BannerCard close button state. It needs to change color on hover and to become visible only when the card is hovered.
337 lines
11 KiB
QML
337 lines
11 KiB
QML
import QtQuick 2.15
|
|
import QtQuick.Controls 2.15
|
|
import QtQuick.Layouts 1.15
|
|
|
|
import shared.views 1.0
|
|
import utils 1.0
|
|
|
|
import Storybook 1.0
|
|
|
|
import AppLayouts.Wallet.controls 1.0
|
|
import AppLayouts.Wallet.panels 1.0
|
|
|
|
import Qt.labs.settings 1.1
|
|
|
|
import StatusQ.Popups.Dialog 0.1
|
|
|
|
SplitView {
|
|
id: root
|
|
|
|
ListModel {
|
|
id: assetsModel
|
|
|
|
function format(amount, symbol) {
|
|
return `${amount.toLocaleString(Qt.locale())} ${symbol}`
|
|
}
|
|
|
|
Component.onCompleted: {
|
|
const data = [
|
|
{
|
|
key: "key_ETH",
|
|
symbol: "ETH",
|
|
name: "Ether",
|
|
icon: Constants.tokenIcon("ETH", false),
|
|
balance: 10.0,
|
|
balanceText: format(10.0, "ETH"),
|
|
error: "",
|
|
|
|
marketDetailsAvailable: true,
|
|
marketDetailsLoading: true,
|
|
marketPrice: 0,
|
|
marketChangePct24hour: 0,
|
|
|
|
communityId: "",
|
|
communityName: "",
|
|
communityIcon: Qt.resolvedUrl(""),
|
|
|
|
position: 2,
|
|
canBeHidden: false
|
|
},
|
|
{
|
|
key: "key_SNT",
|
|
symbol: "SNT",
|
|
name: "Status",
|
|
icon: Constants.tokenIcon("SNT", false),
|
|
balance: 20023.0,
|
|
balanceText: format(20023.0, "SNT"),
|
|
error: "",
|
|
|
|
marketDetailsAvailable: true,
|
|
marketDetailsLoading: false,
|
|
marketPrice: 50.23,
|
|
marketChangePct24hour: 12,
|
|
|
|
communityId: "",
|
|
communityName: "",
|
|
communityIcon: Qt.resolvedUrl(""),
|
|
|
|
position: 1,
|
|
canBeHidden: true
|
|
},
|
|
{
|
|
key: "key_MCT",
|
|
symbol: "MCT",
|
|
name: "My custom token",
|
|
icon: Constants.tokenIcon("ZRX", false),
|
|
balance: 102.4,
|
|
balanceText: format(102.4, "MCT"),
|
|
error: "",
|
|
|
|
marketDetailsAvailable: false,
|
|
marketDetailsLoading: false,
|
|
marketPrice: 0,
|
|
marketChangePct24hour: 0,
|
|
|
|
communityId: "34",
|
|
communityName: "Crypto Kitties",
|
|
communityIcon: Constants.tokenIcon("DAI", false),
|
|
|
|
position: 4,
|
|
canBeHidden: true
|
|
},
|
|
{
|
|
key: "key_DAI",
|
|
symbol: "DAI",
|
|
name: "Dai",
|
|
icon: Constants.tokenIcon("DAI", false),
|
|
balance: 123.24,
|
|
balanceText: format(123.24, "DAI"),
|
|
error: "",
|
|
|
|
marketDetailsAvailable: true,
|
|
marketDetailsLoading: false,
|
|
marketPrice: 23.23,
|
|
marketChangePct24hour: 2.3,
|
|
|
|
communityId: "",
|
|
communityName: "",
|
|
communityIcon: Qt.resolvedUrl(""),
|
|
|
|
position: 3,
|
|
canBeHidden: true
|
|
},
|
|
{
|
|
key: "key_USDT",
|
|
symbol: "USDT",
|
|
name: "USDT",
|
|
icon: Constants.tokenIcon("USDT", false),
|
|
balance: 15.24,
|
|
balanceText: format(15.24, "USDT"),
|
|
error: "",
|
|
|
|
marketDetailsAvailable: true,
|
|
marketDetailsLoading: false,
|
|
marketPrice: 0.99,
|
|
marketChangePct24hour: 0,
|
|
|
|
communityId: "",
|
|
communityName: "",
|
|
communityIcon: Qt.resolvedUrl(""),
|
|
|
|
position: 5,
|
|
canBeHidden: true
|
|
},
|
|
{
|
|
key: "key_TBT",
|
|
symbol: "TBT",
|
|
name: "The best token",
|
|
icon: Constants.tokenIcon("UNI", false),
|
|
balance: 102,
|
|
balanceText: format(102, "TBT"),
|
|
error: "Pocket Network (POKT) & Infura are currently both "
|
|
+ "unavailable for %1. %1 balances are as of %2."
|
|
.arg("TBT").arg("10/06/2024"),
|
|
|
|
marketDetailsAvailable: false,
|
|
marketDetailsLoading: false,
|
|
marketPrice: 0,
|
|
marketChangePct24hour: 0,
|
|
|
|
communityId: "3423",
|
|
communityName: "Best tokens",
|
|
communityIcon: Constants.tokenIcon("UNI", false),
|
|
|
|
position: 6,
|
|
canBeHidden: true
|
|
}
|
|
]
|
|
|
|
append(data)
|
|
}
|
|
}
|
|
|
|
SplitView {
|
|
SplitView.fillWidth: true
|
|
SplitView.fillHeight: true
|
|
|
|
orientation: Qt.Vertical
|
|
|
|
Pane {
|
|
SplitView.fillWidth: true
|
|
SplitView.fillHeight: true
|
|
|
|
AssetsView {
|
|
id: assetView
|
|
anchors.fill: parent
|
|
|
|
loading: loadingCheckBox.checked
|
|
sorterVisible: sorterVisibleCheckBox.checked
|
|
customOrderAvailable: customOrderAvailableCheckBox.checked
|
|
|
|
sendEnabled: sendEnabledCheckBox.checked
|
|
swapEnabled: swapEnabledCheckBox.checked
|
|
swapVisible: swapVisibleCheckBox.checked
|
|
communitySwapVisible: communitySwapVisibleCheckBox.checked
|
|
|
|
balanceError: balanceErrorCheckBox.checked
|
|
? "Balance error!" : ""
|
|
|
|
marketDataError: marketDataErrorCheckBox.checked
|
|
? "Market data error!" : ""
|
|
|
|
model: assetsModel
|
|
|
|
onSendRequested: logs.logEvent(`send requested: ${key}`)
|
|
onReceiveRequested: logs.logEvent(`receive requested: ${key}`)
|
|
onSwapRequested: logs.logEvent(`swap requested: ${key}`)
|
|
onAssetClicked: logs.logEvent(`asset clicked: ${key}`)
|
|
|
|
onHideRequested: logs.logEvent(`hide requested: ${key}`)
|
|
onHideCommunityAssetsRequested: logs.logEvent(`hide community assets requested: ${communityKey}`)
|
|
onManageTokensRequested: logs.logEvent(`manage tokens requested`)
|
|
|
|
bannerComponent: buyReceiveBannerComponent
|
|
|
|
Component {
|
|
id: buyReceiveBannerComponent
|
|
BuyReceiveBanner {
|
|
id: banner
|
|
topPadding: anyVisibleItems ? 8 : 0
|
|
bottomPadding: anyVisibleItems ? 20 : 0
|
|
|
|
onCloseBuy: buyEnabled = false
|
|
onCloseReceive: receiveEnabled = false
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
Logs {
|
|
id: logs
|
|
}
|
|
|
|
LogsView {
|
|
clip: true
|
|
|
|
SplitView.preferredHeight: 150
|
|
SplitView.fillWidth: true
|
|
|
|
logText: logs.logText
|
|
}
|
|
}
|
|
|
|
Pane {
|
|
SplitView.preferredWidth: 300
|
|
|
|
ColumnLayout {
|
|
CheckBox {
|
|
id: loadingCheckBox
|
|
|
|
text: "loading"
|
|
}
|
|
CheckBox {
|
|
id: sorterVisibleCheckBox
|
|
|
|
text: "sorter visible"
|
|
checked: false
|
|
}
|
|
CheckBox {
|
|
id: customOrderAvailableCheckBox
|
|
|
|
text: "custom order available"
|
|
}
|
|
CheckBox {
|
|
id: sendEnabledCheckBox
|
|
|
|
text: "send enabled"
|
|
}
|
|
CheckBox {
|
|
id: swapEnabledCheckBox
|
|
|
|
text: "swap enabled"
|
|
}
|
|
CheckBox {
|
|
id: swapVisibleCheckBox
|
|
|
|
text: "swap visible"
|
|
}
|
|
CheckBox {
|
|
id: communitySwapVisibleCheckBox
|
|
|
|
text: "community swap visible"
|
|
}
|
|
CheckBox {
|
|
id: balanceErrorCheckBox
|
|
|
|
text: "balance error"
|
|
}
|
|
CheckBox {
|
|
id: marketDataErrorCheckBox
|
|
|
|
text: "market data error"
|
|
}
|
|
ColumnLayout {
|
|
spacing: 5
|
|
Button {
|
|
text: "Sort desc"
|
|
onClicked: assetView.setSortOrder(Qt.DescendingOrder)
|
|
}
|
|
|
|
Button {
|
|
text: "Sort asc"
|
|
onClicked: assetView.setSortOrder(Qt.AscendingOrder)
|
|
}
|
|
}
|
|
ColumnLayout {
|
|
spacing: 10
|
|
Layout.fillWidth: true
|
|
Label {
|
|
text: "Sort by:"
|
|
}
|
|
|
|
ComboBox {
|
|
id: sortValueComboBox
|
|
Layout.fillWidth: true
|
|
textRole: "text"
|
|
valueRole: "value"
|
|
displayText: currentText || ""
|
|
currentIndex: 4
|
|
model: [
|
|
{ value: SortOrderComboBox.TokenOrderCurrencyBalance, text: "TokenOrderCurrencyBalance" },
|
|
{ value: SortOrderComboBox.TokenOrderBalance, text: "TokenOrderBalance" },
|
|
{ value: SortOrderComboBox.TokenOrderCurrencyPrice, text: "TokenOrderCurrencyPrice" },
|
|
{ value: SortOrderComboBox.TokenOrder1DChange, text: "TokenOrder1DChange" },
|
|
{ value: SortOrderComboBox.TokenOrderAlpha, text: "TokenOrderAlpha" },
|
|
{ value: SortOrderComboBox.TokenOrderCustom, text: "TokenOrderCustom" }
|
|
]
|
|
|
|
onCurrentValueChanged: assetView.sortByValue(currentValue)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
Settings {
|
|
property alias loading: loadingCheckBox.checked
|
|
property alias filterVisible: sorterVisibleCheckBox.checked
|
|
property alias customOrderAvailable: customOrderAvailableCheckBox.checked
|
|
property alias sendEnabled: sendEnabledCheckBox.checked
|
|
property alias swapEnabled: swapEnabledCheckBox.checked
|
|
property alias swapVisible: swapVisibleCheckBox.checked
|
|
property alias balanceError: balanceErrorCheckBox.checked
|
|
property alias marketDataError: marketDataErrorCheckBox.checked
|
|
}
|
|
}
|
|
|
|
// category: Views
|