2024-10-15 21:26:12 +02:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQuick.Controls 2.15
|
2021-09-28 18:04:06 +03:00
|
|
|
|
|
|
|
import utils 1.0
|
2020-06-03 16:50:59 -04:00
|
|
|
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared 1.0
|
|
|
|
import shared.panels 1.0
|
|
|
|
import shared.status 1.0
|
2022-04-07 21:02:54 +02:00
|
|
|
import shared.controls.chat 1.0
|
2021-10-12 20:26:02 +02:00
|
|
|
|
2021-10-25 14:30:23 +02:00
|
|
|
import StatusQ.Controls 0.1 as StatusQControls
|
2021-10-21 00:47:23 +02:00
|
|
|
import StatusQ.Components 0.1
|
2024-10-15 21:26:12 +02:00
|
|
|
import StatusQ.Core.Theme 0.1
|
2021-10-25 14:30:23 +02:00
|
|
|
|
2021-10-14 10:04:15 +02:00
|
|
|
Rectangle {
|
2022-04-01 13:46:32 +02:00
|
|
|
id: root
|
2021-10-12 20:26:02 +02:00
|
|
|
|
2020-06-03 16:50:59 -04:00
|
|
|
property string username: "Jotaro Kujo"
|
2021-07-26 09:17:49 +02:00
|
|
|
property string keyUid: "0x123345677890987654321123456"
|
|
|
|
property string address: ""
|
2022-04-07 21:02:54 +02:00
|
|
|
property var colorHash
|
|
|
|
property int colorId
|
2022-03-30 17:30:28 +02:00
|
|
|
property url image: ""
|
2020-06-04 09:00:17 -04:00
|
|
|
property var onAccountSelect: function() {}
|
2020-06-13 11:17:54 -04:00
|
|
|
property var isSelected: function() {}
|
|
|
|
property bool selected: {
|
2021-10-14 10:04:15 +02:00
|
|
|
return isSelected(index, keyUid)
|
2020-06-13 11:17:54 -04:00
|
|
|
}
|
2020-06-11 17:23:27 -04:00
|
|
|
property bool isHovered: false
|
2020-06-03 16:50:59 -04:00
|
|
|
|
2020-06-11 17:23:27 -04:00
|
|
|
height: 64
|
2020-06-03 16:50:59 -04:00
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.left: parent.left
|
2020-06-11 17:23:27 -04:00
|
|
|
border.width: 0
|
2020-09-29 16:39:29 +10:00
|
|
|
color: getBgColor()
|
2024-10-15 21:26:12 +02:00
|
|
|
radius: Theme.radius
|
2020-06-03 16:50:59 -04:00
|
|
|
|
2020-09-29 16:39:29 +10:00
|
|
|
function getBgColor() {
|
2024-10-15 21:26:12 +02:00
|
|
|
if (selected) return Theme.palette.secondaryBackground
|
|
|
|
if (isHovered) return Theme.palette.backgroundHover
|
|
|
|
return Theme.palette.transparent
|
2020-09-29 16:39:29 +10:00
|
|
|
}
|
|
|
|
|
2022-04-07 21:02:54 +02:00
|
|
|
UserImage {
|
2020-06-11 17:23:27 -04:00
|
|
|
id: accountImage
|
2022-04-07 21:02:54 +02:00
|
|
|
|
2020-06-11 17:23:27 -04:00
|
|
|
anchors.left: parent.left
|
2024-10-15 21:26:12 +02:00
|
|
|
anchors.leftMargin: Theme.padding
|
2020-06-11 17:23:27 -04:00
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
2022-04-07 21:02:54 +02:00
|
|
|
|
2022-04-01 13:46:32 +02:00
|
|
|
name: root.username
|
2022-04-07 21:02:54 +02:00
|
|
|
image: root.image
|
|
|
|
colorId: root.colorId
|
|
|
|
colorHash: root.colorHash
|
2020-06-11 17:23:27 -04:00
|
|
|
}
|
2021-10-21 00:47:23 +02:00
|
|
|
|
2020-06-19 14:06:58 -04:00
|
|
|
StyledText {
|
2020-06-11 17:23:27 -04:00
|
|
|
id: usernameText
|
|
|
|
text: username
|
2020-06-13 11:17:54 -04:00
|
|
|
elide: Text.ElideRight
|
|
|
|
anchors.right: parent.right
|
2024-10-15 21:26:12 +02:00
|
|
|
anchors.rightMargin: Theme.padding + radio.width
|
2020-06-11 17:23:27 -04:00
|
|
|
font.pixelSize: 17
|
|
|
|
anchors.top: accountImage.top
|
|
|
|
anchors.left: accountImage.right
|
2024-10-15 21:26:12 +02:00
|
|
|
anchors.leftMargin: Theme.padding
|
2020-06-11 17:23:27 -04:00
|
|
|
}
|
|
|
|
|
2020-06-19 14:06:58 -04:00
|
|
|
StyledText {
|
2020-06-11 17:23:27 -04:00
|
|
|
id: addressText
|
|
|
|
width: 108
|
|
|
|
text: address
|
2024-10-15 21:26:12 +02:00
|
|
|
font.family: Theme.monoFont.name
|
2020-06-11 17:23:27 -04:00
|
|
|
elide: Text.ElideMiddle
|
|
|
|
anchors.bottom: accountImage.bottom
|
|
|
|
anchors.bottomMargin: 0
|
|
|
|
anchors.left: usernameText.left
|
|
|
|
anchors.leftMargin: 0
|
|
|
|
font.pixelSize: 15
|
2024-10-15 21:26:12 +02:00
|
|
|
color: Theme.palette.secondaryText
|
2020-06-11 17:23:27 -04:00
|
|
|
}
|
|
|
|
|
2021-10-25 14:30:23 +02:00
|
|
|
StatusQControls.StatusRadioButton {
|
2020-09-29 16:39:29 +10:00
|
|
|
id: radio
|
|
|
|
anchors.right: parent.right
|
2024-10-15 21:26:12 +02:00
|
|
|
anchors.rightMargin: Theme.padding
|
2020-09-29 16:39:29 +10:00
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
2022-04-01 13:46:32 +02:00
|
|
|
checked: root.selected
|
2020-09-29 16:39:29 +10:00
|
|
|
}
|
|
|
|
|
2020-06-11 17:23:27 -04:00
|
|
|
MouseArea {
|
|
|
|
hoverEnabled: true
|
|
|
|
anchors.fill: parent
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
onClicked: {
|
2021-10-14 10:04:15 +02:00
|
|
|
onAccountSelect(index)
|
2020-06-03 16:50:59 -04:00
|
|
|
}
|
2020-06-11 17:23:27 -04:00
|
|
|
onEntered: {
|
2022-04-01 13:46:32 +02:00
|
|
|
root.isHovered = true
|
2020-06-03 16:50:59 -04:00
|
|
|
}
|
2020-06-11 17:23:27 -04:00
|
|
|
onExited: {
|
2022-04-01 13:46:32 +02:00
|
|
|
root.isHovered = false
|
2020-06-03 16:50:59 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|