post.data.ts 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. import { reactive } from 'vue'
  2. import { useI18n } from '@/hooks/web/useI18n'
  3. import { required } from '@/utils/formRules'
  4. import { DICT_TYPE } from '@/utils/dict'
  5. import { VxeCrudSchema, useVxeCrudSchemas } from '@/hooks/web/useVxeCrudSchemas'
  6. const { t } = useI18n() // 国际化
  7. // 表单校验
  8. export const rules = reactive({
  9. name: [required],
  10. code: [required],
  11. sort: [required]
  12. })
  13. // CrudSchema
  14. const crudSchemas = reactive<VxeCrudSchema>({
  15. primaryKey: 'id',
  16. primaryType: 'seq',
  17. primaryTitle: '岗位编号',
  18. action: true,
  19. columns: [
  20. {
  21. title: '岗位名称',
  22. field: 'name',
  23. isSearch: true
  24. },
  25. {
  26. title: '岗位编码',
  27. field: 'code',
  28. isSearch: true
  29. },
  30. {
  31. title: '岗位顺序',
  32. field: 'sort'
  33. },
  34. {
  35. title: t('common.status'),
  36. field: 'status',
  37. dictType: DICT_TYPE.COMMON_STATUS,
  38. dictClass: 'number',
  39. isSearch: true
  40. },
  41. {
  42. title: '备注',
  43. field: 'remark',
  44. isTable: false
  45. },
  46. {
  47. title: t('common.createTime'),
  48. field: 'createTime',
  49. formatter: 'formatDate',
  50. isForm: false
  51. }
  52. ]
  53. })
  54. export const { allSchemas } = useVxeCrudSchemas(crudSchemas)