mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-09 13:56:10 +00:00
4a30d13bdc
* feat(StatusQ): Adding numberToLocaleStringInCompactForm function to LocaleUtils This function will format the number in a compact form E.g: 1000 -> 1K; 1000000 -> 1M; 1100000 -> 1.1M + adding tests fix(statusQ): Update numberToLocaleStringInCompactForm to return the locale number when greter than 999T fix(StatusQ): extend the test_numberToLocaleStringInCompactForm with new data * feat(LinkPreviews): Update the link preview area in StatusChatInput to use the new model Changes: 1. Create a new component `LinkPreviewMiniCardDelegate.qml` that filters the model data to properly fill the link preview card with the needed data based on the preview type 2. Update storybook pages 3. Small updates to LinkPreviewMiniCard * feat(LinkPreviews): Update the link previews in message history to use the new backend Changes: 1. Create delegate items for LinkPreviewCard and gif link preview to clean the LinksMessageView component and filter the model data based on the preview type 2. Remove UserProfileCard and reuse the LinkPreviewCard to display contacts link previews 3. Update LinkPreviewCard so that it can accommodate status link previews (communities, channels, contacts). The generic properties (title, description, footer) have been dropped and replaced with specialised properties for each preview type. 4. Fix LinkPreviewCard layout to better accommodate different content variants (missing properties, long/short title, missing description, missing icon) 5. Fixing the link preview context menu and click actions fix: Move inline components to separate files Fixing the linux builds using Qt 5.15.2 affected by this bug: https://bugreports.qt.io/browse/QTBUG-89180 * fix: Align LinkPreviewMiniCard implementation with LinkPreviewCard and remove state based model filtering
355 lines
18 KiB
QML
355 lines
18 KiB
QML
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
|
|
|
|
|
|
SplitView {
|
|
id: root
|
|
|
|
property string ytBannerQuality: "hqdefault"
|
|
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 = {}
|
|
}
|
|
}
|
|
|
|
Pane {
|
|
SplitView.fillWidth: true
|
|
SplitView.fillHeight: true
|
|
|
|
LinkPreviewCard {
|
|
id: previewCard
|
|
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 === Style.png("tokens/SOCKS")
|
|
onToggled: root.image = Style.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
|