import QtQuick 2.15 import QtQuick.Controls 2.15 import QtQuick.Layouts 1.15 import Qt.labs.settings 1.0 import StatusQ.Core.Theme 0.1 import shared.controls.chat 1.0 import utils 1.0 import shared.stores 1.0 SplitView { id: root property string ytBannerQuality: "hqdefault" property string image: Theme.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 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 = {} } } Pane { SplitView.fillWidth: true SplitView.fillHeight: true LinkPreviewCard { id: previewCard utilsStore: UtilsStore { function getEmojiHash(publicKey) { return JSON.stringify(["๐Ÿ‘จ๐Ÿปโ€๐Ÿผ", "๐Ÿƒ๐Ÿฟโ€โ™‚๏ธ", "๐ŸŒ‡", "๐Ÿคถ๐Ÿฟ", "๐Ÿฎ","๐Ÿคท๐Ÿปโ€โ™‚๏ธ", "๐Ÿคฆ๐Ÿป", "๐Ÿ“ฃ", "๐ŸคŽ", "๐Ÿ‘ท๐Ÿฝ", "๐Ÿ˜บ", "๐Ÿฅž", "๐Ÿ”ƒ", "๐Ÿง๐Ÿฝโ€โ™‚๏ธ"]) } } 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" } } } } ScrollView { SplitView.preferredWidth: 500 SplitView.fillHeight: true leftPadding: 10 ColumnLayout { id: layout spacing: 24 ColumnLayout { 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 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" } 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." } } ColumnLayout { visible: previewCard.type === Constants.LinkPreviewType.Standard Label { text: "Footer" } TextField { id: footerInput Layout.fillHeight: true Layout.fillWidth: true text: "X" } } 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" } } } ColumnLayout { visible: previewCard.type === Constants.LinkPreviewType.StatusContact Label { text: "User name" } TextField { id: userNameInput Layout.fillHeight: true Layout.fillWidth: true text: "Test user name" } 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." } } } 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 ? "๐Ÿ‘‹" : "" } RadioButton { text: qsTr("Blue channel color") checked: previewCard.channelData.color === "blue" onToggled: previewCard.channelData.color = "blue" } RadioButton { text: qsTr("Red channel color") checked: previewCard.channelData.color === "red" onToggled: previewCard.channelData.color = "red" } } 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 === Theme.png("tokens/SOCKS") onToggled: root.image = Theme.png("tokens/SOCKS") } ColumnLayout { visible: previewCard.type !== Constants.LinkPreviewType.StatusContact 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" } } CheckBox { id: rawImageCheck readonly property string rawImageData: "" text: qsTr("Raw image banner") checked: root.banner === rawImageData } ColumnLayout { Label { Layout.fillWidth: true text: "UserName" } } 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 } } } } Settings { property alias linkType: previewCard.type } } // category: Controls // https://www.figma.com/file/Mr3rqxxgKJ2zMQ06UAKiWL/๐Ÿ’ฌ-ChatโŽœDesktop?type=design&node-id=22347-219545&mode=design&t=bODv5MUGQgU9ThJF-0