From c0f825c69001289d3993a34346ce9050b47f4f91 Mon Sep 17 00:00:00 2001
From: Noelia <97019400+noeliaSD@users.noreply.github.com>
Date: Wed, 16 Feb 2022 11:37:48 +0100
Subject: [PATCH] feat(StatusContactVerificationIcons): Create new row control
that includes mutual connect and trust indicator icons (#559)
Create `StatusContactVerificationIcons` row component.
Refactor in `StatusMemberListItem`. It now uses `StatusContactVerificationIcons` component.
Refactor in `StatusListItem`. It now contains a Loader for dynamically decide if a row icons component is defined aside the title.
Refactor in `StatusMessageHeader` and `StatusMessage`. They now use `StatusContactVerificationIcons` component.
Closes #542
BREAKING CHANGES:
Removed `titleIcon1Visible` and `titleIcon1Visible` from `StatusListItem`.
Removed `ContactType` enumeration in `StatusMessage`. Now, contact verification type is managed by enum `TrustedType` in `StatusContactVerificationIcons` component.
---
sandbox/controls/ListItems.qml | 4 +-
sandbox/demoapp/ChatChannelView.qml | 3 +-
sandbox/demoapp/data/Models.qml | 50 +++++++-----
.../StatusContactVerificationIcons.qml | 79 +++++++++++++++++++
src/StatusQ/Components/StatusListItem.qml | 76 ++++--------------
.../Components/StatusMemberListItem.qml | 25 ++----
src/StatusQ/Components/StatusMessage.qml | 15 +---
.../Components/StatusMessageDetails.qml | 5 +-
.../statusMessage/StatusMessageHeader.qml | 60 ++------------
src/StatusQ/Components/qmldir | 1 +
statusq.qrc | 1 +
11 files changed, 149 insertions(+), 170 deletions(-)
create mode 100644 src/StatusQ/Components/StatusContactVerificationIcons.qml
diff --git a/sandbox/controls/ListItems.qml b/sandbox/controls/ListItems.qml
index 8e6ee0e0..8cbe8556 100644
--- a/sandbox/controls/ListItems.qml
+++ b/sandbox/controls/ListItems.qml
@@ -351,7 +351,7 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
nickName: "This is an example"
userName: "annabelle"
chatKey: "0x043a7ed0e8752236a4688563652fd0296453cef00a5dcddbe252dc74f72cc1caa97a2b65e4a1a52d9c30a84c9966beaaaf6b333d659cbdd2e486b443ed1012cf04"
- trustIndicator: StatusMemberListItem.TrustedType.Verified
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Verified
isMutualContact: true
image.source: "
nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2ImYgiNITTlTdG1nUZ5a92VITQxITFiJmIIjSE0htAYQrMHAAD//+wwFVpz+yqXAAAAAElFTkSuQmCC"
@@ -362,7 +362,7 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
StatusMemberListItem {
nickName: "carmen.eth"
isOnline: false
- trustIndicator: StatusMemberListItem.TrustedType.Untrustworthy
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Untrustworthy
}
StatusMemberListItem {
diff --git a/sandbox/demoapp/ChatChannelView.qml b/sandbox/demoapp/ChatChannelView.qml
index 25f41203..1ac163a0 100644
--- a/sandbox/demoapp/ChatChannelView.qml
+++ b/sandbox/demoapp/ChatChannelView.qml
@@ -41,7 +41,8 @@ ListView {
}
messageText: model.message
hasMention: model.hasMention
- contactType: model.contactType
+ isMutualContact: model.isMutualContact
+ trustIndicator: model.trustIndicator
isPinned: model.isPinned
pinnedBy: model.pinnedBy
hasExpired: model.hasExpired
diff --git a/sandbox/demoapp/data/Models.qml b/sandbox/demoapp/data/Models.qml
index 2ee36aba..09689de9 100644
--- a/sandbox/demoapp/data/Models.qml
+++ b/sandbox/demoapp/data/Models.qml
@@ -497,7 +497,8 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2ImYgiNITTlTdG1nUZ5a92VITQxITFiJmIIjSE0htAYQrMHAAD//+wwFVpz+yqXAAAAAElFTkSuQmCC"
isIdenticon: true
chatKey: "0x04d1bed19c523299cbd07ddec7b8949ad7dd923819a68e0b733c9c0bc38cde276bd256f098e755f8f028395c2c91f438a22adaff6caded060b7cc0ef3f470f5789"
- contactType: 2
+ isMutualContact: true
+ trustIndicator: StatusContactVerificationIcons.TrustedType.None
hasMention: false
editMode: false
isReply: false
@@ -525,7 +526,8 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2ImYgiNITTlTdG1nUZ5a92VITQxITFiJmIIjSE0htAYQrMHAAD//+wwFVpz+yqXAAAAAElFTkSuQmCC"
isIdenticon: true
chatKey: "0x04d1bed19c523299cbd07ddec7b8949ad7dd923819a68e0b733c9c0bc38cde276bd256f098e755f8f028395c2c91f438a22adaff6caded060b7cc0ef3f470f2333"
- contactType: 3
+ isMutualContact: true
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Verified
hasMention: false
editMode: false
isReply: false
@@ -552,7 +554,8 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
profileImage: ""
isIdenticon: true
chatKey: "0x04d1bed19c523299cbd07ddec7b8949ad7dd923819a68e0b733c9c0bc38cde276bd256f098e755f8f028395c2c91f438a22adaff6caded060b7cc0ef3f470f2333"
- contactType: 3
+ isMutualContact: true
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Verified
hasMention: false
editMode: false
isReply: false
@@ -579,7 +582,8 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
profileImage: ""
isIdenticon: true
chatKey: "0x04d1bed19c523299cbd07ddec7b8949ad7dd923819a68e0b733c9c0bc38cde276bd256f098e755f8f028395c2c91f438a22adaff6caded060b7cc0ef3f470f6789"
- contactType: 4
+ isMutualContact: false
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Untrustworthy
hasMention: false
editMode: false
isReply: false
@@ -607,7 +611,8 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
profileImage: ""
isIdenticon: true
chatKey: "0x04d1bed19c523299cbd07ddec7b8949ad7dd923819a68e0b733c9c0bc38cde276bd256f098e755f8f028395c2c91f438a22adaff6caded060b7cc0ef3f470f1234"
- contactType: 0
+ isMutualContact: true
+ trustIndicator: StatusContactVerificationIcons.TrustedType.None
hasMention: false
editMode: false
isReply: false
@@ -635,7 +640,8 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
profileImage: ""
isIdenticon: true
chatKey: "0x04d1bed19c523299cbd07ddec7b8949ad7dd923819a68e0b733c9c0bc38cde276bd256f098e755f8f028395c2c91f438a22adaff6caded060b7cc0ef3f470f1234"
- contactType: 0
+ isMutualContact: false
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Untrustworthy
hasMention: false
editMode: false
isReply: false
@@ -663,7 +669,8 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
profileImage: ""
isIdenticon: true
chatKey: "0x04d1bed19c523299cbd07ddec7b8949ad7dd923819a68e0b733c9c0bc38cde276bd256f098e755f8f028395c2c91f438a22adaff6caded060b7cc0ef3f470f1234"
- contactType: 0
+ isMutualContact: false
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Untrustworthy
hasMention: true
editMode: false
isReply: false
@@ -692,7 +699,8 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
profileImage: ""
isIdenticon: true
chatKey: "0x04d1bed19c523299cbd07ddec7b8949ad7dd923819a68e0b733c9c0bc38cde276bd256f098e755f8f028395c2c91f438a22adaff6caded060b7cc0ef3f470f1234"
- contactType: 0
+ isMutualContact: false
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Untrustworthy
hasMention: false
editMode: false
isReply: true
@@ -721,7 +729,8 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
profileImage: ""
isIdenticon: true
chatKey: "0x04d1bed19c523299cbd07ddec7b8949ad7dd923819a68e0b733c9c0bc38cde276bd256f098e755f8f028395c2c91f438a22adaff6caded060b7cc0ef3f470f1234"
- contactType: 0
+ isMutualContact: false
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Untrustworthy
hasMention: false
editMode: false
isReply: true
@@ -750,7 +759,8 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
profileImage: ""
isIdenticon: true
chatKey: "0x04d1bed19c523299cbd07ddec7b8949ad7dd923819a68e0b733c9c0bc38cde276bd256f098e755f8f028395c2c91f438a22adaff6caded060b7cc0ef3f470f1234"
- contactType: 0
+ isMutualContact: false
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Untrustworthy
hasMention: false
editMode: false
isReply: true
@@ -779,7 +789,8 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
profileImage: ""
isIdenticon: true
chatKey: "0x04d1bed19c523299cbd07ddec7b8949ad7dd923819a68e0b733c9c0bc38cde276bd256f098e755f8f028395c2c91f438a22adaff6caded060b7cc0ef3f470f1234"
- contactType: 0
+ isMutualContact: false
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Untrustworthy
hasMention: false
editMode: false
isReply: true
@@ -807,7 +818,8 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
profileImage: ""
isIdenticon: true
chatKey: "0x04d1bed19c523299cbd07ddec7b8949ad7dd923819a68e0b733c9c0bc38cde276bd256f098e755f8f028395c2c91f438a22adaff6caded060b7cc0ef3f470f1234"
- contactType: 0
+ isMutualContact: false
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Verified
hasMention: false
editMode: false
isReply: false
@@ -834,7 +846,8 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
profileImage: ""
isIdenticon: true
chatKey: "0x04d1bed19c523299cbd07ddec7b8949ad7dd923819a68e0b733c9c0bc38cde276bd256f098e755f8f028395c2c91f438a22adaff6caded060b7cc0ef3f470f1234"
- contactType: 0
+ isMutualContact: true
+ trustIndicator: StatusContactVerificationIcons.TrustedType.None
hasMention: false
editMode: false
isReply: false
@@ -861,7 +874,8 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
profileImage: ""
isIdenticon: true
chatKey: "0x04d1bed19c523299cbd07ddec7b8949ad7dd923819a68e0b733c9c0bc38cde276bd256f098e755f8f028395c2c91f438a22adaff6caded060b7cc0ef3f470f1234"
- contactType: 0
+ isMutualContact: true
+ trustIndicator: StatusContactVerificationIcons.TrustedType.None
hasMention: false
editMode: false
isReply: false
@@ -883,7 +897,7 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
nickName: "This is an example"
userName: "annabelle"
chatKey: "0x043a7ed0e8752236a4688563652fd0296453cef00a5dcddbe252dc74f72cc1caa97a2b65e4a1a52d9c30a84c9966beaaaf6b333d659cbdd2e486b443ed1012cf04"
- trustIndicator: StatusMemberListItem.TrustedType.Verified
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Verified
isMutualContact: true
isOnline: true
source: "
@@ -894,7 +908,7 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
nickName: "carmen.eth"
userName: ""
chatKey: ""
- trustIndicator: StatusMemberListItem.TrustedType.Untrustworthy
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Untrustworthy
isMutualContact: false
isOnline: false
source: ""
@@ -904,7 +918,7 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
nickName: "This girl I know from work"
userName: "annabelle"
chatKey: ""
- trustIndicator: StatusMemberListItem.TrustedType.None
+ trustIndicator: StatusContactVerificationIcons.TrustedType.None
isMutualContact: false
isOnline: true
source: "
@@ -915,7 +929,7 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
nickName: "Mark Cuban"
userName: "annabelle"
chatKey: "0x043a7ed0e8752236a4688563652fd0296453cef00a5dcddbe252dc74f72cc1caa97a2b65e4a1a52d9c30a84c9966beaaaf6b333d659cbdd2e486b443ed1012cf04"
- trustIndicator: StatusMemberListItem.TrustedType.Untrustworthy
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Untrustworthy
isMutualContact: true
isOnline: false
source: "
diff --git a/src/StatusQ/Components/StatusContactVerificationIcons.qml b/src/StatusQ/Components/StatusContactVerificationIcons.qml
new file mode 100644
index 00000000..25418531
--- /dev/null
+++ b/src/StatusQ/Components/StatusContactVerificationIcons.qml
@@ -0,0 +1,79 @@
+import QtQuick 2.0
+
+import StatusQ.Core 0.1
+import StatusQ.Core.Theme 0.1
+
+Row {
+ id: root
+
+ property bool isMutualContact: false
+ property var trustIndicator: StatusContactVerificationIcons.TrustedType.None
+
+ property StatusIconSettings mutualConnectionIcon: StatusIconSettings {
+ name: "tiny/tiny-contact"
+ color: Theme.palette.indirectColor1
+ width: dummyImage.width
+ height: dummyImage.height
+ background: StatusIconBackgroundSettings {
+ width: 10
+ height: 10
+ color: Theme.palette.primaryColor1
+ }
+ // Only used to get implicit width and height from the actual image
+ property Image dummyImage: Image {
+ source: mutualConnectionIcon.name ? "../../assets/img/icons/" + mutualConnectionIcon.name + ".svg": ""
+ visible: false
+ }
+ }
+
+ property StatusIconSettings trustContactIcon: StatusIconSettings {
+ // None and Untrustworthy types, same aspect (Icon will not be visible in case of None type):
+ name: root.trustIndicator === StatusContactVerificationIcons.TrustedType.Verified ? "tiny/tiny-checkmark" : "tiny/subtract"
+ color: Theme.palette.indirectColor1
+ width: dummyImage.width
+ height: dummyImage.height
+ background: StatusIconBackgroundSettings {
+ width: 10
+ height: 10
+ color: root.trustIndicator === StatusContactVerificationIcons.TrustedType.Verified ? Theme.palette.primaryColor1 : Theme.palette.dangerColor1
+ }
+ // Only used to get implicit width and height from the actual image
+ property Image dummyImage: Image {
+ source: trustContactIcon.name ? "../../assets/img/icons/" + trustContactIcon.name + ".svg": ""
+ visible: false
+ }
+ }
+
+ enum TrustedType {
+ None, //0
+ Verified, //1
+ Untrustworthy //2
+ }
+
+ spacing: 4
+ visible: root.isMutualContact || (root.trustIndicator !== StatusContactVerificationIcons.TrustedType.None)
+
+ StatusRoundIcon {
+ visible: root.isMutualContact
+ icon.name: root.mutualConnectionIcon.name
+ icon.width: root.mutualConnectionIcon.width
+ icon.height: root.mutualConnectionIcon.height
+ icon.rotation: root.mutualConnectionIcon.rotation
+ icon.color: root.mutualConnectionIcon.color
+ icon.background.color: root.mutualConnectionIcon.background.color
+ icon.background.width: root.mutualConnectionIcon.background.width
+ icon.background.height: root.mutualConnectionIcon.background.height
+ }
+
+ StatusRoundIcon {
+ visible: root.trustIndicator !== StatusContactVerificationIcons.TrustedType.None
+ icon.name: root.trustContactIcon.name
+ icon.width: root.trustContactIcon.width
+ icon.height: root.trustContactIcon.height
+ icon.rotation: root.trustContactIcon.rotation
+ icon.color: root.trustContactIcon.color
+ icon.background.color: root.trustContactIcon.background.color
+ icon.background.width: root.trustContactIcon.background.width
+ icon.background.height: root.trustContactIcon.background.height
+ }
+ }
diff --git a/src/StatusQ/Components/StatusListItem.qml b/src/StatusQ/Components/StatusListItem.qml
index f5358ef0..5788b66c 100644
--- a/src/StatusQ/Components/StatusListItem.qml
+++ b/src/StatusQ/Components/StatusListItem.qml
@@ -13,8 +13,6 @@ Rectangle {
property string titleId: ""
property string title: ""
property string titleAsideText: ""
- property bool titleIcon1Visible
- property bool titleIcon2Visible
property string subTitle: ""
property string tertiaryTitle: ""
property string label: ""
@@ -52,38 +50,13 @@ Rectangle {
height: 40
isIdenticon: false
}
- property StatusIconSettings titleIcon1: StatusIconSettings {
- width: dummyImage.width
- height: dummyImage.height
- background: StatusIconBackgroundSettings {
- width: 10
- height: 10
- }
- // Only used to get implicit width and height from the actual image
- property Image dummyImage: Image {
- source: titleIcon1.name ? "../../assets/img/icons/" + titleIcon1.name + ".svg": ""
- visible: false
- }
- }
- property StatusIconSettings titleIcon2: StatusIconSettings {
- width: dummyImage.width
- height: dummyImage.height
- background: StatusIconBackgroundSettings {
- width: 10
- height: 10
- }
- // Only used to get implicit width and height from the actual image
- property Image dummyImage: Image {
- source: titleIcon2.name ? "../../assets/img/icons/" + titleIcon2.name + ".svg": ""
- visible: false
- }
- }
property alias sensor: sensor
property alias badge: statusListItemBadge
property alias statusListItemIcon: iconOrImage
property alias statusListItemTitle: statusListItemTitle
property alias statusListItemTitleAside: statusListItemTitleAsideText
+ property alias statusListItemTitleIcons: titleIconsRow
property alias statusListItemTitleArea: statusListItemTitleArea
property alias statusListItemSubTitle: statusListItemSubTitle
property alias statusListItemTertiaryTitle: statusListItemTertiaryTitle
@@ -154,9 +127,17 @@ Rectangle {
Item {
id: statusListItemTitleArea
+
+ function getStatusListItemTitleAnchorsRight() {
+ let isIconsRowVisible = false
+ if(titleIconsRow.item) {
+ isIconsRowVisible = true//titleIconsRow.item.visible
+ }
+ return !statusListItem.titleAsideText && !isIconsRowVisible ? statusListItemTitleArea.right : undefined
+ }
+
anchors.left: iconOrImage.active ? iconOrImage.right : parent.left
- anchors.right: statusListItemLabel.visible ?
- statusListItemLabel.left : statusListItemComponentsSlot.left
+ anchors.right: statusListItemLabel.visible ? statusListItemLabel.left : statusListItemComponentsSlot.left
anchors.leftMargin: statusListItem.leftPadding
anchors.rightMargin: statusListItem.rightPadding
anchors.verticalCenter: parent.verticalCenter
@@ -169,8 +150,7 @@ Rectangle {
height: visible ? contentHeight : 0
wrapMode: Text.WrapAtWordBoundaryOrAnywhere
anchors.left: parent.left
- anchors.right: !statusListItem.titleAsideText && !statusListItem.titleIcon1Visible && !statusListItem.titleIcon2Visible
- ? parent.right : undefined
+ anchors.right: !statusListItem.titleAsideText && !titleIconsRow.sourceComponent ? parent.right : undefined
color: {
if (!statusListItem.enabled) {
return Theme.palette.baseColor1
@@ -208,37 +188,12 @@ Rectangle {
visible: !!statusListItem.titleAsideText
}
- Row {
+ Loader {
id: titleIconsRow
- spacing: 4
anchors.left: !statusListItem.titleAsideText ? statusListItemTitle.right : statusListItemTitleAsideText.right
anchors.verticalCenter: statusListItemTitle.verticalCenter
- anchors.leftMargin: titleIconsRow.spacing
-
- StatusRoundIcon {
- visible: statusListItem.titleIcon1Visible
- icon.name: statusListItem.titleIcon1.name
- icon.width: statusListItem.titleIcon1.width
- icon.height: statusListItem.titleIcon1.height
- icon.rotation: statusListItem.titleIcon1.rotation
- icon.color: statusListItem.titleIcon1.color
- icon.background.color: statusListItem.titleIcon1.background.color
- icon.background.width: statusListItem.titleIcon1.background.width
- icon.background.height: statusListItem.titleIcon1.background.height
- }
-
- StatusRoundIcon {
- visible: statusListItem.titleIcon2Visible
- icon.name: statusListItem.titleIcon2.name
- icon.width: statusListItem.titleIcon2.width
- icon.height: statusListItem.titleIcon2.height
- icon.rotation: statusListItem.titleIcon2.rotation
- icon.color: statusListItem.titleIcon2.color
- icon.background.color: statusListItem.titleIcon2.background.color
- icon.background.width: statusListItem.titleIcon2.background.width
- icon.background.height: statusListItem.titleIcon2.background.height
- }
- }
+ anchors.leftMargin: 4
+ }
StatusBaseText {
id: statusListItemSubTitle
@@ -284,7 +239,6 @@ Rectangle {
visible: !!statusListItem.label
}
-
Row {
id: statusListItemComponentsSlot
anchors.right: parent.right
diff --git a/src/StatusQ/Components/StatusMemberListItem.qml b/src/StatusQ/Components/StatusMemberListItem.qml
index 8111ba41..38e9f01b 100644
--- a/src/StatusQ/Components/StatusMemberListItem.qml
+++ b/src/StatusQ/Components/StatusMemberListItem.qml
@@ -10,15 +10,9 @@ StatusListItem {
property string userName: ""
property string chatKey: ""
property bool isMutualContact: false
- property var trustIndicator: StatusMemberListItem.TrustedType.None
+ property var trustIndicator: StatusContactVerificationIcons.TrustedType.None
property bool isOnline: false
- enum TrustedType {
- None, //0
- Verified, //1
- Untrustworthy //2
- }
-
// Subtitle composition:
function composeSubtitile() {
var compose = ""
@@ -42,8 +36,10 @@ StatusListItem {
// root object settings:
title: root.nickName
- titleIcon1Visible: root.isMutualContact
- titleIcon2Visible: root.trustIndicator !== StatusMemberListItem.TrustedType.None
+ statusListItemTitleIcons.sourceComponent: StatusContactVerificationIcons {
+ isMutualContact: root.isMutualContact
+ trustIndicator: root.trustIndicator
+ }
subTitle: composeSubtitile()
statusListItemSubTitle.font.pixelSize: 10
icon.isLetterIdenticon: !root.image.source.toString()
@@ -51,7 +47,7 @@ StatusListItem {
statusListItemIcon.badge.color: root.isOnline ? Theme.palette.successColor1 : Theme.palette.baseColor1
color: sensor.containsMouse ? Theme.palette.baseColor2 : Theme.palette.baseColor4
- // Default sizes/positions by design
+ // Default sizes / positions by design
implicitWidth: 256
implicitHeight: Math.max(56, statusListItemTitleArea.height + leftPadding)
leftPadding: 8
@@ -64,13 +60,4 @@ StatusListItem {
statusListItemIcon.badge.border.width: 2
statusListItemIcon.badge.implicitHeight: 12 // 8 px + 2 px * 2 borders
statusListItemIcon.badge.implicitWidth: 12 // 8 px + 2 px * 2 borders
-
- // Trusted type icons definition:
- titleIcon1.name: "tiny/tiny-contact"
- titleIcon1.color: Theme.palette.indirectColor1
- titleIcon1.background.color: Theme.palette.primaryColor1
- // None and Untrustworthy types, same aspect (Icon will not be visible in case of None type):
- titleIcon2.name: trustIndicator === StatusMemberListItem.TrustedType.Verified ? "tiny/tiny-checkmark" : "tiny/subtract"
- titleIcon2.color: Theme.palette.indirectColor1
- titleIcon2.background.color: trustIndicator === StatusMemberListItem.TrustedType.Verified ? Theme.palette.primaryColor1 : Theme.palette.dangerColor1
}
diff --git a/src/StatusQ/Components/StatusMessage.qml b/src/StatusQ/Components/StatusMessage.qml
index a8be9dc8..c9ba3769 100644
--- a/src/StatusQ/Components/StatusMessage.qml
+++ b/src/StatusQ/Components/StatusMessage.qml
@@ -21,14 +21,6 @@ Rectangle {
Invitation = 7
}
- enum ContactType {
- STANDARD = 0,
- RENAME = 1,
- CONTACT = 2,
- VERIFIED = 3,
- UNTRUSTWORTHY = 4
- }
-
property alias messageHeader: messageHeader
property alias quickActions:quickActionsPanel.quickActions
property alias statusChatInput: editComponent.inputComponent
@@ -108,11 +100,8 @@ Rectangle {
displayName: messageDetails.displayName
secondaryName: messageDetails.secondaryName
tertiaryDetail: messageDetails.chatID
- icon1.name: messageDetails.contactType === StatusMessage.ContactType.CONTACT ? "tiny/tiny-contact" : ""
- icon2.name: messageDetails.contactType === StatusMessage.ContactType.VERIFIED ? "tiny/tiny-checkmark" :
- messageDetails.contactType === StatusMessage.ContactType.UNTRUSTWORTHY ? "tiny/subtract": ""
- icon2.background.color: messageDetails.contactType === StatusMessage.ContactType.UNTRUSTWORTHY ? Theme.palette.dangerColor1 : Theme.palette.primaryColor1
- icon2.color: Theme.palette.indirectColor1
+ isMutualContact: messageDetails.isMutualContact
+ trustIndicator: messageDetails.trustIndicator
resendText: statusMessage.resendText
showResendButton: messageDetails.hasExpired && messageDetails.amISender
onClicked: statusMessage.senderNameClicked()
diff --git a/src/StatusQ/Components/StatusMessageDetails.qml b/src/StatusQ/Components/StatusMessageDetails.qml
index a53c2574..0dca0d2b 100644
--- a/src/StatusQ/Components/StatusMessageDetails.qml
+++ b/src/StatusQ/Components/StatusMessageDetails.qml
@@ -17,12 +17,13 @@ QtObject {
property string messageText: ""
property int contentType: 0
property string messageContent: ""
- property int contactType: 0
+ property bool isMutualContact: false
+ property var trustIndicator: StatusContactVerificationIcons.TrustedType.None
property bool hasMention: false
property bool isPinned: false
property string pinnedBy: ""
property bool hasExpired: false
- property string timestamp: ""
+ property string timestamp: ""
}
diff --git a/src/StatusQ/Components/private/statusMessage/StatusMessageHeader.qml b/src/StatusQ/Components/private/statusMessage/StatusMessageHeader.qml
index 8ecd5235..76c573f2 100644
--- a/src/StatusQ/Components/private/statusMessage/StatusMessageHeader.qml
+++ b/src/StatusQ/Components/private/statusMessage/StatusMessageHeader.qml
@@ -19,38 +19,8 @@ Item {
property string tertiaryDetail: ""
property string resendText: ""
property bool showResendButton: false
- property StatusIconSettings icon1: StatusIconSettings {
- width: dummyImage.width
- height: dummyImage.height
- rotation: 0
- color: Theme.palette.indirectColor1
- background: StatusIconBackgroundSettings {
- width: 10
- height: 10
- color: Theme.palette.primaryColor1
- }
- // only used to get implicit width and height from the actual image
- property Image dummyImage: Image {
- source: icon1.name ? "../../../../assets/img/icons/" + icon1.name + ".svg": ""
- visible: false
- }
- }
- property StatusIconSettings icon2: StatusIconSettings {
- width: dummyImage.width
- height: dummyImage.height
- rotation: 0
- color: Theme.palette.primaryColor1
- background: StatusIconBackgroundSettings {
- width: 10
- height: 10
- color: Theme.palette.indirectColor1
- }
- // only used to get implicit width and height from the actual image
- property Image dummyImage: Image {
- source: icon2.name ? "../../../../assets/img/icons/" + icon2.name + ".svg": ""
- visible: false
- }
- }
+ property bool isMutualContact: false
+ property var trustIndicator: StatusContactVerificationIcons.TrustedType.None
signal clicked()
signal resendClicked()
@@ -83,28 +53,10 @@ Item {
}
}
Layout.alignment: Qt.AlignBottom
- }
- StatusRoundIcon {
- icon.background.width: icon1.background.width
- icon.background.height: icon1.background.height
- icon.background.color: icon1.background.color
- icon.width: icon1.width
- icon.height: icon1.height
- icon.name: icon1.name
- icon.rotation: icon1.rotation
- icon.color: icon1.color
- visible: !!icon.name
- }
- StatusRoundIcon {
- icon.background.width: icon2.background.width
- icon.background.height: icon2.background.height
- icon.background.color: icon2.background.color
- icon.width: icon2.width
- icon.height: icon2.height
- icon.name: icon2.name
- icon.rotation: icon2.rotation
- icon.color: icon2.color
- visible: !!icon.name
+ }
+ StatusContactVerificationIcons {
+ isMutualContact: statusMessageHeader.isMutualContact
+ trustIndicator: statusMessageHeader.trustIndicator
}
StatusBaseText {
id: secondaryDisplayName
diff --git a/src/StatusQ/Components/qmldir b/src/StatusQ/Components/qmldir
index e220f4b4..dfcf6b68 100644
--- a/src/StatusQ/Components/qmldir
+++ b/src/StatusQ/Components/qmldir
@@ -10,6 +10,7 @@ StatusChatListCategoryItem 0.1 StatusChatListCategoryItem.qml
StatusChatListAndCategories 0.1 StatusChatListAndCategories.qml
StatusChatToolBar 0.1 StatusChatToolBar.qml
StatusContactRequestsIndicatorListItem 0.1 StatusContactRequestsIndicatorListItem.qml
+StatusContactVerificationIcons 0.1 StatusContactVerificationIcons.qml
StatusDescriptionListItem 0.1 StatusDescriptionListItem.qml
StatusLetterIdenticon 0.1 StatusLetterIdenticon.qml
StatusListItem 0.1 StatusListItem.qml
diff --git a/statusq.qrc b/statusq.qrc
index f8cb7bc7..e549085d 100644
--- a/statusq.qrc
+++ b/statusq.qrc
@@ -323,5 +323,6 @@
src/StatusQ/Components/StatusTagSelector.qml
src/StatusQ/Components/StatusToastMessage.qml
src/StatusQ/Components/StatusWizardStepper.qml
+ src/StatusQ/Components/StatusContactVerificationIcons.qml