status-desktop/storybook/pages/CommunityMembershipSetupDialogPage.qml
Lukáš Tinkl 93d808d020 fix(CommunityMembershipSetupDialog): wait for the Join Permission response only
- introduce a new boolean property `checkingPermissionToJoinInProgress`
and use it to enable/disable the Join (share addresses) button when
joining a community
- we don't have to wait for both join and channels permissions check to
finish, as the former is much faster
- renamed `joinPermissionsCheckSuccessful` to
`joinPermissionsCheckCompletedWithoutErrors` to avoid confusion

Fixes #14680
2024-05-17 14:26:55 +02:00

256 lines
8.9 KiB
QML

import QtQuick 2.15
import QtQuick.Controls 2.15
import QtQuick.Layouts 1.15
import QtQml 2.15
import Storybook 1.0
import Models 1.0
import shared.popups 1.0
import utils 1.0
import AppLayouts.Wallet.stores 1.0
SplitView {
SplitView {
id: root
orientation: Qt.Vertical
SplitView.fillWidth: true
Logs { id: logs }
readonly property WalletAssetsStore walletAssetStore: WalletAssetsStore {
assetsWithFilteredBalances: groupedAccountsAssetsModel
}
function openDialog() {
popupComponent.createObject(popupBg)
}
Component.onCompleted: openDialog()
Component {
id: popupComponent
CommunityMembershipSetupDialog {
anchors.centerIn: parent
modal: false
visible: true
closePolicy: Popup.NoAutoClose
isEditMode: ctrlIsEditMode.checked
communityId: "ddls"
communityName: ctrlCommunityName.text
communityIcon: {
if (ctrlIconStatus.checked)
return ModelsData.icons.status
if (ctrlIconCryptoPunks.checked)
return ModelsData.icons.cryptPunks
if (ctrlIconRarible.checked)
return ModelsData.icons.rarible
if (ctrlIconNone.checked)
return ""
}
introMessage: ctrlIntro.text.arg(communityName)
isInvitationPending: ctrlIsInvitationPending.checked
requirementsCheckPending: ctrlRequirementsCheckPending.checked
checkingPermissionToJoinInProgress: ctrlCheckingPermissionToJoinInProgress.checked
joinPermissionsCheckCompletedWithoutErrors: ctrlJoinPermissionsCheckCompletedWithoutErrors.checked
walletAccountsModel: WalletAccountsModel {}
walletAssetsModel: root.walletAssetStore.groupedAccountAssetsModel
walletCollectiblesModel: ListModel {}
permissionsModel: ctrlPermissionsModel.currentValue
assetsModel: AssetsModel {}
collectiblesModel: CollectiblesModel {}
onCancelMembershipRequest: logs.logEvent("CommunityMembershipSetupDialog::onCancelMembershipRequest()")
onPrepareForSigning: logs.logEvent("CommunityMembershipSetupDialog::onPrepareForSigning", ["airdropAddress", "sharedAddresses"], arguments)
onJoinCommunity: logs.logEvent("CommunityMembershipSetupDialog::onJoinCommunity")
onEditRevealedAddresses: logs.logEvent("CommunityMembershipSetupDialog::editRevealedAddresses")
onSignProfileKeypairAndAllNonKeycardKeypairs: logs.logEvent("CommunityMembershipSetupDialog::onSignProfileKeypairAndAllNonKeycardKeypairs")
onSignSharedAddressesForKeypair: logs.logEvent("CommunityMembershipSetupDialog::onSignSharedAddressesForKeypair", ["keyUid"], arguments)
onSharedAddressesUpdated: logs.logEvent("CommunityMembershipSetupDialog::onSharedAddressesUpdated", ["sharedAddresses"], arguments)
getCurrencyAmount: function (balance, symbol) {
return ({
amount: balance,
symbol: symbol.toUpperCase(),
displayDecimals: 2,
stripTrailingZeroes: false
})
}
}
}
Item {
SplitView.fillWidth: true
SplitView.fillHeight: true
PopupBackground {
id: popupBg
anchors.fill: parent
}
Button {
anchors.centerIn: parent
text: "Reopen"
onClicked: root.openDialog()
}
}
LogsAndControlsPanel {
id: logsAndControlsPanel
SplitView.minimumHeight: 100
SplitView.preferredHeight: 200
logsView.logText: logs.logText
}
}
Pane {
SplitView.minimumWidth: 300
SplitView.preferredWidth: 300
ColumnLayout {
anchors.fill: parent
Label {
Layout.fillWidth: true
text: "Community name"
font.weight: Font.Bold
}
TextField {
id: ctrlCommunityName
Layout.fillWidth: true
text: "Status"
}
Label {
Layout.fillWidth: true
text: "Intro"
font.weight: Font.Bold
}
TextField {
id: ctrlIntro
Layout.fillWidth: true
text: "%1 sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo.
1. Ut enim ad minim veniam
2. Excepteur sint occaecat cupidatat non proident
3. Duis aute irure
4. Dolore eu fugiat nulla pariatur
5. 🚗 consectetur adipiscing elit
Nemo enim 😋 ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt."
}
ColumnLayout {
Label {
Layout.fillWidth: true
text: "Icon:"
font.weight: Font.Bold
}
RadioButton {
id: ctrlIconStatus
checked: true
text: "Status"
}
RadioButton {
id: ctrlIconCryptoPunks
text: "Crypto Punks"
}
RadioButton {
id: ctrlIconRarible
text: "Rarible"
}
RadioButton {
id: ctrlIconNone
text: "None"
}
}
CheckBox {
id: ctrlIsInvitationPending
text: "Is invitation pending"
}
CheckBox {
id: ctrlIsEditMode
visible: !ctrlIsInvitationPending.checked
text: "Is edit mode"
}
ColumnLayout {
visible: !ctrlIsInvitationPending.checked
RowLayout {
Layout.fillWidth: true
Layout.leftMargin: 12
Label {
text: "Permissions:"
}
ComboBox {
Layout.fillWidth: true
id: ctrlPermissionsModel
textRole: "text"
valueRole: "value"
model: [
{ value: PermissionsModel.complexCombinedPermissionsModel, text: "complexCombined" },
{ value: PermissionsModel.complexCombinedPermissionsModelNotMet, text: "complexCombinedNotMet" },
{ value: PermissionsModel.complexPermissionsModel, text: "complex" },
{ value: PermissionsModel.complexPermissionsModelNotMet, text: "complexNotMet" },
{ value: PermissionsModel.channelsOnlyPermissionsModel, text: "channelsOnly" },
{ value: PermissionsModel.channelsOnlyPermissionsModelNotMet, text: "channelsOnlyNotMet" },
{ value: null, text: "null" }
]
}
}
}
CheckBox {
Layout.leftMargin: 12
id: ctrlRequirementsCheckPending
visible: !ctrlIsInvitationPending.checked
text: "Requirements check pending"
}
CheckBox {
Layout.leftMargin: 20
id: ctrlCheckingPermissionToJoinInProgress
enabled: !ctrlRequirementsCheckPending.checked
visible: !ctrlIsInvitationPending.checked
text: "Checking perms to join"
Binding on checked {
when: ctrlRequirementsCheckPending.checked
value: true
restoreMode: Binding.RestoreValue
}
}
CheckBox {
Layout.leftMargin: 12
id: ctrlJoinPermissionsCheckCompletedWithoutErrors
visible: !ctrlIsInvitationPending.checked
text: "Join perm. check completed w/o errors"
checked: true
}
Item {
Layout.fillHeight: true
}
}
}
}
// category: Popups
// https://www.figma.com/file/17fc13UBFvInrLgNUKJJg5/Kuba%E2%8E%9CDesktop?node-id=31461%3A563897&mode=dev