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
This commit is contained in:
Noelia 2024-03-27 18:40:49 +01:00 committed by Jonathan Rainville
parent 4b22035602
commit fda0eaa915
2 changed files with 65 additions and 50 deletions

View File

@ -128,8 +128,14 @@ StackLayout {
}) })
} }
onInvitationPendingClicked: { onInvitationPendingClicked: {
root.rootStore.cancelPendingRequest(communityId) Global.openPopup(communityMembershipSetupDialogComponent, {
joinCommunityView.isInvitationPending = root.rootStore.isMyCommunityRequestPending(communityId) communityId: joinCommunityView.communityId,
isInvitationPending: joinCommunityView.isInvitationPending,
communityName: communityData.name,
introMessage: communityData.introMessage,
communityIcon: communityData.image,
accessType: communityData.access
})
} }
Connections { Connections {
@ -196,8 +202,14 @@ StackLayout {
}) })
} }
onInvitationPendingClicked: { onInvitationPendingClicked: {
root.rootStore.cancelPendingRequest(chatView.communityId) Global.openPopup(communityMembershipSetupDialogComponent, {
chatView.isInvitationPending = root.rootStore.isMyCommunityRequestPending(chatView.communityId) 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
})
} }
} }
} }

View File

@ -77,50 +77,7 @@ StatusStackModal {
rightButtons: [d.shareButton, finishButton] rightButtons: [d.shareButton, finishButton]
finishButton: StatusButton { finishButton: root.isInvitationPending ? d.cancelRequestButton : d.shareAddressesButton
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)
}
}
backButton: StatusBackButton { backButton: StatusBackButton {
visible: !!root.replaceLoader.item 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) { function proceedToSigningOrSubmitRequest(uidOfComponentThisFunctionIsCalledFrom) {
const selected = d.getSelectedAddresses() const selected = d.getSelectedAddresses()
root.prepareForSigning(selected.airdropAddress, selected.addresses) root.prepareForSigning(selected.airdropAddress, selected.addresses)