2023-09-13 12:12:47 +03:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQuick.Controls 2.15
|
|
|
|
import QtQuick.Layouts 1.15
|
|
|
|
|
2023-10-25 18:20:02 +03:00
|
|
|
import Qt.labs.settings 1.0
|
|
|
|
|
2023-09-13 12:12:47 +03:00
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
|
|
|
|
import shared.controls.chat 1.0
|
|
|
|
import utils 1.0
|
|
|
|
|
2023-10-25 18:20:02 +03:00
|
|
|
|
2023-09-13 12:12:47 +03:00
|
|
|
SplitView {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
property string ytBannerQuality: "hqdefault"
|
2023-10-25 18:20:02 +03:00
|
|
|
property string image: Style.png("tokens/SOCKS")
|
|
|
|
property string banner: rawImageCheck.checked ? rawImageCheck.rawImageData : "https://img.youtube.com/vi/yHN1M7vcPKU/%1.jpg".arg(root.ytBannerQuality)
|
|
|
|
property bool globalUtilsReady: false
|
|
|
|
|
|
|
|
// globalUtilsInst mock
|
|
|
|
QtObject {
|
|
|
|
function getEmojiHashAsJson(publicKey) {
|
|
|
|
return JSON.stringify(["👨🏻🍼", "🏃🏿♂️", "🌇", "🤶🏿", "🏮","🤷🏻♂️", "🤦🏻", "📣", "🤎", "👷🏽", "😺", "🥞", "🔃", "🧝🏽♂️"])
|
|
|
|
}
|
|
|
|
function getColorId(publicKey) { return 4 }
|
|
|
|
|
|
|
|
function getCompressedPk(publicKey) { return "zx3sh" + publicKey }
|
|
|
|
|
|
|
|
function getColorHashAsJson(publicKey) {
|
|
|
|
return JSON.stringify([{4: 0, segmentLength: 1},
|
|
|
|
{5: 19, segmentLength: 2}])
|
|
|
|
}
|
|
|
|
|
|
|
|
function isCompressedPubKey(publicKey) { return true }
|
|
|
|
|
|
|
|
Component.onCompleted: {
|
|
|
|
Utils.globalUtilsInst = this
|
|
|
|
root.globalUtilsReady = true
|
|
|
|
|
|
|
|
}
|
|
|
|
Component.onDestruction: {
|
|
|
|
root.globalUtilsReady = false
|
|
|
|
Utils.globalUtilsInst = {}
|
|
|
|
}
|
|
|
|
}
|
2023-09-13 12:12:47 +03:00
|
|
|
|
|
|
|
Pane {
|
|
|
|
SplitView.fillWidth: true
|
|
|
|
SplitView.fillHeight: true
|
2023-10-25 18:20:02 +03:00
|
|
|
|
2023-09-13 12:12:47 +03:00
|
|
|
LinkPreviewCard {
|
|
|
|
id: previewCard
|
2023-10-25 18:20:02 +03:00
|
|
|
type: 1
|
|
|
|
linkData {
|
|
|
|
title: titleInput.text
|
|
|
|
description: descriptionInput.text
|
|
|
|
domain: footerInput.text
|
|
|
|
thumbnail: root.banner
|
|
|
|
image: root.image
|
|
|
|
}
|
|
|
|
userData {
|
|
|
|
name: userNameInput.text
|
|
|
|
publicKey: "zQ3shgmVJjmwwhkfAemjDizYJtv9nzot7QD4iRJ52ZkgdU6Ci"
|
|
|
|
bio: bioInput.text
|
|
|
|
image: root.image
|
|
|
|
ensVerified: false
|
|
|
|
}
|
|
|
|
communityData {
|
|
|
|
name: titleInput.text
|
|
|
|
description: descriptionInput.text
|
|
|
|
banner: root.banner
|
|
|
|
image: root.image
|
|
|
|
membersCount: parseInt(membersCountInput.text)
|
|
|
|
activeMembersCount: parseInt(activeMembersCountInput.text)
|
|
|
|
color: "orchid"
|
|
|
|
}
|
|
|
|
channelData {
|
|
|
|
name: titleInput.text
|
|
|
|
description: descriptionInput.text
|
|
|
|
emoji: ""
|
|
|
|
color: "blue"
|
|
|
|
communityData {
|
|
|
|
name: "Community" + titleInput.text
|
|
|
|
description: "Community" + descriptionInput.text
|
|
|
|
banner: root.banner
|
|
|
|
image: root.image
|
|
|
|
membersCount: parseInt(membersCountInput.text)
|
|
|
|
activeMembersCount: parseInt(activeMembersCountInput.text)
|
|
|
|
color: "orchid"
|
|
|
|
}
|
|
|
|
}
|
2023-09-13 12:12:47 +03:00
|
|
|
}
|
|
|
|
}
|
2023-10-25 18:20:02 +03:00
|
|
|
|
2023-09-13 12:12:47 +03:00
|
|
|
|
2023-10-25 18:20:02 +03:00
|
|
|
ScrollView {
|
2023-09-13 12:12:47 +03:00
|
|
|
SplitView.preferredWidth: 500
|
|
|
|
SplitView.fillHeight: true
|
2023-10-25 18:20:02 +03:00
|
|
|
leftPadding: 10
|
2023-09-13 12:12:47 +03:00
|
|
|
ColumnLayout {
|
2023-10-25 18:20:02 +03:00
|
|
|
id: layout
|
2023-09-13 12:12:47 +03:00
|
|
|
spacing: 24
|
|
|
|
ColumnLayout {
|
2023-10-25 18:20:02 +03:00
|
|
|
Label {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
text: "Card type"
|
|
|
|
}
|
|
|
|
|
|
|
|
RadioButton {
|
|
|
|
text: qsTr("Link")
|
|
|
|
checked: previewCard.type === Constants.LinkPreviewType.Standard
|
|
|
|
onToggled: previewCard.type = Constants.LinkPreviewType.Standard
|
|
|
|
}
|
|
|
|
|
|
|
|
RadioButton {
|
|
|
|
text: qsTr("Contact")
|
|
|
|
checked: previewCard.type === Constants.LinkPreviewType.StatusContact
|
|
|
|
onToggled: previewCard.type = Constants.LinkPreviewType.StatusContact
|
|
|
|
}
|
|
|
|
|
|
|
|
RadioButton {
|
|
|
|
text: qsTr("Community")
|
|
|
|
checked: previewCard.type === Constants.LinkPreviewType.StatusCommunity
|
|
|
|
onToggled: {
|
|
|
|
previewCard.type = Constants.LinkPreviewType.StatusCommunity
|
|
|
|
titleInput.text = "Socks"
|
|
|
|
descriptionInput.text = "Community description goes here. If blank it will enable multi line title."
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
RadioButton {
|
|
|
|
text: qsTr("Channel")
|
|
|
|
checked: previewCard.type === Constants.LinkPreviewType.StatusCommunityChannel
|
|
|
|
onToggled: {
|
|
|
|
previewCard.type = Constants.LinkPreviewType.StatusCommunityChannel
|
|
|
|
titleInput.text = "general"
|
|
|
|
descriptionInput.text = "Channel description goes here. If blank it will enable multi line title."
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
ColumnLayout {
|
|
|
|
visible: previewCard.type !== Constants.LinkPreviewType.StatusContact
|
2023-09-13 12:12:47 +03:00
|
|
|
Label {
|
|
|
|
text: "Title"
|
|
|
|
}
|
|
|
|
|
|
|
|
TextField {
|
|
|
|
id: titleInput
|
|
|
|
Layout.fillHeight: true
|
|
|
|
Layout.fillWidth: true
|
|
|
|
text: "What Is Web3? A Decentralized Internet Via Blockchain Technology That Will Revolutionise All Sectors- Decrypt (@decryptmedia) August 31 2021"
|
|
|
|
}
|
2023-10-25 18:20:02 +03:00
|
|
|
|
2023-09-13 12:12:47 +03:00
|
|
|
Label {
|
|
|
|
text: "Description"
|
|
|
|
}
|
|
|
|
RowLayout {
|
|
|
|
TextField {
|
|
|
|
id: descriptionInput
|
|
|
|
Layout.fillHeight: true
|
|
|
|
Layout.fillWidth: true
|
|
|
|
text: "Link description goes here. If blank it will enable multi line title."
|
|
|
|
}
|
|
|
|
Button {
|
|
|
|
text: "clear"
|
|
|
|
onClicked: descriptionInput.text = ""
|
|
|
|
}
|
|
|
|
Button {
|
|
|
|
text: "Set"
|
|
|
|
onClicked: descriptionInput.text = "Link description goes here. If blank it will enable multi line title."
|
|
|
|
}
|
|
|
|
}
|
2023-10-25 18:20:02 +03:00
|
|
|
ColumnLayout {
|
|
|
|
visible: previewCard.type === Constants.LinkPreviewType.Standard
|
|
|
|
Label {
|
|
|
|
text: "Footer"
|
|
|
|
}
|
2023-09-13 12:12:47 +03:00
|
|
|
|
2023-10-25 18:20:02 +03:00
|
|
|
TextField {
|
|
|
|
id: footerInput
|
|
|
|
Layout.fillHeight: true
|
|
|
|
Layout.fillWidth: true
|
|
|
|
text: "X"
|
|
|
|
}
|
2023-09-13 12:12:47 +03:00
|
|
|
}
|
|
|
|
|
2023-10-25 18:20:02 +03:00
|
|
|
ColumnLayout {
|
|
|
|
visible: previewCard.type === Constants.LinkPreviewType.StatusCommunity
|
|
|
|
Label {
|
|
|
|
text: "MembersCount"
|
|
|
|
}
|
|
|
|
TextField {
|
|
|
|
id: membersCountInput
|
|
|
|
Layout.fillHeight: true
|
|
|
|
Layout.fillWidth: true
|
|
|
|
inputMethodHints: Qt.ImhDigitsOnly
|
|
|
|
text: "629200"
|
|
|
|
}
|
|
|
|
TextField {
|
|
|
|
id: activeMembersCountInput
|
|
|
|
Layout.fillHeight: true
|
|
|
|
Layout.fillWidth: true
|
|
|
|
inputMethodHints: Qt.ImhDigitsOnly
|
|
|
|
text: "112100"
|
|
|
|
}
|
2023-09-13 12:12:47 +03:00
|
|
|
}
|
|
|
|
}
|
2023-10-25 18:20:02 +03:00
|
|
|
|
2023-09-13 12:12:47 +03:00
|
|
|
ColumnLayout {
|
2023-10-25 18:20:02 +03:00
|
|
|
visible: previewCard.type === Constants.LinkPreviewType.StatusContact
|
2023-09-13 12:12:47 +03:00
|
|
|
Label {
|
2023-10-25 18:20:02 +03:00
|
|
|
text: "User name"
|
2023-09-13 12:12:47 +03:00
|
|
|
}
|
|
|
|
|
2023-10-25 18:20:02 +03:00
|
|
|
TextField {
|
|
|
|
id: userNameInput
|
|
|
|
Layout.fillHeight: true
|
|
|
|
Layout.fillWidth: true
|
|
|
|
text: "Test user name"
|
2023-09-13 12:12:47 +03:00
|
|
|
}
|
|
|
|
|
2023-10-25 18:20:02 +03:00
|
|
|
Label {
|
|
|
|
text: "Bio"
|
|
|
|
}
|
|
|
|
RowLayout {
|
|
|
|
TextField {
|
|
|
|
id: bioInput
|
|
|
|
Layout.fillHeight: true
|
|
|
|
Layout.fillWidth: true
|
|
|
|
text: "User bio description goes here. If blank it will enable multi line title."
|
|
|
|
}
|
|
|
|
Button {
|
|
|
|
text: "clear"
|
|
|
|
onClicked: bioInput.text = ""
|
|
|
|
}
|
|
|
|
Button {
|
|
|
|
text: "Set"
|
|
|
|
onClicked: bioInput.text = "User bio description goes here. If blank it will enable multi line title."
|
2023-09-13 12:12:47 +03:00
|
|
|
}
|
|
|
|
}
|
2023-10-25 18:20:02 +03:00
|
|
|
}
|
2023-09-13 12:12:47 +03:00
|
|
|
|
2023-10-25 18:20:02 +03:00
|
|
|
ColumnLayout {
|
|
|
|
visible: previewCard.type === Constants.LinkPreviewType.StatusCommunityChannel
|
|
|
|
Label {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
text: "channel settings"
|
|
|
|
}
|
|
|
|
CheckBox {
|
|
|
|
text: qsTr("Emoji")
|
|
|
|
checked: previewCard.channelData.emoji === "👋"
|
|
|
|
onToggled: previewCard.channelData.emoji = checked ? "👋" : ""
|
2023-09-13 12:12:47 +03:00
|
|
|
}
|
|
|
|
RadioButton {
|
2023-10-25 18:20:02 +03:00
|
|
|
text: qsTr("Blue channel color")
|
|
|
|
checked: previewCard.channelData.color === "blue"
|
|
|
|
onToggled: previewCard.channelData.color = "blue"
|
2023-09-13 12:12:47 +03:00
|
|
|
}
|
|
|
|
RadioButton {
|
2023-10-25 18:20:02 +03:00
|
|
|
text: qsTr("Red channel color")
|
|
|
|
checked: previewCard.channelData.color === "red"
|
|
|
|
onToggled: previewCard.channelData.color = "red"
|
2023-09-13 12:12:47 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-10-25 18:20:02 +03:00
|
|
|
Label {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
text: "Logo"
|
|
|
|
}
|
|
|
|
|
|
|
|
RadioButton {
|
|
|
|
text: qsTr("no image")
|
|
|
|
checked: root.image === ""
|
|
|
|
onToggled: root.image = ""
|
|
|
|
}
|
|
|
|
|
|
|
|
RadioButton {
|
|
|
|
readonly property string rawImageData: ""
|
|
|
|
text: qsTr("Raw image")
|
|
|
|
checked: root.image === rawImageData
|
|
|
|
onToggled: root.image = rawImageData
|
|
|
|
}
|
|
|
|
|
|
|
|
RadioButton {
|
|
|
|
text: qsTr("QRC asset: SOCKS")
|
|
|
|
checked: root.image === Style.png("tokens/SOCKS")
|
|
|
|
onToggled: root.image = Style.png("tokens/SOCKS")
|
|
|
|
}
|
|
|
|
|
2023-09-13 12:12:47 +03:00
|
|
|
ColumnLayout {
|
2023-10-25 18:20:02 +03:00
|
|
|
visible: previewCard.type !== Constants.LinkPreviewType.StatusContact
|
2023-09-13 12:12:47 +03:00
|
|
|
Label {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
text: "Banner size"
|
|
|
|
}
|
|
|
|
RadioButton {
|
|
|
|
text: qsTr("Low (120x90)")
|
|
|
|
checked: ytBannerQuality === "default"
|
|
|
|
onToggled: ytBannerQuality = "default"
|
|
|
|
}
|
|
|
|
RadioButton {
|
|
|
|
text: qsTr("Medium(320x180)")
|
|
|
|
checked: ytBannerQuality === "mqdefault"
|
|
|
|
onToggled: ytBannerQuality = "mqdefault"
|
|
|
|
}
|
|
|
|
RadioButton {
|
|
|
|
text: qsTr("High(480x360)")
|
|
|
|
checked: ytBannerQuality === "hqdefault"
|
|
|
|
onToggled: ytBannerQuality = "hqdefault"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-10-25 18:20:02 +03:00
|
|
|
CheckBox {
|
|
|
|
id: rawImageCheck
|
|
|
|
readonly property string rawImageData: "
|
|
|
|
text: qsTr("Raw image banner")
|
|
|
|
checked: root.banner === rawImageData
|
|
|
|
}
|
|
|
|
|
2023-09-13 12:12:47 +03:00
|
|
|
ColumnLayout {
|
|
|
|
Label {
|
|
|
|
Layout.fillWidth: true
|
2023-10-25 18:20:02 +03:00
|
|
|
text: "UserName"
|
2023-09-13 12:12:47 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ColumnLayout {
|
|
|
|
Label {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
text: "Tail position"
|
|
|
|
}
|
|
|
|
RadioButton {
|
|
|
|
text: qsTr("Left")
|
|
|
|
checked: previewCard.leftTail === true
|
|
|
|
onToggled: previewCard.leftTail = true
|
|
|
|
}
|
|
|
|
RadioButton {
|
|
|
|
text: qsTr("Right")
|
|
|
|
checked: previewCard.leftTail === false
|
|
|
|
onToggled: previewCard.leftTail = false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-10-25 18:20:02 +03:00
|
|
|
|
|
|
|
Settings {
|
|
|
|
property alias linkType: previewCard.type
|
|
|
|
}
|
2023-09-13 12:12:47 +03:00
|
|
|
}
|
2023-10-25 18:20:02 +03:00
|
|
|
|
|
|
|
// category: Controls
|
|
|
|
|
|
|
|
// https://www.figma.com/file/Mr3rqxxgKJ2zMQ06UAKiWL/💬-Chat⎜Desktop?type=design&node-id=22347-219545&mode=design&t=bODv5MUGQgU9ThJF-0
|