status-desktop/ui/app/AppLayouts/Profile/Sections/MyProfileContainer.qml

160 lines
4.5 KiB
QML
Raw Normal View History

import QtQuick 2.13
import QtQuick.Layouts 1.13
import QtGraphicalEffects 1.13
import "../../../../imports"
import "../../../../shared"
2020-12-04 20:45:30 +02:00
import "../../../../shared/status"
Item {
2020-11-30 12:03:52 -05:00
property string ensName: profileModel.profile.preferredUsername || ""
property string username: profileModel.profile.username
property string pubkey: profileModel.profile.pubKey
id: profileHeaderContent
height: parent.height
Layout.fillWidth: true
2020-11-30 12:03:52 -05:00
Component {
id: changeProfileModalComponent
ChangeProfilePicModal {}
}
Item {
id: profileImgNameContainer
anchors.top: parent.top
anchors.topMargin: 64
anchors.right: parent.right
anchors.rightMargin: contentMargin
anchors.left: parent.left
anchors.leftMargin: contentMargin
height: this.childrenRect.height
2020-11-30 12:03:52 -05:00
Item {
id: profileImgContainer
width: profileImg.width
height: profileImg.height
2020-11-30 12:03:52 -05:00
RoundedImage {
id: profileImg
width: 64
height: 64
border.width: 1
border.color: Style.current.border
source: profileModel.profile.thumbnailImage || ""
smooth: false
antialiasing: true
}
2020-11-30 12:03:52 -05:00
RoundedIcon {
source: "../../../img/pencil.svg"
anchors.bottom: parent.bottom
anchors.bottomMargin: -3
anchors.right: parent.right
anchors.rightMargin: -3
width: 24
height: 24
border.width: 1
border.color: Style.current.background
}
MouseArea {
anchors.fill: parent
cursorShape: Qt.PointingHandCursor
onClicked: {
const popup = changeProfileModalComponent.createObject(profileHeaderContent);
popup.open()
}
}
}
StyledText {
id: profileName
2020-08-06 14:19:26 -04:00
text: ensName !== "" ? ensName : username
2020-11-30 12:03:52 -05:00
anchors.left: profileImgContainer.right
2020-12-29 13:18:50 -05:00
anchors.leftMargin: Style.current.halfPadding
2020-11-30 12:03:52 -05:00
anchors.top: profileImgContainer.top
2020-12-29 13:18:50 -05:00
anchors.topMargin: 4
font.weight: Font.Bold
font.pixelSize: 20
}
Address {
id: pubkeyText
2020-08-06 14:19:26 -04:00
text: ensName !== "" ? username : pubkey
2020-11-30 12:03:52 -05:00
anchors.bottom: profileImgContainer.bottom
anchors.left: profileName.left
anchors.bottomMargin: 4
2020-08-06 14:19:26 -04:00
width: 200
font.pixelSize: 15
}
2020-12-04 20:45:30 +02:00
StatusIconButton {
id: qrCodeButton
anchors.right: parent.right
height: 32
width: 32
radius: 8
2020-12-29 13:18:50 -05:00
anchors.verticalCenter: profileImgContainer.verticalCenter
2020-12-04 20:45:30 +02:00
icon.name: "qr-code-icon"
iconColor: Style.current.textColor
onClicked: {
qrCodePopup.open()
}
}
Separator {
id: lineSeparator
2020-11-30 12:03:52 -05:00
anchors.top: profileImgContainer.bottom
anchors.topMargin: 36
}
}
ModalPopup {
id: qrCodePopup
width: 420
height: 420
2020-08-19 17:01:22 -04:00
Image {
asynchronous: true
fillMode: Image.PreserveAspectFit
source: profileModel.qrCode(pubkey)
2020-12-29 13:18:50 -05:00
anchors.verticalCenterOffset: 20
2020-08-19 17:01:22 -04:00
anchors.horizontalCenter: parent.horizontalCenter
2020-12-29 13:18:50 -05:00
anchors.verticalCenter: parent.verticalCenter
height: 312
width: 312
2020-08-19 17:01:22 -04:00
mipmap: true
smooth: false
}
}
Column {
anchors.right: profileImgNameContainer.right
anchors.left: profileImgNameContainer.left
spacing: Style.current.bigPadding
anchors.top: profileImgNameContainer.bottom
anchors.topMargin: Style.current.smallPadding
TextWithLabel {
2020-08-26 11:52:26 -04:00
//% "Chat key"
label: qsTrId("chat-key")
text: pubkey.substring(0, 13) + "..." + pubkey.substring(pubkey.length - 13)
textToCopy: pubkey
}
TextWithLabel {
2020-08-26 11:52:26 -04:00
//% "Share Profile URL"
label: qsTrId("share-profile-url")
text: `https://join.status.im/u/${pubkey.substring(0, 5)}...${pubkey.substring(pubkey.length - 5)}`
textToCopy: `https://join.status.im/u/${pubkey}`
}
}
}
/*##^##
Designer {
D{i:0;formeditorColor:"#ffffff"}
}
##^##*/