chore(permissions): Improve performance by using the `Fast` expressions and add necessary models and APIs in the PermissionsStore

Changes:
1. Adding the `Fast` expressions where needed
2. Break the channel permissions into categories in PermissionsStore
3. Remove unused/unneeded code
This commit is contained in:
Alex Jbanca 2024-02-06 11:22:33 +02:00 committed by Alex Jbanca
parent 35c1475403
commit 055d8e8322
3 changed files with 62 additions and 31 deletions

View File

@ -40,15 +40,6 @@ SortFilterProxyModel {
expression: model.icon expression: model.icon
expectedRoles: ["icon"] expectedRoles: ["icon"]
}, },
FastExpressionRole {
function getColor(color, colorId) {
return !!color ? color
: Theme.palette.userCustomizationColors[colorId]
}
name: "color"
expression: getColor(model.color, model.colorId)
expectedRoles: ["color", "colorId"]
},
FastExpressionRole { FastExpressionRole {
name: "operator" name: "operator"

View File

@ -5,6 +5,7 @@ import AppLayouts.Communities.panels 1.0
import AppLayouts.Communities.controls 1.0 import AppLayouts.Communities.controls 1.0
import StatusQ.Core.Utils 0.1 import StatusQ.Core.Utils 0.1
import StatusQ 0.1
import utils 1.0 import utils 1.0
@ -21,7 +22,7 @@ SortFilterProxyModel {
} }
proxyRoles: [ proxyRoles: [
ExpressionRole { FastExpressionRole {
name: "text" name: "text"
function getName(type, key) { function getName(type, key) {
@ -50,8 +51,9 @@ SortFilterProxyModel {
_collectiblesChanges.revision _collectiblesChanges.revision
return getText(model.type, model.key, model.amount) return getText(model.type, model.key, model.amount)
} }
expectedRoles: ["type", "key", "amount"]
}, },
ExpressionRole { FastExpressionRole {
name: "imageSource" name: "imageSource"
function getIcon(type, key) { function getIcon(type, key) {
@ -69,14 +71,16 @@ SortFilterProxyModel {
_collectiblesChanges.revision _collectiblesChanges.revision
return getIcon(model.type, model.key) return getIcon(model.type, model.key)
} }
expectedRoles: ["type", "key"]
}, },
ExpressionRole { FastExpressionRole {
name: "operator" name: "operator"
// Direct call for singleton enum is not handled properly by SortFilterProxyModel. // Direct call for singleton enum is not handled properly by SortFilterProxyModel.
readonly property int none: OperatorsUtils.Operators.None readonly property int none: OperatorsUtils.Operators.None
expression: none expression: none
expectedRoles: []
} }
] ]
} }

View File

@ -1,6 +1,9 @@
import QtQml 2.15 import QtQml 2.15
import SortFilterProxyModel 0.2 import SortFilterProxyModel 0.2
import StatusQ 0.1
import utils 1.0 import utils 1.0
QtObject { QtObject {
@ -14,16 +17,43 @@ QtObject {
readonly property var permissionsModel: readonly property var permissionsModel:
chatCommunitySectionModuleInst.permissionsModel chatCommunitySectionModuleInst.permissionsModel
readonly property var becomeMemberPermissionsModel: SortFilterProxyModel { function setViewOnlyCanAddReaction(chatId, checked) {
id: becomeMemberPermissionsModel //TODO: backend implementation
}
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 sourceModel: root.permissionsModel
function filterPredicate(modelData) { function filterPredicate(modelData) {
return (modelData.permissionType == Constants.permissionType.member) && return root.permissionsModel.belongsToChat(modelData.id, root.activeChannelId) &&
(modelData.tokenCriteriaMet || !modelData.isPrivate) (modelData.tokenCriteriaMet || !modelData.isPrivate)
} }
filters: [ filters: [
ExpressionFilter { FastExpressionFilter {
expression: becomeMemberPermissionsModel.filterPredicate(model) expression: {
root.activeChannelId // ensure predicate is re-triggered when activeChannelId changes
selectedChannelPermissionsModel.filterPredicate(model)
}
expectedRoles: ["id", "tokenCriteriaMet", "isPrivate"]
} }
] ]
} }
@ -38,11 +68,12 @@ QtObject {
(modelData.tokenCriteriaMet || !modelData.isPrivate) (modelData.tokenCriteriaMet || !modelData.isPrivate)
} }
filters: [ filters: [
ExpressionFilter { FastExpressionFilter {
expression: { expression: {
root.activeChannelId // ensure predicate is re-triggered when activeChannelId changes root.activeChannelId // ensure predicate is re-triggered when activeChannelId changes
viewOnlyPermissionsModel.filterPredicate(model) viewOnlyPermissionsModel.filterPredicate(model)
} }
expectedRoles: ["id", "tokenCriteriaMet", "isPrivate", "permissionType"]
} }
] ]
} }
@ -56,11 +87,27 @@ QtObject {
(modelData.tokenCriteriaMet || !modelData.isPrivate) (modelData.tokenCriteriaMet || !modelData.isPrivate)
} }
filters: [ filters: [
ExpressionFilter { FastExpressionFilter {
expression: { expression: {
root.activeChannelId // ensure predicate is re-triggered when activeChannelId changes root.activeChannelId // ensure predicate is re-triggered when activeChannelId changes
viewAndPostPermissionsModel.filterPredicate(model) viewAndPostPermissionsModel.filterPredicate(model)
} }
expectedRoles: ["id", "tokenCriteriaMet", "isPrivate", "permissionType"]
}
]
}
readonly property var becomeMemberPermissionsModel: SortFilterProxyModel {
id: becomeMemberPermissionsModel
sourceModel: root.permissionsModel
function filterPredicate(modelData) {
return (modelData.permissionType == Constants.permissionType.member) &&
(modelData.tokenCriteriaMet || !modelData.isPrivate)
}
filters: [
FastExpressionFilter {
expression: becomeMemberPermissionsModel.filterPredicate(model)
expectedRoles: ["permissionType", "tokenCriteriaMet", "isPrivate"]
} }
] ]
} }
@ -72,19 +119,8 @@ QtObject {
readonly property QtObject _d: QtObject { readonly property QtObject _d: QtObject {
id: d id: d
function createPermissionEntry(holdings, permissionType, isPrivate,
channels) {
return {
holdingsListModel: holdings,
channelsListModel: channels,
permissionType,
isPrivate
}
}
function createOrEdit(key, holdings, permissionType, isPrivate, function createOrEdit(key, holdings, permissionType, isPrivate,
channels) { channels) {
root.chatCommunitySectionModuleInst.createOrEditCommunityTokenPermission( root.chatCommunitySectionModuleInst.createOrEditCommunityTokenPermission(
root.activeSectionId, key, root.activeSectionId, key,
permissionType, permissionType,