moment/harmonyqml/components/base/Avatar.qml

41 lines
1008 B
QML
Raw Normal View History

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
property string name: "?"
2019-03-22 14:28:14 +11:00
property var imageSource: null
property int dimmension: 48
id: "root"
2019-03-22 14:28:14 +11:00
width: dimmension
height: invisible ? 1 : dimmension
Rectangle {
id: "letterRectangle"
2019-03-22 14:28:14 +11:00
anchors.fill: parent
visible: ! invisible && imageSource === null
color: Qt.hsla(Backend.hueFromString(name), 0.22, 0.5, 1)
2019-03-22 14:28:14 +11:00
HLabel {
2019-03-22 14:28:14 +11:00
anchors.centerIn: parent
text: name.charAt(0)
2019-03-22 14:28:14 +11:00
color: "white"
font.pixelSize: letterRectangle.height / 1.4
}
}
Image {
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
}
}