Improve messaging
This commit is contained in:
parent
3e3b965bb3
commit
bb8aacd830
|
@ -65,11 +65,27 @@
|
||||||
|
|
||||||
$: requiresPlanToModify = permissions.requiresPlanToModify
|
$: requiresPlanToModify = permissions.requiresPlanToModify
|
||||||
|
|
||||||
let dependantResources
|
let dependantsInfoMessage
|
||||||
async function loadDependantResources() {
|
async function loadDependantInfo() {
|
||||||
dependantResources = await permissionsStore.getDependantsCount(resourceId)
|
const dependantsInfo = await permissionsStore.getDependantsInfo(resourceId)
|
||||||
|
|
||||||
|
const resourceByType = dependantsInfo?.resourceByType
|
||||||
|
|
||||||
|
if (resourceByType) {
|
||||||
|
const total = Object.values(resourceByType).reduce((p, c) => p + c, 0)
|
||||||
|
let resourceDisplay =
|
||||||
|
Object.keys(resourceByType).length === 1 && resourceByType.view
|
||||||
|
? "view"
|
||||||
|
: "resource"
|
||||||
|
|
||||||
|
if (total === 1) {
|
||||||
|
dependantsInfoMessage = `1 ${resourceDisplay} is inheriting this access.`
|
||||||
|
} else if (total > 1) {
|
||||||
|
dependantsInfoMessage = `${total} ${resourceDisplay}s are inheriting this access.`
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
loadDependantResources()
|
loadDependantInfo()
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<ModalContent showCancelButton={false} confirmText="Done">
|
<ModalContent showCancelButton={false} confirmText="Done">
|
||||||
|
@ -101,12 +117,12 @@
|
||||||
{/each}
|
{/each}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{#if dependantResources}
|
{#if dependantsInfoMessage}
|
||||||
<div class="inheriting-resources">
|
<div class="inheriting-resources">
|
||||||
<Icon name="Alert" />
|
<Icon name="Alert" />
|
||||||
<Body size="S">
|
<Body size="S">
|
||||||
<i>
|
<i>
|
||||||
{dependantResources} resource/s are inheriting this access.
|
{dependantsInfoMessage}
|
||||||
</i>
|
</i>
|
||||||
</Body>
|
</Body>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -26,8 +26,8 @@ export function createPermissionStore() {
|
||||||
forResourceDetailed: async resourceId => {
|
forResourceDetailed: async resourceId => {
|
||||||
return await API.getPermissionForResource(resourceId)
|
return await API.getPermissionForResource(resourceId)
|
||||||
},
|
},
|
||||||
getDependantsCount: async resourceId => {
|
getDependantsInfo: async resourceId => {
|
||||||
return (await API.getDependants(resourceId)).total
|
return await API.getDependants(resourceId)
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -185,7 +185,7 @@ export async function getDependantResources(
|
||||||
) {
|
) {
|
||||||
const resourceId = ctx.params.resourceId
|
const resourceId = ctx.params.resourceId
|
||||||
ctx.body = {
|
ctx.body = {
|
||||||
total: await sdk.permissions.getDependantResources(resourceId),
|
resourceByType: await sdk.permissions.getDependantResources(resourceId),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -137,9 +137,11 @@ export async function getResourcePerms(
|
||||||
return result
|
return result
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function getDependantResources(resourceId: string) {
|
export async function getDependantResources(
|
||||||
|
resourceId: string
|
||||||
|
): Promise<Record<string, number> | undefined> {
|
||||||
if (db.isTableId(resourceId)) {
|
if (db.isTableId(resourceId)) {
|
||||||
const dependants = new Set<string>()
|
const dependants: Record<string, Set<string>> = {}
|
||||||
|
|
||||||
const table = await sdk.tables.getTable(resourceId)
|
const table = await sdk.tables.getTable(resourceId)
|
||||||
const views = Object.values(table.views || {})
|
const views = Object.values(table.views || {})
|
||||||
|
@ -152,13 +154,17 @@ export async function getDependantResources(resourceId: string) {
|
||||||
const permissions = await getResourcePerms(view.id)
|
const permissions = await getResourcePerms(view.id)
|
||||||
for (const [level, roleInfo] of Object.entries(permissions)) {
|
for (const [level, roleInfo] of Object.entries(permissions)) {
|
||||||
if (roleInfo.type === PermissionSource.INHERITED) {
|
if (roleInfo.type === PermissionSource.INHERITED) {
|
||||||
dependants.add(view.id)
|
dependants[VirtualDocumentType.VIEW] ??= new Set()
|
||||||
|
dependants[VirtualDocumentType.VIEW].add(view.id)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return dependants.size
|
return Object.entries(dependants).reduce((p, [type, resources]) => {
|
||||||
|
p[type] = resources.size
|
||||||
|
return p
|
||||||
|
}, {} as Record<string, number>)
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0
|
return
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,5 +12,5 @@ export interface GetResourcePermsResponse {
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface GetDependantResourcesResponse {
|
export interface GetDependantResourcesResponse {
|
||||||
total: number
|
resourceByType?: Record<string, number>
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue