@ -404,6 +404,18 @@ export default {
return encodeURIComponent ( this . user . id + this . rand )
} ,
availableGroups ( ) {
const groups = ( this . settings . isAdmin || this . settings . isDelegatedAdmin )
? this . $store . getters . getSortedGroups
: this . $store . getters . getSubAdminGroups
return groups . filter ( group => group . id !== '__nc_internal_recent' && group . id !== 'disabled' )
} ,
availableSubAdminGroups ( ) {
return this . availableGroups . filter ( group => group . id !== 'admin' )
} ,
userGroupsLabels ( ) {
return this . userGroups
. map ( group => group . name ? ? group . id )
@ -553,7 +565,11 @@ export default {
this . loading . groupsDetails = true
try {
const groups = await loadUserGroups ( { userId : this . user . id } )
this . availableGroups = this . availableGroups . map ( availableGroup => groups . find ( group => group . id === availableGroup . id ) ? ? availableGroup )
/ / P o p u l a t e s t o r e f r o m s e r v e r r e q u e s t
for ( const group of groups ) {
this . $store . commit ( 'addGroup' , group )
}
this . selectedGroups = this . selectedGroups . map ( selectedGroup => groups . find ( group => group . id === selectedGroup . id ) ? ? selectedGroup )
} catch ( error ) {
logger . error ( t ( 'settings' , 'Failed to load groups with details' ) , { error } )
}
@ -566,7 +582,11 @@ export default {
this . loading . subAdminGroupsDetails = true
try {
const groups = await loadUserSubAdminGroups ( { userId : this . user . id } )
this . availableSubAdminGroups = this . availableSubAdminGroups . map ( availableGroup => groups . find ( group => group . id === availableGroup . id ) ? ? availableGroup )
/ / P o p u l a t e s t o r e f r o m s e r v e r r e q u e s t
for ( const group of groups ) {
this . $store . commit ( 'addGroup' , group )
}
this . selectedSubAdminGroups = this . selectedSubAdminGroups . map ( selectedGroup => groups . find ( group => group . id === selectedGroup . id ) ? ? selectedGroup )
} catch ( error ) {
logger . error ( t ( 'settings' , 'Failed to load subadmin groups with details' ) , { error } )
}
@ -589,8 +609,10 @@ export default {
limit : 25 ,
} )
const groups = await this . promise
this . availableGroups = groups
this . availableSubAdminGroups = groups . filter ( group => group . id !== 'admin' )
/ / P o p u l a t e s t o r e f r o m s e r v e r r e q u e s t
for ( const group of groups ) {
this . $store . commit ( 'addGroup' , group )
}
} catch ( error ) {
logger . error ( t ( 'settings' , 'Failed to search groups' ) , { error } )
}
@ -753,8 +775,6 @@ export default {
this . loading . groups = true
try {
await this . $store . dispatch ( 'addGroup' , gid )
this . availableGroups . push ( { id : gid , name : gid } )
this . availableSubAdminGroups . push ( { id : gid , name : gid } )
const userid = this . user . id
await this . $store . dispatch ( 'addUserGroup' , { userid , gid } )
this . userGroups . push ( { id : gid , name : gid } )