mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-09 22:06:25 +00:00
fix(@desktop/communities): request to join fixes (#14287)
This commit is contained in:
parent
9ad27133d0
commit
02d80429d6
@ -16,6 +16,7 @@ import ../../../../app_service/service/token/service as token_service
|
|||||||
import ../../../../app_service/service/community_tokens/service as community_tokens_service
|
import ../../../../app_service/service/community_tokens/service as community_tokens_service
|
||||||
import ../../../../app_service/service/visual_identity/service as procs_from_visual_identity_service
|
import ../../../../app_service/service/visual_identity/service as procs_from_visual_identity_service
|
||||||
import ../../../../app_service/service/shared_urls/service as shared_urls_service
|
import ../../../../app_service/service/shared_urls/service as shared_urls_service
|
||||||
|
import ../../../../app_service/common/types
|
||||||
import backend/collectibles as backend_collectibles
|
import backend/collectibles as backend_collectibles
|
||||||
|
|
||||||
import ../../../core/signals/types
|
import ../../../core/signals/types
|
||||||
@ -420,6 +421,16 @@ proc init*(self: Controller) =
|
|||||||
continue
|
continue
|
||||||
self.delegate.onCommunityMemberMessagesDeleted(messagesIds)
|
self.delegate.onCommunityMemberMessagesDeleted(messagesIds)
|
||||||
|
|
||||||
|
self.events.on(SIGNAL_COMMUNITY_MY_REQUEST_ADDED) do(e:Args):
|
||||||
|
let args = CommunityRequestArgs(e)
|
||||||
|
if args.communityRequest.communityId == self.sectionId:
|
||||||
|
self.delegate.updateRequestToJoinState(RequestToJoinState.Requested)
|
||||||
|
|
||||||
|
self.events.on(SIGNAL_REQUEST_TO_JOIN_COMMUNITY_CANCELED) do(e:Args):
|
||||||
|
let args = community_service.CommunityIdArgs(e)
|
||||||
|
if args.communityId == self.sectionId:
|
||||||
|
self.delegate.updateRequestToJoinState(RequestToJoinState.None)
|
||||||
|
|
||||||
proc isCommunity*(self: Controller): bool =
|
proc isCommunity*(self: Controller): bool =
|
||||||
return self.isCommunitySection
|
return self.isCommunitySection
|
||||||
|
|
||||||
@ -759,3 +770,6 @@ proc getWalletAccounts*(self: Controller): seq[wallet_account_service.WalletAcco
|
|||||||
|
|
||||||
proc deleteCommunityMemberMessages*(self: Controller, memberPubKey: string, messageId: string, chatId: string) =
|
proc deleteCommunityMemberMessages*(self: Controller, memberPubKey: string, messageId: string, chatId: string) =
|
||||||
self.messageService.deleteCommunityMemberMessages(self.getMySectionId(), memberPubKey, messageId, chatId)
|
self.messageService.deleteCommunityMemberMessages(self.getMySectionId(), memberPubKey, messageId, chatId)
|
||||||
|
|
||||||
|
proc isMyCommunityRequestPending*(self: Controller): bool =
|
||||||
|
return self.communityService.isMyCommunityRequestPending(self.sectionId)
|
@ -9,6 +9,7 @@ import ../../../../app_service/service/message/service as message_service
|
|||||||
import ../../../../app_service/service/gif/service as gif_service
|
import ../../../../app_service/service/gif/service as gif_service
|
||||||
import ../../../../app_service/service/mailservers/service as mailservers_service
|
import ../../../../app_service/service/mailservers/service as mailservers_service
|
||||||
import ../../../../app_service/service/shared_urls/service as shared_urls_service
|
import ../../../../app_service/service/shared_urls/service as shared_urls_service
|
||||||
|
import ../../../../app_service/common/types
|
||||||
|
|
||||||
import model as chats_model
|
import model as chats_model
|
||||||
import item as chat_item
|
import item as chat_item
|
||||||
@ -421,3 +422,6 @@ method communityContainsChat*(self: AccessInterface, chatId: string): bool {.bas
|
|||||||
|
|
||||||
method openCommunityChatAndScrollToMessage*(self: AccessInterface, chatId: string, messageId: string) {.base.} =
|
method openCommunityChatAndScrollToMessage*(self: AccessInterface, chatId: string, messageId: string) {.base.} =
|
||||||
raise newException(ValueError, "No implementation available")
|
raise newException(ValueError, "No implementation available")
|
||||||
|
|
||||||
|
method updateRequestToJoinState*(self: AccessInterface, state: RequestToJoinState) {.base.} =
|
||||||
|
raise newException(ValueError, "No implementation available")
|
||||||
|
@ -443,6 +443,11 @@ method onChatsLoaded*(
|
|||||||
let community = self.controller.getMyCommunity()
|
let community = self.controller.getMyCommunity()
|
||||||
self.view.setAmIMember(community.joined)
|
self.view.setAmIMember(community.joined)
|
||||||
self.view.setWaitingOnNewCommunityOwnerToConfirmRequestToRejoin(self.controller.waitingOnNewCommunityOwnerToConfirmRequestToRejoin(community.id))
|
self.view.setWaitingOnNewCommunityOwnerToConfirmRequestToRejoin(self.controller.waitingOnNewCommunityOwnerToConfirmRequestToRejoin(community.id))
|
||||||
|
var requestToJoinState = RequestToJoinState.None
|
||||||
|
if self.controller.isMyCommunityRequestPending():
|
||||||
|
requestToJoinState = RequestToJoinState.Requested
|
||||||
|
|
||||||
|
self.view.setRequestToJoinState(requestToJoinState)
|
||||||
self.initCommunityTokenPermissionsModel(channelGroup)
|
self.initCommunityTokenPermissionsModel(channelGroup)
|
||||||
self.onCommunityCheckAllChannelsPermissionsResponse(channelGroup.channelPermissions)
|
self.onCommunityCheckAllChannelsPermissionsResponse(channelGroup.channelPermissions)
|
||||||
self.controller.asyncCheckPermissionsToJoin()
|
self.controller.asyncCheckPermissionsToJoin()
|
||||||
@ -1075,6 +1080,7 @@ method onJoinedCommunity*(self: Module) =
|
|||||||
self.rebuildCommunityTokenPermissionsModel()
|
self.rebuildCommunityTokenPermissionsModel()
|
||||||
self.view.setAmIMember(true)
|
self.view.setAmIMember(true)
|
||||||
self.view.setWaitingOnNewCommunityOwnerToConfirmRequestToRejoin(false)
|
self.view.setWaitingOnNewCommunityOwnerToConfirmRequestToRejoin(false)
|
||||||
|
self.view.setRequestToJoinState(RequestToJoinState.None)
|
||||||
|
|
||||||
method onMarkAllMessagesRead*(self: Module, chat: ChatDto) =
|
method onMarkAllMessagesRead*(self: Module, chat: ChatDto) =
|
||||||
self.updateBadgeNotifications(chat, hasUnreadMessages=false, unviewedMentionsCount=0)
|
self.updateBadgeNotifications(chat, hasUnreadMessages=false, unviewedMentionsCount=0)
|
||||||
@ -1580,3 +1586,6 @@ method openCommunityChatAndScrollToMessage*(self: Module, chatId: string, messag
|
|||||||
if chatId in self.chatContentModules:
|
if chatId in self.chatContentModules:
|
||||||
self.setActiveItem(chatId)
|
self.setActiveItem(chatId)
|
||||||
self.chatContentModules[chatId].scrollToMessage(messageId)
|
self.chatContentModules[chatId].scrollToMessage(messageId)
|
||||||
|
|
||||||
|
method updateRequestToJoinState*(self: Module, state: RequestToJoinState) =
|
||||||
|
self.view.setRequestToJoinState(state)
|
||||||
|
@ -4,6 +4,7 @@ import item, active_item
|
|||||||
import ../../shared_models/user_model as user_model
|
import ../../shared_models/user_model as user_model
|
||||||
import ../../shared_models/message_model as member_msg_model
|
import ../../shared_models/message_model as member_msg_model
|
||||||
import ../../shared_models/token_permissions_model
|
import ../../shared_models/token_permissions_model
|
||||||
|
import ../../../../app_service/common/types
|
||||||
import io_interface
|
import io_interface
|
||||||
|
|
||||||
QtObject:
|
QtObject:
|
||||||
@ -35,6 +36,7 @@ QtObject:
|
|||||||
allChannelsAreHiddenBecauseNotPermitted: bool
|
allChannelsAreHiddenBecauseNotPermitted: bool
|
||||||
memberMessagesModel: member_msg_model.Model
|
memberMessagesModel: member_msg_model.Model
|
||||||
memberMessagesModelVariant: QVariant
|
memberMessagesModelVariant: QVariant
|
||||||
|
requestToJoinState: RequestToJoinState
|
||||||
|
|
||||||
|
|
||||||
proc delete*(self: View) =
|
proc delete*(self: View) =
|
||||||
@ -79,6 +81,7 @@ QtObject:
|
|||||||
result.isWaitingOnNewCommunityOwnerToConfirmRequestToRejoin = false
|
result.isWaitingOnNewCommunityOwnerToConfirmRequestToRejoin = false
|
||||||
result.memberMessagesModel = member_msg_model.newModel()
|
result.memberMessagesModel = member_msg_model.newModel()
|
||||||
result.memberMessagesModelVariant = newQVariant(result.memberMessagesModel)
|
result.memberMessagesModelVariant = newQVariant(result.memberMessagesModel)
|
||||||
|
result.requestToJoinState = RequestToJoinState.None
|
||||||
|
|
||||||
proc load*(self: View) =
|
proc load*(self: View) =
|
||||||
self.delegate.viewDidLoad()
|
self.delegate.viewDidLoad()
|
||||||
@ -534,3 +537,18 @@ QtObject:
|
|||||||
|
|
||||||
proc openCommunityChatAndScrollToMessage*(self: View, chatId: string, messageId: string) {.slot.} =
|
proc openCommunityChatAndScrollToMessage*(self: View, chatId: string, messageId: string) {.slot.} =
|
||||||
self.delegate.openCommunityChatAndScrollToMessage(chatId, messageId)
|
self.delegate.openCommunityChatAndScrollToMessage(chatId, messageId)
|
||||||
|
|
||||||
|
proc requestToJoinStateChanged*(self: View) {.signal.}
|
||||||
|
|
||||||
|
proc getRequestToJoinState*(self: View): int {.slot.} =
|
||||||
|
return self.requestToJoinState.int
|
||||||
|
|
||||||
|
QtProperty[int] requestToJoinState:
|
||||||
|
read = getRequestToJoinState
|
||||||
|
notify = requestToJoinStateChanged
|
||||||
|
|
||||||
|
proc setRequestToJoinState*(self: View, requestToJoinState: RequestToJoinState) =
|
||||||
|
if self.requestToJoinState == requestToJoinState:
|
||||||
|
return
|
||||||
|
self.requestToJoinState = requestToJoinState
|
||||||
|
self.requestToJoinStateChanged()
|
@ -359,6 +359,7 @@ method communityAccessRequested*(self: Module, communityId: string) =
|
|||||||
method communityAccessFailed*(self: Module, communityId, err: string) =
|
method communityAccessFailed*(self: Module, communityId, err: string) =
|
||||||
error "communities: ", err
|
error "communities: ", err
|
||||||
self.cleanJoinEditCommunityData()
|
self.cleanJoinEditCommunityData()
|
||||||
|
self.delegate.updateRequestToJoinState(communityId, RequestToJoinState.None)
|
||||||
self.view.communityAccessFailed(communityId, err)
|
self.view.communityAccessFailed(communityId, err)
|
||||||
|
|
||||||
method communityEditSharedAddressesSucceeded*(self: Module, communityId: string) =
|
method communityEditSharedAddressesSucceeded*(self: Module, communityId: string) =
|
||||||
@ -845,6 +846,9 @@ method joinCommunityOrEditSharedAddresses*(self: Module) =
|
|||||||
addressesToShare,
|
addressesToShare,
|
||||||
airdropAddress,
|
airdropAddress,
|
||||||
signatures)
|
signatures)
|
||||||
|
|
||||||
|
self.delegate.updateRequestToJoinState(self.joiningCommunityDetails.communityId, RequestToJoinState.InProgress)
|
||||||
|
|
||||||
# The user reveals address after sending join coummunity request, before that he sees only the name of the wallet account, not the address.
|
# The user reveals address after sending join coummunity request, before that he sees only the name of the wallet account, not the address.
|
||||||
self.events.emit(MARK_WALLET_ADDRESSES_AS_SHOWN, WalletAddressesArgs(addresses: addressesToShare))
|
self.events.emit(MARK_WALLET_ADDRESSES_AS_SHOWN, WalletAddressesArgs(addresses: addressesToShare))
|
||||||
return
|
return
|
||||||
|
@ -16,7 +16,7 @@ import app_service/service/community_tokens/community_collectible_owner
|
|||||||
import app_service/service/shared_urls/service as urls_service
|
import app_service/service/shared_urls/service as urls_service
|
||||||
import app_service/service/network/service as network_service
|
import app_service/service/network/service as network_service
|
||||||
import app_service/service/network/dto as network_dto
|
import app_service/service/network/dto as network_dto
|
||||||
from app_service/common/types import StatusType, ContractTransactionStatus, MembershipRequestState, Shard
|
from app_service/common/types import StatusType, ContractTransactionStatus, MembershipRequestState, Shard, RequestToJoinState
|
||||||
|
|
||||||
import app/global/app_signals
|
import app/global/app_signals
|
||||||
import app/core/eventemitter
|
import app/core/eventemitter
|
||||||
@ -424,6 +424,9 @@ method checkIfAddressWasCopied*(self: AccessInterface, value: string) {.base.} =
|
|||||||
method openSectionChatAndMessage*(self: AccessInterface, sectionId: string, chatId: string, messageId: string) {.base.} =
|
method openSectionChatAndMessage*(self: AccessInterface, sectionId: string, chatId: string, messageId: string) {.base.} =
|
||||||
raise newException(ValueError, "No implementation available")
|
raise newException(ValueError, "No implementation available")
|
||||||
|
|
||||||
|
method updateRequestToJoinState*(self: AccessInterface, sectionId: string, requestToJoinState: RequestToJoinState) {.base.} =
|
||||||
|
raise newException(ValueError, "No implementation available")
|
||||||
|
|
||||||
# This way (using concepts) is used only for the modules managed by AppController
|
# This way (using concepts) is used only for the modules managed by AppController
|
||||||
type
|
type
|
||||||
DelegateInterface* = concept c
|
DelegateInterface* = concept c
|
||||||
|
@ -350,7 +350,7 @@ proc createChannelGroupItem[T](self: Module[T], channelGroup: ChannelGroupDto):
|
|||||||
let state = memberState.toMembershipRequestState()
|
let state = memberState.toMembershipRequestState()
|
||||||
case state:
|
case state:
|
||||||
of MembershipRequestState.Banned, MembershipRequestState.BannedWithAllMessagesDelete, MembershipRequestState.UnbannedPending:
|
of MembershipRequestState.Banned, MembershipRequestState.BannedWithAllMessagesDelete, MembershipRequestState.UnbannedPending:
|
||||||
bannedMembers.add(self.createMemberItem(memberId, state, MemberRole.None))
|
bannedMembers.add(self.createMemberItem(memberId, "", state, MemberRole.None))
|
||||||
else:
|
else:
|
||||||
discard
|
discard
|
||||||
|
|
||||||
@ -392,7 +392,7 @@ proc createChannelGroupItem[T](self: Module[T], channelGroup: ChannelGroupDto):
|
|||||||
elif not member.joined:
|
elif not member.joined:
|
||||||
state = MembershipRequestState.AwaitingAddress
|
state = MembershipRequestState.AwaitingAddress
|
||||||
|
|
||||||
result = self.createMemberItem(member.id, state, member.role)
|
result = self.createMemberItem(member.id, "", state, member.role)
|
||||||
),
|
),
|
||||||
# pendingRequestsToJoin
|
# pendingRequestsToJoin
|
||||||
if (isCommunity): communityDetails.pendingRequestsToJoin.map(x => pending_request_item.initItem(
|
if (isCommunity): communityDetails.pendingRequestsToJoin.map(x => pending_request_item.initItem(
|
||||||
@ -408,11 +408,11 @@ proc createChannelGroupItem[T](self: Module[T], channelGroup: ChannelGroupDto):
|
|||||||
bannedMembers,
|
bannedMembers,
|
||||||
# pendingMemberRequests
|
# pendingMemberRequests
|
||||||
if (isCommunity): communityDetails.pendingRequestsToJoin.map(proc(requestDto: CommunityMembershipRequestDto): MemberItem =
|
if (isCommunity): communityDetails.pendingRequestsToJoin.map(proc(requestDto: CommunityMembershipRequestDto): MemberItem =
|
||||||
result = self.createMemberItem(requestDto.publicKey, MembershipRequestState(requestDto.state), MemberRole.None)
|
result = self.createMemberItem(requestDto.publicKey, requestDto.id, MembershipRequestState(requestDto.state), MemberRole.None)
|
||||||
) else: @[],
|
) else: @[],
|
||||||
# declinedMemberRequests
|
# declinedMemberRequests
|
||||||
if (isCommunity): communityDetails.declinedRequestsToJoin.map(proc(requestDto: CommunityMembershipRequestDto): MemberItem =
|
if (isCommunity): communityDetails.declinedRequestsToJoin.map(proc(requestDto: CommunityMembershipRequestDto): MemberItem =
|
||||||
result = self.createMemberItem(requestDto.publicKey, MembershipRequestState(requestDto.state), MemberRole.None)
|
result = self.createMemberItem(requestDto.publicKey, requestDto.id, MembershipRequestState(requestDto.state), MemberRole.None)
|
||||||
) else: @[],
|
) else: @[],
|
||||||
channelGroup.encrypted,
|
channelGroup.encrypted,
|
||||||
communityTokensItems,
|
communityTokensItems,
|
||||||
@ -1392,8 +1392,7 @@ method ephemeralNotificationClicked*[T](self: Module[T], id: int64) =
|
|||||||
self.osNotificationClicked(item.details)
|
self.osNotificationClicked(item.details)
|
||||||
|
|
||||||
method onMyRequestAdded*[T](self: Module[T]) =
|
method onMyRequestAdded*[T](self: Module[T]) =
|
||||||
self.displayEphemeralNotification("Your Request has been submitted", "" , "checkmark-circle", false, EphemeralNotificationType.Success.int, "")
|
self.displayEphemeralNotification("Your Request has been submitted", "" , "checkmark-circle", false, EphemeralNotificationType.Success.int, "")
|
||||||
|
|
||||||
|
|
||||||
proc switchToContactOrDisplayUserProfile[T](self: Module[T], publicKey: string) =
|
proc switchToContactOrDisplayUserProfile[T](self: Module[T], publicKey: string) =
|
||||||
let contact = self.controller.getContact(publicKey)
|
let contact = self.controller.getContact(publicKey)
|
||||||
@ -1644,7 +1643,11 @@ method openSectionChatAndMessage*[T](self: Module[T], sectionId: string, chatId:
|
|||||||
if sectionId in self.channelGroupModules:
|
if sectionId in self.channelGroupModules:
|
||||||
self.channelGroupModules[sectionId].openCommunityChatAndScrollToMessage(chatId, messageId)
|
self.channelGroupModules[sectionId].openCommunityChatAndScrollToMessage(chatId, messageId)
|
||||||
|
|
||||||
proc createMemberItem*[T](self: Module[T], memberId: string, state: MembershipRequestState, role: MemberRole): MemberItem =
|
method updateRequestToJoinState*[T](self: Module[T], sectionId: string, requestToJoinState: RequestToJoinState) =
|
||||||
|
if sectionId in self.channelGroupModules:
|
||||||
|
self.channelGroupModules[sectionId].updateRequestToJoinState(requestToJoinState)
|
||||||
|
|
||||||
|
proc createMemberItem*[T](self: Module[T], memberId: string, requestId: string, state: MembershipRequestState, role: MemberRole): MemberItem =
|
||||||
let contactDetails = self.controller.getContactDetails(memberId)
|
let contactDetails = self.controller.getContactDetails(memberId)
|
||||||
let status = self.controller.getStatusForContactWithId(memberId)
|
let status = self.controller.getStatusForContactWithId(memberId)
|
||||||
return initMemberItem(
|
return initMemberItem(
|
||||||
@ -1662,6 +1665,7 @@ proc createMemberItem*[T](self: Module[T], memberId: string, state: MembershipRe
|
|||||||
isVerified = contactDetails.dto.isContactVerified(),
|
isVerified = contactDetails.dto.isContactVerified(),
|
||||||
memberRole = role,
|
memberRole = role,
|
||||||
membershipRequestState = state,
|
membershipRequestState = state,
|
||||||
|
requestToJoinId = requestId
|
||||||
)
|
)
|
||||||
|
|
||||||
{.pop.}
|
{.pop.}
|
||||||
|
@ -91,3 +91,8 @@ type TokenType* {.pure.} = enum
|
|||||||
ERC1155 = 3,
|
ERC1155 = 3,
|
||||||
Unknown = 4,
|
Unknown = 4,
|
||||||
ENS = 5
|
ENS = 5
|
||||||
|
|
||||||
|
type RequestToJoinState* {.pure.} = enum
|
||||||
|
None = 0
|
||||||
|
InProgress
|
||||||
|
Requested
|
@ -2055,7 +2055,7 @@ QtObject:
|
|||||||
|
|
||||||
community.pendingRequestsToJoin.delete(i)
|
community.pendingRequestsToJoin.delete(i)
|
||||||
self.communities[communityId] = community
|
self.communities[communityId] = community
|
||||||
self.events.emit(SIGNAL_REQUEST_TO_JOIN_COMMUNITY_CANCELED, Args())
|
self.events.emit(SIGNAL_REQUEST_TO_JOIN_COMMUNITY_CANCELED, CommunityIdArgs(communityId: communityId))
|
||||||
checkAndEmitACNotificationsFromResponse(self.events, response.result{"activityCenterNotifications"})
|
checkAndEmitACNotificationsFromResponse(self.events, response.result{"activityCenterNotifications"})
|
||||||
return
|
return
|
||||||
|
|
||||||
|
@ -38,7 +38,9 @@ Nemo enim 😋 ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit,
|
|||||||
|
|
||||||
// Overlay component:
|
// Overlay component:
|
||||||
property bool requirementsMet: true
|
property bool requirementsMet: true
|
||||||
property bool isInvitationPending: true
|
property int requestToJoinState: Constants.RequestToJoinState.None
|
||||||
|
property bool isInvitationPending: requestToJoinState !== Constants.RequestToJoinState.None
|
||||||
|
|
||||||
property bool isJoinRequestRejected: false
|
property bool isJoinRequestRejected: false
|
||||||
property bool requiresRequest: false
|
property bool requiresRequest: false
|
||||||
|
|
||||||
@ -115,7 +117,7 @@ Nemo enim 😋 ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit,
|
|||||||
channelDesc: d.channelDesc
|
channelDesc: d.channelDesc
|
||||||
joinCommunity: d.joinCommunity
|
joinCommunity: d.joinCommunity
|
||||||
accessType: d.accessType
|
accessType: d.accessType
|
||||||
isInvitationPending: d.isInvitationPending
|
requestToJoinState: d.requestToJoinState
|
||||||
|
|
||||||
// Blur background properties:
|
// Blur background properties:
|
||||||
membersCount: d.membersCount
|
membersCount: d.membersCount
|
||||||
@ -226,12 +228,15 @@ Nemo enim 😋 ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit,
|
|||||||
|
|
||||||
CheckBox {
|
CheckBox {
|
||||||
checked: d.isInvitationPending
|
checked: d.isInvitationPending
|
||||||
onCheckedChanged: d.isInvitationPending = checked
|
onCheckedChanged: {
|
||||||
|
d.isInvitationPending = checked
|
||||||
|
d.requestToJoinState = d.isInvitationPending ? Constants.RequestToJoinState.Requested : Constants.RequestToJoinState.None
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ColumnLayout {
|
ColumnLayout {
|
||||||
visible: !d.isInvitationPending
|
visible: d.requestToJoinState === Constants.RequestToJoinState.None
|
||||||
Label {
|
Label {
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
text: "Access type:"
|
text: "Access type:"
|
||||||
@ -260,7 +265,7 @@ Nemo enim 😋 ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit,
|
|||||||
channelName: d.chanelName
|
channelName: d.chanelName
|
||||||
joinCommunity: d.joinCommunity
|
joinCommunity: d.joinCommunity
|
||||||
requirementsMet: d.requirementsMet
|
requirementsMet: d.requirementsMet
|
||||||
isInvitationPending: d.isInvitationPending
|
isInvitationPending: d.requestToJoinState !== Constants.RequestToJoinState.None
|
||||||
isJoinRequestRejected: d.isJoinRequestRejected
|
isJoinRequestRejected: d.isJoinRequestRejected
|
||||||
requiresRequest: d.requiresRequest
|
requiresRequest: d.requiresRequest
|
||||||
|
|
||||||
|
@ -40,6 +40,7 @@ StackLayout {
|
|||||||
readonly property bool isTokenMasterOwner: sectionItemModel.memberRole === Constants.memberRole.tokenMaster
|
readonly property bool isTokenMasterOwner: sectionItemModel.memberRole === Constants.memberRole.tokenMaster
|
||||||
readonly property bool isControlNode: sectionItemModel.isControlNode
|
readonly property bool isControlNode: sectionItemModel.isControlNode
|
||||||
readonly property bool isPrivilegedUser: isControlNode || isOwner || isAdmin || isTokenMasterOwner
|
readonly property bool isPrivilegedUser: isControlNode || isOwner || isAdmin || isTokenMasterOwner
|
||||||
|
readonly property int isInvitationPending: root.rootStore.chatCommunitySectionModule.requestToJoinState !== Constants.RequestToJoinState.None
|
||||||
|
|
||||||
property bool communitySettingsDisabled
|
property bool communitySettingsDisabled
|
||||||
|
|
||||||
@ -113,29 +114,20 @@ StackLayout {
|
|||||||
viewAndPostHoldingsModel: root.permissionsStore.viewAndPostPermissionsModel
|
viewAndPostHoldingsModel: root.permissionsStore.viewAndPostPermissionsModel
|
||||||
assetsModel: root.rootStore.assetsModel
|
assetsModel: root.rootStore.assetsModel
|
||||||
collectiblesModel: root.rootStore.collectiblesModel
|
collectiblesModel: root.rootStore.collectiblesModel
|
||||||
isInvitationPending: root.rootStore.isMyCommunityRequestPending(communityId)
|
requestToJoinState: root.rootStore.chatCommunitySectionModule.requestToJoinState
|
||||||
notificationCount: activityCenterStore.unreadNotificationsCount
|
notificationCount: activityCenterStore.unreadNotificationsCount
|
||||||
hasUnseenNotifications: activityCenterStore.hasUnseenNotifications
|
hasUnseenNotifications: activityCenterStore.hasUnseenNotifications
|
||||||
openCreateChat: rootStore.openCreateChat
|
openCreateChat: rootStore.openCreateChat
|
||||||
onNotificationButtonClicked: Global.openActivityCenterPopup()
|
onNotificationButtonClicked: Global.openActivityCenterPopup()
|
||||||
onAdHocChatButtonClicked: rootStore.openCloseCreateChatView()
|
onAdHocChatButtonClicked: rootStore.openCloseCreateChatView()
|
||||||
onRequestToJoinClicked: {
|
onRequestToJoinClicked: {
|
||||||
Global.communityIntroPopupRequested(joinCommunityView.communityId, communityData.name, communityData.introMessage,
|
Global.communityIntroPopupRequested(joinCommunityView.communityId, communityData.name,
|
||||||
communityData.image, root.rootStore.isMyCommunityRequestPending(communityId))
|
communityData.introMessage, communityData.image,
|
||||||
|
root.isInvitationPending)
|
||||||
}
|
}
|
||||||
onInvitationPendingClicked: {
|
onInvitationPendingClicked: {
|
||||||
Global.communityIntroPopupRequested(joinCommunityView.communityId, communityData.name, communityData.introMessage,
|
Global.communityIntroPopupRequested(joinCommunityView.communityId, communityData.name, communityData.introMessage,
|
||||||
communityData.image, root.rootStore.isMyCommunityRequestPending(communityId))
|
communityData.image, root.isInvitationPending)
|
||||||
joinCommunityView.isInvitationPending = root.rootStore.isMyCommunityRequestPending(communityId)
|
|
||||||
}
|
|
||||||
|
|
||||||
Connections {
|
|
||||||
target: root.rootStore.communitiesModuleInst
|
|
||||||
function onCommunityAccessRequested(communityId: string) {
|
|
||||||
if (communityId === joinCommunityView.communityId) {
|
|
||||||
joinCommunityView.isInvitationPending = root.rootStore.isMyCommunityRequestPending(communityId)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -168,7 +160,7 @@ StackLayout {
|
|||||||
viewAndPostPermissionsModel: root.permissionsStore.viewAndPostPermissionsModel
|
viewAndPostPermissionsModel: root.permissionsStore.viewAndPostPermissionsModel
|
||||||
assetsModel: root.rootStore.assetsModel
|
assetsModel: root.rootStore.assetsModel
|
||||||
collectiblesModel: root.rootStore.collectiblesModel
|
collectiblesModel: root.rootStore.collectiblesModel
|
||||||
isInvitationPending: root.rootStore.isMyCommunityRequestPending(chatView.communityId)
|
requestToJoinState: sectionItem.requestToJoinState
|
||||||
|
|
||||||
isPendingOwnershipRequest: root.isPendingOwnershipRequest
|
isPendingOwnershipRequest: root.isPendingOwnershipRequest
|
||||||
|
|
||||||
@ -184,12 +176,11 @@ StackLayout {
|
|||||||
}
|
}
|
||||||
onRequestToJoinClicked: {
|
onRequestToJoinClicked: {
|
||||||
Global.communityIntroPopupRequested(communityId, root.sectionItemModel.name, root.sectionItemModel.introMessage,
|
Global.communityIntroPopupRequested(communityId, root.sectionItemModel.name, root.sectionItemModel.introMessage,
|
||||||
root.sectionItemModel.image, root.rootStore.isMyCommunityRequestPending(chatView.communityId))
|
root.sectionItemModel.image, root.isInvitationPending)
|
||||||
}
|
}
|
||||||
onInvitationPendingClicked: {
|
onInvitationPendingClicked: {
|
||||||
Global.communityIntroPopupRequested(communityId, root.sectionItemModel.name, root.sectionItemModel.introMessage,
|
Global.communityIntroPopupRequested(communityId, root.sectionItemModel.name, root.sectionItemModel.introMessage,
|
||||||
root.sectionItemModel.image, root.rootStore.isMyCommunityRequestPending(chatView.communityId))
|
root.sectionItemModel.image, root.isInvitationPending)
|
||||||
chatView.isInvitationPending = root.rootStore.isMyCommunityRequestPending(dialogRoot.communityId)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -255,14 +246,4 @@ StackLayout {
|
|||||||
onAdHocChatButtonClicked: rootStore.openCloseCreateChatView()
|
onAdHocChatButtonClicked: rootStore.openCloseCreateChatView()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Connections {
|
|
||||||
target: root.rootStore
|
|
||||||
enabled: mainViewLoader.item
|
|
||||||
function onCommunityAccessRequested(communityId: string) {
|
|
||||||
if (communityId === mainViewLoader.item.communityId) {
|
|
||||||
mainViewLoader.item.isInvitationPending = root.rootStore.isMyCommunityRequestPending(communityId)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -57,7 +57,7 @@ StatusSectionLayout {
|
|||||||
property bool amISectionAdmin: false
|
property bool amISectionAdmin: false
|
||||||
readonly property bool allChannelsAreHiddenBecauseNotPermitted: rootStore.allChannelsAreHiddenBecauseNotPermitted
|
readonly property bool allChannelsAreHiddenBecauseNotPermitted: rootStore.allChannelsAreHiddenBecauseNotPermitted
|
||||||
|
|
||||||
property bool isInvitationPending: false
|
property int requestToJoinState: Constants.RequestToJoinState.None
|
||||||
|
|
||||||
property var viewOnlyPermissionsModel
|
property var viewOnlyPermissionsModel
|
||||||
property var viewAndPostPermissionsModel
|
property var viewAndPostPermissionsModel
|
||||||
@ -258,7 +258,7 @@ StatusSectionLayout {
|
|||||||
viewAndPostHoldingsModel: root.viewAndPostPermissionsModel
|
viewAndPostHoldingsModel: root.viewAndPostPermissionsModel
|
||||||
assetsModel: root.assetsModel
|
assetsModel: root.assetsModel
|
||||||
collectiblesModel: root.collectiblesModel
|
collectiblesModel: root.collectiblesModel
|
||||||
isInvitationPending: root.isInvitationPending
|
requestToJoinState: root.requestToJoinState
|
||||||
requiresRequest: !root.amIMember
|
requiresRequest: !root.amIMember
|
||||||
requirementsMet: (viewOnlyPermissionsSatisfied && viewOnlyPermissionsModel.count > 0) ||
|
requirementsMet: (viewOnlyPermissionsSatisfied && viewOnlyPermissionsModel.count > 0) ||
|
||||||
(viewAndPostPermissionsSatisfied && viewAndPostPermissionsModel.count > 0)
|
(viewAndPostPermissionsSatisfied && viewAndPostPermissionsModel.count > 0)
|
||||||
|
@ -8,6 +8,8 @@ import StatusQ.Components 0.1
|
|||||||
import StatusQ.Controls 0.1
|
import StatusQ.Controls 0.1
|
||||||
import StatusQ.Layout 0.1
|
import StatusQ.Layout 0.1
|
||||||
|
|
||||||
|
import utils 1.0
|
||||||
|
|
||||||
ColumnLayout {
|
ColumnLayout {
|
||||||
id: root
|
id: root
|
||||||
|
|
||||||
@ -17,7 +19,7 @@ ColumnLayout {
|
|||||||
property string name
|
property string name
|
||||||
property string channelName
|
property string channelName
|
||||||
|
|
||||||
property bool isInvitationPending: false
|
property int requestToJoinState: Constants.RequestToJoinState.None
|
||||||
property bool isJoinRequestRejected: false
|
property bool isJoinRequestRejected: false
|
||||||
property bool requiresRequest: false
|
property bool requiresRequest: false
|
||||||
|
|
||||||
@ -143,7 +145,7 @@ ColumnLayout {
|
|||||||
allChannelsAreHiddenBecauseNotPermitted: root.allChannelsAreHiddenBecauseNotPermitted
|
allChannelsAreHiddenBecauseNotPermitted: root.allChannelsAreHiddenBecauseNotPermitted
|
||||||
requirementsMet: root.requirementsMet
|
requirementsMet: root.requirementsMet
|
||||||
requirementsCheckPending: root.requirementsCheckPending
|
requirementsCheckPending: root.requirementsCheckPending
|
||||||
isInvitationPending: root.isInvitationPending
|
requestToJoinState: root.requestToJoinState
|
||||||
isJoinRequestRejected: root.isJoinRequestRejected
|
isJoinRequestRejected: root.isJoinRequestRejected
|
||||||
requiresRequest: root.requiresRequest
|
requiresRequest: root.requiresRequest
|
||||||
communityName: root.name
|
communityName: root.name
|
||||||
|
@ -23,7 +23,9 @@ Control {
|
|||||||
property bool requirementsMet: false
|
property bool requirementsMet: false
|
||||||
property bool requirementsCheckPending: false
|
property bool requirementsCheckPending: false
|
||||||
property bool requiresRequest: false
|
property bool requiresRequest: false
|
||||||
property bool isInvitationPending: false
|
property int requestToJoinState: Constants.RequestToJoinState.None
|
||||||
|
property bool isInvitationPending: root.requestToJoinState !== Constants.RequestToJoinState.None
|
||||||
|
|
||||||
property bool isJoinRequestRejected: false
|
property bool isJoinRequestRejected: false
|
||||||
property string communityName
|
property string communityName
|
||||||
property var communityHoldingsModel
|
property var communityHoldingsModel
|
||||||
@ -160,6 +162,7 @@ Control {
|
|||||||
&& root.requiresRequest
|
&& root.requiresRequest
|
||||||
&& !d.onlyPrivateNotMetPermissions
|
&& !d.onlyPrivateNotMetPermissions
|
||||||
&& !root.allChannelsAreHiddenBecauseNotPermitted
|
&& !root.allChannelsAreHiddenBecauseNotPermitted
|
||||||
|
loading: root.requestToJoinState === Constants.RequestToJoinState.InProgress
|
||||||
text: root.isInvitationPending ? (root.joinCommunity ? d.communityMembershipRequestPendingText : d.channelMembershipRequestPendingText)
|
text: root.isInvitationPending ? (root.joinCommunity ? d.communityMembershipRequestPendingText : d.channelMembershipRequestPendingText)
|
||||||
: d.communityRequestToJoinText
|
: d.communityRequestToJoinText
|
||||||
font.pixelSize: 13
|
font.pixelSize: 13
|
||||||
|
@ -44,6 +44,8 @@ Item {
|
|||||||
property var communityData
|
property var communityData
|
||||||
property alias createChannelPopup: createChannelPopup
|
property alias createChannelPopup: createChannelPopup
|
||||||
|
|
||||||
|
property int requestToJoinState: Constants.RequestToJoinState.None
|
||||||
|
|
||||||
// Community transfer ownership related props:
|
// Community transfer ownership related props:
|
||||||
required property bool isPendingOwnershipRequest
|
required property bool isPendingOwnershipRequest
|
||||||
signal finaliseOwnershipClicked
|
signal finaliseOwnershipClicked
|
||||||
@ -64,11 +66,8 @@ Item {
|
|||||||
readonly property bool discordImportInProgress: (root.communitiesStore.discordImportProgress > 0 && root.communitiesStore.discordImportProgress < 100)
|
readonly property bool discordImportInProgress: (root.communitiesStore.discordImportProgress > 0 && root.communitiesStore.discordImportProgress < 100)
|
||||||
|| root.communitiesStore.discordImportInProgress
|
|| root.communitiesStore.discordImportInProgress
|
||||||
|
|
||||||
property bool invitationPending: root.store.isMyCommunityRequestPending(communityData.id)
|
readonly property int requestToJoinState: root.communitySectionModule.requestToJoinState
|
||||||
|
readonly property bool invitationPending: d.requestToJoinState !== Constants.RequestToJoinState.None
|
||||||
property bool joiningCommunityInProgress: false
|
|
||||||
|
|
||||||
onShowJoinButtonChanged: invitationPending = root.store.isMyCommunityRequestPending(communityData.id)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ColumnHeaderPanel {
|
ColumnHeaderPanel {
|
||||||
@ -486,11 +485,11 @@ Item {
|
|||||||
anchors.bottomMargin: Style.current.halfPadding
|
anchors.bottomMargin: Style.current.halfPadding
|
||||||
anchors.horizontalCenter: parent.horizontalCenter
|
anchors.horizontalCenter: parent.horizontalCenter
|
||||||
enabled: !root.communityData.amIBanned
|
enabled: !root.communityData.amIBanned
|
||||||
loading: d.joiningCommunityInProgress
|
loading: d.requestToJoinState === Constants.RequestToJoinState.InProgress
|
||||||
|
|
||||||
text: {
|
text: {
|
||||||
if (root.communityData.amIBanned) return qsTr("You were banned from community")
|
if (root.communityData.amIBanned) return qsTr("You were banned from community")
|
||||||
if (d.invitationPending) return qsTr("Membership request pending...")
|
if (d.requestToJoinState === Constants.RequestToJoinState.Requested) return qsTr("Membership request pending...")
|
||||||
|
|
||||||
return root.communityData.access === Constants.communityChatOnRequestAccess ?
|
return root.communityData.access === Constants.communityChatOnRequestAccess ?
|
||||||
qsTr("Request to join") : qsTr("Join Community")
|
qsTr("Request to join") : qsTr("Join Community")
|
||||||
@ -502,19 +501,11 @@ Item {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Connections {
|
Connections {
|
||||||
enabled: d.joiningCommunityInProgress
|
enabled: d.showJoinButton
|
||||||
target: root.store.communitiesModuleInst
|
target: root.store.communitiesModuleInst
|
||||||
function onCommunityAccessRequested(communityId: string) {
|
|
||||||
if (communityId === root.communityData.id) {
|
|
||||||
d.invitationPending = root.store.isMyCommunityRequestPending(communityId)
|
|
||||||
d.joiningCommunityInProgress = false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function onCommunityAccessFailed(communityId: string, error: string) {
|
function onCommunityAccessFailed(communityId: string, error: string) {
|
||||||
if (communityId === root.communityData.id) {
|
if (communityId === root.communityData.id) {
|
||||||
d.invitationPending = false
|
|
||||||
d.joiningCommunityInProgress = false
|
|
||||||
Global.displayToastMessage(qsTr("Request to join failed"),
|
Global.displayToastMessage(qsTr("Request to join failed"),
|
||||||
qsTr("Please try again later"),
|
qsTr("Please try again later"),
|
||||||
"",
|
"",
|
||||||
|
@ -30,7 +30,7 @@ StatusSectionLayout {
|
|||||||
property string channelDesc
|
property string channelDesc
|
||||||
property bool joinCommunity: true // Otherwise it means join channel action
|
property bool joinCommunity: true // Otherwise it means join channel action
|
||||||
property int accessType
|
property int accessType
|
||||||
property bool isInvitationPending: false
|
property int requestToJoinState: Constants.RequestToJoinState.None
|
||||||
|
|
||||||
// Permission overlay view properties:
|
// Permission overlay view properties:
|
||||||
property bool requirementsMet: true
|
property bool requirementsMet: true
|
||||||
@ -128,7 +128,7 @@ StatusSectionLayout {
|
|||||||
name: root.name
|
name: root.name
|
||||||
channelName: root.channelName
|
channelName: root.channelName
|
||||||
|
|
||||||
isInvitationPending: root.isInvitationPending
|
requestToJoinState: root.requestToJoinState
|
||||||
isJoinRequestRejected: root.isJoinRequestRejected
|
isJoinRequestRejected: root.isJoinRequestRejected
|
||||||
requiresRequest: root.requiresRequest
|
requiresRequest: root.requiresRequest
|
||||||
requirementsMet: root.requirementsMet
|
requirementsMet: root.requirementsMet
|
||||||
|
@ -1283,4 +1283,10 @@ QtObject {
|
|||||||
Collection = 2,
|
Collection = 2,
|
||||||
Community = 3
|
Community = 3
|
||||||
}
|
}
|
||||||
|
|
||||||
|
enum RequestToJoinState {
|
||||||
|
None = 0,
|
||||||
|
InProgress = 1,
|
||||||
|
Requested = 2
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user