66 lines
1.4 KiB
TypeScript
Raw Normal View History

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'
2022-11-22 13:15:07 +08:00
import { VxeCrudSchema, useVxeCrudSchemas } from '@/hooks/web/useVxeCrudSchemas'
2022-07-18 19:06:37 +08:00
const { t } = useI18n() // 国际化
// 表单校验
export const rules = reactive({
name: [required],
id: [required],
type: [required],
remark: [required],
status: [required],
menuIds: [required]
})
// CrudSchema
2022-11-22 13:15:07 +08:00
const crudSchemas = reactive<VxeCrudSchema>({
primaryKey: 'id',
primaryType: 'seq',
primaryTitle: '套餐编号',
2022-11-22 13:15:07 +08:00
action: true,
columns: [
{
title: '套餐名称',
field: 'name',
isSearch: true
2022-07-18 19:06:37 +08:00
},
2022-11-22 13:15:07 +08:00
{
title: t('common.status'),
field: 'status',
dictType: DICT_TYPE.COMMON_STATUS,
dictClass: 'number',
isSearch: true
2022-07-18 19:06:37 +08:00
},
2022-11-22 13:15:07 +08:00
{
title: '菜单权限',
field: 'menuIds', // TODO 星语:菜单权限,表单可以搞大点哇?
2022-11-22 13:15:07 +08:00
isTable: false
2022-07-18 19:06:37 +08:00
},
2022-11-22 13:15:07 +08:00
{
title: t('form.remark'),
field: 'remark',
isTable: false,
form: {
component: 'Input',
componentProps: {
type: 'textarea',
rows: 4
},
colProps: {
span: 24
}
}
},
{
title: '创建时间',
field: 'createTime',
formatter: 'formatDate',
isForm: false
2022-07-18 19:06:37 +08:00
}
2022-11-22 13:15:07 +08:00
]
})
export const { allSchemas } = useVxeCrudSchemas(crudSchemas)