mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-23 04:50:28 +00:00
211 lines
7.5 KiB
QML
211 lines
7.5 KiB
QML
import QtQuick 2.15
|
|
import QtQuick.Controls 2.15
|
|
import QtQuick.Layouts 1.15
|
|
import QtQml 2.15
|
|
|
|
import StatusQ 0.1
|
|
import StatusQ.Core.Utils 0.1 as StatusQUtils
|
|
|
|
import Storybook 1.0
|
|
import Models 1.0
|
|
|
|
import AppLayouts.Communities.popups 1.0
|
|
|
|
SplitView {
|
|
id: root
|
|
|
|
Logs { id: logs }
|
|
|
|
orientation: Qt.Vertical
|
|
|
|
property var dialog
|
|
|
|
function createAndOpenDialog() {
|
|
dialog = dlgComponent.createObject(popupBg)
|
|
dialog.open()
|
|
}
|
|
|
|
Component.onCompleted: createAndOpenDialog()
|
|
|
|
Item {
|
|
SplitView.fillWidth: true
|
|
SplitView.fillHeight: true
|
|
|
|
PopupBackground {
|
|
id: popupBg
|
|
anchors.fill: parent
|
|
|
|
Button {
|
|
anchors.centerIn: parent
|
|
text: "Reopen"
|
|
|
|
onClicked: createAndOpenDialog()
|
|
}
|
|
}
|
|
|
|
Component {
|
|
id: dlgComponent
|
|
CreateChannelPopup {
|
|
id: dialog
|
|
anchors.centerIn: parent
|
|
destroyOnClose: true
|
|
isEdit: true
|
|
isDeleteable: isDeleteableCheckBox.checked
|
|
isDiscordImport: isDiscordCheckBox.checked
|
|
chatId: "_general"
|
|
channelName: "general"
|
|
channelDescription: "general discussion"
|
|
channelColor: "#4360DF"
|
|
activeCommunity: QtObject {
|
|
readonly property string id: "0x039c47e9837a1a7dcd00a6516399d0eb521ab0a92d512ca20a44ac6278bfdbb5c5"
|
|
readonly property string name: "test-1"
|
|
readonly property string image: ModelsData.icons.superRare
|
|
readonly property string color: "#4360DF"
|
|
readonly property int memberRole: 0
|
|
}
|
|
assetsModel: AssetsModel {}
|
|
channelsModel: ChannelsModel {}
|
|
collectiblesModel: CollectiblesModel {}
|
|
|
|
permissionsModel: ListModel {
|
|
id: permissionsModel
|
|
Component.onCompleted: {
|
|
append(PermissionsModel.channelsOnlyPermissionsModelData)
|
|
}
|
|
}
|
|
|
|
communitiesStore: QtObject {
|
|
property string discordImportChannelName
|
|
readonly property bool discordImportInProgress: false
|
|
readonly property bool discordDataExtractionInProgress: false
|
|
readonly property int discordImportErrorsCount: 0
|
|
readonly property int discordImportWarningsCount: 0
|
|
readonly property int discordOldestMessageTimestamp: 0
|
|
|
|
property var discordFileList: ListModel {
|
|
readonly property int selectedCount: count
|
|
property bool selectedFilesValid
|
|
}
|
|
|
|
property var discordCategoriesModel: ListModel {}
|
|
|
|
property var discordChannelsModel: ListModel {
|
|
property bool hasSelectedItems
|
|
readonly property int count: 32 // hide the parsing/loading spinner
|
|
}
|
|
|
|
function setFileListItems(filePaths) {
|
|
for (const filePath of filePaths) {
|
|
discordFileList.append({"filePath": filePath, errorMessage: ""})
|
|
}
|
|
}
|
|
|
|
function removeFileListItem(path) {
|
|
for (let i = 0; i < discordFileList.count; i++) {
|
|
const item = discordFileList.get(i)
|
|
if (item.filePath === path)
|
|
discordFileList.remove(i)
|
|
}
|
|
}
|
|
|
|
function clearFileList() {
|
|
discordFileList.clear()
|
|
discordFileList.selectedFilesValid = false
|
|
}
|
|
|
|
function clearDiscordCategoriesAndChannels() {
|
|
discordCategoriesModel.clear()
|
|
discordChannelsModel.clear()
|
|
discordChannelsModel.hasSelectedItems = false
|
|
}
|
|
|
|
function requestExtractChannelsAndCategories() {
|
|
discordFileList.selectedFilesValid = true
|
|
}
|
|
|
|
function toggleOneDiscordChannel(id) {
|
|
logs.logEvent("toggleOneDiscordChannel", ["id"], arguments)
|
|
}
|
|
|
|
function resetDiscordImport() {
|
|
logs.logEvent("resetDiscordImport")
|
|
}
|
|
|
|
function requestCancelDiscordChannelImport(id) {
|
|
logs.logEvent("requestCancelDiscordChannelImport", ["id"], arguments)
|
|
}
|
|
|
|
function requestImportDiscordChannel(args, timestamp) {
|
|
logs.logEvent("requestImportDiscordChannel", ["args", "timestamp"], arguments)
|
|
}
|
|
}
|
|
|
|
emojiPopup: Popup {
|
|
id: inner_emojiPopup
|
|
|
|
parent: root
|
|
|
|
property var emojiSize
|
|
|
|
Button {
|
|
text: "😃"
|
|
onClicked: {
|
|
emojiPopup.emojiSelected(text, false)
|
|
emojiPopup.close()
|
|
}
|
|
}
|
|
|
|
signal emojiSelected(string emoji, bool atCu)
|
|
}
|
|
|
|
|
|
onCreateCommunityChannel: function(chName, chDescription, chEmoji, chColor, chCategoryId) {
|
|
logs.logEvent("onCreateCommunityChannel",
|
|
["chName", "chDescription", "chEmoji", "chColor", "chCategoryId"], arguments)
|
|
}
|
|
|
|
onEditCommunityChannel: function(chName, chDescription, chEmoji, chColor, chCategoryId) {
|
|
logs.logEvent("onEditCommunityChannel",
|
|
["chName", "chDescription", "chEmoji", "chColor", "chCategoryId"], arguments)
|
|
}
|
|
|
|
onDeleteCommunityChannel: () => {
|
|
logs.logEvent("onDeleteCommunityChannel")
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
LogsAndControlsPanel {
|
|
SplitView.minimumHeight: 100
|
|
SplitView.preferredHeight: 200
|
|
|
|
logsView.logText: logs.logText
|
|
|
|
RowLayout {
|
|
CheckBox {
|
|
id: isDeleteableCheckBox
|
|
text: "isDeleteable"
|
|
}
|
|
CheckBox {
|
|
id: isDiscordCheckBox
|
|
text: "isDiscordImport"
|
|
onToggled: {
|
|
if (!!dialog && dialog.opened)
|
|
dialog.close()
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// category: Popups
|
|
|
|
// https://www.figma.com/file/17fc13UBFvInrLgNUKJJg5/Kuba%E2%8E%9CDesktop?node-id=2975%3A488608
|
|
// https://www.figma.com/file/17fc13UBFvInrLgNUKJJg5/Kuba%E2%8E%9CDesktop?node-id=2975%3A488256
|
|
// https://www.figma.com/file/17fc13UBFvInrLgNUKJJg5/Kuba%E2%8E%9CDesktop?node-id=2903%3A348301
|
|
// https://www.figma.com/file/17fc13UBFvInrLgNUKJJg5/Kuba%E2%8E%9CDesktop?node-id=2975%3A488848
|
|
// https://www.figma.com/file/17fc13UBFvInrLgNUKJJg5/Kuba%E2%8E%9CDesktop?node-id=2975%3A489237
|
|
// https://www.figma.com/file/17fc13UBFvInrLgNUKJJg5/Kuba%E2%8E%9CDesktop?node-id=2975%3A489607
|
|
// https://www.figma.com/file/17fc13UBFvInrLgNUKJJg5/Kuba%E2%8E%9CDesktop?node-id=2975%3A492910
|