2020-08-06 14:19:26 -04:00
|
|
|
|
import QtQuick 2.12
|
|
|
|
|
import QtQuick.Controls 2.3
|
|
|
|
|
import QtQuick.Layouts 1.3
|
|
|
|
|
import QtQml.Models 2.3
|
2021-09-28 18:04:06 +03:00
|
|
|
|
|
2022-07-13 15:29:38 +03:00
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
|
|
2021-09-28 18:04:06 +03:00
|
|
|
|
import utils 1.0
|
2021-10-28 00:27:49 +03:00
|
|
|
|
import shared 1.0
|
|
|
|
|
import shared.panels 1.0
|
|
|
|
|
import shared.popups 1.0
|
2020-08-06 14:19:26 -04:00
|
|
|
|
|
2021-10-14 13:33:34 +02:00
|
|
|
|
// TODO: replace with StatusModal
|
2020-08-06 14:19:26 -04:00
|
|
|
|
ModalPopup {
|
|
|
|
|
id: popup
|
|
|
|
|
|
2022-04-04 13:26:30 +02:00
|
|
|
|
title: qsTr("Primary username")
|
2020-08-06 14:19:26 -04:00
|
|
|
|
|
2022-01-17 09:56:44 +01:00
|
|
|
|
property var ensUsernamesStore
|
2020-08-06 14:19:26 -04:00
|
|
|
|
property string newUsername: ""
|
|
|
|
|
|
|
|
|
|
onOpened: {
|
|
|
|
|
for(var i in ensNames.contentItem.children){
|
2022-01-17 09:56:44 +01:00
|
|
|
|
ensNames.contentItem.children[i].checked = ensNames.contentItem.children[i].text === popup.ensUsernamesStore.preferredUsername
|
2020-08-06 14:19:26 -04:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
StyledText {
|
|
|
|
|
id: lbl1
|
2022-01-17 09:56:44 +01:00
|
|
|
|
text: popup.ensUsernamesStore.preferredUsername ?
|
2022-04-04 13:26:30 +02:00
|
|
|
|
qsTr("Your messages are displayed to others with this username:")
|
2022-01-17 09:56:44 +01:00
|
|
|
|
:
|
2022-04-04 13:26:30 +02:00
|
|
|
|
qsTr("Once you select a username, you won’t be able to disable it afterwards. You will only be able choose a different username to display.")
|
2020-08-06 14:19:26 -04:00
|
|
|
|
font.pixelSize: 15
|
2020-09-29 13:04:14 +02:00
|
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
|
width: parent.width
|
2020-08-06 14:19:26 -04:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
StyledText {
|
|
|
|
|
id: lbl2
|
|
|
|
|
anchors.top: lbl1.bottom
|
|
|
|
|
anchors.topMargin: Style.current.padding
|
2022-01-17 09:56:44 +01:00
|
|
|
|
text: popup.ensUsernamesStore.preferredUsername
|
2020-08-06 14:19:26 -04:00
|
|
|
|
font.pixelSize: 17
|
|
|
|
|
font.weight: Font.Bold
|
|
|
|
|
}
|
2022-02-09 10:43:23 +01:00
|
|
|
|
|
2022-07-13 15:29:38 +03:00
|
|
|
|
StatusScrollView {
|
2020-08-06 14:19:26 -04:00
|
|
|
|
anchors.fill: parent
|
|
|
|
|
anchors.top: lbl2.bottom
|
|
|
|
|
anchors.topMargin: 70
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
Layout.fillHeight: true
|
|
|
|
|
|
|
|
|
|
ScrollBar.horizontal.policy: ScrollBar.AlwaysOff
|
|
|
|
|
ScrollBar.vertical.policy: ensNames.contentHeight > ensNames.height ? ScrollBar.AlwaysOn : ScrollBar.AlwaysOff
|
|
|
|
|
|
2022-07-14 14:03:36 +03:00
|
|
|
|
StatusListView {
|
2020-08-06 14:19:26 -04:00
|
|
|
|
anchors.fill: parent
|
2022-01-17 09:56:44 +01:00
|
|
|
|
model: root.ensUsernamesStore.ensUsernamesModel
|
2020-08-06 14:19:26 -04:00
|
|
|
|
spacing: 0
|
|
|
|
|
id: ensNames
|
|
|
|
|
delegate: RadioDelegate {
|
|
|
|
|
id: radioDelegate
|
2022-01-17 09:56:44 +01:00
|
|
|
|
text: ensUsername
|
|
|
|
|
checked: popup.ensUsernamesStore.preferredUsername === ensUsername
|
2020-09-29 13:04:14 +02:00
|
|
|
|
|
2020-09-29 13:36:31 +02:00
|
|
|
|
contentItem: StyledText {
|
2020-09-29 13:04:14 +02:00
|
|
|
|
color: Style.current.textColor
|
|
|
|
|
text: radioDelegate.text
|
|
|
|
|
rightPadding: radioDelegate.indicator.width + radioDelegate.spacing
|
|
|
|
|
topPadding: Style.current.halfPadding
|
|
|
|
|
}
|
|
|
|
|
|
2020-08-06 14:19:26 -04:00
|
|
|
|
MouseArea {
|
|
|
|
|
anchors.fill: parent
|
|
|
|
|
onClicked: {
|
|
|
|
|
parent.checked = true
|
2022-01-17 09:56:44 +01:00
|
|
|
|
newUsername = ensUsername;
|
2020-08-06 14:19:26 -04:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
onNewUsernameChanged: {
|
2022-01-17 09:56:44 +01:00
|
|
|
|
btnSelectPreferred.state = newUsername === popup.ensUsernamesStore.preferredUsername ? "inactive" : "active"
|
2020-08-06 14:19:26 -04:00
|
|
|
|
}
|
2022-02-09 10:43:23 +01:00
|
|
|
|
|
2020-08-06 14:19:26 -04:00
|
|
|
|
footer: Item {
|
2021-01-13 14:15:52 -05:00
|
|
|
|
width: parent.width
|
|
|
|
|
height: btnSelectPreferred.height
|
2020-08-06 14:19:26 -04:00
|
|
|
|
|
|
|
|
|
Button {
|
|
|
|
|
id: btnSelectPreferred
|
|
|
|
|
width: 44
|
|
|
|
|
height: 44
|
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
|
anchors.right: parent.right
|
|
|
|
|
state: "inactive"
|
|
|
|
|
states: [
|
|
|
|
|
State {
|
|
|
|
|
name: "inactive"
|
|
|
|
|
PropertyChanges {
|
|
|
|
|
target: btnContinue
|
2021-09-28 18:04:06 +03:00
|
|
|
|
source: Style.svg("arrow-right-btn-inactive")
|
2020-08-06 14:19:26 -04:00
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
State {
|
|
|
|
|
name: "active"
|
|
|
|
|
PropertyChanges {
|
|
|
|
|
target: btnContinue
|
2021-09-28 18:04:06 +03:00
|
|
|
|
source: Style.svg("arrow-right-btn-active")
|
2020-08-06 14:19:26 -04:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
SVGImage {
|
|
|
|
|
id: btnContinue
|
|
|
|
|
width: 50
|
|
|
|
|
height: 50
|
|
|
|
|
}
|
|
|
|
|
background: Rectangle {
|
|
|
|
|
color: "transparent"
|
|
|
|
|
}
|
|
|
|
|
MouseArea {
|
|
|
|
|
cursorShape: btnSelectPreferred.state === "active" ? Qt.PointingHandCursor : Qt.ArrowCursor
|
|
|
|
|
anchors.fill: parent
|
|
|
|
|
onClicked : {
|
|
|
|
|
if(btnSelectPreferred.state === "active"){
|
2022-01-17 09:56:44 +01:00
|
|
|
|
popup.ensUsernamesStore.setPrefferedEnsUsername(newUsername);
|
|
|
|
|
newUsername = "";
|
|
|
|
|
popup.close();
|
2020-08-06 14:19:26 -04:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|