import type { RolePermissions } from './rolePermissions' import rolePermissions from './rolePermissions' import { useState } from '#app' import { USER_PROJECT_ROLES } from '~/lib/constants' export function useUIPermission() { const { $state } = useNuxtApp() const projectRoles = useState>(USER_PROJECT_ROLES, () => ({})) const isUIAllowed = (permission: RolePermissions, _skipPreviewAs = false) => { const user = $state.user let userRoles = user?.value?.roles || {} // if string populate key-value paired object if (typeof userRoles === 'string') { userRoles = userRoles.split(',').reduce>((acc, role) => { acc[role] = true return acc }, {}) } // merge user role and project specific user roles const roles = { ...userRoles, ...(projectRoles?.value || {}), } // todo: handle preview as // if (state.previewAs && !skipPreviewAs) { // roles = { // [state.previewAs]: true // }; // } return Object.entries(roles).some(([role, hasRole]) => { const rolePermission = rolePermissions[role as keyof typeof rolePermissions] return ( hasRole && (rolePermission === '*' || typeof rolePermission === 'object' ? rolePermission[permission as keyof typeof rolePermission] === true : false) ) }) } return { isUIAllowed } }