2024-01-19 16:30:46 +08:00
|
|
|
<template>
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-dialog class="cn-operate-dialog" v-model="dialogVisible" :title="title">
|
2024-09-30 15:37:33 +08:00
|
|
|
|
|
|
|
|
<el-form :model="form" label-width="auto" class="form-two" :rules="rules">
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-form-item label="用户名" prop="name">
|
|
|
|
|
<el-input v-model="form.name" placeholder="请输入昵称" />
|
2024-01-19 16:30:46 +08:00
|
|
|
</el-form-item>
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-form-item label="登录名" prop="loginName">
|
|
|
|
|
<el-input v-model="form.loginName" placeholder="请输入登录名" />
|
2024-01-19 16:30:46 +08:00
|
|
|
</el-form-item>
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-form-item label="默认密码" prop="password" v-if="title === '新增用户'">
|
|
|
|
|
<el-input v-model="form.password" placeholder="请输入密码" disabled />
|
2024-01-19 16:30:46 +08:00
|
|
|
</el-form-item>
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-form-item label="权限类型" prop="type">
|
2024-02-02 09:29:19 +08:00
|
|
|
<el-select
|
2024-01-22 15:20:30 +08:00
|
|
|
v-model="form.type"
|
|
|
|
|
@change="changeValue"
|
2024-01-19 16:30:46 +08:00
|
|
|
disabled
|
2024-01-22 15:20:30 +08:00
|
|
|
placeholder="请选择权限类型"
|
2024-01-19 16:30:46 +08:00
|
|
|
>
|
|
|
|
|
<el-option
|
2024-01-22 15:20:30 +08:00
|
|
|
v-for="(item, index) in UserTypeOption"
|
|
|
|
|
:label="item.label"
|
|
|
|
|
:value="item.value"
|
|
|
|
|
:key="index"
|
2024-01-19 16:30:46 +08:00
|
|
|
></el-option>
|
|
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-form-item label="用户类型" prop="casualUser">
|
2024-02-02 09:29:19 +08:00
|
|
|
<el-select v-model="form.casualUser" placeholder="请选择权限类型">
|
2024-01-19 16:30:46 +08:00
|
|
|
<el-option
|
2024-01-22 15:20:30 +08:00
|
|
|
v-for="(item, index) in TypeOptions"
|
|
|
|
|
:label="item.label"
|
|
|
|
|
:value="item.value"
|
|
|
|
|
:key="index"
|
2024-01-19 16:30:46 +08:00
|
|
|
></el-option>
|
|
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-form-item label="所属部门" prop="deptId">
|
2024-09-30 15:37:33 +08:00
|
|
|
<Area v-model="form.deptId" />
|
2024-01-19 16:30:46 +08:00
|
|
|
</el-form-item>
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-form-item label="角色" prop="role">
|
2024-02-02 09:29:19 +08:00
|
|
|
<el-select v-model="form.role" placeholder="请选择角色" multiple collapse-tags>
|
2024-01-19 16:30:46 +08:00
|
|
|
<el-option
|
2024-01-22 15:20:30 +08:00
|
|
|
v-for="(item, index) in roleOptions"
|
|
|
|
|
:label="item.label"
|
|
|
|
|
:value="item.value"
|
|
|
|
|
:key="index"
|
2024-01-19 16:30:46 +08:00
|
|
|
></el-option>
|
|
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-form-item label="手机号" prop="phone">
|
|
|
|
|
<el-input v-model="form.phone" placeholder="请输入手机号" />
|
2024-01-19 16:30:46 +08:00
|
|
|
</el-form-item>
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-form-item label="邮箱" prop="email">
|
2024-09-27 16:22:34 +08:00
|
|
|
<el-input v-model="form.email" placeholder="请输入描述" />
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="时间段" prop="limitTime">
|
2024-09-30 15:37:33 +08:00
|
|
|
<el-slider v-model="form.limitTime" style="width: 95%" range show-stops :max="24" />
|
2024-01-19 16:30:46 +08:00
|
|
|
</el-form-item>
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-form-item label="起始IP" prop="limitIpStart">
|
|
|
|
|
<el-input v-model="form.limitIpStart" placeholder="请输入描述" />
|
2024-01-19 16:30:46 +08:00
|
|
|
</el-form-item>
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-form-item label="结束IP" prop="limitIpEnd">
|
|
|
|
|
<el-input v-model="form.limitIpEnd" placeholder="请输入描述" />
|
2024-01-19 16:30:46 +08:00
|
|
|
</el-form-item>
|
2024-09-27 16:22:34 +08:00
|
|
|
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-form-item label="短信通知" prop="smsNotice">
|
2024-09-27 16:22:34 +08:00
|
|
|
<el-radio-group v-model="form.smsNotice" style="width: 200px">
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-radio-button :label="0">是</el-radio-button>
|
|
|
|
|
<el-radio-button :label="1">否</el-radio-button>
|
2024-01-19 16:30:46 +08:00
|
|
|
</el-radio-group>
|
|
|
|
|
</el-form-item>
|
2024-09-27 16:22:34 +08:00
|
|
|
<el-form-item label="邮件通知" prop="emailNotice" >
|
|
|
|
|
<el-radio-group v-model="form.emailNotice" style="width: 200px">
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-radio-button :label="0">是</el-radio-button>
|
|
|
|
|
<el-radio-button :label="1">否</el-radio-button>
|
2024-01-19 16:30:46 +08:00
|
|
|
</el-radio-group>
|
|
|
|
|
</el-form-item>
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-form-item label="用户ID">
|
2024-09-27 16:22:34 +08:00
|
|
|
<div style="display: flex; width: 100%" >
|
2024-01-22 15:20:30 +08:00
|
|
|
<el-radio-group v-model="useId">
|
|
|
|
|
<el-radio-button :label="1">是</el-radio-button>
|
|
|
|
|
<el-radio-button :label="0">否</el-radio-button>
|
2024-01-19 16:30:46 +08:00
|
|
|
</el-radio-group>
|
|
|
|
|
<el-input
|
2024-01-22 14:21:31 +08:00
|
|
|
:disabled="title !== '新增用户'"
|
2024-01-22 15:20:30 +08:00
|
|
|
v-model="form.id"
|
|
|
|
|
placeholder="请输入用户id"
|
2024-09-30 15:37:33 +08:00
|
|
|
|
2024-01-22 15:20:30 +08:00
|
|
|
v-if="useId"
|
2024-09-30 15:37:33 +08:00
|
|
|
style="flex: 1;"
|
2024-01-22 15:20:30 +08:00
|
|
|
class="ml10"
|
2024-01-19 16:30:46 +08:00
|
|
|
></el-input>
|
|
|
|
|
</div>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</el-form>
|
|
|
|
|
|
|
|
|
|
<template #footer>
|
2024-01-22 15:20:30 +08:00
|
|
|
<span class="dialog-footer">
|
|
|
|
|
<el-button @click="dialogVisible = false">取消</el-button>
|
|
|
|
|
<el-button type="primary" @click="submit">确认</el-button>
|
2024-01-19 16:30:46 +08:00
|
|
|
</span>
|
|
|
|
|
</template>
|
|
|
|
|
</el-dialog>
|
|
|
|
|
</template>
|
2024-01-22 15:20:30 +08:00
|
|
|
<script lang="ts" setup>
|
2024-01-19 16:30:46 +08:00
|
|
|
import { ref, inject } from 'vue'
|
|
|
|
|
import { reactive } from 'vue'
|
|
|
|
|
import TableStore from '@/utils/tableStore'
|
2024-01-22 15:20:30 +08:00
|
|
|
import { ElMessage, FormItemRule } from 'element-plus'
|
2024-01-22 10:31:07 +08:00
|
|
|
import { roleList } from '@/api/user-boot/role'
|
|
|
|
|
import { add, edit } from '@/api/user-boot/user'
|
2024-01-19 16:30:46 +08:00
|
|
|
import { useAdminInfo } from '@/stores/adminInfo'
|
|
|
|
|
import Area from '@/components/form/area/index.vue'
|
2024-01-22 15:20:30 +08:00
|
|
|
import { Arrayable } from 'element-plus/es/utils'
|
2024-01-19 16:30:46 +08:00
|
|
|
|
|
|
|
|
const adminInfo = useAdminInfo()
|
|
|
|
|
const tableStore = inject('tableStore') as TableStore
|
|
|
|
|
// do not use same name with ref
|
|
|
|
|
const form = reactive({
|
|
|
|
|
id: '',
|
|
|
|
|
name: '',
|
2024-01-22 10:31:07 +08:00
|
|
|
password: '123456',
|
2024-01-19 16:30:46 +08:00
|
|
|
email: '',
|
|
|
|
|
limitIpStart: '',
|
|
|
|
|
deptId: '',
|
|
|
|
|
deptName: '',
|
|
|
|
|
casualUser: 1,
|
|
|
|
|
loginName: '',
|
|
|
|
|
phone: '',
|
|
|
|
|
limitIpEnd: '',
|
2024-01-22 10:31:07 +08:00
|
|
|
limitTime: [1, 2],
|
2024-01-19 16:30:46 +08:00
|
|
|
role: [],
|
|
|
|
|
smsNotice: 0,
|
|
|
|
|
emailNotice: 0,
|
2024-01-22 10:31:07 +08:00
|
|
|
type: 0
|
2024-01-19 16:30:46 +08:00
|
|
|
})
|
2024-01-22 15:20:30 +08:00
|
|
|
const rules:Partial<Record<string, Arrayable<FormItemRule>>> = {
|
2024-01-22 10:31:07 +08:00
|
|
|
name: [{ required: true, message: '用户名不能为空', trigger: 'blur' }],
|
|
|
|
|
role: [{ required: true, message: '角色不能为空', trigger: 'blur' }],
|
|
|
|
|
password: [{ required: true, message: '用户密码不能为空', trigger: 'blur' }],
|
|
|
|
|
loginName: [{ required: true, message: '登录名不能为空', trigger: 'blur' }],
|
|
|
|
|
casualUser: [{ required: true, message: '用户类型不能为空', trigger: 'blur' }],
|
|
|
|
|
smsNotice: [{ required: true, message: '短信通知不能为空', trigger: 'blur' }],
|
|
|
|
|
emailNotice: [{ required: true, message: '邮件通知不能为空', trigger: 'blur' }],
|
|
|
|
|
email: [
|
|
|
|
|
{ required: false, message: '邮箱不能为空', trigger: 'blur' },
|
|
|
|
|
{
|
|
|
|
|
type: 'email',
|
2024-01-22 15:20:30 +08:00
|
|
|
message: "'请输入正确的邮箱地址",
|
2024-01-22 10:31:07 +08:00
|
|
|
trigger: ['blur', 'change']
|
|
|
|
|
}
|
|
|
|
|
],
|
|
|
|
|
phone: [
|
|
|
|
|
{ required: false, message: '手机号不能为空', trigger: 'blur' },
|
|
|
|
|
{
|
|
|
|
|
pattern: /^1[3|4|5|6|7|8|9][0-9]\d{8}$/,
|
|
|
|
|
message: '请输入正确的手机号码',
|
|
|
|
|
trigger: 'blur'
|
|
|
|
|
}
|
|
|
|
|
],
|
|
|
|
|
limitTime: [{ required: true, message: '时间段不能为空', trigger: 'blur' }],
|
|
|
|
|
limitIpStart: [
|
|
|
|
|
{ required: true, message: '起始IP不能为空', trigger: 'blur' },
|
|
|
|
|
{
|
|
|
|
|
required: true,
|
|
|
|
|
validator: (rule: any, value: string, callback: any) => {
|
|
|
|
|
let regexp = /^((2(5[0-5]|[0-4]\d))|[0-1]?\d{1,2})(\.((2(5[0-5]|[0-4]\d))|[0-1]?\d{1,2})){3}$/
|
|
|
|
|
let isCorrect = regexp.test(value)
|
|
|
|
|
if (value == '') {
|
|
|
|
|
return callback(new Error('请输入IP地址'))
|
|
|
|
|
} else if (!isCorrect) {
|
|
|
|
|
callback(new Error('请输入正确的IP地址'))
|
|
|
|
|
} else {
|
|
|
|
|
callback()
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
trigger: 'blur'
|
|
|
|
|
}
|
|
|
|
|
],
|
|
|
|
|
limitIpEnd: [
|
|
|
|
|
{ required: true, message: '结束IP不能为空', trigger: 'blur' },
|
|
|
|
|
{
|
|
|
|
|
required: true,
|
|
|
|
|
validator: (rule: any, value: string, callback: any) => {
|
|
|
|
|
let regexp = /^((2(5[0-5]|[0-4]\d))|[0-1]?\d{1,2})(\.((2(5[0-5]|[0-4]\d))|[0-1]?\d{1,2})){3}$/
|
|
|
|
|
let isCorrect = regexp.test(value)
|
|
|
|
|
if (value == '') {
|
|
|
|
|
return callback(new Error('请输入IP地址'))
|
|
|
|
|
} else if (!isCorrect) {
|
|
|
|
|
callback(new Error('请输入正确的IP地址'))
|
|
|
|
|
} else {
|
|
|
|
|
callback()
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
trigger: 'blur'
|
|
|
|
|
}
|
|
|
|
|
]
|
2024-01-19 16:30:46 +08:00
|
|
|
}
|
|
|
|
|
const UserTypeOption = [
|
|
|
|
|
{ label: '管理员', value: 1 },
|
|
|
|
|
{ label: '普通用户', value: 2 }
|
|
|
|
|
]
|
|
|
|
|
const TypeOptions = [
|
|
|
|
|
{ label: '临时用户', value: 0 },
|
|
|
|
|
{ label: '长期用户', value: 1 }
|
|
|
|
|
]
|
|
|
|
|
const useId = ref(1)
|
2024-01-22 10:31:07 +08:00
|
|
|
const roleOptions = ref<treeData>()
|
|
|
|
|
const queryRole = () => {
|
|
|
|
|
roleList(adminInfo.$state.userType).then((res: any) => {
|
|
|
|
|
roleOptions.value = res.data.map((item: any) => {
|
|
|
|
|
return {
|
|
|
|
|
label: item.name,
|
|
|
|
|
value: item.id
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
queryRole()
|
2024-01-19 16:30:46 +08:00
|
|
|
const dialogVisible = ref(false)
|
|
|
|
|
const title = ref('新增菜单')
|
|
|
|
|
const open = (text: string, data?: anyObj) => {
|
|
|
|
|
title.value = text
|
|
|
|
|
dialogVisible.value = true
|
|
|
|
|
if (data) {
|
|
|
|
|
for (let key in form) {
|
|
|
|
|
form[key] = data[key]
|
|
|
|
|
}
|
2024-01-22 14:21:31 +08:00
|
|
|
form.limitTime = data.limitTime.split('-')
|
|
|
|
|
form.role = data.roleList
|
2024-01-19 16:30:46 +08:00
|
|
|
} else {
|
|
|
|
|
for (let key in form) {
|
|
|
|
|
form[key] = ''
|
|
|
|
|
}
|
2024-01-22 10:31:07 +08:00
|
|
|
form.casualUser = 1
|
2024-09-27 16:22:34 +08:00
|
|
|
form.limitTime = [0, 24]
|
2024-01-22 10:31:07 +08:00
|
|
|
form.role = []
|
|
|
|
|
form.smsNotice = 0
|
|
|
|
|
form.emailNotice = 0
|
|
|
|
|
useId.value = 1
|
2024-01-22 14:21:31 +08:00
|
|
|
form.id = ''
|
|
|
|
|
form.limitIpStart = '0.0.0.0'
|
|
|
|
|
form.limitIpEnd = '255.255.255.255'
|
|
|
|
|
form.password = '123456'
|
2024-01-19 16:30:46 +08:00
|
|
|
}
|
2024-01-22 14:21:31 +08:00
|
|
|
form.type = adminInfo.$state.userType + 1
|
2024-01-19 16:30:46 +08:00
|
|
|
}
|
|
|
|
|
const submit = async () => {
|
2024-01-22 10:31:07 +08:00
|
|
|
let obj = JSON.parse(JSON.stringify(form))
|
|
|
|
|
obj.limitTime = obj.limitTime.join('-')
|
|
|
|
|
delete obj.password
|
2024-01-19 16:30:46 +08:00
|
|
|
if (form.id) {
|
2024-01-22 10:31:07 +08:00
|
|
|
await edit(obj)
|
|
|
|
|
ElMessage.success('修改成功')
|
2024-01-19 16:30:46 +08:00
|
|
|
} else {
|
|
|
|
|
form.type = adminInfo.$state.userType + 1
|
2024-01-22 10:31:07 +08:00
|
|
|
await add(obj)
|
|
|
|
|
ElMessage.success('新增成功')
|
2024-01-19 16:30:46 +08:00
|
|
|
}
|
|
|
|
|
tableStore.index()
|
|
|
|
|
dialogVisible.value = false
|
|
|
|
|
}
|
|
|
|
|
|
2024-01-22 15:20:30 +08:00
|
|
|
const changeValue = () => {}
|
2024-01-19 16:30:46 +08:00
|
|
|
defineExpose({ open })
|
|
|
|
|
</script>
|