2024-09-18 10:19:08 +02:00
|
|
|
import QtQuick 2.15
|
|
|
|
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared 1.0
|
|
|
|
import shared.panels 1.0
|
2021-10-01 18:58:36 +03:00
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
|
2022-03-09 11:27:32 +01:00
|
|
|
import StatusQ.Components 0.1
|
2022-04-07 21:02:54 +02:00
|
|
|
import StatusQ.Core.Theme 0.1
|
2022-03-09 11:27:32 +01:00
|
|
|
|
2021-10-01 18:58:36 +03:00
|
|
|
Loader {
|
|
|
|
id: root
|
2022-03-09 11:27:32 +01:00
|
|
|
|
2022-08-10 17:04:56 +03:00
|
|
|
property int imageHeight: 44
|
|
|
|
property int imageWidth: 44
|
2022-03-09 11:27:32 +01:00
|
|
|
|
|
|
|
property string name
|
2022-03-30 17:30:28 +02:00
|
|
|
property string image
|
2024-01-05 16:34:20 +01:00
|
|
|
property bool showRing: !ensVerified && !root.isBridgedAccount
|
2022-03-09 11:27:32 +01:00
|
|
|
property bool interactive: true
|
2022-09-15 09:31:38 +02:00
|
|
|
property bool disabled: false
|
2022-12-01 11:24:25 +01:00
|
|
|
property bool ensVerified: false
|
2023-04-06 10:56:50 +03:00
|
|
|
property bool loading: false
|
2024-01-05 16:34:20 +01:00
|
|
|
property bool isBridgedAccount: false
|
2024-02-09 16:52:28 +01:00
|
|
|
property int onlineStatus: Constants.onlineStatus.unknown
|
2022-03-09 11:27:32 +01:00
|
|
|
|
2024-11-06 21:08:22 +01:00
|
|
|
property int colorId
|
|
|
|
property var colorHash: []
|
2022-04-07 21:02:54 +02:00
|
|
|
|
2022-03-09 11:27:32 +01:00
|
|
|
signal clicked()
|
|
|
|
|
|
|
|
sourceComponent: StatusSmartIdenticon {
|
|
|
|
name: root.name
|
2022-08-11 14:55:08 +03:00
|
|
|
asset {
|
2022-03-09 11:27:32 +01:00
|
|
|
width: root.imageWidth
|
|
|
|
height: root.imageHeight
|
2022-12-01 11:24:25 +01:00
|
|
|
color: Utils.colorForColorId(root.colorId)
|
2022-08-11 14:55:08 +03:00
|
|
|
name: root.image
|
|
|
|
isImage: true
|
2022-03-09 11:27:32 +01:00
|
|
|
}
|
|
|
|
ringSettings {
|
2022-04-07 21:02:54 +02:00
|
|
|
ringSpecModel: root.showRing ? root.colorHash : undefined
|
2022-03-09 11:27:32 +01:00
|
|
|
}
|
2023-04-06 10:56:50 +03:00
|
|
|
loading: root.loading
|
2024-02-09 16:52:28 +01:00
|
|
|
|
|
|
|
badge.visible: root.onlineStatus !== Constants.onlineStatus.unknown && !root.isBridgedAccount
|
|
|
|
badge.width: root.imageWidth/4
|
|
|
|
badge.height: root.imageWidth/4
|
|
|
|
badge.border.width: 0.05 * root.imageWidth
|
|
|
|
badge.border.color: Theme.palette.statusBadge.foregroundColor
|
|
|
|
badge.color: {
|
|
|
|
if (root.onlineStatus === Constants.onlineStatus.online)
|
2024-10-15 21:26:12 +02:00
|
|
|
return Theme.palette.successColor1
|
|
|
|
return Theme.palette.baseColor1
|
2024-02-09 16:52:28 +01:00
|
|
|
}
|
|
|
|
badge.anchors.rightMargin: badge.border.width/2
|
|
|
|
badge.anchors.bottomMargin: badge.border.width/2
|
|
|
|
|
2024-01-05 16:34:20 +01:00
|
|
|
bridgeBadge.visible: root.isBridgedAccount
|
2024-10-15 21:26:12 +02:00
|
|
|
bridgeBadge.image.source: Theme.svg("discord-bridge")
|
2022-03-09 11:27:32 +01:00
|
|
|
|
|
|
|
Loader {
|
|
|
|
anchors.fill: parent
|
|
|
|
|
|
|
|
active: root.interactive
|
2021-12-09 13:53:40 +01:00
|
|
|
|
2022-03-09 11:27:32 +01:00
|
|
|
sourceComponent: MouseArea {
|
2022-09-15 09:31:38 +02:00
|
|
|
cursorShape: hoverEnabled ? Qt.PointingHandCursor : Qt.ArrowCursor
|
|
|
|
hoverEnabled: !root.disabled
|
2022-07-21 12:57:41 +02:00
|
|
|
onClicked: {
|
2022-09-15 09:31:38 +02:00
|
|
|
if (!root.disabled) {
|
|
|
|
root.clicked()
|
|
|
|
}
|
2022-07-21 12:57:41 +02:00
|
|
|
}
|
2021-10-01 18:58:36 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|