mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-10 14:26:34 +00:00
chore(CommunitySettingsView): Not needed top level Loader removed
This commit is contained in:
parent
7a9c76966d
commit
6247110293
@ -33,13 +33,29 @@ StatusSectionLayout {
|
|||||||
notificationCount: activityCenterStore.unreadNotificationsCount
|
notificationCount: activityCenterStore.unreadNotificationsCount
|
||||||
hasUnseenNotifications: activityCenterStore.hasUnseenNotifications
|
hasUnseenNotifications: activityCenterStore.hasUnseenNotifications
|
||||||
onNotificationButtonClicked: Global.openActivityCenterPopup()
|
onNotificationButtonClicked: Global.openActivityCenterPopup()
|
||||||
// TODO: get this model from backend?
|
|
||||||
property var settingsMenuModel: [{id: Constants.CommunitySettingsSections.Overview, name: qsTr("Overview"), icon: "show", enabled: true},
|
|
||||||
{id: Constants.CommunitySettingsSections.Members, name: qsTr("Members"), icon: "group-chat", enabled: true, },
|
|
||||||
|
|
||||||
{id: Constants.CommunitySettingsSections.Permissions, name: qsTr("Permissions"), icon: "objects", enabled: true},
|
readonly property var settingsMenuModel: [
|
||||||
{id: Constants.CommunitySettingsSections.MintTokens, name: qsTr("Mint Tokens"), icon: "token", enabled: root.isOwner},
|
{
|
||||||
{id: Constants.CommunitySettingsSections.Airdrops, name: qsTr("Airdrops"), icon: "airdrop", enabled: root.isOwner}]
|
id: Constants.CommunitySettingsSections.Overview,
|
||||||
|
name: qsTr("Overview"), icon: "show", enabled: true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: Constants.CommunitySettingsSections.Members,
|
||||||
|
name: qsTr("Members"), icon: "group-chat", enabled: true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: Constants.CommunitySettingsSections.Permissions,
|
||||||
|
name: qsTr("Permissions"), icon: "objects", enabled: true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: Constants.CommunitySettingsSections.MintTokens,
|
||||||
|
name: qsTr("Mint Tokens"), icon: "token", enabled: root.isOwner
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: Constants.CommunitySettingsSections.Airdrops,
|
||||||
|
name: qsTr("Airdrops"), icon: "airdrop", enabled: root.isOwner
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
// TODO: Next community settings options:
|
// TODO: Next community settings options:
|
||||||
// {name: qsTr("Token sales"), icon: "token-sale"},
|
// {name: qsTr("Token sales"), icon: "token-sale"},
|
||||||
@ -54,21 +70,18 @@ StatusSectionLayout {
|
|||||||
readonly property bool isAdmin: isOwner || community.memberRole === Constants.memberRole.admin
|
readonly property bool isAdmin: isOwner || community.memberRole === Constants.memberRole.admin
|
||||||
|
|
||||||
readonly property string filteredSelectedTags: {
|
readonly property string filteredSelectedTags: {
|
||||||
var tagsArray = []
|
let tagsArray = []
|
||||||
if (community && community.tags) {
|
if (community && community.tags) {
|
||||||
try {
|
try {
|
||||||
const json = JSON.parse(community.tags)
|
const json = JSON.parse(community.tags)
|
||||||
if (!!json) {
|
|
||||||
tagsArray = json.map(tag => {
|
if (!!json)
|
||||||
return tag.name
|
tagsArray = json.map(tag => tag.name)
|
||||||
})
|
} catch (e) {
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (e) {
|
|
||||||
console.warn("Error parsing community tags: ", community.tags, " error: ", e.message)
|
console.warn("Error parsing community tags: ", community.tags, " error: ", e.message)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return JSON.stringify(tagsArray);
|
return JSON.stringify(tagsArray)
|
||||||
}
|
}
|
||||||
|
|
||||||
signal backToCommunityClicked
|
signal backToCommunityClicked
|
||||||
@ -79,7 +92,7 @@ StatusSectionLayout {
|
|||||||
}
|
}
|
||||||
|
|
||||||
onBackButtonClicked: {
|
onBackButtonClicked: {
|
||||||
centerPanelContentLoader.item.children[d.currentIndex].navigateBack()
|
stackLayout.children[d.currentIndex].navigateBack()
|
||||||
}
|
}
|
||||||
|
|
||||||
leftPanel: Item {
|
leftPanel: Item {
|
||||||
@ -159,430 +172,434 @@ StatusSectionLayout {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
centerPanel: Loader {
|
centerPanel: StackLayout {
|
||||||
id: centerPanelContentLoader
|
id: stackLayout
|
||||||
|
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
active: root.community
|
|
||||||
sourceComponent: StackLayout {
|
|
||||||
id: stackLayout
|
|
||||||
currentIndex: d.currentIndex
|
|
||||||
|
|
||||||
OverviewSettingsPanel {
|
currentIndex: d.currentIndex
|
||||||
communityId: root.community.id
|
|
||||||
name: root.community.name
|
|
||||||
description: root.community.description
|
|
||||||
introMessage: root.community.introMessage
|
|
||||||
outroMessage: root.community.outroMessage
|
|
||||||
logoImageData: root.community.image
|
|
||||||
bannerImageData: root.community.bannerImageData
|
|
||||||
color: root.community.color
|
|
||||||
tags: root.rootStore.communityTags
|
|
||||||
selectedTags: root.filteredSelectedTags
|
|
||||||
archiveSupportEnabled: root.community.historyArchiveSupportEnabled
|
|
||||||
requestToJoinEnabled: root.community.access === Constants.communityChatOnRequestAccess
|
|
||||||
pinMessagesEnabled: root.community.pinMessageAllMembersEnabled
|
|
||||||
editable: true
|
|
||||||
owned: root.community.memberRole === Constants.memberRole.owner
|
|
||||||
|
|
||||||
onEdited: {
|
OverviewSettingsPanel {
|
||||||
const error = root.chatCommunitySectionModule.editCommunity(
|
communityId: root.community.id
|
||||||
StatusQUtils.Utils.filterXSS(item.name),
|
name: root.community.name
|
||||||
StatusQUtils.Utils.filterXSS(item.description),
|
description: root.community.description
|
||||||
StatusQUtils.Utils.filterXSS(item.introMessage),
|
introMessage: root.community.introMessage
|
||||||
StatusQUtils.Utils.filterXSS(item.outroMessage),
|
outroMessage: root.community.outroMessage
|
||||||
item.options.requestToJoinEnabled ? Constants.communityChatOnRequestAccess : Constants.communityChatPublicAccess,
|
logoImageData: root.community.image
|
||||||
item.color.toString().toUpperCase(),
|
bannerImageData: root.community.bannerImageData
|
||||||
item.selectedTags,
|
color: root.community.color
|
||||||
Utils.getImageAndCropInfoJson(item.logoImagePath, item.logoCropRect),
|
tags: root.rootStore.communityTags
|
||||||
Utils.getImageAndCropInfoJson(item.bannerPath, item.bannerCropRect),
|
selectedTags: root.filteredSelectedTags
|
||||||
item.options.archiveSupportEnabled,
|
archiveSupportEnabled: root.community.historyArchiveSupportEnabled
|
||||||
item.options.pinMessagesEnabled
|
requestToJoinEnabled: root.community.access === Constants.communityChatOnRequestAccess
|
||||||
)
|
pinMessagesEnabled: root.community.pinMessageAllMembersEnabled
|
||||||
if (error) {
|
editable: true
|
||||||
errorDialog.text = error.error
|
owned: root.community.memberRole === Constants.memberRole.owner
|
||||||
errorDialog.open()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
onInviteNewPeopleClicked: {
|
onEdited: {
|
||||||
Global.openInviteFriendsToCommunityPopup(root.community,
|
const error = root.chatCommunitySectionModule.editCommunity(
|
||||||
root.chatCommunitySectionModule,
|
StatusQUtils.Utils.filterXSS(item.name),
|
||||||
null)
|
StatusQUtils.Utils.filterXSS(item.description),
|
||||||
}
|
StatusQUtils.Utils.filterXSS(item.introMessage),
|
||||||
|
StatusQUtils.Utils.filterXSS(item.outroMessage),
|
||||||
onAirdropTokensClicked: root.goTo(Constants.CommunitySettingsSections.Airdrops)
|
item.options.requestToJoinEnabled ? Constants.communityChatOnRequestAccess : Constants.communityChatPublicAccess,
|
||||||
onBackUpClicked: {
|
item.color.toString().toUpperCase(),
|
||||||
Global.openPopup(transferOwnershipPopup, {
|
item.selectedTags,
|
||||||
privateKey: root.chatCommunitySectionModule.exportCommunity(root.community.id),
|
Utils.getImageAndCropInfoJson(item.logoImagePath, item.logoCropRect),
|
||||||
})
|
Utils.getImageAndCropInfoJson(item.bannerPath, item.bannerCropRect),
|
||||||
}
|
item.options.archiveSupportEnabled,
|
||||||
onPreviousPageNameChanged: root.backButtonName = previousPageName
|
item.options.pinMessagesEnabled
|
||||||
}
|
)
|
||||||
|
if (error) {
|
||||||
MembersSettingsPanel {
|
errorDialog.text = error.error
|
||||||
rootStore: root.rootStore
|
errorDialog.open()
|
||||||
membersModel: root.community.members
|
|
||||||
bannedMembersModel: root.community.bannedMembers
|
|
||||||
pendingMemberRequestsModel: root.community.pendingMemberRequests
|
|
||||||
declinedMemberRequestsModel: root.community.declinedMemberRequests
|
|
||||||
editable: root.isAdmin
|
|
||||||
communityName: root.community.name
|
|
||||||
|
|
||||||
onKickUserClicked: root.rootStore.removeUserFromCommunity(id)
|
|
||||||
onBanUserClicked: root.rootStore.banUserFromCommunity(id)
|
|
||||||
onUnbanUserClicked: root.rootStore.unbanUserFromCommunity(id)
|
|
||||||
onAcceptRequestToJoin: root.rootStore.acceptRequestToJoinCommunity(id, root.community.id)
|
|
||||||
onDeclineRequestToJoin: root.rootStore.declineRequestToJoinCommunity(id, root.community.id)
|
|
||||||
}
|
|
||||||
|
|
||||||
PermissionsSettingsPanel {
|
|
||||||
readonly property PermissionsStore permissionsStore:
|
|
||||||
rootStore.permissionsStore
|
|
||||||
|
|
||||||
permissionsModel: permissionsStore.permissionsModel
|
|
||||||
|
|
||||||
// temporary solution to provide icons for assets, similar
|
|
||||||
// method is used in wallet (constructing filename from asset's
|
|
||||||
// symbol) and is intended to be replaced by more robust
|
|
||||||
// solution soon.
|
|
||||||
|
|
||||||
assetsModel: rootStore.assetsModel
|
|
||||||
collectiblesModel: rootStore.collectiblesModel
|
|
||||||
channelsModel: rootStore.chatCommunitySectionModule.model
|
|
||||||
|
|
||||||
communityDetails: d.communityDetails
|
|
||||||
|
|
||||||
onCreatePermissionRequested:
|
|
||||||
permissionsStore.createPermission(holdings, permissionType,
|
|
||||||
isPrivate, channels)
|
|
||||||
|
|
||||||
onUpdatePermissionRequested:
|
|
||||||
permissionsStore.editPermission(
|
|
||||||
key, holdings, permissionType, channels, isPrivate)
|
|
||||||
|
|
||||||
onRemovePermissionRequested:
|
|
||||||
permissionsStore.removePermission(key)
|
|
||||||
|
|
||||||
onPreviousPageNameChanged: root.backButtonName = previousPageName
|
|
||||||
|
|
||||||
onNavigateToMintTokenSettings: root.goTo(Constants.CommunitySettingsSections.MintTokens)
|
|
||||||
}
|
|
||||||
|
|
||||||
MintTokensSettingsPanel {
|
|
||||||
id: mintPanel
|
|
||||||
|
|
||||||
readonly property CommunityTokensStore communityTokensStore:
|
|
||||||
rootStore.communityTokensStore
|
|
||||||
|
|
||||||
function setFeesInfo(ethCurrency, fiatCurrency, errorCode) {
|
|
||||||
if (errorCode === Constants.ComputeFeeErrorCode.Success || errorCode === Constants.ComputeFeeErrorCode.Balance) {
|
|
||||||
let valueStr = LocaleUtils.currencyAmountToLocaleString(ethCurrency) + "(" + LocaleUtils.currencyAmountToLocaleString(fiatCurrency) + ")"
|
|
||||||
mintPanel.feeText = valueStr
|
|
||||||
if (errorCode === Constants.ComputeFeeErrorCode.Balance) {
|
|
||||||
mintPanel.errorText = qsTr("Not enough funds to make transaction")
|
|
||||||
}
|
|
||||||
mintPanel.isFeeLoading = false
|
|
||||||
return
|
|
||||||
} else if (errorCode === Constants.ComputeFeeErrorCode.Infura) {
|
|
||||||
mintPanel.errorText = qsTr("Infura error")
|
|
||||||
mintPanel.isFeeLoading = true
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
mintPanel.errorText = qsTr("Unknown error")
|
|
||||||
mintPanel.isFeeLoading = true
|
|
||||||
}
|
|
||||||
|
|
||||||
communityName: root.community.name
|
|
||||||
tokensModel: root.community.communityTokens
|
|
||||||
layer1Networks: communityTokensStore.layer1Networks
|
|
||||||
layer2Networks: communityTokensStore.layer2Networks
|
|
||||||
testNetworks: communityTokensStore.testNetworks
|
|
||||||
enabledNetworks: communityTokensStore.enabledNetworks
|
|
||||||
allNetworks: communityTokensStore.allNetworks
|
|
||||||
accounts: root.rootStore.accounts
|
|
||||||
|
|
||||||
onPreviousPageNameChanged: root.backButtonName = previousPageName
|
|
||||||
onSignMintTransactionOpened: communityTokensStore.computeDeployFee(chainId, accountAddress, tokenType)
|
|
||||||
onMintCollectible: communityTokensStore.deployCollectible(root.community.id, collectibleItem)
|
|
||||||
onMintAsset: communityTokensStore.deployAsset(root.community.id, assetItem)
|
|
||||||
onSignRemoteDestructTransactionOpened: communityTokensStore.computeSelfDestructFee(remotelyDestructTokensList, tokenKey)
|
|
||||||
onRemotelyDestructCollectibles: {
|
|
||||||
communityTokensStore.remoteSelfDestructCollectibles(root.community.id,
|
|
||||||
remotelyDestructTokensList,
|
|
||||||
tokenKey)
|
|
||||||
}
|
|
||||||
onSignBurnTransactionOpened: communityTokensStore.computeBurnFee(tokenKey, amount)
|
|
||||||
onBurnToken: communityTokensStore.burnToken(root.community.id, tokenKey, amount)
|
|
||||||
onAirdropToken: root.goTo(Constants.CommunitySettingsSections.Airdrops)
|
|
||||||
onDeleteToken: communityTokensStore.deleteToken(root.community.id, tokenKey)
|
|
||||||
|
|
||||||
Connections {
|
|
||||||
target: rootStore.communityTokensStore
|
|
||||||
function onDeployFeeUpdated(ethCurrency, fiatCurrency, errorCode) {
|
|
||||||
mintPanel.setFeesInfo(ethCurrency, fiatCurrency, errorCode)
|
|
||||||
}
|
|
||||||
|
|
||||||
function onSelfDestructFeeUpdated(ethCurrency, fiatCurrency, errorCode) {
|
|
||||||
mintPanel.setFeesInfo(ethCurrency, fiatCurrency, errorCode)
|
|
||||||
}
|
|
||||||
|
|
||||||
function onBurnFeeUpdated(ethCurrency, fiatCurrency, errorCode) {
|
|
||||||
mintPanel.setFeesInfo(ethCurrency, fiatCurrency, errorCode)
|
|
||||||
}
|
|
||||||
|
|
||||||
function onRemoteDestructStateChanged(communityId, tokenName, status, url) {
|
|
||||||
if (root.community.id !== communityId) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
let title = ""
|
|
||||||
let loading = false
|
|
||||||
let type = Constants.ephemeralNotificationType.normal
|
|
||||||
switch (status) {
|
|
||||||
case Constants.ContractTransactionStatus.InProgress:
|
|
||||||
title = qsTr("Remotely destroying tokens...")
|
|
||||||
loading = true
|
|
||||||
break
|
|
||||||
case Constants.ContractTransactionStatus.Completed:
|
|
||||||
title = qsTr("%1 tokens destroyed").arg(tokenName)
|
|
||||||
type = Constants.ephemeralNotificationType.success
|
|
||||||
break
|
|
||||||
case Constants.ContractTransactionStatus.Failed:
|
|
||||||
title = qsTr("%1 tokens destruction failed").arg(tokenName)
|
|
||||||
break
|
|
||||||
default:
|
|
||||||
console.warn("Unknown destruction state: "+status)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
Global.displayToastMessage(title,
|
|
||||||
qsTr("View on etherscan"),
|
|
||||||
"",
|
|
||||||
loading,
|
|
||||||
type,
|
|
||||||
url)
|
|
||||||
}
|
|
||||||
|
|
||||||
function onAirdropStateChanged(communityId, tokenName, chainName, status, url) {
|
|
||||||
if (root.community.id !== communityId) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
let title = ""
|
|
||||||
let loading = false
|
|
||||||
let type = Constants.ephemeralNotificationType.normal
|
|
||||||
switch (status) {
|
|
||||||
case Constants.ContractTransactionStatus.InProgress:
|
|
||||||
title = qsTr("Airdrop on %1 in progress...").arg(chainName)
|
|
||||||
loading = true
|
|
||||||
break
|
|
||||||
case Constants.ContractTransactionStatus.Completed:
|
|
||||||
title = qsTr("Airdrop on %1 in complete").arg(chainName)
|
|
||||||
type = Constants.ephemeralNotificationType.success
|
|
||||||
break
|
|
||||||
case Constants.ContractTransactionStatus.Failed:
|
|
||||||
title = qsTr("Airdrop on %1 failed").arg(chainName)
|
|
||||||
break
|
|
||||||
default:
|
|
||||||
console.warn("Unknown airdrop state: "+status)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
Global.displayToastMessage(title,
|
|
||||||
qsTr("View on etherscan"),
|
|
||||||
"",
|
|
||||||
loading,
|
|
||||||
type,
|
|
||||||
url)
|
|
||||||
}
|
|
||||||
|
|
||||||
function onBurnStateChanged(communityId, tokenName, status, url) {
|
|
||||||
if (root.community.id !== communityId) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
let title = ""
|
|
||||||
let loading = false
|
|
||||||
let type = Constants.ephemeralNotificationType.normal
|
|
||||||
switch (status) {
|
|
||||||
case Constants.ContractTransactionStatus.InProgress:
|
|
||||||
title = qsTr("%1 being burned...").arg(tokenName)
|
|
||||||
loading = true
|
|
||||||
break
|
|
||||||
case Constants.ContractTransactionStatus.Completed:
|
|
||||||
title = qsTr("%1 burning is complete").arg(tokenName)
|
|
||||||
type = Constants.ephemeralNotificationType.success
|
|
||||||
break
|
|
||||||
case Constants.ContractTransactionStatus.Failed:
|
|
||||||
title = qsTr("%1 burning is failed").arg(tokenName)
|
|
||||||
break
|
|
||||||
default:
|
|
||||||
console.warn("Unknown burning state: "+status)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
Global.displayToastMessage(title,
|
|
||||||
qsTr("View on etherscan"),
|
|
||||||
"",
|
|
||||||
loading,
|
|
||||||
type,
|
|
||||||
url)
|
|
||||||
}
|
|
||||||
|
|
||||||
function onDeploymentStateChanged(communityId, status, url) {
|
|
||||||
if (root.community.id !== communityId) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
let title = ""
|
|
||||||
let loading = false
|
|
||||||
let type = Constants.ephemeralNotificationType.normal
|
|
||||||
switch (status) {
|
|
||||||
case Constants.ContractTransactionStatus.InProgress:
|
|
||||||
title = qsTr("Token is being minted...")
|
|
||||||
loading = true
|
|
||||||
break
|
|
||||||
case Constants.ContractTransactionStatus.Completed:
|
|
||||||
title = qsTr("Token minting finished")
|
|
||||||
type = Constants.ephemeralNotificationType.success
|
|
||||||
break
|
|
||||||
case Constants.ContractTransactionStatus.Failed:
|
|
||||||
title = qsTr("Token minting failed")
|
|
||||||
break
|
|
||||||
default:
|
|
||||||
console.warn("Unknown deploy state: "+status)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
Global.displayToastMessage(title,
|
|
||||||
qsTr("View on etherscan"),
|
|
||||||
"",
|
|
||||||
loading,
|
|
||||||
type,
|
|
||||||
url)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Connections {
|
|
||||||
target: airdropPanel
|
|
||||||
|
|
||||||
function onNavigateToMintTokenSettings(isAssetType) {
|
|
||||||
mintPanel.openNewTokenForm(isAssetType)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
AirdropsSettingsPanel {
|
onInviteNewPeopleClicked: {
|
||||||
id: airdropPanel
|
Global.openInviteFriendsToCommunityPopup(root.community,
|
||||||
|
root.chatCommunitySectionModule,
|
||||||
communityDetails: d.communityDetails
|
null)
|
||||||
readonly property CommunityTokensStore communityTokensStore:
|
|
||||||
rootStore.communityTokensStore
|
|
||||||
|
|
||||||
readonly property var communityTokens: root.community.communityTokens
|
|
||||||
|
|
||||||
Loader {
|
|
||||||
id: assetsModelLoader
|
|
||||||
active: airdropPanel.communityTokens
|
|
||||||
|
|
||||||
sourceComponent: SortFilterProxyModel {
|
|
||||||
|
|
||||||
sourceModel: airdropPanel.communityTokens
|
|
||||||
filters: ValueFilter {
|
|
||||||
roleName: "tokenType"
|
|
||||||
value: Constants.TokenType.ERC20
|
|
||||||
}
|
|
||||||
proxyRoles: [
|
|
||||||
ExpressionRole {
|
|
||||||
name: "category"
|
|
||||||
|
|
||||||
// Singleton cannot be used directly in the expression
|
|
||||||
readonly property int category: TokenCategories.Category.Own
|
|
||||||
expression: category
|
|
||||||
},
|
|
||||||
ExpressionRole {
|
|
||||||
name: "iconSource"
|
|
||||||
expression: model.image
|
|
||||||
},
|
|
||||||
ExpressionRole {
|
|
||||||
name: "key"
|
|
||||||
expression: model.symbol
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Loader {
|
|
||||||
id: collectiblesModelLoader
|
|
||||||
active: airdropPanel.communityTokens
|
|
||||||
|
|
||||||
sourceComponent: SortFilterProxyModel {
|
|
||||||
|
|
||||||
sourceModel: airdropPanel.communityTokens
|
|
||||||
filters: ValueFilter {
|
|
||||||
roleName: "tokenType"
|
|
||||||
value: Constants.TokenType.ERC721
|
|
||||||
}
|
|
||||||
proxyRoles: [
|
|
||||||
ExpressionRole {
|
|
||||||
name: "category"
|
|
||||||
|
|
||||||
// Singleton cannot be used directly in the epression
|
|
||||||
readonly property int category: TokenCategories.Category.Own
|
|
||||||
expression: category
|
|
||||||
},
|
|
||||||
ExpressionRole {
|
|
||||||
name: "iconSource"
|
|
||||||
expression: model.image
|
|
||||||
},
|
|
||||||
ExpressionRole {
|
|
||||||
name: "key"
|
|
||||||
expression: model.symbol
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
assetsModel: assetsModelLoader.item
|
|
||||||
collectiblesModel: collectiblesModelLoader.item
|
|
||||||
membersModel: {
|
|
||||||
const chatContentModule = root.rootStore.currentChatContentModule()
|
|
||||||
if (!chatContentModule || !chatContentModule.usersModule) {
|
|
||||||
// New communities have no chats, so no chatContentModule
|
|
||||||
return null
|
|
||||||
}
|
|
||||||
return chatContentModule.usersModule.model
|
|
||||||
}
|
|
||||||
|
|
||||||
onPreviousPageNameChanged: root.backButtonName = previousPageName
|
|
||||||
onAirdropClicked: communityTokensStore.airdrop(root.community.id, airdropTokens, addresses)
|
|
||||||
onNavigateToMintTokenSettings: root.goTo(Constants.CommunitySettingsSections.MintTokens)
|
|
||||||
|
|
||||||
onAirdropFeesRequested:
|
|
||||||
communityTokensStore.computeAirdropFee(
|
|
||||||
root.community.id, contractKeysAndAmounts, addresses)
|
|
||||||
|
|
||||||
Connections {
|
|
||||||
target: mintPanel
|
|
||||||
|
|
||||||
function onAirdropToken(tokenKey, type, addresses) {
|
|
||||||
// Force a token selection to be airdroped with default amount 1
|
|
||||||
airdropPanel.selectToken(tokenKey, 1, type)
|
|
||||||
|
|
||||||
// Set given addresses as recipients
|
|
||||||
airdropPanel.addAddresses(addresses)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Connections {
|
|
||||||
target: rootStore.communityTokensStore
|
|
||||||
|
|
||||||
function onAirdropFeeUpdated(airdropFees) {
|
|
||||||
airdropPanel.airdropFees = airdropFees
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
onCurrentIndexChanged:
|
onAirdropTokensClicked: root.goTo(Constants.CommunitySettingsSections.Airdrops)
|
||||||
root.backButtonName = centerPanelContentLoader.item.children[d.currentIndex].previousPageName || ""
|
onBackUpClicked: {
|
||||||
|
Global.openPopup(transferOwnershipPopup, {
|
||||||
|
privateKey: root.chatCommunitySectionModule.exportCommunity(root.community.id),
|
||||||
|
})
|
||||||
|
}
|
||||||
|
onPreviousPageNameChanged: root.backButtonName = previousPageName
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MembersSettingsPanel {
|
||||||
|
rootStore: root.rootStore
|
||||||
|
membersModel: root.community.members
|
||||||
|
bannedMembersModel: root.community.bannedMembers
|
||||||
|
pendingMemberRequestsModel: root.community.pendingMemberRequests
|
||||||
|
declinedMemberRequestsModel: root.community.declinedMemberRequests
|
||||||
|
editable: root.isAdmin
|
||||||
|
communityName: root.community.name
|
||||||
|
|
||||||
|
onKickUserClicked: root.rootStore.removeUserFromCommunity(id)
|
||||||
|
onBanUserClicked: root.rootStore.banUserFromCommunity(id)
|
||||||
|
onUnbanUserClicked: root.rootStore.unbanUserFromCommunity(id)
|
||||||
|
onAcceptRequestToJoin: root.rootStore.acceptRequestToJoinCommunity(id, root.community.id)
|
||||||
|
onDeclineRequestToJoin: root.rootStore.declineRequestToJoinCommunity(id, root.community.id)
|
||||||
|
}
|
||||||
|
|
||||||
|
PermissionsSettingsPanel {
|
||||||
|
readonly property PermissionsStore permissionsStore:
|
||||||
|
rootStore.permissionsStore
|
||||||
|
|
||||||
|
permissionsModel: permissionsStore.permissionsModel
|
||||||
|
|
||||||
|
// temporary solution to provide icons for assets, similar
|
||||||
|
// method is used in wallet (constructing filename from asset's
|
||||||
|
// symbol) and is intended to be replaced by more robust
|
||||||
|
// solution soon.
|
||||||
|
|
||||||
|
assetsModel: rootStore.assetsModel
|
||||||
|
collectiblesModel: rootStore.collectiblesModel
|
||||||
|
channelsModel: rootStore.chatCommunitySectionModule.model
|
||||||
|
|
||||||
|
communityDetails: d.communityDetails
|
||||||
|
|
||||||
|
onCreatePermissionRequested:
|
||||||
|
permissionsStore.createPermission(holdings, permissionType,
|
||||||
|
isPrivate, channels)
|
||||||
|
|
||||||
|
onUpdatePermissionRequested:
|
||||||
|
permissionsStore.editPermission(
|
||||||
|
key, holdings, permissionType, channels, isPrivate)
|
||||||
|
|
||||||
|
onRemovePermissionRequested:
|
||||||
|
permissionsStore.removePermission(key)
|
||||||
|
|
||||||
|
onPreviousPageNameChanged: root.backButtonName = previousPageName
|
||||||
|
|
||||||
|
onNavigateToMintTokenSettings: {
|
||||||
|
root.goTo(Constants.CommunitySettingsSections.MintTokens)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
MintTokensSettingsPanel {
|
||||||
|
id: mintPanel
|
||||||
|
|
||||||
|
readonly property CommunityTokensStore communityTokensStore:
|
||||||
|
rootStore.communityTokensStore
|
||||||
|
|
||||||
|
function setFeesInfo(ethCurrency, fiatCurrency, errorCode) {
|
||||||
|
if (errorCode === Constants.ComputeFeeErrorCode.Success || errorCode === Constants.ComputeFeeErrorCode.Balance) {
|
||||||
|
let valueStr = LocaleUtils.currencyAmountToLocaleString(ethCurrency) + "(" + LocaleUtils.currencyAmountToLocaleString(fiatCurrency) + ")"
|
||||||
|
mintPanel.feeText = valueStr
|
||||||
|
if (errorCode === Constants.ComputeFeeErrorCode.Balance) {
|
||||||
|
mintPanel.errorText = qsTr("Not enough funds to make transaction")
|
||||||
|
}
|
||||||
|
mintPanel.isFeeLoading = false
|
||||||
|
return
|
||||||
|
} else if (errorCode === Constants.ComputeFeeErrorCode.Infura) {
|
||||||
|
mintPanel.errorText = qsTr("Infura error")
|
||||||
|
mintPanel.isFeeLoading = true
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
mintPanel.errorText = qsTr("Unknown error")
|
||||||
|
mintPanel.isFeeLoading = true
|
||||||
|
}
|
||||||
|
|
||||||
|
communityName: root.community.name
|
||||||
|
tokensModel: root.community.communityTokens
|
||||||
|
layer1Networks: communityTokensStore.layer1Networks
|
||||||
|
layer2Networks: communityTokensStore.layer2Networks
|
||||||
|
testNetworks: communityTokensStore.testNetworks
|
||||||
|
enabledNetworks: communityTokensStore.enabledNetworks
|
||||||
|
allNetworks: communityTokensStore.allNetworks
|
||||||
|
accounts: root.rootStore.accounts
|
||||||
|
|
||||||
|
onPreviousPageNameChanged: root.backButtonName = previousPageName
|
||||||
|
onSignMintTransactionOpened: communityTokensStore.computeDeployFee(chainId, accountAddress, tokenType)
|
||||||
|
onMintCollectible: communityTokensStore.deployCollectible(root.community.id, collectibleItem)
|
||||||
|
onMintAsset: communityTokensStore.deployAsset(root.community.id, assetItem)
|
||||||
|
onSignRemoteDestructTransactionOpened: communityTokensStore.computeSelfDestructFee(remotelyDestructTokensList, tokenKey)
|
||||||
|
onRemotelyDestructCollectibles: {
|
||||||
|
communityTokensStore.remoteSelfDestructCollectibles(root.community.id,
|
||||||
|
remotelyDestructTokensList,
|
||||||
|
tokenKey)
|
||||||
|
}
|
||||||
|
onSignBurnTransactionOpened: communityTokensStore.computeBurnFee(tokenKey, amount)
|
||||||
|
onBurnToken: communityTokensStore.burnToken(root.community.id, tokenKey, amount)
|
||||||
|
onDeleteToken: communityTokensStore.deleteToken(root.community.id, tokenKey)
|
||||||
|
|
||||||
|
onAirdropToken: {
|
||||||
|
root.goTo(Constants.CommunitySettingsSections.Airdrops)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Connections {
|
||||||
|
target: rootStore.communityTokensStore
|
||||||
|
function onDeployFeeUpdated(ethCurrency, fiatCurrency, errorCode) {
|
||||||
|
mintPanel.setFeesInfo(ethCurrency, fiatCurrency, errorCode)
|
||||||
|
}
|
||||||
|
|
||||||
|
function onSelfDestructFeeUpdated(ethCurrency, fiatCurrency, errorCode) {
|
||||||
|
mintPanel.setFeesInfo(ethCurrency, fiatCurrency, errorCode)
|
||||||
|
}
|
||||||
|
|
||||||
|
function onBurnFeeUpdated(ethCurrency, fiatCurrency, errorCode) {
|
||||||
|
mintPanel.setFeesInfo(ethCurrency, fiatCurrency, errorCode)
|
||||||
|
}
|
||||||
|
|
||||||
|
function onRemoteDestructStateChanged(communityId, tokenName, status, url) {
|
||||||
|
if (root.community.id !== communityId) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
let title = ""
|
||||||
|
let loading = false
|
||||||
|
let type = Constants.ephemeralNotificationType.normal
|
||||||
|
switch (status) {
|
||||||
|
case Constants.ContractTransactionStatus.InProgress:
|
||||||
|
title = qsTr("Remotely destroying tokens...")
|
||||||
|
loading = true
|
||||||
|
break
|
||||||
|
case Constants.ContractTransactionStatus.Completed:
|
||||||
|
title = qsTr("%1 tokens destroyed").arg(tokenName)
|
||||||
|
type = Constants.ephemeralNotificationType.success
|
||||||
|
break
|
||||||
|
case Constants.ContractTransactionStatus.Failed:
|
||||||
|
title = qsTr("%1 tokens destruction failed").arg(tokenName)
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
console.warn("Unknown destruction state: "+status)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
Global.displayToastMessage(title,
|
||||||
|
qsTr("View on etherscan"),
|
||||||
|
"",
|
||||||
|
loading,
|
||||||
|
type,
|
||||||
|
url)
|
||||||
|
}
|
||||||
|
|
||||||
|
function onAirdropStateChanged(communityId, tokenName, chainName, status, url) {
|
||||||
|
if (root.community.id !== communityId) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
let title = ""
|
||||||
|
let loading = false
|
||||||
|
let type = Constants.ephemeralNotificationType.normal
|
||||||
|
switch (status) {
|
||||||
|
case Constants.ContractTransactionStatus.InProgress:
|
||||||
|
title = qsTr("Airdrop on %1 in progress...").arg(chainName)
|
||||||
|
loading = true
|
||||||
|
break
|
||||||
|
case Constants.ContractTransactionStatus.Completed:
|
||||||
|
title = qsTr("Airdrop on %1 in complete").arg(chainName)
|
||||||
|
type = Constants.ephemeralNotificationType.success
|
||||||
|
break
|
||||||
|
case Constants.ContractTransactionStatus.Failed:
|
||||||
|
title = qsTr("Airdrop on %1 failed").arg(chainName)
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
console.warn("Unknown airdrop state: "+status)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
Global.displayToastMessage(title,
|
||||||
|
qsTr("View on etherscan"),
|
||||||
|
"",
|
||||||
|
loading,
|
||||||
|
type,
|
||||||
|
url)
|
||||||
|
}
|
||||||
|
|
||||||
|
function onBurnStateChanged(communityId, tokenName, status, url) {
|
||||||
|
if (root.community.id !== communityId) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
let title = ""
|
||||||
|
let loading = false
|
||||||
|
let type = Constants.ephemeralNotificationType.normal
|
||||||
|
switch (status) {
|
||||||
|
case Constants.ContractTransactionStatus.InProgress:
|
||||||
|
title = qsTr("%1 being burned...").arg(tokenName)
|
||||||
|
loading = true
|
||||||
|
break
|
||||||
|
case Constants.ContractTransactionStatus.Completed:
|
||||||
|
title = qsTr("%1 burning is complete").arg(tokenName)
|
||||||
|
type = Constants.ephemeralNotificationType.success
|
||||||
|
break
|
||||||
|
case Constants.ContractTransactionStatus.Failed:
|
||||||
|
title = qsTr("%1 burning is failed").arg(tokenName)
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
console.warn("Unknown burning state: "+status)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
Global.displayToastMessage(title,
|
||||||
|
qsTr("View on etherscan"),
|
||||||
|
"",
|
||||||
|
loading,
|
||||||
|
type,
|
||||||
|
url)
|
||||||
|
}
|
||||||
|
|
||||||
|
function onDeploymentStateChanged(communityId, status, url) {
|
||||||
|
if (root.community.id !== communityId) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
let title = ""
|
||||||
|
let loading = false
|
||||||
|
let type = Constants.ephemeralNotificationType.normal
|
||||||
|
switch (status) {
|
||||||
|
case Constants.ContractTransactionStatus.InProgress:
|
||||||
|
title = qsTr("Token is being minted...")
|
||||||
|
loading = true
|
||||||
|
break
|
||||||
|
case Constants.ContractTransactionStatus.Completed:
|
||||||
|
title = qsTr("Token minting finished")
|
||||||
|
type = Constants.ephemeralNotificationType.success
|
||||||
|
break
|
||||||
|
case Constants.ContractTransactionStatus.Failed:
|
||||||
|
title = qsTr("Token minting failed")
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
console.warn("Unknown deploy state: "+status)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
Global.displayToastMessage(title,
|
||||||
|
qsTr("View on etherscan"),
|
||||||
|
"",
|
||||||
|
loading,
|
||||||
|
type,
|
||||||
|
url)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Connections {
|
||||||
|
target: airdropPanel
|
||||||
|
|
||||||
|
function onNavigateToMintTokenSettings(isAssetType) {
|
||||||
|
mintPanel.openNewTokenForm(isAssetType)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
AirdropsSettingsPanel {
|
||||||
|
id: airdropPanel
|
||||||
|
|
||||||
|
communityDetails: d.communityDetails
|
||||||
|
readonly property CommunityTokensStore communityTokensStore:
|
||||||
|
rootStore.communityTokensStore
|
||||||
|
|
||||||
|
readonly property var communityTokens: root.community.communityTokens
|
||||||
|
|
||||||
|
Loader {
|
||||||
|
id: assetsModelLoader
|
||||||
|
active: airdropPanel.communityTokens
|
||||||
|
|
||||||
|
sourceComponent: SortFilterProxyModel {
|
||||||
|
|
||||||
|
sourceModel: airdropPanel.communityTokens
|
||||||
|
filters: ValueFilter {
|
||||||
|
roleName: "tokenType"
|
||||||
|
value: Constants.TokenType.ERC20
|
||||||
|
}
|
||||||
|
proxyRoles: [
|
||||||
|
ExpressionRole {
|
||||||
|
name: "category"
|
||||||
|
|
||||||
|
// Singleton cannot be used directly in the expression
|
||||||
|
readonly property int category: TokenCategories.Category.Own
|
||||||
|
expression: category
|
||||||
|
},
|
||||||
|
ExpressionRole {
|
||||||
|
name: "iconSource"
|
||||||
|
expression: model.image
|
||||||
|
},
|
||||||
|
ExpressionRole {
|
||||||
|
name: "key"
|
||||||
|
expression: model.symbol
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Loader {
|
||||||
|
id: collectiblesModelLoader
|
||||||
|
active: airdropPanel.communityTokens
|
||||||
|
|
||||||
|
sourceComponent: SortFilterProxyModel {
|
||||||
|
|
||||||
|
sourceModel: airdropPanel.communityTokens
|
||||||
|
filters: ValueFilter {
|
||||||
|
roleName: "tokenType"
|
||||||
|
value: Constants.TokenType.ERC721
|
||||||
|
}
|
||||||
|
proxyRoles: [
|
||||||
|
ExpressionRole {
|
||||||
|
name: "category"
|
||||||
|
|
||||||
|
// Singleton cannot be used directly in the epression
|
||||||
|
readonly property int category: TokenCategories.Category.Own
|
||||||
|
expression: category
|
||||||
|
},
|
||||||
|
ExpressionRole {
|
||||||
|
name: "iconSource"
|
||||||
|
expression: model.image
|
||||||
|
},
|
||||||
|
ExpressionRole {
|
||||||
|
name: "key"
|
||||||
|
expression: model.symbol
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
assetsModel: assetsModelLoader.item
|
||||||
|
collectiblesModel: collectiblesModelLoader.item
|
||||||
|
membersModel: {
|
||||||
|
const chatContentModule = root.rootStore.currentChatContentModule()
|
||||||
|
if (!chatContentModule || !chatContentModule.usersModule) {
|
||||||
|
// New communities have no chats, so no chatContentModule
|
||||||
|
return null
|
||||||
|
}
|
||||||
|
return chatContentModule.usersModule.model
|
||||||
|
}
|
||||||
|
|
||||||
|
onPreviousPageNameChanged: root.backButtonName = previousPageName
|
||||||
|
onAirdropClicked: communityTokensStore.airdrop(root.community.id, airdropTokens, addresses)
|
||||||
|
onNavigateToMintTokenSettings: root.goTo(Constants.CommunitySettingsSections.MintTokens)
|
||||||
|
|
||||||
|
onAirdropFeesRequested:
|
||||||
|
communityTokensStore.computeAirdropFee(
|
||||||
|
root.community.id, contractKeysAndAmounts, addresses)
|
||||||
|
|
||||||
|
Connections {
|
||||||
|
target: mintPanel
|
||||||
|
|
||||||
|
function onAirdropToken(tokenKey, type, addresses) {
|
||||||
|
// Force a token selection to be airdroped with default amount 1
|
||||||
|
airdropPanel.selectToken(tokenKey, 1, type)
|
||||||
|
|
||||||
|
// Set given addresses as recipients
|
||||||
|
airdropPanel.addAddresses(addresses)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Connections {
|
||||||
|
target: rootStore.communityTokensStore
|
||||||
|
|
||||||
|
function onAirdropFeeUpdated(airdropFees) {
|
||||||
|
airdropPanel.airdropFees = airdropFees
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
onCurrentIndexChanged:
|
||||||
|
root.backButtonName = stackLayout.children[d.currentIndex].previousPageName || ""
|
||||||
}
|
}
|
||||||
|
|
||||||
onSettingsMenuModelChanged: d.currentIndex = 0
|
onSettingsMenuModelChanged: d.currentIndex = 0
|
||||||
@ -591,8 +608,8 @@ StatusSectionLayout {
|
|||||||
id: d
|
id: d
|
||||||
|
|
||||||
property int currentIndex: 0
|
property int currentIndex: 0
|
||||||
readonly property var currentItem: centerPanelContentLoader.item && centerPanelContentLoader.item.children[d.currentIndex]
|
readonly property var currentItem: stackLayout && stackLayout.children[d.currentIndex]
|
||||||
? centerPanelContentLoader.item.children[d.currentIndex]
|
? stackLayout.children[d.currentIndex]
|
||||||
: null
|
: null
|
||||||
|
|
||||||
readonly property QtObject communityDetails: QtObject {
|
readonly property QtObject communityDetails: QtObject {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user