2022-08-08 23:12:12 +02:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
|
|
|
import QtQuick.Controls 2.14
|
|
|
|
import QtQuick.Window 2.12
|
|
|
|
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
|
|
|
|
import utils 1.0
|
2022-09-05 17:50:20 +03:00
|
|
|
import shared.views 1.0
|
2022-08-08 23:12:12 +02:00
|
|
|
import shared.controls 1.0
|
2023-01-20 00:14:23 +03:00
|
|
|
import shared.stores 1.0
|
2022-08-08 23:12:12 +02:00
|
|
|
|
|
|
|
|
2022-10-28 20:17:16 +03:00
|
|
|
/// \beware: heavy shortcuts here, refactor to match the requirements when touching this again
|
|
|
|
/// \todo split into token history and balance views; they have different requirements that introduce unnecessary complexity
|
|
|
|
/// \todo take a declarative approach, move logic into the typed backend and remove multiple source of truth (e.g. time ranges)
|
2022-08-08 23:12:12 +02:00
|
|
|
Item {
|
|
|
|
id: root
|
|
|
|
|
2023-02-17 17:51:34 +01:00
|
|
|
property var token: ({})
|
2023-03-15 10:17:25 +01:00
|
|
|
property var networkConnectionStore
|
2022-10-28 20:17:16 +03:00
|
|
|
/*required*/ property string address: ""
|
2023-11-29 12:19:59 +01:00
|
|
|
property bool showAllAccounts: false
|
2023-04-25 18:54:50 +02:00
|
|
|
property bool assetsLoading: true
|
2022-10-28 20:17:16 +03:00
|
|
|
|
2022-09-05 17:50:20 +03:00
|
|
|
QtObject {
|
|
|
|
id: d
|
2022-09-27 10:30:18 +02:00
|
|
|
property var marketValueStore : RootStore.marketValueStore
|
2023-12-06 11:54:36 +01:00
|
|
|
readonly property string symbol: root.token ? root.token.symbol : ""
|
2022-09-27 10:30:18 +02:00
|
|
|
}
|
2022-09-05 17:50:20 +03:00
|
|
|
|
2022-09-27 10:30:18 +02:00
|
|
|
Connections {
|
|
|
|
target: walletSectionAllTokens
|
2023-01-18 11:25:36 +02:00
|
|
|
function onTokenHistoricalDataReady(tokenDetails: string) {
|
2022-09-27 10:30:18 +02:00
|
|
|
let response = JSON.parse(tokenDetails)
|
|
|
|
if (response === null) {
|
2022-10-28 20:17:16 +03:00
|
|
|
console.debug("error parsing json message for tokenHistoricalDataReady")
|
2022-09-27 10:30:18 +02:00
|
|
|
return
|
2022-09-05 17:50:20 +03:00
|
|
|
}
|
2022-09-27 10:30:18 +02:00
|
|
|
if(response.historicalData === null || response.historicalData <= 0)
|
|
|
|
return
|
2022-09-05 17:50:20 +03:00
|
|
|
|
2022-09-27 10:30:18 +02:00
|
|
|
d.marketValueStore.setTimeAndValueData(response.historicalData, response.range)
|
2022-09-05 17:50:20 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-08-08 23:12:12 +02:00
|
|
|
AssetsDetailsHeader {
|
|
|
|
id: tokenDetailsHeader
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
|
|
|
width: parent.width
|
2022-08-11 14:55:08 +03:00
|
|
|
asset.name: token && token.symbol ? Style.png("tokens/%1".arg(token.symbol)) : ""
|
|
|
|
asset.isImage: true
|
2023-12-08 19:41:12 +05:30
|
|
|
primaryText: token && token.name ? token.name : Constants.dummyText
|
|
|
|
secondaryText: token && token.enabledNetworkBalance ? LocaleUtils.currencyAmountToLocaleString(token.enabledNetworkBalance) : Constants.dummyText
|
|
|
|
tertiaryText: token && token.enabledNetworkCurrencyBalance ? LocaleUtils.currencyAmountToLocaleString(token.enabledNetworkCurrencyBalance) : Constants.dummyText
|
2022-12-29 13:44:51 -03:00
|
|
|
balances: token && token.balances ? token.balances : null
|
2023-10-30 23:18:58 +01:00
|
|
|
networksModel: RootStore.allNetworks
|
2023-04-25 18:54:50 +02:00
|
|
|
isLoading: root.assetsLoading
|
2023-03-22 23:08:36 +01:00
|
|
|
errorTooltipText: token && token.balances ? networkConnectionStore.getBlockchainNetworkDownTextForToken(token.balances): ""
|
2022-12-29 13:44:51 -03:00
|
|
|
formatBalance: function(balance){
|
2023-01-08 19:23:51 -03:00
|
|
|
return LocaleUtils.currencyAmountToLocaleString(balance)
|
2022-12-29 13:44:51 -03:00
|
|
|
}
|
2022-08-08 23:12:12 +02:00
|
|
|
}
|
|
|
|
|
2022-10-28 20:17:16 +03:00
|
|
|
enum GraphType {
|
|
|
|
Price = 0,
|
|
|
|
Balance
|
|
|
|
}
|
|
|
|
|
2022-09-05 17:50:20 +03:00
|
|
|
Loader {
|
|
|
|
id: graphDetailLoader
|
|
|
|
width: parent.width
|
|
|
|
height: 290
|
2022-08-08 23:12:12 +02:00
|
|
|
anchors.top: tokenDetailsHeader.bottom
|
|
|
|
anchors.topMargin: 24
|
2022-09-05 17:50:20 +03:00
|
|
|
active: root.visible
|
|
|
|
sourceComponent: StatusChartPanel {
|
|
|
|
id: graphDetail
|
2022-10-28 20:17:16 +03:00
|
|
|
|
|
|
|
property int selectedGraphType: AssetsDetailView.GraphType.Price
|
|
|
|
property var selectedStore: d.marketValueStore
|
|
|
|
|
|
|
|
function dataReady() {
|
|
|
|
return typeof selectedStore != "undefined"
|
|
|
|
}
|
|
|
|
function timeRangeSelected() {
|
|
|
|
return dataReady() && graphDetail.timeRangeTabBarIndex >= 0 && graphDetail.selectedTimeRange.length > 0
|
|
|
|
}
|
|
|
|
|
|
|
|
readonly property var labelsData: {
|
|
|
|
return timeRangeSelected()
|
|
|
|
? selectedStore.timeRange[graphDetail.timeRangeTabBarIndex][graphDetail.selectedTimeRange]
|
|
|
|
: []
|
|
|
|
}
|
|
|
|
readonly property var dataRange: {
|
|
|
|
return timeRangeSelected()
|
|
|
|
? selectedStore.dataRange[graphDetail.timeRangeTabBarIndex][graphDetail.selectedTimeRange]
|
|
|
|
: []
|
|
|
|
}
|
|
|
|
readonly property var maxTicksLimit: {
|
|
|
|
return timeRangeSelected() && typeof selectedStore.maxTicks != "undefined"
|
|
|
|
? selectedStore.maxTicks[graphDetail.timeRangeTabBarIndex][graphDetail.selectedTimeRange]
|
|
|
|
: 0
|
|
|
|
}
|
|
|
|
|
|
|
|
graphsModel: [
|
|
|
|
{text: qsTr("Price"), enabled: true, id: AssetsDetailView.GraphType.Price},
|
2022-11-15 23:48:59 +02:00
|
|
|
{text: qsTr("Balance"), enabled: true, id: AssetsDetailView.GraphType.Balance},
|
2022-10-28 20:17:16 +03:00
|
|
|
]
|
|
|
|
defaultTimeRangeIndexShown: ChartStoreBase.TimeRange.All
|
|
|
|
timeRangeModel: dataReady() && selectedStore.timeRangeTabsModel
|
|
|
|
onHeaderTabClicked: (privateIdentifier, isTimeRange) => {
|
|
|
|
if(!isTimeRange && graphDetail.selectedGraphType !== privateIdentifier) {
|
|
|
|
graphDetail.selectedGraphType = privateIdentifier
|
|
|
|
}
|
|
|
|
|
|
|
|
if(graphDetail.selectedGraphType === AssetsDetailView.GraphType.Balance) {
|
2022-11-15 23:48:59 +02:00
|
|
|
graphDetail.updateBalanceStore()
|
2022-10-28 20:17:16 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
if(!isTimeRange) {
|
|
|
|
graphDetail.selectedStore = graphDetail.selectedGraphType === AssetsDetailView.GraphType.Price ? d.marketValueStore : balanceStore
|
|
|
|
}
|
|
|
|
|
|
|
|
chart.animateToNewData()
|
|
|
|
}
|
2023-10-06 13:00:35 +02:00
|
|
|
|
|
|
|
readonly property var dateToShortLabel: function (value) {
|
|
|
|
const range = balanceStore.timeRangeStrToEnum(graphDetail.selectedTimeRange)
|
|
|
|
return range === ChartStoreBase.TimeRange.Weekly || range === ChartStoreBase.TimeRange.Monthly ?
|
|
|
|
LocaleUtils.getDayMonth(value) :
|
|
|
|
LocaleUtils.getMonthYear(value)
|
|
|
|
}
|
2022-09-05 17:50:20 +03:00
|
|
|
chart.chartType: 'line'
|
|
|
|
chart.chartData: {
|
|
|
|
return {
|
2023-01-10 14:04:23 +01:00
|
|
|
labels: RootStore.marketHistoryIsLoading ? [] : graphDetail.labelsData,
|
2022-09-05 17:50:20 +03:00
|
|
|
datasets: [{
|
|
|
|
xAxisId: 'x-axis-1',
|
|
|
|
yAxisId: 'y-axis-1',
|
|
|
|
backgroundColor: (Theme.palette.name === "dark") ? 'rgba(136, 176, 255, 0.2)' : 'rgba(67, 96, 223, 0.2)',
|
|
|
|
borderColor: (Theme.palette.name === "dark") ? 'rgba(136, 176, 255, 1)' : 'rgba(67, 96, 223, 1)',
|
2023-09-15 19:27:00 +02:00
|
|
|
borderWidth: graphDetail.selectedGraphType === AssetsDetailView.GraphType.Price ? 3 : 2,
|
2022-09-05 17:50:20 +03:00
|
|
|
pointRadius: 0,
|
2023-01-10 14:04:23 +01:00
|
|
|
data: RootStore.marketHistoryIsLoading ? [] : graphDetail.dataRange,
|
2022-09-27 10:30:18 +02:00
|
|
|
parsing: false,
|
2022-09-05 17:50:20 +03:00
|
|
|
}]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
chart.chartOptions: {
|
|
|
|
return {
|
|
|
|
maintainAspectRatio: false,
|
|
|
|
responsive: true,
|
|
|
|
legend: {
|
|
|
|
display: false
|
|
|
|
},
|
2023-09-15 19:27:00 +02:00
|
|
|
elements: {
|
|
|
|
line: {
|
|
|
|
cubicInterpolationMode: 'monotone' // without it interpolation makes the line too curvy that can extend horizontally farther then data points
|
|
|
|
}
|
|
|
|
},
|
2022-09-05 17:50:20 +03:00
|
|
|
//TODO enable zoom
|
|
|
|
//zoom: {
|
|
|
|
// enabled: true,
|
|
|
|
// drag: true,
|
|
|
|
// speed: 0.1,
|
|
|
|
// threshold: 2
|
|
|
|
//},
|
|
|
|
//pan:{enabled:true,mode:'x'},
|
|
|
|
tooltips: {
|
2023-10-06 13:00:35 +02:00
|
|
|
format: {
|
|
|
|
enabled: graphDetail.selectedGraphType === AssetsDetailView.GraphType.Balance,
|
|
|
|
callback: function (value) {
|
|
|
|
return graphDetail.dateToShortLabel(value)
|
|
|
|
},
|
|
|
|
valueCallback: function(value) {
|
|
|
|
return LocaleUtils.currencyAmountToLocaleString({ amount: value, symbol: RootStore.currencyStore.currentCurrencySymbol, displayDecimals: 2 })
|
|
|
|
}
|
|
|
|
},
|
2022-09-05 17:50:20 +03:00
|
|
|
intersect: false,
|
|
|
|
displayColors: false,
|
|
|
|
callbacks: {
|
|
|
|
label: function(tooltipItem, data) {
|
|
|
|
let label = data.datasets[tooltipItem.datasetIndex].label || '';
|
|
|
|
if (label) {
|
|
|
|
label += ': ';
|
|
|
|
}
|
2023-09-15 19:27:00 +02:00
|
|
|
|
2023-10-06 13:00:35 +02:00
|
|
|
if (graphDetail.selectedGraphType === AssetsDetailView.GraphType.Balance)
|
|
|
|
return label + tooltipItem.yLabel // already formatted in tooltips.value.callback
|
|
|
|
|
|
|
|
const value = LocaleUtils.currencyAmountToLocaleString({ amount: tooltipItem.yLabel, symbol: RootStore.currencyStore.currentCurrencySymbol, displayDecimals: 2 })
|
2023-09-15 19:27:00 +02:00
|
|
|
return label + value
|
2022-09-05 17:50:20 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
scales: {
|
2023-10-06 13:00:35 +02:00
|
|
|
labelFormat: {
|
|
|
|
callback: function (value) {
|
|
|
|
return graphDetail.dateToShortLabel(value)
|
|
|
|
},
|
|
|
|
enabled: graphDetail.selectedGraphType === AssetsDetailView.GraphType.Balance,
|
|
|
|
},
|
2022-09-05 17:50:20 +03:00
|
|
|
xAxes: [{
|
|
|
|
id: 'x-axis-1',
|
|
|
|
position: 'bottom',
|
2023-09-15 19:27:00 +02:00
|
|
|
type: graphDetail.selectedGraphType === AssetsDetailView.GraphType.Price ? 'category' : 'time',
|
2022-09-05 17:50:20 +03:00
|
|
|
gridLines: {
|
|
|
|
drawOnChartArea: false,
|
|
|
|
drawBorder: false,
|
|
|
|
drawTicks: false,
|
|
|
|
},
|
|
|
|
ticks: {
|
|
|
|
fontSize: 10,
|
|
|
|
fontColor: (Theme.palette.name === "dark") ? '#909090' : '#939BA1',
|
|
|
|
padding: 16,
|
2022-09-27 10:30:18 +02:00
|
|
|
maxRotation: 0,
|
|
|
|
minRotation: 0,
|
2022-10-28 20:17:16 +03:00
|
|
|
maxTicksLimit: graphDetail.maxTicksLimit,
|
2022-09-27 10:30:18 +02:00
|
|
|
},
|
2023-09-15 19:27:00 +02:00
|
|
|
time: {
|
|
|
|
minUnit: 'day' // for '7days' timeframe, otherwise labels are '10PM', '10AM', '10PM', etc
|
|
|
|
}
|
2022-09-05 17:50:20 +03:00
|
|
|
}],
|
|
|
|
yAxes: [{
|
|
|
|
position: 'left',
|
|
|
|
id: 'y-axis-1',
|
|
|
|
gridLines: {
|
|
|
|
borderDash: [8, 4],
|
|
|
|
drawBorder: false,
|
|
|
|
drawTicks: false,
|
|
|
|
color: (Theme.palette.name === "dark") ? '#909090' : '#939BA1'
|
|
|
|
},
|
|
|
|
beforeDataLimits: (axis) => {
|
|
|
|
axis.paddingTop = 25;
|
|
|
|
axis.paddingBottom = 0;
|
|
|
|
},
|
2022-10-28 20:17:16 +03:00
|
|
|
afterDataLimits: (axis) => {
|
|
|
|
if(axis.min < 0)
|
|
|
|
axis.min = 0;
|
|
|
|
},
|
2022-09-05 17:50:20 +03:00
|
|
|
ticks: {
|
|
|
|
fontSize: 10,
|
|
|
|
fontColor: (Theme.palette.name === "dark") ? '#909090' : '#939BA1',
|
|
|
|
padding: 8,
|
|
|
|
callback: function(value, index, ticks) {
|
2023-01-08 19:23:51 -03:00
|
|
|
return LocaleUtils.numberToLocaleString(value)
|
2022-09-05 17:50:20 +03:00
|
|
|
},
|
|
|
|
}
|
|
|
|
}]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-10-28 20:17:16 +03:00
|
|
|
|
2023-01-10 14:04:23 +01:00
|
|
|
LoadingGraphView {
|
|
|
|
anchors.fill: chart
|
|
|
|
active: RootStore.marketHistoryIsLoading
|
|
|
|
}
|
|
|
|
|
2022-11-15 23:48:59 +02:00
|
|
|
function updateBalanceStore() {
|
|
|
|
let selectedTimeRangeEnum = balanceStore.timeRangeStrToEnum(graphDetail.selectedTimeRange)
|
|
|
|
|
|
|
|
let currencySymbol = RootStore.currencyStore.currentCurrency
|
2023-11-29 12:19:59 +01:00
|
|
|
if(!balanceStore.hasData(root.address, root.showAllAccounts, token.symbol, currencySymbol, selectedTimeRangeEnum)) {
|
|
|
|
RootStore.fetchHistoricalBalanceForTokenAsJson(root.address, root.showAllAccounts, token.symbol, currencySymbol, selectedTimeRangeEnum)
|
2022-11-15 23:48:59 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-28 20:17:16 +03:00
|
|
|
TokenBalanceHistoryStore {
|
|
|
|
id: balanceStore
|
|
|
|
|
2022-11-15 23:48:59 +02:00
|
|
|
onNewDataReady: (address, tokenSymbol, currencySymbol, timeRange) => {
|
|
|
|
if (timeRange === timeRangeStrToEnum(graphDetail.selectedTimeRange)) {
|
2022-10-28 20:17:16 +03:00
|
|
|
chart.updateToNewData()
|
|
|
|
}
|
|
|
|
}
|
2022-11-15 23:48:59 +02:00
|
|
|
|
|
|
|
Connections {
|
|
|
|
target: root
|
|
|
|
function onAddressChanged() { graphDetail.updateBalanceStore() }
|
|
|
|
}
|
|
|
|
|
|
|
|
Connections {
|
2023-12-06 11:54:36 +01:00
|
|
|
target: d
|
|
|
|
function onSymbolChanged() { if (d.symbol) graphDetail.updateBalanceStore() }
|
2022-11-15 23:48:59 +02:00
|
|
|
}
|
2022-10-28 20:17:16 +03:00
|
|
|
}
|
2022-09-05 17:50:20 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ColumnLayout {
|
|
|
|
anchors.top: graphDetailLoader.bottom
|
|
|
|
anchors.topMargin: 24
|
|
|
|
anchors.bottom: parent.bottom
|
2022-08-08 23:12:12 +02:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
|
|
|
|
|
|
|
width: parent.width
|
|
|
|
|
|
|
|
spacing: Style.current.padding
|
|
|
|
|
|
|
|
RowLayout {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
InformationTile {
|
|
|
|
maxWidth: parent.width
|
|
|
|
primaryText: qsTr("Market Cap")
|
2023-03-15 10:17:25 +01:00
|
|
|
secondaryText: token && token.marketCap ? LocaleUtils.currencyAmountToLocaleString(token.marketCap) : Constants.dummyText
|
2023-04-25 18:54:50 +02:00
|
|
|
isLoading: root.assetsLoading
|
2022-08-08 23:12:12 +02:00
|
|
|
}
|
|
|
|
InformationTile {
|
|
|
|
maxWidth: parent.width
|
|
|
|
primaryText: qsTr("Day Low")
|
2023-03-15 10:17:25 +01:00
|
|
|
secondaryText: token && token.lowDay ? LocaleUtils.currencyAmountToLocaleString(token.lowDay) : Constants.dummyText
|
2023-04-25 18:54:50 +02:00
|
|
|
isLoading: root.assetsLoading
|
2022-08-08 23:12:12 +02:00
|
|
|
}
|
|
|
|
InformationTile {
|
|
|
|
maxWidth: parent.width
|
|
|
|
primaryText: qsTr("Day High")
|
2023-03-15 10:17:25 +01:00
|
|
|
secondaryText: token && token.highDay ? LocaleUtils.currencyAmountToLocaleString(token.highDay) : Constants.dummyText
|
2023-04-25 18:54:50 +02:00
|
|
|
isLoading: root.assetsLoading
|
2022-08-08 23:12:12 +02:00
|
|
|
}
|
|
|
|
Item {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
}
|
|
|
|
InformationTile {
|
2023-12-08 19:41:12 +05:30
|
|
|
readonly property double changePctHour: token && token.changePctHour ? token.changePctHour : 0
|
2022-08-08 23:12:12 +02:00
|
|
|
maxWidth: parent.width
|
|
|
|
primaryText: qsTr("Hour")
|
2023-05-02 16:05:04 +02:00
|
|
|
secondaryText: "%1%".arg(LocaleUtils.numberToLocaleString(changePctHour, 2))
|
2023-03-15 10:17:25 +01:00
|
|
|
secondaryLabel.customColor: changePctHour === 0 ? Theme.palette.directColor1 :
|
|
|
|
changePctHour < 0 ? Theme.palette.dangerColor1 :
|
|
|
|
Theme.palette.successColor1
|
2023-04-25 18:54:50 +02:00
|
|
|
isLoading: root.assetsLoading
|
2022-08-08 23:12:12 +02:00
|
|
|
}
|
|
|
|
InformationTile {
|
2023-12-08 19:41:12 +05:30
|
|
|
readonly property double changePctDay: token && token.changePctDay ? token.changePctDay : 0
|
2022-08-08 23:12:12 +02:00
|
|
|
maxWidth: parent.width
|
|
|
|
primaryText: qsTr("Day")
|
2023-05-02 16:05:04 +02:00
|
|
|
secondaryText: "%1%".arg(LocaleUtils.numberToLocaleString(changePctDay, 2))
|
2023-03-15 10:17:25 +01:00
|
|
|
secondaryLabel.customColor: changePctDay === 0 ? Theme.palette.directColor1 :
|
|
|
|
changePctDay < 0 ? Theme.palette.dangerColor1 :
|
|
|
|
Theme.palette.successColor1
|
2023-04-25 18:54:50 +02:00
|
|
|
isLoading: root.assetsLoading
|
2022-08-08 23:12:12 +02:00
|
|
|
}
|
|
|
|
InformationTile {
|
2023-12-08 19:41:12 +05:30
|
|
|
readonly property double changePct24hour: token && token.changePct24hour ? token.changePct24hour : 0
|
2022-08-08 23:12:12 +02:00
|
|
|
maxWidth: parent.width
|
|
|
|
primaryText: qsTr("24 Hours")
|
2023-05-02 16:05:04 +02:00
|
|
|
secondaryText: "%1%".arg(LocaleUtils.numberToLocaleString(changePct24hour, 2))
|
2023-03-15 10:17:25 +01:00
|
|
|
secondaryLabel.customColor: changePct24hour === 0 ? Theme.palette.directColor1 :
|
|
|
|
changePct24hour < 0 ? Theme.palette.dangerColor1 :
|
|
|
|
Theme.palette.successColor1
|
2023-04-25 18:54:50 +02:00
|
|
|
isLoading: root.assetsLoading
|
2022-08-08 23:12:12 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusTabBar {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.topMargin: Style.current.xlPadding
|
|
|
|
|
|
|
|
StatusTabButton {
|
|
|
|
leftPadding: 0
|
|
|
|
width: implicitWidth
|
|
|
|
text: qsTr("Overview")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
StackLayout {
|
|
|
|
id: stack
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
|
|
|
StatusScrollView {
|
|
|
|
id: scrollView
|
|
|
|
Layout.preferredWidth: parent.width
|
|
|
|
Layout.preferredHeight: parent.height
|
|
|
|
topPadding: 8
|
|
|
|
bottomPadding: 8
|
2023-05-31 23:58:23 +03:00
|
|
|
contentWidth: availableWidth
|
2022-08-08 23:12:12 +02:00
|
|
|
Flow {
|
|
|
|
id: detailsFlow
|
|
|
|
|
|
|
|
readonly property bool isOverflowing: detailsFlow.width - tagsLayout.width - tokenDescriptionText.width < 24
|
|
|
|
|
|
|
|
spacing: 24
|
|
|
|
|
|
|
|
width: scrollView.availableWidth
|
2023-03-15 10:17:25 +01:00
|
|
|
StatusTextWithLoadingState {
|
2022-08-08 23:12:12 +02:00
|
|
|
id: tokenDescriptionText
|
|
|
|
width: Math.max(536 , scrollView.availableWidth - tagsLayout.width - 24)
|
|
|
|
|
|
|
|
font.pixelSize: 15
|
|
|
|
lineHeight: 22
|
|
|
|
lineHeightMode: Text.FixedHeight
|
2023-12-08 19:41:12 +05:30
|
|
|
text: token && token.description ? token.description : Constants.dummyText
|
2023-03-15 10:17:25 +01:00
|
|
|
customColor: Theme.palette.directColor1
|
2022-08-08 23:12:12 +02:00
|
|
|
elide: Text.ElideRight
|
|
|
|
wrapMode: Text.Wrap
|
|
|
|
textFormat: Qt.RichText
|
2023-04-25 18:54:50 +02:00
|
|
|
loading: root.assetsLoading
|
2022-08-08 23:12:12 +02:00
|
|
|
}
|
|
|
|
ColumnLayout {
|
|
|
|
id: tagsLayout
|
|
|
|
spacing: 10
|
|
|
|
InformationTag {
|
|
|
|
id: website
|
|
|
|
Layout.alignment: detailsFlow.isOverflowing ? Qt.AlignLeft : Qt.AlignRight
|
|
|
|
iconAsset.icon: "browser"
|
|
|
|
tagPrimaryLabel.text: qsTr("Website")
|
2022-10-28 20:17:16 +03:00
|
|
|
visible: typeof token != "undefined" && token && token.assetWebsiteUrl !== ""
|
2023-01-13 00:26:48 +01:00
|
|
|
customBackground: Component {
|
|
|
|
Rectangle {
|
|
|
|
color: Theme.palette.baseColor2
|
|
|
|
border.width: 1
|
|
|
|
border.color: "transparent"
|
|
|
|
radius: 36
|
|
|
|
}
|
|
|
|
}
|
2022-08-08 23:12:12 +02:00
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
onClicked: Global.openLink(token.assetWebsiteUrl)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
InformationTag {
|
|
|
|
id: smartContractAddress
|
|
|
|
Layout.alignment: detailsFlow.isOverflowing ? Qt.AlignLeft : Qt.AlignRight
|
|
|
|
|
2023-04-04 14:09:36 +02:00
|
|
|
image.source: {
|
|
|
|
if (!token || token.builtOn === "") {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
let networkIconUrl = RootStore.getNetworkIconUrl(token.builtOn)
|
|
|
|
return networkIconUrl ? Style.svg("tiny/" + networkIconUrl) : ""
|
|
|
|
}
|
2022-08-08 23:12:12 +02:00
|
|
|
tagPrimaryLabel.text: token && token.builtOn !== "" ? RootStore.getNetworkName(token.builtOn) : "---"
|
2023-12-08 19:41:12 +05:30
|
|
|
tagSecondaryLabel.text: token && token.address ? token.address : "---"
|
2022-11-03 15:11:13 +01:00
|
|
|
visible: typeof token != "undefined" && token && token.builtOn !== "" && token.address !== ""
|
2023-01-13 00:26:48 +01:00
|
|
|
customBackground: Component {
|
|
|
|
Rectangle {
|
|
|
|
color: Theme.palette.baseColor2
|
|
|
|
border.width: 1
|
|
|
|
border.color: "transparent"
|
|
|
|
radius: 36
|
|
|
|
}
|
|
|
|
}
|
2022-08-08 23:12:12 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|