From fda0eaa9150008fec27603c2748d0cb908e88d6b Mon Sep 17 00:00:00 2001 From: Noelia Date: Wed, 27 Mar 2024 18:40:49 +0100 Subject: [PATCH] fix(CancelCommunityMembership): Added popup instead of directly cancelling request - Added dialog instead of calling directly to the cancel method. - Updated `Cancel` button format according to figma in `CommunityMembershipSetupDialog`. Closes #14097 --- ui/app/AppLayouts/Chat/ChatLayout.qml | 20 +++- .../popups/CommunityMembershipSetupDialog.qml | 95 ++++++++++--------- 2 files changed, 65 insertions(+), 50 deletions(-) diff --git a/ui/app/AppLayouts/Chat/ChatLayout.qml b/ui/app/AppLayouts/Chat/ChatLayout.qml index 934e057f11..5c95e89021 100644 --- a/ui/app/AppLayouts/Chat/ChatLayout.qml +++ b/ui/app/AppLayouts/Chat/ChatLayout.qml @@ -128,8 +128,14 @@ StackLayout { }) } onInvitationPendingClicked: { - root.rootStore.cancelPendingRequest(communityId) - joinCommunityView.isInvitationPending = root.rootStore.isMyCommunityRequestPending(communityId) + Global.openPopup(communityMembershipSetupDialogComponent, { + communityId: joinCommunityView.communityId, + isInvitationPending: joinCommunityView.isInvitationPending, + communityName: communityData.name, + introMessage: communityData.introMessage, + communityIcon: communityData.image, + accessType: communityData.access + }) } Connections { @@ -196,8 +202,14 @@ StackLayout { }) } onInvitationPendingClicked: { - root.rootStore.cancelPendingRequest(chatView.communityId) - chatView.isInvitationPending = root.rootStore.isMyCommunityRequestPending(chatView.communityId) + Global.openPopup(communityMembershipSetupDialogComponent, { + communityId: chatView.communityId, + isInvitationPending: root.rootStore.isMyCommunityRequestPending(chatView.communityId), + communityName: root.sectionItemModel.name, + introMessage: root.sectionItemModel.introMessage, + communityIcon: root.sectionItemModel.image, + accessType: root.sectionItemModel.access + }) } } } diff --git a/ui/imports/shared/popups/CommunityMembershipSetupDialog.qml b/ui/imports/shared/popups/CommunityMembershipSetupDialog.qml index 3415ccb47c..3bcce3c879 100644 --- a/ui/imports/shared/popups/CommunityMembershipSetupDialog.qml +++ b/ui/imports/shared/popups/CommunityMembershipSetupDialog.qml @@ -77,50 +77,7 @@ StatusStackModal { rightButtons: [d.shareButton, finishButton] - finishButton: StatusButton { - text: { - if (root.isInvitationPending) { - return qsTr("Cancel Membership Request") - } else if (root.accessType === Constants.communityChatOnRequestAccess) { - if (d.selectedSharedAddressesCount === d.totalNumOfAddressesForSharing) { - return qsTr("Share all addresses to join") - } - return qsTr("Share %n address(s) to join", "", d.selectedSharedAddressesCount) - } - return qsTr("Join %1").arg(root.communityName) - } - type: root.isInvitationPending ? StatusBaseButton.Type.Danger - : StatusBaseButton.Type.Normal - - icon.name: { - if (root.profileProvesOwnershipOfSelectedAddresses) { - if (userProfile.usingBiometricLogin) { - return "touch-id" - } - - if (userProfile.isKeycardUser) { - return "keycard" - } - - return "password" - } - if (root.allAddressesToRevealBelongToSingleNonProfileKeypair) { - return "keycard" - } - - return "" - } - - onClicked: { - if (root.isInvitationPending) { - root.cancelMembershipRequest() - root.close() - return - } - - d.proceedToSigningOrSubmitRequest(d.communityIntroUid) - } - } + finishButton: root.isInvitationPending ? d.cancelRequestButton : d.shareAddressesButton backButton: StatusBackButton { visible: !!root.replaceLoader.item @@ -181,6 +138,52 @@ StatusStackModal { ] } + readonly property StatusFlatButton cancelRequestButton: StatusFlatButton { + text: qsTr("Cancel Membership Request") + type: StatusBaseButton.Type.Danger + onClicked: { + if (root.isInvitationPending) { + root.cancelMembershipRequest() + root.close() + return + } + } + } + + readonly property StatusButton shareAddressesButton: StatusButton { + text: { + if (root.accessType === Constants.communityChatOnRequestAccess) { + if (d.selectedSharedAddressesCount === d.totalNumOfAddressesForSharing) { + return qsTr("Share all addresses to join") + } + return qsTr("Share %n address(s) to join", "", d.selectedSharedAddressesCount) + } + return qsTr("Join %1").arg(root.communityName) + } + type: StatusBaseButton.Type.Normal + icon.name: { + if (root.profileProvesOwnershipOfSelectedAddresses) { + if (userProfile.usingBiometricLogin) { + return "touch-id" + } + + if (userProfile.isKeycardUser) { + return "keycard" + } + + return "password" + } + + if (root.allAddressesToRevealBelongToSingleNonProfileKeypair) { + return "keycard" + } + + return "" + } + + onClicked: d.proceedToSigningOrSubmitRequest(d.communityIntroUid) + } + function proceedToSigningOrSubmitRequest(uidOfComponentThisFunctionIsCalledFrom) { const selected = d.getSelectedAddresses() root.prepareForSigning(selected.airdropAddress, selected.addresses) @@ -406,7 +409,7 @@ StatusStackModal { stackItems: [ StatusScrollView { - id: scrollView + id: scrollView contentWidth: availableWidth ColumnLayout { @@ -418,7 +421,7 @@ StatusStackModal { Layout.preferredWidth: 64 Layout.preferredHeight: Layout.preferredWidth visible: ((image.status == Image.Loading) || - (image.status == Image.Ready)) && + (image.status == Image.Ready)) && !image.isError image.source: root.communityIcon }