iot-ui-vue/src/views/system/Role/Detail/Permiss/index.vue

146 lines
4.0 KiB
Vue

<template>
<div class="role-permiss-container">
<!-- <section class="card">
<h5>基本信息</h5>
<j-form
ref="formRef"
class="basic-form"
:model="form.data"
layout="vertical"
>
<j-form-item
name="name"
label="名称"
:rules="[
{ required: true, message: '请输入名称' },
{ max: 64, message: '最多可输入64个字符' },
]"
>
<j-input
v-model:value="form.data.name"
placeholder="请输入角色名称"
/>
</j-form-item>
<j-form-item label="说明">
<j-textarea
v-model:value="form.data.description"
placeholder="请输入说明"
:maxlength="200"
show-count
/>
</j-form-item>
</j-form>
</section> -->
<section class="card">
<h5>权限分配</h5>
<PermissTree v-model:select-items="form.menus" />
<j-button
type="primary"
:confirm-loading="form.loading"
@click="form.clickSave"
style="margin-top: 24px"
>保存</j-button
>
</section>
</div>
</template>
<script setup lang="ts" name="RolePermiss">
import { FormInstance } from 'ant-design-vue';
import PermissTree from '../components/PermissTree.vue';
import { useMenuStore } from '@/store/menu';
// import { USER_CENTER_MENU_DATA } from '@/views/init-home/data/baseMenu'
import {
getRoleDetails_api,
updateRole_api,
editRole_api,
updatePrimissTree_api,
} from '@/api/system/role';
import { onlyMessage } from '@/utils/comm';
const { jumpPage } = useMenuStore();
const route = useRoute();
const router = useRouter();
const roleId = route.params.id as string;
// 表单相关
const formRef = ref<FormInstance>();
const form = reactive({
loading: false,
// data: {
// name: '',
// description: '',
// },
menus: [], // USER_CENTER_MENU_DATA
// getForm: () => {
// getRoleDetails_api(roleId).then((resp) => {
// if (resp.status) {
// form.data = resp.result;
// }
// });
// },
clickSave: () => {
// formRef.value?.validate().then(() => {
// const updateRole = editRole_api(roleId, form.data);
const updateTree = updatePrimissTree_api(roleId, {
menus: form.menus,
});
Promise.all([ updateTree]).then((resp) => {
onlyMessage('操作成功');
// jumpPage(`system/Role`);
})
// });
},
});
// form.getForm();
</script>
<style lang="less" scoped>
.role-permiss-container {
.card {
margin-bottom: 24px;
background-color: #fff;
padding: 24px;
h5 {
position: relative;
display: flex;
align-items: center;
margin-bottom: 20px;
padding: 4px 0 4px 12px;
font-weight: bold;
font-size: 16px;
&::before {
position: absolute;
top: 5px px;
left: 0;
width: 4px;
height: calc(100% - 10px);
background-color: #1d39c4;
border-radius: 2px;
content: ' ';
}
}
.basic-form {
:deep(.ant-form-item-required) {
padding-right: 12px;
&::before {
right: 0;
}
}
.ant-form-item {
display: block;
width: 60%;
}
}
}
}
</style>