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.

143 lines
4.3 KiB

<template>
<div>
<vxe-modal
:value="isShow"
show-footer
title="角色"
show-confirm-button
:width="600"
:height="600"
esc-closable
@input="e => $emit('update:isShow',e)"
>
<el-form ref="elForm" :model="form" :rules="rules" label-position="top" label-width="100">
<el-form-item label="姓名" prop="name" required>
<el-input v-model="form.name" clearable />
</el-form-item>
<el-form-item label="用户名" prop="username" required>
<el-input v-model="form.username" clearable />
</el-form-item>
<el-form-item label="密码" prop="password" required>
<el-input v-model="form.password" type="password" show-password clearable />
</el-form-item>
<el-form-item label="是否关闭打卡" prop="attendance_closed">
<el-switch v-model="form.attendance_closed" :active-value="1" :inactive-value="0" active-text="是" inactive-text="否" />
</el-form-item>
<el-form-item label="手机号" prop="mobile">
<el-input v-model="form.mobile" clearable />
</el-form-item>
<el-form-item label="参加工作时间" prop="start_work_date">
<el-date-picker v-model="form.start_work_date" type="month" value-format="yyyy-MM" clearable />
</el-form-item>
<el-form-item label="年假天数" prop="year_holiday">
<el-input-number v-model="form.year_holiday" controls-position="right" clearable />
</el-form-item>
<el-form-item label="部门" prop="department_id">
<el-select v-model="form.department_id" clearable>
<el-option v-for="item in departments" :key="item.id" :value="item.id" :label="item.name" />
</el-select>
</el-form-item>
<el-form-item label="职位" prop="position">
<el-input v-model="form.position" clearable />
</el-form-item>
<el-form-item label="排序" prop="sortnumber">
<el-input-number v-model="form.sortnumber" controls-position="right" :precision="0" />
</el-form-item>
</el-form>
<template #footer>
<el-button type="primary" :loading="loading" @click="submit">确认</el-button>
</template>
</vxe-modal>
</div>
</template>
<script>
import { save } from '@/api/user'
export default {
props: {
isShow: {
type: Boolean,
default: false,
required: true
},
departments: {
type: Array,
default: () => []
}
},
data() {
return {
loading: false,
form: {
name: '',
username: '',
password: '',
attendance_closed: 0,
mobile: '',
start_work_date: '',
year_holiday: '',
department_id: '',
position: '',
sortnumber: 0
},
rules: {
name: [
{ required: true, message: '请输入姓名' }
],
username: [
{ required: true, message: '请输入用户名' }
],
password: [
{ required: true, message: '请输入密码' },
{
validator: (rule, value, callback) => {
const reg = new RegExp('(?=.*[0-9])(?=.*[a-zA-Z])(?=.*[^a-zA-Z0-9]).{8,20}')
if (reg.test(value)) {
callback()
} else {
callback(new Error('您的密码复杂度太低(密码中必须包含字母、数字、特殊字符)!'))
}
}
}
],
mobile: [
{
validator: (rule, value, callback) => {
if (/^1[3456789]\d{9}$/.test(value)) {
callback()
} else {
callback(new Error('手机号格式错误!'))
}
}
}
]
}
}
},
computed: {},
methods: {
submit() {
this.$refs['elForm'].validate(async valid => {
if (valid) {
this.loading = true
try {
await save(this.form)
this.$message.success('新增成功')
this.$emit('refresh')
this.$emit('update:isShow', false)
this.loading = false
this.$refs['elForm'].resetFields()
} catch (err) {
this.loading = false
}
}
})
}
}
}
</script>
<style scoped lang="scss">
</style>