import QtQuick 2.14 import QtQml.Models 2.14 import QtQuick.Controls 2.14 import StatusQ.Core 0.1 import StatusQ.Core.Theme 0.1 import StatusQ.Core.Utils 0.1 import StatusQ.Components 0.1 import StatusQ.Controls 0.1 import utils 1.0 StatusListItem { id: root property bool displayChevronComponent: true property string keycardName: "" property string keycardUid: "" property bool keycardLocked: false property int keyPairType: Constants.keycard.keyPairType.unknown property string keyPairIcon: "" property string keyPairImage: "" property string keyPairAccounts: "" signal keycardSelected() color: root.keycardLocked? Theme.palette.dangerColor3 : Theme.palette.baseColor2 title: root.keycardName statusListItemTitleAside.textFormat: Text.RichText statusListItemTitleAside.visible: !!statusListItemTitleAside.text statusListItemTitleAside.text: { let t = "" if (root.keyPairType === Constants.keycard.keyPairType.profile) { t = Utils.getElidedCompressedPk(d.myPublicKey) } if (root.keycardLocked) { let label = qsTr("Keycard Locked") t += ` ${label}` } return t } statusListItemSubTitle.text: !!root.keycardUid? "(%1)".arg(root.keycardUid) : "" statusListItemSubTitle.font.pixelSize: 10 statusListItemSubTitle.visible: !!statusListItemSubTitle.text asset { width: root.keyPairIcon? 24 : 40 height: root.keyPairIcon? 24 : 40 name: root.keyPairImage? root.keyPairImage : root.keyPairIcon isImage: !!root.keyPairImage color: root.keyPairType === Constants.keycard.keyPairType.profile? Utils.colorForPubkey(d.myPublicKey) : root.keycardLocked? Theme.palette.dangerColor1 : Theme.palette.primaryColor1 letterSize: Math.max(4, asset.width / 2.4) charactersLen: 2 isLetterIdenticon: !root.keyPairIcon && !asset.name.toString() bgColor: root.keycardLocked? Theme.palette.dangerColor3 : Theme.palette.primaryColor3 } ringSettings { ringSpecModel: root.keyPairType === Constants.keycard.keyPairType.profile? Utils.getColorHashAsJson(d.myPublicKey) : [] ringPxSize: Math.max(asset.width / 24.0) } tagsModel: ListModel{} tagsDelegate: StatusListItemTag { color: model.color height: Style.current.bigPadding radius: 6 closeButtonVisible: false asset { emoji: model.emoji emojiSize: Emoji.size.verySmall isLetterIdenticon: !!model.emoji name: model.icon color: Theme.palette.indirectColor1 width: 16 height: 16 } title: model.name titleText.font.pixelSize: 12 titleText.color: Theme.palette.indirectColor1 } components: [ StatusIcon { visible: root.displayChevronComponent icon: "tiny/chevron-right" color: Theme.palette.baseColor1 } ] onClicked: { root.keycardSelected() } onKeyPairAccountsChanged: { tagsModel.clear() if (root.keyPairAccounts === "") { // should never be here, as it's not possible to have keypair item without at least a single account console.warn("accounts list is empty for selecting keycard pair") return } let obj = JSON.parse(root.keyPairAccounts) if (obj.error) { console.warn("error parsing accounts for selecting keycard pair, error: ", obj.error) return } for (var i=0; i