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