2022-01-18 21:54:45 +02:00
|
|
|
import QtQuick 2.12
|
|
|
|
import QtQuick.Controls 2.14
|
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Popups 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Layout 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
|
|
|
|
import "data" 1.0
|
|
|
|
|
|
|
|
StatusAppThreePanelLayout {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
property string communityDetailModalTitle: ""
|
|
|
|
property string communityDetailModalImage: ""
|
|
|
|
signal chatInfoButtonClicked()
|
|
|
|
|
|
|
|
handle: Rectangle {
|
|
|
|
implicitWidth: 5
|
|
|
|
color: SplitHandle.pressed ? Theme.palette.baseColor2
|
|
|
|
: (SplitHandle.hovered ? Qt.darker(Theme.palette.baseColor5, 1.1) : "transparent")
|
|
|
|
}
|
|
|
|
leftPanel: Item {
|
|
|
|
id: leftPanel
|
|
|
|
|
|
|
|
StatusChatInfoToolBar {
|
|
|
|
id: statusChatInfoToolBar
|
|
|
|
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
|
|
|
|
chatInfoButton.title: "CryptoKitties"
|
|
|
|
chatInfoButton.subTitle: "128 Members"
|
2022-07-22 16:42:05 +03:00
|
|
|
chatInfoButton.image.source: "qrc:/demoapp/data/profile-image-1.jpeg"
|
2022-01-18 21:54:45 +02:00
|
|
|
chatInfoButton.icon.color: Theme.palette.miscColor6
|
|
|
|
chatInfoButton.onClicked: { chatInfoButtonClicked(); }
|
|
|
|
|
|
|
|
popupMenu: StatusPopupMenu {
|
|
|
|
|
|
|
|
StatusMenuItem {
|
|
|
|
text: "Create channel"
|
|
|
|
icon.name: "channel"
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusMenuItem {
|
|
|
|
text: "Create category"
|
|
|
|
icon.name: "channel-category"
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusMenuSeparator {}
|
|
|
|
|
|
|
|
StatusMenuItem {
|
|
|
|
text: "Invite people"
|
|
|
|
icon.name: "share-ios"
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-14 15:29:14 +03:00
|
|
|
StatusScrollView {
|
2022-01-18 21:54:45 +02:00
|
|
|
id: scrollView
|
|
|
|
|
|
|
|
anchors.top: statusChatInfoToolBar.bottom
|
|
|
|
anchors.topMargin: 8
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
width: leftPanel.width
|
|
|
|
|
|
|
|
contentHeight: communityCategories.height
|
|
|
|
clip: true
|
|
|
|
|
|
|
|
StatusChatListAndCategories {
|
|
|
|
id: communityCategories
|
|
|
|
width: leftPanel.width
|
|
|
|
height: implicitHeight > (leftPanel.height - 64) ? implicitHeight + 8 : leftPanel.height - 64
|
|
|
|
|
|
|
|
draggableItems: true
|
|
|
|
draggableCategories: false
|
2022-02-01 16:20:57 +01:00
|
|
|
model: Models.demoCommunityChatListItems
|
2022-01-18 21:54:45 +02:00
|
|
|
|
|
|
|
showCategoryActionButtons: true
|
|
|
|
|
|
|
|
categoryPopupMenu: StatusPopupMenu {
|
|
|
|
|
|
|
|
property string categoryId
|
|
|
|
|
|
|
|
openHandler: function (id) {
|
|
|
|
categoryId = id
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusMenuItem {
|
|
|
|
text: "Mute Category"
|
|
|
|
icon.name: "notification"
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusMenuItem {
|
|
|
|
text: "Mark as Read"
|
|
|
|
icon.name: "checkmark-circle"
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusMenuItem {
|
|
|
|
text: "Edit Category"
|
|
|
|
icon.name: "edit"
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusMenuSeparator {}
|
|
|
|
|
|
|
|
StatusMenuItem {
|
|
|
|
text: "Delete Category"
|
|
|
|
icon.name: "delete"
|
|
|
|
type: StatusMenuItem.Type.Danger
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
chatListPopupMenu: StatusPopupMenu {
|
|
|
|
|
|
|
|
property string chatId
|
|
|
|
|
|
|
|
StatusMenuItem {
|
|
|
|
text: "Mute chat"
|
|
|
|
icon.name: "notification"
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusMenuItem {
|
|
|
|
text: "Mark as Read"
|
|
|
|
icon.name: "checkmark-circle"
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusMenuItem {
|
|
|
|
text: "Clear history"
|
|
|
|
icon.name: "close-circle"
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusMenuSeparator {}
|
|
|
|
|
|
|
|
StatusMenuItem {
|
|
|
|
text: "Delete chat"
|
|
|
|
icon.name: "delete"
|
|
|
|
type: StatusMenuItem.Type.Danger
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
popupMenu: StatusPopupMenu {
|
|
|
|
StatusMenuItem {
|
|
|
|
text: "Create channel"
|
|
|
|
icon.name: "channel"
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusMenuItem {
|
|
|
|
text: "Create category"
|
|
|
|
icon.name: "channel-category"
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusMenuSeparator {}
|
|
|
|
|
|
|
|
StatusMenuItem {
|
|
|
|
text: "Invite people"
|
|
|
|
icon.name: "share-ios"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
centerPanel: Item {
|
|
|
|
StatusChatToolBar {
|
|
|
|
id: statusChatToolBar
|
2022-05-31 11:21:32 +02:00
|
|
|
|
2022-01-18 21:54:45 +02:00
|
|
|
width: parent.width
|
2022-05-31 11:21:32 +02:00
|
|
|
toolbarComponent: statusChatInfoButton
|
2022-01-18 21:54:45 +02:00
|
|
|
|
|
|
|
onSearchButtonClicked: {
|
|
|
|
searchButton.highlighted = !searchButton.highlighted;
|
|
|
|
searchPopup.setSearchSelection(communityDetailModalTitle,
|
|
|
|
"",
|
|
|
|
communityDetailModalImage);
|
|
|
|
searchPopup.open();
|
|
|
|
}
|
|
|
|
membersButton.onClicked: membersButton.highlighted = !membersButton.highlighted
|
|
|
|
onMembersButtonClicked: {
|
|
|
|
root.showRightPanel = !root.showRightPanel;
|
|
|
|
}
|
2022-05-31 11:21:32 +02:00
|
|
|
|
|
|
|
Component {
|
|
|
|
id: statusChatInfoButton
|
|
|
|
|
|
|
|
StatusChatInfoButton {
|
|
|
|
width: Math.min(implicitWidth, parent.width)
|
|
|
|
title: "general"
|
|
|
|
subTitle: "Community Chat"
|
|
|
|
icon.color: Theme.palette.miscColor6
|
|
|
|
type: StatusChatInfoButton.Type.CommunityChat
|
|
|
|
}
|
|
|
|
}
|
2022-01-18 21:54:45 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
StatusSearchPopup {
|
|
|
|
id: searchPopup
|
|
|
|
searchOptionsPopupMenu: searchPopupMenu
|
|
|
|
onAboutToHide: {
|
|
|
|
if (searchPopupMenu.visible) {
|
|
|
|
searchPopupMenu.close();
|
|
|
|
}
|
|
|
|
//clear menu
|
|
|
|
for (var i = 2; i < searchPopupMenu.count; i++) {
|
|
|
|
searchPopupMenu.removeItem(searchPopupMenu.takeItem(i));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
onClosed: {
|
|
|
|
statusChatToolBar.searchButton.highlighted = false
|
|
|
|
searchPopupMenu.dismiss();
|
|
|
|
}
|
|
|
|
onSearchTextChanged: {
|
|
|
|
if (searchPopup.searchText !== "") {
|
|
|
|
searchPopup.loading = true;
|
|
|
|
searchModelSimTimer.start();
|
|
|
|
} else {
|
|
|
|
searchPopup.searchResults = [];
|
|
|
|
searchModelSimTimer.stop();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Timer {
|
|
|
|
id: searchModelSimTimer
|
|
|
|
interval: 500
|
|
|
|
onTriggered: {
|
|
|
|
if (searchPopup.searchText.startsWith("c")) {
|
|
|
|
searchPopup.searchResults = Models.searchResultsA;
|
|
|
|
} else {
|
|
|
|
searchPopup.searchResults = Models.searchResultsB;
|
|
|
|
}
|
|
|
|
searchPopup.loading = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
StatusSearchLocationMenu {
|
|
|
|
id: searchPopupMenu
|
|
|
|
searchPopup: searchPopup
|
|
|
|
locationModel: Models.optionsModel
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
rightPanel: Item {
|
|
|
|
id: rightPanel
|
|
|
|
StatusBaseText {
|
|
|
|
id: titleText
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin:16
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: 16
|
|
|
|
opacity: (rightPanel.width > 50) ? 1.0 : 0.0
|
|
|
|
visible: (opacity > 0.1)
|
|
|
|
font.pixelSize: 15
|
|
|
|
text: qsTr("Members")
|
|
|
|
}
|
|
|
|
|
|
|
|
ListView {
|
|
|
|
anchors.top: titleText.bottom
|
|
|
|
anchors.topMargin: 16
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: 8
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: 8
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
anchors.bottomMargin: 16
|
|
|
|
boundsBehavior: Flickable.StopAtBounds
|
2022-01-28 15:29:29 +01:00
|
|
|
model: Models.membersListModel
|
|
|
|
delegate: StatusMemberListItem {
|
|
|
|
implicitWidth: parent.width
|
2022-06-12 16:25:17 +02:00
|
|
|
nickName: model.localNickname
|
|
|
|
userName: model.displayName
|
|
|
|
pubKey: model.pubKey
|
|
|
|
isVerified: model.isVerified
|
|
|
|
isUntrustworthy: model.isUntrustworthy
|
|
|
|
isContact: model.isContact
|
2022-05-19 12:02:36 +03:00
|
|
|
image.source: model.icon
|
2022-06-12 16:25:17 +02:00
|
|
|
image.isIdenticon: false
|
|
|
|
status: model.onlineStatus
|
2022-01-18 21:54:45 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|