Improve messaging

This commit is contained in:
Adria Navarro 2023-09-01 17:23:47 +02:00
parent 3e3b965bb3
commit bb8aacd830
5 changed files with 37 additions and 15 deletions

View File

@ -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>

View File

@ -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)
}, },
} }
} }

View File

@ -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),
} }
} }

View File

@ -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
} }

View File

@ -12,5 +12,5 @@ export interface GetResourcePermsResponse {
} }
export interface GetDependantResourcesResponse { export interface GetDependantResourcesResponse {
total: number resourceByType?: Record<string, number>
} }