2023-03-20 13:29:05 +01:00
|
|
|
import QtQuick 2.14
|
|
|
|
import QtQuick.Controls 2.14
|
2024-02-09 12:05:51 +01:00
|
|
|
import QtQuick.Layouts 1.15
|
2023-03-20 13:29:05 +01:00
|
|
|
|
2024-02-28 14:19:14 +02:00
|
|
|
import StatusQ 0.1
|
2023-03-20 13:29:05 +01:00
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Utils 0.1 as CoreUtils
|
|
|
|
|
2024-02-28 14:19:14 +02:00
|
|
|
import SortFilterProxyModel 0.2
|
|
|
|
|
2023-03-20 13:29:05 +01:00
|
|
|
import mainui 1.0
|
|
|
|
import AppLayouts.Profile.panels 1.0
|
2023-10-23 13:36:33 +02:00
|
|
|
import shared.stores 1.0
|
2023-03-20 13:29:05 +01:00
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
|
|
|
|
import Storybook 1.0
|
|
|
|
import Models 1.0
|
|
|
|
|
2024-01-13 08:54:57 +05:30
|
|
|
import AppLayouts.Wallet.stores 1.0
|
|
|
|
|
2023-03-20 13:29:05 +01:00
|
|
|
SplitView {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
Logs { id: logs }
|
|
|
|
|
|
|
|
orientation: Qt.Vertical
|
|
|
|
|
2024-01-13 08:54:57 +05:30
|
|
|
readonly property WalletAssetsStore walletAssetStore: WalletAssetsStore {
|
|
|
|
assetsWithFilteredBalances: walletAssetStore.groupedAccountsAssetsModel
|
2023-03-20 13:29:05 +01:00
|
|
|
}
|
|
|
|
|
2024-02-28 14:19:14 +02:00
|
|
|
SortFilterProxyModel {
|
|
|
|
id: inShowcaseModelItem
|
|
|
|
sourceModel: !emptyModelChecker.checked ? walletAssetStore.groupedAccountAssetsModel : null
|
|
|
|
proxyRoles: [
|
|
|
|
FastExpressionRole {
|
2024-03-05 00:07:09 +02:00
|
|
|
name: "showcaseKey"
|
2024-02-28 14:19:14 +02:00
|
|
|
expression: "Asset 1" + index
|
|
|
|
},
|
|
|
|
FastExpressionRole {
|
2024-03-05 00:07:09 +02:00
|
|
|
name: "showcaseVisibility"
|
2024-02-28 14:19:14 +02:00
|
|
|
expression: 1
|
2023-11-09 18:24:05 +04:00
|
|
|
}
|
2024-02-28 14:19:14 +02:00
|
|
|
]
|
|
|
|
}
|
2023-11-09 18:24:05 +04:00
|
|
|
|
2024-02-28 14:19:14 +02:00
|
|
|
SortFilterProxyModel {
|
|
|
|
id: hiddenShowcaseModelItem
|
|
|
|
sourceModel: !emptyModelChecker.checked ? walletAssetStore.groupedAccountAssetsModel : null
|
|
|
|
proxyRoles: [
|
|
|
|
FastExpressionRole {
|
2024-03-05 00:07:09 +02:00
|
|
|
name: "showcaseKey"
|
2024-02-28 14:19:14 +02:00
|
|
|
expression: "Asset 2" + index
|
|
|
|
},
|
|
|
|
FastExpressionRole {
|
2024-03-05 00:07:09 +02:00
|
|
|
name: "showcaseVisibility"
|
2024-02-28 14:19:14 +02:00
|
|
|
expression: 0
|
2023-11-09 18:24:05 +04:00
|
|
|
}
|
2024-02-28 14:19:14 +02:00
|
|
|
]
|
2023-11-09 18:24:05 +04:00
|
|
|
}
|
|
|
|
|
2024-02-28 14:19:14 +02:00
|
|
|
ProfileShowcaseAssetsPanel {
|
|
|
|
id: showcasePanel
|
2023-03-20 13:29:05 +01:00
|
|
|
SplitView.fillWidth: true
|
|
|
|
SplitView.preferredHeight: 500
|
2024-02-28 14:19:14 +02:00
|
|
|
inShowcaseModel: inShowcaseModelItem
|
|
|
|
hiddenModel: hiddenShowcaseModelItem
|
2024-03-03 12:02:30 +01:00
|
|
|
showcaseLimit: 8
|
2024-02-09 12:05:51 +01:00
|
|
|
|
2024-02-28 14:19:14 +02:00
|
|
|
addAccountsButtonVisible: !hasAllAccountsChecker.checked
|
2024-02-09 12:05:51 +01:00
|
|
|
|
2024-02-28 14:19:14 +02:00
|
|
|
formatCurrencyAmount: function (amount, symbol) {
|
|
|
|
const currencyAmount = ({amount: amount,
|
|
|
|
symbol: symbol.toUpperCase(),
|
|
|
|
displayDecimals: 4,
|
|
|
|
stripTrailingZeroes: false})
|
|
|
|
return LocaleUtils.currencyAmountToLocaleString(currencyAmount)
|
2023-03-20 13:29:05 +01:00
|
|
|
}
|
2024-02-28 14:19:14 +02:00
|
|
|
|
|
|
|
onNavigateToAccountsTab: logs.logEvent("ProfileShowcaseAssetsPanel::onNavigateToAccountsTab")
|
2023-03-20 13:29:05 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
LogsAndControlsPanel {
|
|
|
|
id: logsAndControlsPanel
|
|
|
|
|
|
|
|
SplitView.minimumHeight: 100
|
|
|
|
SplitView.preferredHeight: 200
|
|
|
|
|
|
|
|
logsView.logText: logs.logText
|
|
|
|
|
2024-02-09 12:05:51 +01:00
|
|
|
ColumnLayout {
|
|
|
|
CheckBox {
|
|
|
|
id: hasAllAccountsChecker
|
|
|
|
|
|
|
|
text: "Has the user already shared all of their accounts"
|
|
|
|
checked: true
|
|
|
|
}
|
2024-02-15 18:26:05 +01:00
|
|
|
|
|
|
|
CheckBox {
|
|
|
|
id: emptyModelChecker
|
|
|
|
|
|
|
|
text: "Empty model"
|
|
|
|
checked: false
|
|
|
|
}
|
2023-03-20 13:29:05 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-07-31 14:21:14 +02:00
|
|
|
|
|
|
|
// category: Panels
|
2023-10-03 13:56:30 +02:00
|
|
|
|
|
|
|
// https://www.figma.com/file/idUoxN7OIW2Jpp3PMJ1Rl8/%E2%9A%99%EF%B8%8F-Settings-%7C-Desktop?node-id=14588-319260&t=RkXAEv3G6mp3EUvl-0
|
|
|
|
// https://www.figma.com/file/idUoxN7OIW2Jpp3PMJ1Rl8/%E2%9A%99%EF%B8%8F-Settings-%7C-Desktop?node-id=14609-238808&t=RkXAEv3G6mp3EUvl-0
|
|
|
|
// https://www.figma.com/file/idUoxN7OIW2Jpp3PMJ1Rl8/%E2%9A%99%EF%B8%8F-Settings-%7C-Desktop?node-id=14609-239912&t=RkXAEv3G6mp3EUvl-0
|
|
|
|
// https://www.figma.com/file/idUoxN7OIW2Jpp3PMJ1Rl8/%E2%9A%99%EF%B8%8F-Settings-%7C-Desktop?node-id=14609-240991&t=RkXAEv3G6mp3EUvl-0
|
2024-02-09 12:05:51 +01:00
|
|
|
// https://www.figma.com/file/ibJOTPlNtIxESwS96vJb06/%F0%9F%91%A4-Profile-%7C-Desktop?type=design&node-id=2460%3A30679&mode=design&t=6rs9xMrPv4sGZKe4-1
|