import QtQuick 2.15 import QtQuick.Controls 2.15 import QtQuick.Layouts 1.15 import StatusQ.Controls 0.1 import StatusQ.Core 0.1 import StatusQ.Core.Theme 0.1 import StatusQ.Core.Utils 0.1 as StatusQUtils import StatusQ.Popups 0.1 import shared.controls.delegates 1.0 import utils 1.0 Item { id: root required property string mainDisplayName required property var socialLinksModel property alias cellWidth: webView.cellWidth property alias cellHeight: webView.cellHeight signal copyToClipboard(string text) StatusBaseText { anchors.centerIn: parent visible: (webView.count === 0) horizontalAlignment: Text.AlignHCenter verticalAlignment: Text.AlignVCenter color: Theme.palette.directColor1 text: qsTr("%1 has not shared any links").arg(root.mainDisplayName) } StatusGridView { id: webView anchors.fill: parent topMargin: Style.current.bigPadding bottomMargin: Style.current.bigPadding leftMargin: Style.current.bigPadding visible: count model: root.socialLinksModel ScrollBar.vertical: StatusScrollBar { anchors.right: parent.right; anchors.rightMargin: width / 2 } delegate: InfoCard { id: socialLinksInfoDelegate readonly property int linkType: ProfileUtils.linkTextToType(model.text) width: GridView.view.cellWidth - Style.current.padding height: GridView.view.cellHeight - Style.current.padding title: !!ProfileUtils.linkTypeToText(linkType) ? ProfileUtils.linkTypeToText(linkType) : model.text asset.bgColor: ProfileUtils.linkTypeBgColor(linkType) asset.name: ProfileUtils.linkTypeToIcon(linkType) asset.color: ProfileUtils.linkTypeColor(linkType) asset.width: 20 asset.height: 20 asset.bgWidth: 32 asset.bgHeight: 32 asset.isImage: false subTitle: model.url onClicked: { if (mouse.button === Qt.RightButton) { Global.openMenu(delegatesActionsMenu, this, { url: model.url }); } } highlight: hovered rightSideButtons: RowLayout { StatusFlatRoundButton { implicitWidth: 24 implicitHeight: 24 type: StatusFlatRoundButton.Type.Secondary icon.name: "external" icon.width: 16 icon.height: 16 radius: width/2 highlighted: true visible: socialLinksInfoDelegate.hovered icon.color: socialLinksInfoDelegate.hovered && !hovered ? Theme.palette.baseColor1 : Theme.palette.directColor1 onClicked: { Global.openLinkWithConfirmation(model.url, StatusQUtils.StringUtils.extractDomainFromLink(model.url)); } } } } } Item { width: 279 height: 32 anchors.bottom: parent.bottom anchors.bottomMargin: 20 anchors.horizontalCenter: parent.horizontalCenter visible: (webView.count > 0) Rectangle { anchors.fill: parent color: Style.current.background radius: 30 border.color: Theme.palette.baseColor2 } Row { anchors.centerIn: parent spacing: 4 StatusIcon { width: 16 height: 16 icon: "info" color: Theme.palette.directColor1 } StatusBaseText { font.pixelSize: 13 text: qsTr("Social handles and links are unverified") } } } Component { id: delegatesActionsMenu StatusMenu { id: contextMenu property string url StatusSuccessAction { id: copyAddressAction successText: qsTr("Copied") text: qsTr("Copy link") icon.name: "copy" onTriggered: { root.copyToClipboard(contextMenu.url); } } } } }