Files

48 lines
1.1 KiB
Vue

<script setup lang="ts">
import type { RoleAccesses } from '~/models/role'
import Error from '~/components/pub/my-ui/error/error.vue'
import { permissions } from '~/const/page-permission/client'
definePageMeta({
middleware: ['rbac'],
roles: ['doctor', 'nurse', 'admisi', 'pharmacy', 'billing', 'management'],
title: 'Tambah Pasien',
contentFrame: 'cf-container-2xl',
})
const route = useRoute()
useHead({
title: () => route.meta.title as string,
})
const roleAccess: RoleAccesses = permissions['/client/patient/add'] ?? {}
const { checkRole, hasReadAccess } = useRBAC()
// Check if user has access to this page
const hasAccess = checkRole(roleAccess)
if (!hasAccess) {
navigateTo('/403')
}
// Define permission-based computed properties
const canRead = hasReadAccess(roleAccess)
const callbackUrl = route.query['return-path'] as string | undefined
</script>
<template>
<div>
<div v-if="canRead">
<ContentPatientForm
:mode="'add'"
:callback-url="callbackUrl"
/>
</div>
<Error
v-else
:status-code="403"
/>
</div>
</template>