REVIEW 用户管理(修改用户)

pull/85/head
YunaiV 2023-03-31 23:34:19 +08:00
parent 7d84f86081
commit 0a69041602
3 changed files with 94 additions and 117 deletions

View File

@ -23,17 +23,17 @@ export const getUserPage = (params: PageParam) => {
}
// 查询用户详情
export const getUserApi = (id: number) => {
export const getUser = (id: number) => {
return request.get({ url: '/system/user/get?id=' + id })
}
// 新增用户
export const createUserApi = (data: UserVO | Recordable) => {
export const createUser = (data: UserVO) => {
return request.post({ url: '/system/user/create', data })
}
// 修改用户
export const updateUserApi = (data: UserVO | Recordable) => {
export const updateUser = (data: UserVO) => {
return request.put({ url: '/system/user/update', data })
}

View File

@ -1,7 +1,12 @@
<template>
<!-- 添加或修改参数配置对话框 -->
<Dialog :title="title" :modelValue="showDialog" width="600px" append-to-body @close="closeDialog">
<el-form ref="formRef" :model="formData" :rules="rules" label-width="80px">
<Dialog :title="modelTitle" v-model="modelVisible">
<el-form
ref="formRef"
:model="formData"
:rules="formRules"
label-width="80px"
v-loading="formLoading"
>
<el-row>
<el-col :span="12">
<el-form-item label="用户昵称" prop="nickname">
@ -13,7 +18,7 @@
<el-tree-select
node-key="id"
v-model="formData.deptId"
:data="deptOptions"
:data="deptList"
:props="defaultProps"
check-strictly
placeholder="请选择归属部门"
@ -67,7 +72,7 @@
<el-form-item label="岗位">
<el-select v-model="formData.postIds" multiple placeholder="请选择">
<el-option
v-for="item in postOptions"
v-for="item in postList"
:key="item.id"
:label="item.name"
:value="item.id"
@ -85,52 +90,26 @@
</el-row>
</el-form>
<template #footer>
<div class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
<el-button @click="submitForm" type="primary" :disabled="formLoading"> </el-button>
<el-button @click="modelVisible = false"> </el-button>
</template>
</Dialog>
</template>
<script lang="ts" setup>
import { PostVO } from '@/api/system/post'
import * as PostApi from '@/api/system/post'
import { createUserApi, getUserApi, updateUserApi } from '@/api/system/user'
import * as DeptApi from '@/api/system/dept'
import { DICT_TYPE, getIntDictOptions } from '@/utils/dict'
import { CommonStatusEnum } from '@/utils/constants'
import { defaultProps, handleTree } from '@/utils/tree'
import { ElForm, FormItemRule } from 'element-plus'
import { Arrayable } from 'element-plus/es/utils'
type Form = InstanceType<typeof ElForm>
const emits = defineEmits(['success'])
import * as PostApi from '@/api/system/post'
import * as DeptApi from '@/api/system/dept'
import * as UserApi from '@/api/system/user'
const { t } = useI18n() //
const message = useMessage() //
const showDialog = ref(false)
//
const title = computed(() => {
return formData.value?.id ? '修改用户' : '添加用户'
})
const deptOptions = ref<Tree[]>([]) //
const getTree = async () => {
const res = await DeptApi.getSimpleDeptList()
deptOptions.value = []
deptOptions.value.push(...handleTree(res))
}
//
const postOptions = ref<PostVO[]>([]) //
const getPostOptions = async () => {
const res = (await PostApi.getSimplePostList()) as PostVO[]
postOptions.value.push(...res)
}
//
const initParams = {
const modelVisible = ref(false) //
const modelTitle = ref('') //
const formLoading = ref(false) // 12
const formType = ref('') // create - update -
const formData = ref({
nickname: '',
deptId: '',
mobile: '',
@ -138,15 +117,13 @@ const initParams = {
id: undefined,
username: '',
password: '',
sex: 1,
sex: undefined,
postIds: [],
remark: '',
status: '0',
status: CommonStatusEnum.ENABLE,
roleIds: []
}
//
const rules = {
})
const formRules = reactive({
username: [{ required: true, message: '用户名称不能为空', trigger: 'blur' }],
nickname: [{ required: true, message: '用户昵称不能为空', trigger: 'blur' }],
password: [{ required: true, message: '用户密码不能为空', trigger: 'blur' }],
@ -164,74 +141,75 @@ const rules = {
trigger: 'blur'
}
]
} as Partial<Record<string, Arrayable<FormItemRule>>>
const formRef = ref<Form | null>()
const formData = ref<Recordable>({ ...initParams })
})
const formRef = ref() // Ref
const deptList = ref<Tree[]>([]) //
const postList = ref([]) //
const resetForm = () => {
let form = formRef?.value
if (!form) return
formData.value = { ...initParams }
form && (form as Form).resetFields()
}
const closeDialog = () => {
showDialog.value = false
}
//
const operateOk = () => {
emits('success', true)
closeDialog()
}
const submitForm = () => {
let form = formRef.value as Form
form.validate(async (valid) => {
let data = formData.value
if (valid) {
try {
if (data?.id !== undefined) {
await updateUserApi(data)
message.success(t('common.updateSuccess'))
operateOk()
} else {
await createUserApi(data)
message.success(t('common.createSuccess'))
operateOk()
}
} catch (err) {
console.error(err)
}
}
})
}
/* 取消 */
const cancel = () => {
closeDialog()
}
/* 打开弹框 */
const open = (type: string, id?: number) => {
console.log(type, id)
/** 打开弹窗 */
const open = async (type: string, id?: number) => {
modelVisible.value = true
modelTitle.value = t('action.' + type)
formType.value = type
resetForm()
getTree() //
if (row && row.id) {
const id = row.id
getUserApi(id).then((response) => {
formData.value = response
})
} else {
formData.value = { ...initParams }
//
if (id) {
formLoading.value = true
try {
formData.value = await UserApi.getUser(id)
} finally {
formLoading.value = false
}
}
//
deptList.value = handleTree(await DeptApi.getSimpleDeptList())
//
postList.value = await PostApi.getSimplePostList()
}
defineExpose({ open }) // open
showDialog.value = true
/** 提交表单 */
const emit = defineEmits(['success']) // success
const submitForm = async () => {
//
if (!formRef) return
const valid = await formRef.value.validate()
if (!valid) return
//
formLoading.value = true
try {
const data = formData.value as unknown as UserApi.UserVO
if (formType.value === 'create') {
await UserApi.createUser(data)
message.success(t('common.createSuccess'))
} else {
await UserApi.updateUser(data)
message.success(t('common.updateSuccess'))
}
modelVisible.value = false
//
emit('success')
} finally {
formLoading.value = false
}
}
// ========== ==========
onMounted(async () => {
await getPostOptions()
})
defineExpose({
resetForm,
open
})
/** 重置表单 */
const resetForm = () => {
formData.value = {
nickname: '',
deptId: '',
mobile: '',
email: '',
id: undefined,
username: '',
password: '',
sex: undefined,
postIds: [],
remark: '',
status: CommonStatusEnum.ENABLE,
roleIds: []
}
formRef.value?.resetFields()
}
</script>

View File

@ -187,14 +187,13 @@
<!-- 分配角色 -->
<UserAssignRoleForm ref="assignRoleFormRef" @success="getList" />
</template>
<script setup lang="ts" name="User">
import { DICT_TYPE, getIntDictOptions } from '@/utils/dict'
import { dateFormatter } from '@/utils/formatTime'
import download from '@/utils/download'
import { CommonStatusEnum } from '@/utils/constants'
import * as UserApi from '@/api/system/user'
import UserForm from './components/UserForm.vue'
import UserForm from './UserForm.vue'
import UserImportForm from './components/UserImportForm.vue'
import UserAssignRoleForm from './UserAssignRoleForm.vue'
import DeptTree from './DeptTree.vue'