2022-07-18 19:06:37 +08:00
|
|
|
import { reactive } from 'vue'
|
|
|
|
import { required } from '@/utils/formRules'
|
|
|
|
import { useI18n } from '@/hooks/web/useI18n'
|
|
|
|
import { DICT_TYPE } from '@/utils/dict'
|
|
|
|
import { CrudSchema, useCrudSchemas } from '@/hooks/web/useCrudSchemas'
|
|
|
|
// 国际化
|
|
|
|
const { t } = useI18n()
|
|
|
|
// 表单校验
|
|
|
|
export const rules = reactive({
|
|
|
|
name: [required],
|
|
|
|
code: [required],
|
|
|
|
sort: [required],
|
|
|
|
status: [required]
|
|
|
|
})
|
|
|
|
// crudSchemas
|
|
|
|
const crudSchemas = reactive<CrudSchema[]>([
|
|
|
|
{
|
|
|
|
label: t('common.index'),
|
|
|
|
field: 'id',
|
|
|
|
type: 'index',
|
|
|
|
form: {
|
|
|
|
show: false
|
|
|
|
},
|
|
|
|
detail: {
|
|
|
|
show: false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: '用户账号',
|
|
|
|
field: 'username',
|
|
|
|
search: {
|
|
|
|
show: true
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: '用户昵称',
|
|
|
|
field: 'nickname'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: '用户邮箱',
|
|
|
|
field: 'email'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: '手机号码',
|
|
|
|
field: 'mobile',
|
|
|
|
search: {
|
|
|
|
show: true
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: '用户性别',
|
|
|
|
field: 'sex',
|
|
|
|
dictType: DICT_TYPE.SYSTEM_USER_SEX
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: '部门',
|
|
|
|
field: 'deptId',
|
|
|
|
table: {
|
|
|
|
show: false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: '岗位',
|
|
|
|
field: 'postIds',
|
|
|
|
table: {
|
|
|
|
show: false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: t('common.status'),
|
|
|
|
field: 'status',
|
|
|
|
dictType: DICT_TYPE.COMMON_STATUS,
|
|
|
|
search: {
|
|
|
|
show: true
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: '最后登录时间',
|
|
|
|
field: 'loginDate',
|
|
|
|
form: {
|
|
|
|
show: false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: '最后登录IP',
|
|
|
|
field: 'loginIp',
|
|
|
|
table: {
|
|
|
|
show: false
|
|
|
|
},
|
|
|
|
form: {
|
|
|
|
show: false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: t('form.remark'),
|
|
|
|
field: 'remark',
|
|
|
|
table: {
|
|
|
|
show: false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: t('common.createTime'),
|
|
|
|
field: 'daterange',
|
|
|
|
table: {
|
|
|
|
show: false
|
|
|
|
},
|
|
|
|
form: {
|
|
|
|
show: false
|
|
|
|
},
|
|
|
|
detail: {
|
|
|
|
show: false
|
|
|
|
},
|
|
|
|
search: {
|
|
|
|
show: true,
|
|
|
|
component: 'DatePicker',
|
|
|
|
componentProps: {
|
|
|
|
type: 'daterange',
|
|
|
|
valueFormat: 'YYYY-MM-DD HH:mm:ss'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
field: 'action',
|
2022-07-19 22:33:54 +08:00
|
|
|
width: '340px',
|
2022-07-18 19:06:37 +08:00
|
|
|
label: t('table.action'),
|
|
|
|
form: {
|
|
|
|
show: false
|
|
|
|
},
|
|
|
|
detail: {
|
|
|
|
show: false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
])
|
|
|
|
export const { allSchemas } = useCrudSchemas(crudSchemas)
|