post.data.ts 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  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. action: true,
  18. columns: [
  19. {
  20. title: '岗位名称',
  21. field: 'name',
  22. isSearch: true
  23. },
  24. {
  25. title: '岗位编码',
  26. field: 'code',
  27. isSearch: true
  28. },
  29. {
  30. title: '岗位顺序',
  31. field: 'sort'
  32. },
  33. {
  34. title: t('common.status'),
  35. field: 'status',
  36. dictType: DICT_TYPE.COMMON_STATUS,
  37. isSearch: true
  38. },
  39. {
  40. title: '备注',
  41. field: 'remark',
  42. isTable: false
  43. },
  44. {
  45. title: t('common.createTime'),
  46. field: 'createTime',
  47. formatter: 'formatDate',
  48. isForm: false
  49. }
  50. ]
  51. })
  52. export const { allSchemas } = useVxeCrudSchemas(crudSchemas)