feat: role scope init

pull/4/MERGE
xingyuv 2023-04-12 16:17:27 +08:00
parent 7dccdf502e
commit e40fb13ab9
3 changed files with 103 additions and 3 deletions

View File

@ -0,0 +1,50 @@
<template>
<BasicModal v-bind="$attrs" @register="registerModal" :title="isUpdate ? '编辑' : '新增'" @ok="handleSubmit">
<BasicForm @register="registerForm" />
</BasicModal>
</template>
<script lang="ts" setup name="RoleMenuModal">
import { ref, unref } from 'vue'
import { BasicModal, useModalInner } from '@/components/Modal'
import { BasicForm, useForm } from '@/components/Form'
import { dataScopeFormSchema } from './role.data'
import { createRole, getRole, updateRole } from '@/api/system/role'
const emit = defineEmits(['success', 'register'])
const isUpdate = ref(true)
const [registerForm, { setFieldsValue, resetFields, validate }] = useForm({
labelWidth: 120,
baseColProps: { span: 24 },
schemas: dataScopeFormSchema,
showActionButtonGroup: false,
actionColOptions: { span: 23 }
})
const [registerModal, { setModalProps, closeModal }] = useModalInner(async (data) => {
resetFields()
setModalProps({ confirmLoading: false })
isUpdate.value = !!data?.isUpdate
if (unref(isUpdate)) {
const res = await getRole(data.record.id)
setFieldsValue({ ...res })
}
})
async function handleSubmit() {
try {
const values = await validate()
setModalProps({ confirmLoading: true })
if (unref(isUpdate)) {
await updateRole(values)
} else {
await createRole(values)
}
closeModal()
emit('success')
} finally {
setModalProps({ confirmLoading: false })
}
}
</script>

View File

@ -20,13 +20,13 @@
icon: IconEnum.EDIT, icon: IconEnum.EDIT,
label: '菜单权限', label: '菜单权限',
auth: 'system:permission:assign-role-menu', auth: 'system:permission:assign-role-menu',
onClick: handleEdit.bind(null, record) onClick: handleMenu.bind(null, record)
}, },
{ {
icon: IconEnum.EDIT, icon: IconEnum.EDIT,
label: '数据权限', label: '数据权限',
auth: 'system:permission:assign-role-data-scope', auth: 'system:permission:assign-role-data-scope',
onClick: handleEdit.bind(null, record) onClick: handleDataScope.bind(null, record)
}, },
{ {
icon: IconEnum.DELETE, icon: IconEnum.DELETE,
@ -45,6 +45,8 @@
</template> </template>
</BasicTable> </BasicTable>
<RoleModal @register="registerModal" @success="reload()" /> <RoleModal @register="registerModal" @success="reload()" />
<RoleMenuModal @register="registerMenuModal" @success="reload()" />
<RoleScopeModal @register="registerScopeModal" @success="reload()" />
</div> </div>
</template> </template>
<script lang="ts" setup name="Role"> <script lang="ts" setup name="Role">
@ -52,6 +54,8 @@ import { useI18n } from '@/hooks/web/useI18n'
import { useMessage } from '@/hooks/web/useMessage' import { useMessage } from '@/hooks/web/useMessage'
import { useModal } from '@/components/Modal' import { useModal } from '@/components/Modal'
import RoleModal from './RoleModal.vue' import RoleModal from './RoleModal.vue'
import RoleMenuModal from './RoleMenuModal.vue'
import RoleScopeModal from './RoleScopeModal.vue'
import { IconEnum } from '@/enums/appEnum' import { IconEnum } from '@/enums/appEnum'
import { BasicTable, useTable, TableAction } from '@/components/Table' import { BasicTable, useTable, TableAction } from '@/components/Table'
import { RoleExportReqVO, deleteRole, exportRole, getRolePage } from '@/api/system/role' import { RoleExportReqVO, deleteRole, exportRole, getRolePage } from '@/api/system/role'
@ -60,6 +64,8 @@ import { columns, searchFormSchema } from './role.data'
const { t } = useI18n() const { t } = useI18n()
const { createConfirm, createMessage } = useMessage() const { createConfirm, createMessage } = useMessage()
const [registerModal, { openModal }] = useModal() const [registerModal, { openModal }] = useModal()
const [registerMenuModal, { openModal: openMenuModal }] = useModal()
const [registerScopeModal, { openModal: openScopeModal }] = useModal()
const [registerTable, { getForm, reload }] = useTable({ const [registerTable, { getForm, reload }] = useTable({
title: '角色列表', title: '角色列表',
api: getRolePage, api: getRolePage,
@ -84,6 +90,14 @@ function handleEdit(record: Recordable) {
openModal(true, { record, isUpdate: true }) openModal(true, { record, isUpdate: true })
} }
function handleMenu(record: Recordable) {
openMenuModal(true, { record, isUpdate: true })
}
function handleDataScope(record: Recordable) {
openScopeModal(true, { record, isUpdate: true })
}
async function handleExport() { async function handleExport() {
createConfirm({ createConfirm({
title: t('common.exportTitle'), title: t('common.exportTitle'),

View File

@ -2,6 +2,7 @@ import { BasicColumn, FormSchema, useRender } from '@/components/Table'
import { DICT_TYPE, getIntDictOptions } from '@/utils/dict' import { DICT_TYPE, getIntDictOptions } from '@/utils/dict'
import { listSimpleDept } from '@/api/system/dept' import { listSimpleDept } from '@/api/system/dept'
import { SystemDataScopeEnum } from '@/enums/systemEnum' import { SystemDataScopeEnum } from '@/enums/systemEnum'
import { listSimpleMenus } from '@/api/system/menu'
export const columns: BasicColumn[] = [ export const columns: BasicColumn[] = [
{ {
@ -151,7 +152,7 @@ export const dataScopeFormSchema: FormSchema[] = [
}, },
{ {
label: '数据权限', label: '数据权限',
field: 'status', field: 'dataScopeDeptIds',
component: 'ApiTreeSelect', component: 'ApiTreeSelect',
ifShow: ({ values }) => values.dataScope === SystemDataScopeEnum.DEPT_CUSTOM, ifShow: ({ values }) => values.dataScope === SystemDataScopeEnum.DEPT_CUSTOM,
componentProps: { componentProps: {
@ -165,3 +166,38 @@ export const dataScopeFormSchema: FormSchema[] = [
} }
} }
] ]
export const menuScopeFormSchema: FormSchema[] = [
{
label: '编号',
field: 'id',
show: false,
component: 'Input'
},
{
label: '角色名称',
field: 'name',
dynamicDisabled: true,
component: 'Input'
},
{
label: '角色标识',
field: 'code',
dynamicDisabled: true,
component: 'Input'
},
{
label: '菜单权限',
field: 'menuIds',
component: 'ApiTreeSelect',
componentProps: {
api: () => listSimpleMenus(),
fieldNames: {
label: 'name',
key: 'id',
value: 'id'
},
handleTree: 'id'
}
}
]