2020-12-11 15:38:10 -05:00
|
|
|
import QtQuick 2.3
|
2021-04-29 15:54:09 -04:00
|
|
|
import QtQuick.Dialogs 1.3
|
2022-06-08 16:43:46 +02:00
|
|
|
import QtQuick.Layouts 1.14
|
2021-10-01 18:58:36 +03:00
|
|
|
|
2021-09-28 18:04:06 +03:00
|
|
|
import utils 1.0
|
2020-12-11 15:38:10 -05:00
|
|
|
|
2021-10-18 14:32:48 +02:00
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared.panels 1.0
|
|
|
|
import shared.popups 1.0
|
2021-10-18 14:32:48 +02:00
|
|
|
|
2020-12-11 15:38:10 -05:00
|
|
|
Item {
|
|
|
|
id: root
|
|
|
|
anchors.left: parent.left
|
2021-08-30 11:50:45 +02:00
|
|
|
height: rectangleBubbleLoader.height
|
2021-04-30 10:45:13 -04:00
|
|
|
width: rectangleBubbleLoader.width
|
2020-12-11 15:38:10 -05:00
|
|
|
|
2021-10-21 03:41:54 +03:00
|
|
|
property string communityId
|
|
|
|
property var invitedCommunity
|
|
|
|
property int innerMargin: 12
|
|
|
|
property bool isLink: false
|
|
|
|
property var store
|
|
|
|
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
function getCommunity() {
|
2022-02-11 16:41:34 -05:00
|
|
|
try {
|
|
|
|
const communityJson = root.store.getSectionByIdJson(communityId)
|
|
|
|
if (!communityJson) {
|
|
|
|
return null
|
|
|
|
}
|
2021-07-22 11:22:02 -04:00
|
|
|
|
2022-02-11 16:41:34 -05:00
|
|
|
return JSON.parse(communityJson);
|
|
|
|
} catch (e) {
|
|
|
|
console.error("Error parsing community", e)
|
|
|
|
}
|
2021-07-22 11:22:02 -04:00
|
|
|
|
2022-02-11 16:41:34 -05:00
|
|
|
return null
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
}
|
|
|
|
|
2020-12-11 15:38:10 -05:00
|
|
|
Component.onCompleted: {
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
root.invitedCommunity = getCommunity()
|
|
|
|
}
|
2020-12-11 15:38:10 -05:00
|
|
|
|
2022-02-11 16:41:34 -05:00
|
|
|
Connections {
|
|
|
|
target: root.store.communitiesModuleInst
|
|
|
|
onCommunityChanged: function (communityId) {
|
|
|
|
if (communityId === root.communityId) {
|
|
|
|
root.invitedCommunity = getCommunity()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-12-11 15:38:10 -05:00
|
|
|
|
2022-05-26 17:46:02 +02:00
|
|
|
Component {
|
|
|
|
id: communityIntroDialog
|
|
|
|
|
|
|
|
CommunityIntroDialog {
|
|
|
|
anchors.centerIn: parent
|
|
|
|
|
|
|
|
property var joinMethod: () => {}
|
|
|
|
|
|
|
|
name: root.invitedCommunity ? root.invitedCommunity.name : ""
|
|
|
|
introMessage: root.invitedCommunity ? root.invitedCommunity.introMessage : ""
|
|
|
|
imageSrc: root.invitedCommunity ? root.invitedCommunity.image : ""
|
|
|
|
|
|
|
|
onJoined: joinMethod()
|
|
|
|
}
|
|
|
|
}
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
|
2020-12-11 15:38:10 -05:00
|
|
|
Loader {
|
|
|
|
id: rectangleBubbleLoader
|
|
|
|
active: !!invitedCommunity
|
|
|
|
|
|
|
|
sourceComponent: Component {
|
|
|
|
Rectangle {
|
|
|
|
id: rectangleBubble
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
property alias button: joinBtn
|
2022-02-11 16:41:34 -05:00
|
|
|
property bool isPendingRequest: root.store.isCommunityRequestPending(communityId)
|
2020-12-11 15:38:10 -05:00
|
|
|
width: 270
|
2022-06-08 16:43:46 +02:00
|
|
|
height: column.implicitHeight
|
2020-12-11 15:38:10 -05:00
|
|
|
radius: 16
|
|
|
|
color: Style.current.background
|
|
|
|
border.color: Style.current.border
|
|
|
|
border.width: 1
|
|
|
|
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
states: [
|
|
|
|
State {
|
|
|
|
name: "requiresEns"
|
2022-02-11 16:41:34 -05:00
|
|
|
when: invitedCommunity.ensOnly && !userProfile.ensName
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
PropertyChanges {
|
|
|
|
target: joinBtn
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("Membership requires an ENS username")
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
enabled: false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
State {
|
|
|
|
name: "inviteOnly"
|
|
|
|
when: invitedCommunity.access === Constants.communityChatInvitationOnlyAccess
|
|
|
|
PropertyChanges {
|
|
|
|
target: joinBtn
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("You need to be invited")
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
enabled: false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
State {
|
|
|
|
name: "pending"
|
|
|
|
when: invitedCommunity.access === Constants.communityChatOnRequestAccess &&
|
|
|
|
rectangleBubble.isPendingRequest
|
|
|
|
PropertyChanges {
|
|
|
|
target: joinBtn
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("Pending")
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
enabled: false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
State {
|
|
|
|
name: "joined"
|
2021-09-14 16:01:43 +10:00
|
|
|
when: (invitedCommunity.joined && invitedCommunity.isMember) ||
|
|
|
|
(invitedCommunity.access === Constants.communityChatPublicAccess &&
|
|
|
|
invitedCommunity.joined)
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
PropertyChanges {
|
|
|
|
target: joinBtn
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("View")
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
}
|
|
|
|
},
|
|
|
|
State {
|
|
|
|
name: "requestToJoin"
|
|
|
|
when: invitedCommunity.access === Constants.communityChatOnRequestAccess &&
|
2022-02-11 16:41:34 -05:00
|
|
|
!invitedCommunity.joined && !invitedCommunity.isMember &&
|
2021-07-20 15:08:36 +03:00
|
|
|
invitedCommunity.canRequestAccess
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
PropertyChanges {
|
|
|
|
target: joinBtn
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("Request Access")
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
|
|
|
|
}
|
|
|
|
},
|
|
|
|
State {
|
|
|
|
name: "unjoined"
|
2021-09-14 16:01:43 +10:00
|
|
|
when: (invitedCommunity.access === Constants.communityChatOnRequestAccess &&
|
|
|
|
invitedCommunity.isMember) ||
|
|
|
|
(invitedCommunity.access === Constants.communityChatPublicAccess &&
|
|
|
|
!invitedCommunity.joined)
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
PropertyChanges {
|
|
|
|
target: joinBtn
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("Join")
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
|
2021-12-13 15:24:21 +01:00
|
|
|
// Not Refactored Yet
|
|
|
|
// Connections {
|
|
|
|
// target: root.store.chatsModelInst.communities
|
|
|
|
// onMembershipRequestChanged: function(communityId, communityName, requestAccepted) {
|
|
|
|
// if (communityId === root.communityId) {
|
|
|
|
// rectangleBubble.isPendingRequest = false
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// }
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
|
2022-06-08 16:43:46 +02:00
|
|
|
ColumnLayout {
|
|
|
|
id: column
|
|
|
|
width: parent.width
|
|
|
|
spacing: Style.current.halfPadding
|
|
|
|
|
|
|
|
// TODO add check if verified
|
|
|
|
StatusBaseText {
|
|
|
|
id: title
|
|
|
|
color: invitedCommunity.verifed ? Theme.palette.primaryColor1 : Theme.palette.baseColor1
|
|
|
|
text: invitedCommunity.verifed ?
|
2022-04-04 13:26:30 +02:00
|
|
|
qsTr("Verified community invitation") :
|
|
|
|
qsTr("Community invitation")
|
2022-06-08 16:43:46 +02:00
|
|
|
font.weight: Font.Medium
|
|
|
|
Layout.topMargin: Style.current.halfPadding
|
|
|
|
Layout.leftMargin: root.innerMargin
|
|
|
|
font.pixelSize: 13
|
|
|
|
}
|
|
|
|
StatusBaseText {
|
|
|
|
id: invitedYou
|
|
|
|
visible: text != ""
|
|
|
|
text: {
|
|
|
|
// Not Refactored Yet
|
|
|
|
return ""
|
|
|
|
// if (root.store.chatsModelInst.channelView.activeChannel.chatType === Constants.chatType.oneToOne) {
|
|
|
|
// return isCurrentUser ?
|
2022-04-04 13:26:30 +02:00
|
|
|
// qsTr("You invited %1 to join a community").arg(root.store.chatsModelInst.userNameOrAlias(root.store.chatsModelInst.channelView.activeChannel.id))
|
|
|
|
// : qsTr("%1 invited you to join a community").arg(displayUserName)
|
2022-06-08 16:43:46 +02:00
|
|
|
// } else {
|
|
|
|
// return isCurrentUser ?
|
2022-04-04 13:26:30 +02:00
|
|
|
// qsTr("You shared a community")
|
|
|
|
// : qsTr("A community has been shared")
|
2022-06-08 16:43:46 +02:00
|
|
|
// }
|
|
|
|
}
|
|
|
|
Layout.leftMargin: root.innerMargin
|
|
|
|
Layout.rightMargin: root.innerMargin
|
|
|
|
Layout.fillWidth: true
|
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
font.pixelSize: 15
|
|
|
|
color: Theme.palette.directColor1
|
fix(communities): re-joining of left communities
Fixes: #2649.
Upon receipt of status-go signals which included communities that have been left (`joined: false`), those communities were being rejoined automatically when they should not have been.
fix(communities): Invitation bubble button state updates
The community state inside of the invitation bubble was not reactive to any community actions (such as joining, leaving, updating). In addition, requesting to join a community changed the button’s text to “Pending”, but upon approval, the button’s state was not updating.
The component was setting an observed community in the Component.onCompleted event, which was occurring for all invitation bubbles, but because the community wasn’t bound correctly to the bubble, once a bubble with a different community was encountered, the community in context of the bubble wasn’t updated and instead used a local copy. Once the community was bound correctly (to be reactive), the states started working correctly.
The invitation bubble has been simplied so that it has states instead of using lots of if/else statements inside of the property bindings. This simplified the component’s logic for things like onClick action and made it a lot easier to read and modify.
2021-06-24 17:21:45 +10:00
|
|
|
}
|
2020-12-11 15:38:10 -05:00
|
|
|
|
2022-06-08 16:43:46 +02:00
|
|
|
Separator {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
}
|
2020-12-11 15:38:10 -05:00
|
|
|
|
2022-06-08 16:43:46 +02:00
|
|
|
// TODO add image when it's supported
|
|
|
|
StatusBaseText {
|
|
|
|
id: communityName
|
|
|
|
text: invitedCommunity.name
|
|
|
|
Layout.topMargin: 2
|
|
|
|
Layout.leftMargin: root.innerMargin
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.rightMargin: root.innerMargin
|
|
|
|
font.weight: Font.Bold
|
|
|
|
wrapMode: Text.WrapAtWordBoundaryOrAnywhere
|
|
|
|
font.pixelSize: 17
|
|
|
|
color: Theme.palette.directColor1
|
|
|
|
}
|
2020-12-11 15:38:10 -05:00
|
|
|
|
2022-06-08 16:43:46 +02:00
|
|
|
StatusBaseText {
|
|
|
|
id: communityDesc
|
|
|
|
text: invitedCommunity.description
|
|
|
|
Layout.leftMargin: root.innerMargin
|
|
|
|
Layout.rightMargin: root.innerMargin
|
|
|
|
Layout.fillWidth: true
|
|
|
|
wrapMode: Text.WrapAtWordBoundaryOrAnywhere
|
|
|
|
font.pixelSize: 15
|
|
|
|
color: Theme.palette.directColor1
|
|
|
|
}
|
2020-12-11 15:38:10 -05:00
|
|
|
|
2022-06-08 16:43:46 +02:00
|
|
|
StatusBaseText {
|
|
|
|
id: communityNbMembers
|
|
|
|
// TODO add the plural support
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("%1 members").arg(invitedCommunity.nbMembers)
|
2022-06-08 16:43:46 +02:00
|
|
|
Layout.leftMargin: root.innerMargin
|
|
|
|
font.pixelSize: 13
|
|
|
|
font.weight: Font.Medium
|
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
}
|
2020-12-11 15:38:10 -05:00
|
|
|
|
2022-06-08 16:43:46 +02:00
|
|
|
Separator {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
}
|
|
|
|
|
|
|
|
Item {
|
|
|
|
id: btnItemId
|
|
|
|
Layout.topMargin: -column.spacing
|
|
|
|
Layout.fillWidth: true
|
|
|
|
height: 44
|
|
|
|
clip: true
|
|
|
|
StatusFlatButton {
|
|
|
|
id: joinBtn
|
|
|
|
anchors.fill: parent
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
radius: 16
|
|
|
|
enabled: true
|
|
|
|
text: qsTr("Unsupported state")
|
|
|
|
onClicked: {
|
2022-06-21 11:00:54 +02:00
|
|
|
let error
|
2022-06-08 16:43:46 +02:00
|
|
|
|
2022-06-21 11:00:54 +02:00
|
|
|
if (rectangleBubble.state === "joined") {
|
|
|
|
root.store.setActiveCommunity(communityId);
|
|
|
|
return
|
2022-02-11 16:41:34 -05:00
|
|
|
}
|
2022-06-21 11:00:54 +02:00
|
|
|
if (rectangleBubble.state === "unjoined") {
|
|
|
|
Global.openPopup(communityIntroDialog, { joinMethod: () => {
|
|
|
|
let error = root.store.joinCommunity(communityId)
|
|
|
|
if (error) joiningError.showError(error)
|
|
|
|
} });
|
2022-06-08 16:43:46 +02:00
|
|
|
}
|
2022-06-21 11:00:54 +02:00
|
|
|
else if (rectangleBubble.state === "requestToJoin") {
|
|
|
|
Global.openPopup(communityIntroDialog, { joinMethod: () => {
|
|
|
|
let error = root.store.requestToJoinCommunity(communityId, userProfile.name)
|
|
|
|
if (error) joiningError.showError(error)
|
|
|
|
else rectangleBubble.isPendingRequest = root.store.isCommunityRequestPending(communityId)
|
|
|
|
} });
|
|
|
|
}
|
|
|
|
|
|
|
|
if (error) joiningError.showError(error)
|
2022-02-11 16:41:34 -05:00
|
|
|
}
|
2021-07-12 13:49:06 -04:00
|
|
|
|
2022-06-08 16:43:46 +02:00
|
|
|
MessageDialog {
|
|
|
|
id: joiningError
|
2021-04-29 15:54:09 -04:00
|
|
|
|
2022-06-08 16:43:46 +02:00
|
|
|
function showError(error) {
|
|
|
|
joiningError.text = error
|
|
|
|
joiningError.open()
|
|
|
|
}
|
2022-05-26 17:46:02 +02:00
|
|
|
|
2022-04-04 13:26:30 +02:00
|
|
|
title: qsTr("Error joining the community")
|
2022-06-08 16:43:46 +02:00
|
|
|
icon: StandardIcon.Critical
|
|
|
|
standardButtons: StandardButton.Ok
|
2022-05-26 17:46:02 +02:00
|
|
|
}
|
2021-04-29 15:54:09 -04:00
|
|
|
}
|
|
|
|
}
|
2020-12-11 15:38:10 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|