fixes: generic VariantList FriendModel resetAddresses check null default account address list update on save generic item for white background lists ui fix set photo friend protect friendmodel setters remove main splitview to stick to the mock-up (keeping it commented cause it may be useful to be able to resize the panels) default image avatar fix crash when address not set
118 lines
2.9 KiB
QML
118 lines
2.9 KiB
QML
import QtQuick 2.7
|
|
import QtQuick.Layouts 1.3
|
|
import QtQuick.Controls 2.2
|
|
import QtQuick.Effects
|
|
|
|
import Linphone
|
|
import UtilsCpp
|
|
|
|
// Fill contact, account or call
|
|
// Initials will be displayed if there isn't any avatar.
|
|
// TODO : get FriendGui from Call.
|
|
|
|
StackView {
|
|
id: mainItem
|
|
property AccountGui account: null
|
|
property FriendGui contact: null
|
|
property CallGui call: null
|
|
property string address: account
|
|
? account.core.identityAddress
|
|
: call
|
|
? call.core.peerAddress
|
|
: contact
|
|
? contact.core.defaultAddress
|
|
: ''
|
|
property var displayNameObj: UtilsCpp.getDisplayName(address)
|
|
property string displayNameVal: displayNameObj ? displayNameObj.value : ""
|
|
property bool haveAvatar: (account && account.core.pictureUri )
|
|
|| (contact && contact.core.pictureUri)
|
|
|
|
onHaveAvatarChanged: replace(haveAvatar ? avatar : initials, StackView.Immediate)
|
|
|
|
property bool secured: false
|
|
|
|
initialItem: haveAvatar ? avatar : initials
|
|
|
|
Rectangle {
|
|
visible: mainItem.secured
|
|
anchors.fill: mainItem.currentItem
|
|
radius: mainItem.width / 2
|
|
z: 1
|
|
color: "transparent"
|
|
border {
|
|
width: 3 * DefaultStyle.dp
|
|
color: DefaultStyle.info_500_main
|
|
}
|
|
Image {
|
|
source: AppIcons.trusted
|
|
x: mainItem.width / 7
|
|
width: mainItem.width / 4.5
|
|
height: width
|
|
sourceSize.width: width
|
|
sourceSize.height: height
|
|
fillMode: Image.PreserveAspectFit
|
|
anchors.bottom: parent.bottom
|
|
}
|
|
}
|
|
Component{
|
|
id: initials
|
|
Rectangle {
|
|
id: initialItem
|
|
property string initials: UtilsCpp.getInitials(mainItem.displayNameVal)
|
|
radius: width / 2
|
|
color: DefaultStyle.main2_200
|
|
height: mainItem.height
|
|
width: height
|
|
Text {
|
|
anchors.fill: parent
|
|
anchors.centerIn: parent
|
|
verticalAlignment: Text.AlignVCenter
|
|
horizontalAlignment: Text.AlignHCenter
|
|
text: initialItem.initials
|
|
font {
|
|
pixelSize: initialItem.height * 36 / 120
|
|
weight: 800 * DefaultStyle.dp
|
|
capitalization: Font.AllUppercase
|
|
}
|
|
}
|
|
Image {
|
|
visible: initialItem.initials.length === 0
|
|
width: mainItem.width/3
|
|
height: width
|
|
source: AppIcons.profile
|
|
anchors.centerIn: parent
|
|
}
|
|
}
|
|
}
|
|
Component{
|
|
id: avatar
|
|
Item {
|
|
id: avatarItem
|
|
height: mainItem.height
|
|
width: height
|
|
|
|
Image {
|
|
id: image
|
|
visible: false
|
|
width: parent.width
|
|
height: parent.height
|
|
sourceSize.width: avatarItem.width
|
|
sourceSize.height: avatarItem.height
|
|
fillMode: Image.PreserveAspectCrop
|
|
anchors.centerIn: parent
|
|
source: mainItem.account && mainItem.account.core.pictureUri
|
|
|| mainItem.contact && mainItem.contact.core.pictureUri
|
|
|| ""
|
|
mipmap: true
|
|
}
|
|
ShaderEffect {
|
|
id: roundEffect
|
|
property variant src: image
|
|
property double edge: 0.9
|
|
anchors.fill: parent
|
|
vertexShader: 'qrc:/data/shaders/roundEffect.vert.qsb'
|
|
fragmentShader: 'qrc:/data/shaders/roundEffect.frag.qsb'
|
|
}
|
|
}
|
|
}
|
|
}
|