2023-04-24 20:35:34 +02:00
|
|
|
import QtQuick 2.15
|
2022-03-18 15:47:51 +01:00
|
|
|
|
|
|
|
import StatusQ.Controls 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
|
|
|
|
2023-05-22 17:55:47 +02:00
|
|
|
import utils 1.0
|
|
|
|
|
2024-05-15 23:22:13 +02:00
|
|
|
import shared.controls 1.0
|
2022-03-18 15:47:51 +01:00
|
|
|
|
2023-04-24 20:35:34 +02:00
|
|
|
StatusComboBox {
|
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
|
2023-07-21 10:41:24 +02:00
|
|
|
property var getNetworkShortNames: function(chainIds){}
|
2024-05-15 23:22:13 +02:00
|
|
|
property var formatCurrencyAmount: function(balance, symbol){}
|
2023-04-24 20:35:34 +02:00
|
|
|
property int selectedIndex: -1
|
2022-03-18 15:47:51 +01:00
|
|
|
|
2024-05-15 23:22:13 +02:00
|
|
|
objectName: "accountsModalHeader"
|
|
|
|
popupContentItemObjectName: "accountSelectorList"
|
|
|
|
|
2023-04-24 20:35:34 +02:00
|
|
|
control.padding: 0
|
|
|
|
control.spacing: 0
|
|
|
|
control.leftPadding: 8
|
|
|
|
control.rightPadding: 8
|
|
|
|
control.topPadding: 10
|
2022-05-19 10:53:57 +02:00
|
|
|
|
2023-04-24 20:35:34 +02:00
|
|
|
control.popup.width: 430
|
|
|
|
control.indicator: null
|
|
|
|
|
|
|
|
control.background: Rectangle {
|
2024-05-15 23:22:13 +02:00
|
|
|
objectName: "headerBackground"
|
|
|
|
|
2023-04-24 20:35:34 +02:00
|
|
|
width: contentItem.childrenRect.width + control.leftPadding + control.rightPadding
|
|
|
|
height: 32
|
2022-06-27 15:41:47 +02:00
|
|
|
radius: 8
|
2023-05-22 17:55:47 +02:00
|
|
|
color: !!selectedAccount ? hoverHandler.hovered ?
|
|
|
|
Utils.getHoveredColor(selectedAccount.colorId) :
|
|
|
|
Utils.getColorForId(selectedAccount.colorId) : "transparent"
|
2023-04-24 20:35:34 +02:00
|
|
|
HoverHandler {
|
|
|
|
id: hoverHandler
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
contentItem: Row {
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
width: childrenRect.width
|
|
|
|
spacing: 8
|
2024-01-15 10:19:25 +01:00
|
|
|
Padding {}
|
2023-04-24 20:35:34 +02:00
|
|
|
StatusEmoji {
|
2024-05-15 23:22:13 +02:00
|
|
|
objectName: "headerContentItemEmoji"
|
2023-04-24 20:35:34 +02:00
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
width: 16
|
|
|
|
height: 16
|
2024-05-15 23:22:13 +02:00
|
|
|
emojiId: StatusQUtils.Emoji.iconId(!!selectedAccount && !!selectedAccount.emoji ? selectedAccount.emoji : "", StatusQUtils.Emoji.size.verySmall) || ""
|
2024-01-15 10:19:25 +01:00
|
|
|
visible: !!emojiId
|
2023-04-24 20:35:34 +02:00
|
|
|
}
|
|
|
|
StatusBaseText {
|
2024-05-15 23:22:13 +02:00
|
|
|
objectName: "headerContentItemText"
|
2023-04-24 20:35:34 +02:00
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
2024-05-15 23:22:13 +02:00
|
|
|
text: !!selectedAccount && !!selectedAccount.name ? selectedAccount.name : ""
|
2023-04-24 20:35:34 +02:00
|
|
|
font.pixelSize: 15
|
2023-05-22 17:55:47 +02:00
|
|
|
color: Theme.palette.indirectColor1
|
2023-04-24 20:35:34 +02:00
|
|
|
}
|
|
|
|
StatusIcon {
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
width: 16
|
|
|
|
height: width
|
2024-01-15 10:19:25 +01:00
|
|
|
visible: !!root.model && root.model.count > 1
|
2023-04-24 20:35:34 +02:00
|
|
|
icon: "chevron-down"
|
2023-05-22 17:55:47 +02:00
|
|
|
color: Theme.palette.indirectColor1
|
2022-03-18 15:47:51 +01:00
|
|
|
}
|
2024-01-15 10:19:25 +01:00
|
|
|
Padding {}
|
2022-06-27 15:41:47 +02:00
|
|
|
}
|
2023-04-24 20:35:34 +02:00
|
|
|
|
|
|
|
delegate: WalletAccountListItem {
|
|
|
|
width: ListView.view.width
|
|
|
|
modelData: model
|
2023-07-21 10:41:24 +02:00
|
|
|
getNetworkShortNames: root.getNetworkShortNames
|
2024-05-15 23:22:13 +02:00
|
|
|
formatCurrencyAmount: root.formatCurrencyAmount
|
2023-04-24 20:35:34 +02:00
|
|
|
color: sensor.containsMouse || highlighted ?
|
|
|
|
Theme.palette.baseColor2 :
|
2024-05-15 23:22:13 +02:00
|
|
|
!!selectedAccount && selectedAccount.name === model.name ? Theme.palette.statusListItem.highlightColor : "transparent"
|
2022-06-27 15:41:47 +02:00
|
|
|
onClicked: {
|
2023-04-24 20:35:34 +02:00
|
|
|
selectedIndex = index
|
|
|
|
control.popup.close()
|
2022-03-18 15:47:51 +01:00
|
|
|
}
|
2023-05-04 14:55:39 +02:00
|
|
|
Component.onCompleted:{
|
2024-05-15 23:22:13 +02:00
|
|
|
if(!!selectedAccount && selectedAccount.address === model.address)
|
2023-05-04 14:55:39 +02:00
|
|
|
selectedIndex = index
|
|
|
|
}
|
2022-03-18 15:47:51 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|