2023-02-01 18:33:56 +01:00
import QtQuick 2.14
import QtQuick . Controls 2.14
import QtQuick . Layouts 1.14
import StatusQ . Core . Theme 0.1
import StatusQ . Components 0.1
import AppLayouts . Chat . views . communities 1.0
import Storybook 1.0
import Models 1.0
import utils 1.0
SplitView {
QtObject {
id: d
// General properties:
property string name: "Uniswap"
property string communityDesc: "General channel for the community"
2023-02-02 16:27:37 +01:00
property string introMessage: " % 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 . " . arg ( d . name )
2023-02-01 18:33:56 +01:00
property color color: "orchid"
property string channelName: joinCommunity ? "general" : "#vip"
property string channelDesc: "VIP members only"
property bool joinCommunity: true // Otherwise it means join channel action
2023-02-02 16:27:37 +01:00
property int accessType: Constants . communityChatPublicAccess
2023-02-01 18:33:56 +01:00
// Overlay component:
property bool requirementsMet: true
2023-02-02 16:27:37 +01:00
property bool isInvitationPending: true
2023-02-01 18:33:56 +01:00
property bool isJoinRequestRejected: false
property bool requiresRequest: false
2023-03-30 12:42:28 +03:00
property int loginType: Constants . LoginType . Biometrics
2023-02-13 11:40:13 +01:00
2023-02-14 17:33:23 +01:00
property var communityHoldingsModel: PermissionsModel . shortPermissionsModel
property var viewOnlyHoldingsModel: PermissionsModel . shortPermissionsModel
property var viewAndPostHoldingsModel: PermissionsModel . shortPermissionsModel
property var moderateHoldingsModel: PermissionsModel . shortPermissionsModel
2023-02-13 11:40:13 +01:00
property var assetsModel: AssetsModel { }
property var collectiblesModel: CollectiblesModel { }
2023-02-01 18:33:56 +01:00
// Blur background:
property int membersCount: 184
property bool amISectionAdmin: false
property url image: Style . png ( "tokens/UNI" )
property var communityItemsModel: model1
property string chatDateTimeText: "Dec 31, 2020"
property string listUsersText: "simon, Mark Cuban "
readonly property ListModel model1: ListModel {
ListElement { name: "welcome" ; selected: false ; notificationsCount: 0 ; hasUnreadMessages: false }
ListElement { name: "general" ; selected: false ; notificationsCount: 0 ; hasUnreadMessages: true }
ListElement { name: "design" ; selected: true ; notificationsCount: 3 ; hasUnreadMessages: true }
ListElement { name: "random" ; selected: false ; notificationsCount: 0 ; hasUnreadMessages: false }
ListElement { name: "vip" ; selected: false ; notificationsCount: 0 ; hasUnreadMessages: true }
}
readonly property ListModel model2: ListModel {
ListElement { name: "general" ; selected: false ; notificationsCount: 3 ; hasUnreadMessages: false }
ListElement { name: "blockchain" ; selected: true ; notificationsCount: 3 ; hasUnreadMessages: true }
ListElement { name: "faq" ; selected: false ; notificationsCount: 0 ; hasUnreadMessages: false }
}
readonly property var messagesModel: ListModel {
ListElement {
timestamp: 1656937930
senderDisplayName: "simon"
contentType: StatusMessage . ContentType . Text
message: "Hello, this is awesome! Feels like decentralized Discord!"
isContact: true
trustIndicator: StatusContactVerificationIcons . TrustedType . Verified
colorId: 4
}
ListElement {
timestamp: 1657937930
senderDisplayName: "Mark Cuban"
contentType: StatusMessage . ContentType . Text
message: "I know a lot of you really seem to get off or be validated by arguing with strangers online but please know it's a complete waste of your time and energy"
isContact: false
trustIndicator: StatusContactVerificationIcons . TrustedType . Untrustworthy
colorId: 2
}
}
}
Logs { id: logs }
SplitView {
orientation: Qt . Vertical
SplitView.fillWidth: true
Rectangle {
SplitView.fillWidth: true
SplitView.fillHeight: true
color: Theme . palette . statusAppLayout . rightPanelBackgroundColor
clip: true
JoinCommunityView {
anchors.fill: parent
anchors.margins: 50
// General properties:
name: d . name
communityDesc: d . communityDesc
2023-02-02 16:27:37 +01:00
introMessage: d . introMessage
2023-02-01 18:33:56 +01:00
color: d . color
channelName: d . channelName
channelDesc: d . channelDesc
joinCommunity: d . joinCommunity
2023-02-02 16:27:37 +01:00
accessType: d . accessType
isInvitationPending: d . isInvitationPending
2023-03-30 12:42:28 +03:00
loginType: d . loginType
2023-02-01 18:33:56 +01:00
// Blur background properties:
membersCount: d . membersCount
image: d . image
amISectionAdmin: d . amISectionAdmin
openCreateChat: false
communityItemsModel: d . communityItemsModel
chatDateTimeText: d . chatDateTimeText
listUsersText: d . listUsersText
messagesModel: d . messagesModel
// Permissions properties
requirementsMet: d . requirementsMet
isJoinRequestRejected: d . isJoinRequestRejected
requiresRequest: d . requiresRequest
2023-02-13 11:40:13 +01:00
2023-02-14 17:33:23 +01:00
communityHoldingsModel: d . communityHoldingsModel
viewOnlyHoldingsModel: d . viewOnlyHoldingsModel
viewAndPostHoldingsModel: d . viewAndPostHoldingsModel
moderateHoldingsModel: d . moderateHoldingsModel
2023-02-13 11:40:13 +01:00
assetsModel: d . assetsModel
collectiblesModel: d . collectiblesModel
2023-02-01 18:33:56 +01:00
onInfoButtonClicked: logs . logEvent ( "JoinCommunityView::onInfoButtonClicked()" )
onAdHocChatButtonClicked: {
logs . logEvent ( "JoinCommunityView::store.openCloseCreateChatView(): " + openCreateChat . toString ( ) )
openCreateChat = ! openCreateChat
}
onNotificationButtonClicked: logs . logEvent ( "JoinCommunityView::onNotificationButtonClicked()" )
2023-02-02 16:27:37 +01:00
onRevealAddressClicked: {
logs . logEvent ( "JoinCommunityView::onRevealAddressClicked()" )
openJoinCommunityDialog ( )
}
2023-02-01 18:33:56 +01:00
onInvitationPendingClicked: logs . logEvent ( "JoinCommunityView::onInvitationPendingClicked()" )
2023-02-02 16:27:37 +01:00
onJoined: logs . logEvent ( "JoinCommunityView::onJoined()" )
onCancelMembershipRequest: logs . logEvent ( "JoinCommunityView::onCancelMembershipRequest()" )
2023-02-01 18:33:56 +01:00
}
}
LogsAndControlsPanel {
id: logsAndControlsPanel
SplitView.minimumHeight: 100
SplitView.preferredHeight: 150
logsView.logText: logs . logText
}
}
Pane {
SplitView.minimumWidth: 300
SplitView.preferredWidth: 300
ScrollView {
anchors.fill: parent
ColumnLayout {
spacing: 16
// Blur info editor:
Label {
Layout.fillWidth: true
text: "BLUR INFO EDITOR"
font.bold: true
font.pixelSize: 18
}
CommunityInfoEditor {
name: d . name
membersCount: d . membersCount
amISectionAdmin: d . amISectionAdmin
color: d . color
image: d . image
colorVisible: true
onNameChanged: d . name = name
onMembersCountChanged: d . membersCount = membersCount
onAmISectionAdminChanged: d . amISectionAdmin = amISectionAdmin
onColorChanged: d . color = color
onImageChanged: d . image = image
}
ColumnLayout {
Label {
Layout.fillWidth: true
text: "Community items model:"
}
RadioButton {
checked: true
text: qsTr ( "Model 1" )
onCheckedChanged: if ( checked ) d . communityItemsModel = d . model1
}
RadioButton {
text: qsTr ( "Model 2" )
onCheckedChanged: if ( checked ) d . communityItemsModel = d . model2
}
}
2023-02-02 16:27:37 +01:00
// Join types:
Label {
Layout.fillWidth: true
text: "JOIN TYPES"
font.bold: true
font.pixelSize: 18
}
ColumnLayout {
Label {
Layout.fillWidth: true
text: "Is invitation pending:"
}
CheckBox {
checked: d . isInvitationPending
onCheckedChanged: d . isInvitationPending = checked
}
}
ColumnLayout {
visible: ! d . isInvitationPending
Label {
Layout.fillWidth: true
text: "Access type:"
}
RadioButton {
checked: true
text: qsTr ( "Public access" )
onCheckedChanged: d . accessType = Constants . communityChatPublicAccess
}
RadioButton {
text: qsTr ( "On request" )
onCheckedChanged: d . accessType = Constants . communityChatOnRequestAccess
}
}
2023-02-01 18:33:56 +01:00
// Join community overlay editor:
Label {
Layout.fillWidth: true
text: "JOIN HOLDINGS EDITOR"
font.bold: true
font.pixelSize: 18
}
JoinCommunityPermissionsEditor {
channelName: d . chanelName
joinCommunity: d . joinCommunity
requirementsMet: d . requirementsMet
isInvitationPending: d . isInvitationPending
isJoinRequestRejected: d . isJoinRequestRejected
requiresRequest: d . requiresRequest
onChannelNameChanged: d . channelName = channelName
onJoinCommunityChanged: d . joinCommunity = joinCommunity
onRequirementsMetChanged: d . requirementsMet = requirementsMet
onIsInvitationPendingChanged: d . isInvitationPending = isInvitationPending
onIsJoinRequestRejectedChanged: d . isJoinRequestRejected = isJoinRequestRejected
onRequiresRequestChanged: d . requiresRequest = requiresRequest
2023-02-14 17:33:23 +01:00
onCommunityHoldingsModelChanged: d . communityHoldingsModel = communityHoldingsModel
onViewOnlyHoldingsModelChanged: d . viewOnlyHoldingsModel = viewOnlyHoldingsModel
onViewAndPostHoldingsModelChanged: d . viewAndPostHoldingsModel = viewAndPostHoldingsModel
onModerateHoldingsModelChanged: d . moderateHoldingsModel = moderateHoldingsModel
2023-02-01 18:33:56 +01:00
}
2023-03-30 12:42:28 +03:00
ColumnLayout {
Label {
Layout.fillWidth: true
text: "Login type"
}
ComboBox {
id: loginTypeComboBox
Layout.fillWidth: true
model: [ "Password" , "Biometrics" , "Keycard" ]
onActivated: d . loginType = currentIndex
Component.onCompleted: currentIndex = d . loginType
}
}
2023-02-01 18:33:56 +01:00
}
}
}
}