2019-03-22 14:28:14 +11:00
|
|
|
import QtQuick 2.7
|
|
|
|
import QtQuick.Controls 2.0
|
|
|
|
import QtQuick.Layouts 1.4
|
|
|
|
|
|
|
|
Item {
|
|
|
|
property bool invisible: false
|
2019-03-28 10:21:14 +11:00
|
|
|
property string name: "?"
|
2019-03-22 14:28:14 +11:00
|
|
|
property var imageSource: null
|
|
|
|
property int dimmension: 48
|
|
|
|
|
2019-03-28 10:21:14 +11:00
|
|
|
id: "root"
|
2019-03-22 14:28:14 +11:00
|
|
|
width: dimmension
|
|
|
|
height: invisible ? 1 : dimmension
|
|
|
|
|
|
|
|
Rectangle {
|
2019-03-28 10:21:14 +11:00
|
|
|
id: "letterRectangle"
|
2019-03-22 14:28:14 +11:00
|
|
|
anchors.fill: parent
|
|
|
|
visible: ! invisible && imageSource === null
|
2019-03-28 10:21:14 +11:00
|
|
|
color: Qt.hsla(Backend.hueFromString(name), 0.22, 0.5, 1)
|
2019-03-22 14:28:14 +11:00
|
|
|
|
2019-03-26 20:52:43 +11:00
|
|
|
HLabel {
|
2019-03-22 14:28:14 +11:00
|
|
|
anchors.centerIn: parent
|
2019-03-28 10:21:14 +11:00
|
|
|
text: name.charAt(0)
|
2019-03-22 14:28:14 +11:00
|
|
|
color: "white"
|
|
|
|
font.pixelSize: letterRectangle.height / 1.4
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Image {
|
2019-03-28 10:21:14 +11:00
|
|
|
id: "avatarImage"
|
2019-03-22 14:28:14 +11:00
|
|
|
anchors.fill: parent
|
|
|
|
visible: ! invisible && imageSource !== null
|
|
|
|
|
|
|
|
Component.onCompleted: if (imageSource) {source = imageSource}
|
|
|
|
asynchronous: true
|
|
|
|
mipmap: true
|
|
|
|
fillMode: Image.PreserveAspectCrop
|
|
|
|
sourceSize.width: root.dimmension
|
|
|
|
}
|
|
|
|
}
|