mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-19 02:55:15 +00:00
4144e374a6
* fix(JoinCommunity): Add missing state ONLY private permissions and NOT MET - Modified `becomeMemberModel` in store to provide all member permissions. - Modified permissions model filter to only discard permissions that are private and NOT met. - Updated `storybook/PermissionsModel` with new only private permissions and added new model option in corresponding pages. Closes #14104 * fix(JoinCommunity): Text position when all channels hidden Updated text position when `allChannelsAreHiddenBecauseNotPermitted` in community join process
143 lines
5.2 KiB
QML
143 lines
5.2 KiB
QML
import QtQml 2.15
|
|
|
|
import SortFilterProxyModel 0.2
|
|
|
|
import StatusQ 0.1
|
|
|
|
import utils 1.0
|
|
|
|
QtObject {
|
|
id: root
|
|
|
|
required property string activeSectionId
|
|
required property string activeChannelId
|
|
required property var chatCommunitySectionModuleInst
|
|
|
|
// all permissions model
|
|
readonly property var permissionsModel:
|
|
chatCommunitySectionModuleInst.permissionsModel
|
|
|
|
function setHideIfPermissionsNotMet(chatId, checked) {
|
|
//TODO: backend implementation
|
|
}
|
|
|
|
// TODO: Replace with proper backend implementation
|
|
// This is per chat, not per community
|
|
readonly property bool viewAndPostCriteriaMet: {
|
|
if (selectedChannelPermissionsModel.count == 0)
|
|
return true
|
|
|
|
for (var i = 0; i < selectedChannelPermissionsModel.count; i++) {
|
|
var permissionItem = selectedChannelPermissionsModel.get(i);
|
|
if (permissionItem && permissionItem.tokenCriteriaMet)
|
|
return true
|
|
}
|
|
return false
|
|
}
|
|
|
|
readonly property var selectedChannelPermissionsModel: SortFilterProxyModel {
|
|
id: selectedChannelPermissionsModel
|
|
sourceModel: root.permissionsModel
|
|
|
|
function filterPredicate(modelData) {
|
|
return root.permissionsModel.belongsToChat(modelData.id, root.activeChannelId) &&
|
|
(modelData.tokenCriteriaMet || !modelData.isPrivate)
|
|
}
|
|
filters: [
|
|
FastExpressionFilter {
|
|
expression: {
|
|
root.activeChannelId // ensure predicate is re-triggered when activeChannelId changes
|
|
selectedChannelPermissionsModel.filterPredicate(model)
|
|
}
|
|
expectedRoles: ["id", "tokenCriteriaMet", "isPrivate"]
|
|
}
|
|
]
|
|
}
|
|
|
|
readonly property var viewOnlyPermissionsModel: SortFilterProxyModel {
|
|
id: viewOnlyPermissionsModel
|
|
sourceModel: root.permissionsModel
|
|
|
|
function filterPredicate(modelData) {
|
|
return (modelData.permissionType == Constants.permissionType.read) &&
|
|
root.permissionsModel.belongsToChat(modelData.id, root.activeChannelId) &&
|
|
(modelData.tokenCriteriaMet || !modelData.isPrivate)
|
|
}
|
|
filters: [
|
|
FastExpressionFilter {
|
|
expression: {
|
|
root.activeChannelId // ensure predicate is re-triggered when activeChannelId changes
|
|
viewOnlyPermissionsModel.filterPredicate(model)
|
|
}
|
|
expectedRoles: ["id", "tokenCriteriaMet", "isPrivate", "permissionType"]
|
|
}
|
|
]
|
|
}
|
|
|
|
readonly property var viewAndPostPermissionsModel: SortFilterProxyModel {
|
|
id: viewAndPostPermissionsModel
|
|
sourceModel: root.permissionsModel
|
|
function filterPredicate(modelData) {
|
|
return (modelData.permissionType == Constants.permissionType.viewAndPost) &&
|
|
root.permissionsModel.belongsToChat(modelData.id, root.activeChannelId) &&
|
|
(modelData.tokenCriteriaMet || !modelData.isPrivate)
|
|
}
|
|
filters: [
|
|
FastExpressionFilter {
|
|
expression: {
|
|
root.activeChannelId // ensure predicate is re-triggered when activeChannelId changes
|
|
viewAndPostPermissionsModel.filterPredicate(model)
|
|
}
|
|
expectedRoles: ["id", "tokenCriteriaMet", "isPrivate", "permissionType"]
|
|
}
|
|
]
|
|
}
|
|
|
|
readonly property var becomeMemberPermissionsModel: SortFilterProxyModel {
|
|
id: becomeMemberPermissionsModel
|
|
sourceModel: root.permissionsModel
|
|
function filterPredicate(permissionType) {
|
|
return (permissionType === Constants.permissionType.member ||
|
|
permissionType === Constants.permissionType.admin ||
|
|
permissionType === Constants.permissionType.becomeTokenMaster)
|
|
}
|
|
filters: [
|
|
FastExpressionFilter {
|
|
expression: { return becomeMemberPermissionsModel.filterPredicate(model.permissionType) }
|
|
expectedRoles: ["permissionType"]
|
|
}
|
|
]
|
|
}
|
|
|
|
readonly property bool isOwner: false
|
|
|
|
readonly property bool allTokenRequirementsMet: chatCommunitySectionModuleInst.allTokenRequirementsMet
|
|
|
|
readonly property QtObject _d: QtObject {
|
|
id: d
|
|
|
|
function createOrEdit(key, holdings, permissionType, isPrivate,
|
|
channels) {
|
|
root.chatCommunitySectionModuleInst.createOrEditCommunityTokenPermission(
|
|
root.activeSectionId, key,
|
|
permissionType,
|
|
JSON.stringify(holdings),
|
|
channels.map(c => c.key).join(","),
|
|
isPrivate)
|
|
}
|
|
}
|
|
|
|
function createPermission(holdings, permissionType, isPrivate, channels) {
|
|
d.createOrEdit("", holdings, permissionType, isPrivate, channels)
|
|
}
|
|
|
|
function editPermission(key, holdings, permissionType, channels, isPrivate) {
|
|
d.createOrEdit(key, holdings, permissionType, isPrivate, channels)
|
|
}
|
|
|
|
function removePermission(key) {
|
|
root.chatCommunitySectionModuleInst.deleteCommunityTokenPermission(
|
|
root.activeSectionId, key)
|
|
}
|
|
}
|