import QtQuick 2.12 import QtQuick.Controls 2.12 import QtQuick.Dialogs 1.3 import QtQuick.Layouts 1.13 import QtGraphicalEffects 1.13 import utils 1.0 import shared.controls 1.0 import shared 1.0 import shared.panels 1.0 import shared.status 1.0 import StatusQ.Components 0.1 import StatusQ.Popups 0.1 Column { id: root property string headerTitle: "" property var community property alias contactListSearch: contactFieldAndList function sendInvites(pubKeys) { const error = chatsModel.communities.inviteUsersToCommunityById(root.community.id, JSON.stringify(pubKeys)) if (error) { console.error('Error inviting', error) contactFieldAndList.validationError = error return } //% "Invite successfully sent" contactFieldAndList.successMessage = qsTrId("invite-successfully-sent") } StatusDescriptionListItem { //% "Share community" title: qsTrId("share-community") subTitle: `${Constants.communityLinkPrefix}${root.community && root.community.id.substring(0, 4)}...${root.community && root.community.id.substring(root.community.id.length -2)}` //% "Copy to clipboard" tooltip.text: qsTrId("copy-to-clipboard") icon.name: "copy" iconButton.onClicked: { let link = `${Constants.communityLinkPrefix}${root.community.id}` chatsModel.copyToClipboard(link) tooltip.visible = !tooltip.visible } width: parent.width } StatusModalDivider { bottomPadding: Style.current.padding } StyledText { id: headline text: qsTr("Contacts") font.pixelSize: Style.current.primaryTextFontSize color: Style.current.secondaryText anchors.left: parent.left anchors.leftMargin: Style.current.padding } ContactsListAndSearch { id: contactFieldAndList anchors.horizontalCenter: parent.horizontalCenter width: parent.width - 32 showCheckbox: true hideCommunityMembers: true showSearch: false } }