莳松crm管理系统
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ss-crm-manage-web/src/views/Basic/User/UserForm.vue

236 lines
7.2 KiB

1 year ago
<template>
11 months ago
<Dialog v-model="dialogVisible" :title="dialogTitle" style="width: 800px">
1 year ago
<el-form
ref="formRef"
v-loading="formLoading"
:model="formData"
:rules="formRules"
label-width="80px"
>
11 months ago
<el-row :gutter="20">
1 year ago
<el-col :span="12">
10 months ago
<el-form-item label="用户姓名" prop="nickname">
<el-input v-model="formData.nickname" placeholder="请输入用户姓名" />
1 year ago
</el-form-item>
</el-col>
11 months ago
<el-col :span="12">
<el-form-item label="用户性别">
<el-radio-group v-model="formData.sex">
<el-radio :label="1"> </el-radio>
<el-radio :label="2"> </el-radio>
</el-radio-group>
</el-form-item>
</el-col>
</el-row>
11 months ago
<el-row :gutter="20">
1 year ago
<el-col :span="12">
<el-form-item label="归属部门" prop="deptId">
<el-tree-select
v-model="formData.deptId"
:data="deptList"
:props="defaultProps"
check-strictly
node-key="id"
placeholder="请选择归属部门"
/>
</el-form-item>
</el-col>
11 months ago
<el-col :span="12">
<el-form-item label="角色" prop="role">
11 months ago
<el-select
v-model="formData.roleIds"
multiple
collapse-tags
collapse-tags-tooltip
:max-collapse-tags="2"
placeholder="请选择角色"
>
11 months ago
<el-option
v-for="item in roleOptions"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
</el-form-item>
</el-col>
1 year ago
</el-row>
11 months ago
<el-row :gutter="20">
1 year ago
<el-col :span="12">
<el-form-item label="手机号码" prop="mobile">
<el-input v-model="formData.mobile" maxlength="11" placeholder="请输入手机号码" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="邮箱" prop="email">
<el-input v-model="formData.email" maxlength="50" placeholder="请输入邮箱" />
</el-form-item>
</el-col>
</el-row>
11 months ago
<el-row :gutter="20">
1 year ago
<el-col :span="12">
10 months ago
<el-form-item v-if="formData.id === undefined" label="登录账号" prop="username">
<el-input v-model="formData.username" placeholder="请输入登录账号" />
1 year ago
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item v-if="formData.id === undefined" label="用户密码" prop="password">
<el-input
v-model="formData.password"
placeholder="请输入用户密码"
show-password
type="password"
/>
</el-form-item>
</el-col>
</el-row>
11 months ago
<el-row :gutter="20">
<el-col :span="12" :offset="0">
<el-form-item label="入职日期" prop="hireDate">
<el-date-picker
v-model="formData.hireDate"
type="date"
format="YYYY-MM-DD"
value-format="YYYY-MM-DD"
placeholder="选择日期时间"
/>
</el-form-item>
</el-col>
</el-row>
11 months ago
<el-row :gutter="20">
1 year ago
<el-col :span="24">
<el-form-item label="备注">
<el-input v-model="formData.remark" placeholder="请输入内容" type="textarea" />
</el-form-item>
</el-col>
</el-row>
</el-form>
<template #footer>
<el-button :disabled="formLoading" type="primary" @click="submitForm"> </el-button>
<el-button @click="dialogVisible = false"> </el-button>
</template>
</Dialog>
</template>
<script lang="ts" name="SystemUserForm" setup>
import { CommonStatusEnum } from '@/utils/constants'
11 months ago
import { defaultProps, handleTree } from '@/utils/tree'
11 months ago
import { formatDate } from '@/utils/formatTime'
11 months ago
import * as RoleApi from '@/api/system/role'
import * as DeptApi from '@/api/system/dept'
import * as UserApi from '@/api/system/user'
1 year ago
const { t } = useI18n() // 国际化
const message = useMessage() // 消息弹窗
const dialogVisible = ref(false) // 弹窗的是否展示
const dialogTitle = ref('') // 弹窗的标题
const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
const formType = ref('') // 表单的类型:create - 新增;update - 修改
const formData = ref({
nickname: '',
deptId: '',
mobile: '',
email: '',
id: undefined,
username: '',
password: '',
11 months ago
sex: 1,
1 year ago
remark: '',
status: CommonStatusEnum.ENABLE,
11 months ago
roleIds: [],
8 months ago
hireDate: '',
isNewUserConfirm: false
1 year ago
})
11 months ago
const formRules = ref<any>({
10 months ago
username: [{ required: true, message: '登录账号不能为空', trigger: 'blur' }],
nickname: [{ required: true, message: '用户姓名不能为空', trigger: 'blur' }],
1 year ago
password: [{ required: true, message: '用户密码不能为空', trigger: 'blur' }],
email: [
{
type: 'email',
message: '请输入正确的邮箱地址',
trigger: ['blur', 'change']
}
],
10 months ago
mobile: [{ required: true, message: '手机号不能为空', trigger: 'blur' }]
11 months ago
})
1 year ago
const formRef = ref() // 表单 Ref
const deptList = ref<Tree[]>([]) // 树形结构
11 months ago
const roleOptions = ref<any>([])
1 year ago
/** 打开弹窗 */
const open = async (type: string, id?: number) => {
dialogVisible.value = true
dialogTitle.value = t('action.' + type)
formType.value = type
resetForm()
// 修改时,设置数据
if (id) {
formLoading.value = true
try {
11 months ago
formData.value = await UserApi.getUser(id)
1 year ago
} finally {
formLoading.value = false
}
}
// 加载部门树
11 months ago
deptList.value = handleTree(await DeptApi.getSimpleDeptList())
1 year ago
// 加载岗位列表
11 months ago
roleOptions.value = await RoleApi.getSimpleRoleList()
1 year ago
}
defineExpose({ open }) // 提供 open 方法,用于打开弹窗
/** 提交表单 */
const emit = defineEmits(['success']) // 定义 success 事件,用于操作成功后的回调
const submitForm = async () => {
// 校验表单
11 months ago
if (!formRef.value) return
1 year ago
const valid = await formRef.value.validate()
if (!valid) return
// 提交请求
formLoading.value = true
try {
11 months ago
const data = formData.value as unknown as UserApi.UserVO
1 year ago
if (formType.value === 'create') {
8 months ago
const resp = await UserApi.createUser(data)
if (resp.code == 18888) {
await message.confirm(resp.msg)
formData.value.isNewUserConfirm = true
submitForm()
} else {
message.success(t('common.createSuccess'))
}
1 year ago
} else {
11 months ago
await UserApi.updateUser(data)
1 year ago
message.success(t('common.updateSuccess'))
}
dialogVisible.value = false
// 发送操作成功的事件
emit('success')
} finally {
formLoading.value = false
}
}
/** 重置表单 */
const resetForm = () => {
formData.value = {
nickname: '',
deptId: '',
mobile: '',
email: '',
id: undefined,
username: '',
password: '',
11 months ago
sex: 1,
1 year ago
remark: '',
status: CommonStatusEnum.ENABLE,
11 months ago
roleIds: [],
8 months ago
hireDate: formatDate(new Date(), 'YYYY-MM-DD'),
7 months ago
isNewUserConfirm: false
1 year ago
}
formRef.value?.resetFields()
}
</script>