mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-26 22:39:26 +00:00
e13726e4af
- rework the way social links are displayed/editted; we now only allow to enter a so called "handle" and then substitute that in the final URL template - move the "icon" model role to NIM backend This has several advantages: - we display only the "handle" and don't have to elide some long URL - we won't let users enter random URLs into their profile and spoof the viewing part into clicking it Additionally, make the social link "button" clickable -> navigate to the target URL, and make the tooltip behave as "usual" (on mouse hover).
98 lines
2.6 KiB
QML
98 lines
2.6 KiB
QML
import QtQuick 2.14
|
|
import QtQuick.Layouts 1.14
|
|
|
|
import StatusQ.Core 0.1
|
|
import StatusQ.Core.Theme 0.1
|
|
import StatusQ.Controls 0.1
|
|
import StatusQ.Controls.Validators 0.1
|
|
|
|
import utils 1.0
|
|
import "../controls"
|
|
|
|
Item {
|
|
id: root
|
|
|
|
property alias displayName: displayNameInput
|
|
property alias bio: bioInput
|
|
|
|
property var socialLinksModel
|
|
|
|
signal socialLinkChanged(string uuid, string text, string url)
|
|
signal addSocialLinksClicked
|
|
|
|
implicitHeight: layout.implicitHeight
|
|
implicitWidth: layout.implicitWidth
|
|
|
|
ColumnLayout {
|
|
id: layout
|
|
anchors.fill: parent
|
|
|
|
spacing: 19 // by design
|
|
|
|
StatusInput {
|
|
id: displayNameInput
|
|
objectName: "displayNameInput"
|
|
|
|
Layout.fillWidth: true
|
|
|
|
label: qsTr("Display name")
|
|
placeholderText: qsTr("Display Name")
|
|
charLimit: 24
|
|
validators: Constants.validators.displayName
|
|
|
|
input.tabNavItem: bioInput.input.edit
|
|
}
|
|
|
|
|
|
StatusInput {
|
|
id: bioInput
|
|
objectName: "bioInput"
|
|
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: 5 // by design
|
|
|
|
label: qsTr("Bio")
|
|
placeholderText: qsTr("Tell us about yourself")
|
|
charLimit: 240
|
|
multiline: true
|
|
minimumHeight: 108
|
|
maximumHeight: 108
|
|
input.verticalAlignment: TextEdit.AlignTop
|
|
|
|
input.tabNavItem: socialLinksRepeater.count ? socialLinksRepeater.itemAt(0).input.edit : null
|
|
}
|
|
|
|
Repeater {
|
|
id: socialLinksRepeater
|
|
|
|
model: root.socialLinksModel
|
|
delegate: StaticSocialLinkInput {
|
|
objectName: model.text + "-socialLinkInput"
|
|
|
|
Layout.fillWidth: true
|
|
linkType: model.linkType
|
|
text: Utils.stripSocialLinkPrefix(model.url, model.linkType)
|
|
icon: model.icon
|
|
|
|
onTextChanged: root.socialLinkChanged(model.uuid, model.text, Utils.addSocialLinkPrefix(text, model.linkType))
|
|
|
|
input.tabNavItem: {
|
|
if (index < socialLinksRepeater.count - 1) {
|
|
return socialLinksRepeater.itemAt(index + 1).input.edit
|
|
}
|
|
return addMoreSocialLinksButton
|
|
}
|
|
}
|
|
}
|
|
|
|
StatusIconTextButton {
|
|
id: addMoreSocialLinksButton
|
|
|
|
objectName: "addMoreSocialLinksButton"
|
|
Layout.topMargin: -8 // by design
|
|
text: qsTr("Add more social links")
|
|
onClicked: root.addSocialLinksClicked()
|
|
}
|
|
}
|
|
}
|