4 changed files with 148 additions and 2 deletions
@ -0,0 +1,81 @@ |
|||||
|
<script setup lang="ts"> |
||||
|
import type { IdentityRoleDto } from '../../types'; |
||||
|
import type { |
||||
|
IdentityClaimCreateDto, |
||||
|
IdentityClaimDeleteDto, |
||||
|
IdentityClaimUpdateDto, |
||||
|
} from '../../types/claims'; |
||||
|
|
||||
|
import { defineAsyncComponent } from 'vue'; |
||||
|
|
||||
|
import { useVbenModal } from '@vben/common-ui'; |
||||
|
import { $t } from '@vben/locales'; |
||||
|
|
||||
|
import { |
||||
|
createClaimApi, |
||||
|
deleteClaimApi, |
||||
|
getClaimsApi, |
||||
|
updateClaimApi, |
||||
|
} from '../../api/roles'; |
||||
|
import { IdentitRolePermissions } from '../../constants/permissions'; |
||||
|
|
||||
|
defineOptions({ |
||||
|
name: 'RoleClaimModal', |
||||
|
}); |
||||
|
|
||||
|
const ClaimTable = defineAsyncComponent( |
||||
|
() => import('../claims/ClaimTable.vue'), |
||||
|
); |
||||
|
|
||||
|
const [Modal, modalApi] = useVbenModal({ |
||||
|
draggable: true, |
||||
|
fullscreenButton: false, |
||||
|
onCancel() { |
||||
|
modalApi.close(); |
||||
|
}, |
||||
|
onConfirm: async () => {}, |
||||
|
showCancelButton: false, |
||||
|
showConfirmButton: false, |
||||
|
title: $t('AbpIdentity.ManageClaim'), |
||||
|
}); |
||||
|
|
||||
|
async function onGet() { |
||||
|
const { id } = modalApi.getData<IdentityRoleDto>(); |
||||
|
return await getClaimsApi(id); |
||||
|
} |
||||
|
|
||||
|
async function onCreate(input: IdentityClaimCreateDto) { |
||||
|
const { id } = modalApi.getData<IdentityRoleDto>(); |
||||
|
await createClaimApi(id, input); |
||||
|
} |
||||
|
|
||||
|
async function onDelete(input: IdentityClaimDeleteDto) { |
||||
|
const { id } = modalApi.getData<IdentityRoleDto>(); |
||||
|
await deleteClaimApi(id, input); |
||||
|
} |
||||
|
|
||||
|
async function onUpdate(input: IdentityClaimUpdateDto) { |
||||
|
const { id } = modalApi.getData<IdentityRoleDto>(); |
||||
|
await updateClaimApi(id, input); |
||||
|
} |
||||
|
|
||||
|
defineExpose({ |
||||
|
modalApi, |
||||
|
}); |
||||
|
</script> |
||||
|
|
||||
|
<template> |
||||
|
<Modal> |
||||
|
<ClaimTable |
||||
|
:create-api="onCreate" |
||||
|
:create-policy="IdentitRolePermissions.ManageClaims" |
||||
|
:delete-api="onDelete" |
||||
|
:delete-policy="IdentitRolePermissions.ManageClaims" |
||||
|
:get-api="onGet" |
||||
|
:update-api="onUpdate" |
||||
|
:update-policy="IdentitRolePermissions.ManageClaims" |
||||
|
/> |
||||
|
</Modal> |
||||
|
</template> |
||||
|
|
||||
|
<style scoped></style> |
||||
Loading…
Reference in new issue