2022-03-18 15:47:51 +01:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
|
|
|
import StatusQ.Controls.Validators 0.1
|
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Popups 0.1
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
2022-06-27 15:41:47 +02:00
|
|
|
import StatusQ.Core.Utils 0.1 as StatusQUtils
|
2022-03-18 15:47:51 +01:00
|
|
|
|
|
|
|
import "../controls"
|
|
|
|
import "../views"
|
|
|
|
|
2022-06-27 15:41:47 +02:00
|
|
|
StatusFloatingButtonsSelector {
|
2022-11-11 11:24:26 +02:00
|
|
|
id: root
|
2022-03-18 15:47:51 +01:00
|
|
|
|
2022-06-27 15:41:47 +02:00
|
|
|
property var selectedAccount
|
2022-11-11 11:24:26 +02:00
|
|
|
// Expected signature: function(newAccount, newIndex)
|
2022-08-01 19:04:23 +02:00
|
|
|
property var changeSelectedAccount: function(){}
|
2022-11-11 11:24:26 +02:00
|
|
|
property bool showAllWalletTypes: false
|
2022-03-18 15:47:51 +01:00
|
|
|
|
2022-07-21 14:15:02 +02:00
|
|
|
repeater.objectName: "accountsListFloatingHeader"
|
2022-11-11 11:24:26 +02:00
|
|
|
|
2022-06-27 15:41:47 +02:00
|
|
|
signal updatedSelectedAccount(var account)
|
2022-05-19 10:53:57 +02:00
|
|
|
|
2022-03-18 15:47:51 +01:00
|
|
|
QtObject {
|
2022-06-27 15:41:47 +02:00
|
|
|
id: d
|
|
|
|
property var firstModelData: null
|
2022-11-11 11:24:26 +02:00
|
|
|
|
|
|
|
function isWalletTypeAccepted(walletType, index) {
|
|
|
|
return (root.showAllWalletTypes || walletType !== Constants.watchWalletType)
|
|
|
|
}
|
2022-03-18 15:47:51 +01:00
|
|
|
}
|
|
|
|
|
2022-06-27 15:41:47 +02:00
|
|
|
delegate: Rectangle {
|
|
|
|
width: button.width
|
|
|
|
height: button.height
|
|
|
|
radius: 8
|
2022-11-11 11:24:26 +02:00
|
|
|
visible: root.visibleIndices.includes(index) && d.isWalletTypeAccepted(walletType, index)
|
2022-07-26 20:14:55 +02:00
|
|
|
color: Theme.palette.baseColor3
|
2022-06-27 15:41:47 +02:00
|
|
|
StatusButton {
|
|
|
|
id: button
|
2022-09-19 14:29:02 +02:00
|
|
|
size: StatusBaseButton.Size.Tiny
|
2022-06-27 15:41:47 +02:00
|
|
|
implicitHeight: 32
|
2022-09-13 09:37:09 +02:00
|
|
|
leftPadding: 4
|
2022-06-27 15:41:47 +02:00
|
|
|
text: name
|
2022-07-21 14:15:02 +02:00
|
|
|
objectName: name
|
2022-09-13 09:37:09 +02:00
|
|
|
asset.emoji: !!emoji ? emoji: ""
|
2022-06-27 15:41:47 +02:00
|
|
|
icon.name: !emoji ? "filled-account": ""
|
|
|
|
normalColor: "transparent"
|
2022-07-26 20:14:55 +02:00
|
|
|
hoverColor: Theme.palette.statusFloatingButtonHighlight
|
2022-11-11 11:24:26 +02:00
|
|
|
highlighted: index === root.currentIndex
|
2022-06-27 15:41:47 +02:00
|
|
|
onClicked: {
|
2022-11-11 11:24:26 +02:00
|
|
|
changeSelectedAccount(model, index)
|
|
|
|
root.currentIndex = index
|
2022-03-18 15:47:51 +01:00
|
|
|
}
|
2022-06-27 15:41:47 +02:00
|
|
|
Component.onCompleted: {
|
|
|
|
// On startup make the preseected wallet in the floating menu,
|
|
|
|
// and if the selectedAccount is watch only then select 0th item
|
|
|
|
if(index === 0) {
|
|
|
|
d.firstModelData = model
|
2022-03-18 15:47:51 +01:00
|
|
|
}
|
|
|
|
|
2022-11-11 11:24:26 +02:00
|
|
|
if(name !== root.selectedAccount.name) {
|
2022-06-27 15:41:47 +02:00
|
|
|
return
|
2022-03-18 15:47:51 +01:00
|
|
|
}
|
2022-06-27 15:41:47 +02:00
|
|
|
|
2022-11-11 11:24:26 +02:00
|
|
|
if(name === root.selectedAccount.name) {
|
|
|
|
if(d.isWalletTypeAccepted(walletType, index)) {
|
2022-06-27 15:41:47 +02:00
|
|
|
// If the selected index wont be displayed, added it to the visible indices
|
|
|
|
if(index > 2) {
|
|
|
|
visibleIndices = [0, 1, index]
|
2022-03-18 15:47:51 +01:00
|
|
|
}
|
2022-11-11 11:24:26 +02:00
|
|
|
root.currentIndex = index
|
2022-03-18 15:47:51 +01:00
|
|
|
}
|
2022-06-27 15:41:47 +02:00
|
|
|
else {
|
2022-11-11 11:24:26 +02:00
|
|
|
changeSelectedAccount(root.selectedAccount, 0)
|
|
|
|
root.currentIndex = 0
|
2022-03-18 15:47:51 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-06-27 15:41:47 +02:00
|
|
|
}
|
|
|
|
popupMenuDelegate: StatusListItem {
|
|
|
|
implicitWidth: 272
|
|
|
|
title: name
|
2023-01-08 19:23:51 -03:00
|
|
|
subTitle: LocaleUtils.currencyAmountToLocaleString(currencyBalance)
|
2022-08-11 14:55:08 +03:00
|
|
|
asset.emoji: !!emoji ? emoji: ""
|
|
|
|
asset.color: model.color
|
|
|
|
asset.name: !emoji ? "filled-account": ""
|
|
|
|
asset.letterSize: 14
|
|
|
|
asset.isLetterIdenticon: !!model.emoji
|
|
|
|
asset.bgColor: Theme.palette.indirectColor1
|
2022-06-27 15:41:47 +02:00
|
|
|
onClicked: {
|
2022-11-11 11:24:26 +02:00
|
|
|
changeSelectedAccount(model, index)
|
2022-12-01 19:58:37 +03:00
|
|
|
root.selectItem(index)
|
2022-03-18 15:47:51 +01:00
|
|
|
}
|
2022-11-11 11:24:26 +02:00
|
|
|
visible: !root.visibleIndices.includes(index) && d.isWalletTypeAccepted(walletType, index)
|
2022-03-18 15:47:51 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|