mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-17 01:51:24 +00:00
fac0e50e37
This component introduces `StatusLetterIdenticon`, `StatusImageIdenticon` and `StatusIdenticon`. - `StatusLetterIdenticon` renders an identicon with a single letter based on a name. - `StatusImageIdenticon` renders an actual image based on an identicon URL - `StatusIdenticon` is a composition of the former both, but with a loading mechanism to decide which should be rendered The commit also ensures all of these components are used respectively throughout the application.
178 lines
5.7 KiB
QML
178 lines
5.7 KiB
QML
import QtQuick 2.13
|
|
import QtQuick.Controls 2.13
|
|
import QtQuick.Layouts 1.13
|
|
import QtGraphicalEffects 1.13
|
|
import "../imports"
|
|
import "../shared/status"
|
|
|
|
Item {
|
|
id: root
|
|
property var contacts
|
|
property var selectedContact
|
|
height: select.height
|
|
property int dropdownWidth: width
|
|
//% "Please select a contact"
|
|
property string validationError: qsTrId("please-select-a-contact")
|
|
property alias validationErrorAlignment: select.validationErrorAlignment
|
|
property bool isValid: false
|
|
property var reset: function() {}
|
|
|
|
function resetInternal() {
|
|
contacts = undefined
|
|
selectedContact = undefined
|
|
select.validationError = ""
|
|
isValid = false
|
|
}
|
|
|
|
onContactsChanged: {
|
|
//% "Select a contact"
|
|
root.selectedContact = { name: qsTrId("select-a-contact") }
|
|
}
|
|
|
|
function validate() {
|
|
const isValid = !!(selectedContact && selectedContact.address)
|
|
select.validationError = !isValid ? validationError : ""
|
|
root.isValid = isValid
|
|
return isValid
|
|
}
|
|
|
|
Select {
|
|
id: select
|
|
label: ""
|
|
model: root.contacts
|
|
width: parent.width
|
|
menuAlignment: Select.MenuAlignment.Left
|
|
selectedItemView: Item {
|
|
anchors.fill: parent
|
|
StatusImageIdenticon {
|
|
id: iconImg
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: 14
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
height: 32
|
|
width: (!!selectedContact && !!selectedContact.identicon) ? 32 : 0
|
|
visible: !!selectedContact && !!selectedContact.identicon
|
|
source: (!!selectedContact && !!selectedContact.identicon) ? selectedContact.identicon : ""
|
|
}
|
|
|
|
StyledText {
|
|
id: selectedTextField
|
|
text: !!selectedContact ? selectedContact.name : ""
|
|
anchors.left: iconImg.right
|
|
anchors.leftMargin: 4
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
font.pixelSize: 15
|
|
height: 22
|
|
verticalAlignment: Text.AlignVCenter
|
|
}
|
|
}
|
|
zeroItemsView: Item {
|
|
height: 186
|
|
StyledText {
|
|
anchors.fill: parent
|
|
//% "You don't have any contacts yet"
|
|
text: qsTrId("you-don-t-have-any-contacts-yet")
|
|
verticalAlignment: Text.AlignVCenter
|
|
horizontalAlignment: Text.AlignHCenter
|
|
font.pixelSize: 13
|
|
height: 18
|
|
color: Style.current.secondaryText
|
|
}
|
|
}
|
|
|
|
menu.delegate: menuItem
|
|
menu.width: dropdownWidth
|
|
}
|
|
|
|
Component {
|
|
id: menuItem
|
|
MenuItem {
|
|
id: itemContainer
|
|
property bool isFirstItem: index === 0
|
|
property bool isLastItem: index === contacts.rowCount() - 1
|
|
|
|
width: parent.width
|
|
height: visible ? 72 : 0
|
|
StatusImageIdenticon {
|
|
id: iconImg
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: Style.current.padding
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
source: identicon
|
|
}
|
|
Column {
|
|
anchors.left: iconImg.right
|
|
anchors.leftMargin: 12
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
Text {
|
|
text: name
|
|
font.pixelSize: 15
|
|
font.family: Style.current.fontRegular.name
|
|
font.weight: Font.Medium
|
|
color: Style.current.textColor
|
|
height: 22
|
|
}
|
|
|
|
Row {
|
|
StyledText {
|
|
text: alias + " • "
|
|
visible: ensVerified
|
|
color: Style.current.secondaryText
|
|
font.pixelSize: 12
|
|
height: 16
|
|
}
|
|
StyledText {
|
|
text: address
|
|
width: 85
|
|
elide: Text.ElideMiddle
|
|
color: Style.current.secondaryText
|
|
font.pixelSize: 12
|
|
height: 16
|
|
}
|
|
}
|
|
}
|
|
background: Rectangle {
|
|
color: itemContainer.highlighted ? Style.current.backgroundHover : Style.current.background
|
|
radius: Style.current.radius
|
|
|
|
// cover bottom left/right corners with square corners
|
|
Rectangle {
|
|
visible: !isLastItem
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
anchors.bottom: parent.bottom
|
|
height: parent.radius
|
|
color: parent.color
|
|
}
|
|
|
|
// cover top left/right corners with square corners
|
|
Rectangle {
|
|
visible: !isFirstItem
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
anchors.top: parent.top
|
|
height: parent.radius
|
|
color: parent.color
|
|
}
|
|
}
|
|
MouseArea {
|
|
cursorShape: Qt.PointingHandCursor
|
|
anchors.fill: itemContainer
|
|
onClicked: {
|
|
root.selectedContact = { address, name, alias, isContact, identicon, ensVerified }
|
|
select.menu.close()
|
|
validate()
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
/*##^##
|
|
Designer {
|
|
D{i:0;autoSize:true;height:480;width:640}
|
|
}
|
|
##^##*/
|