dept.data.ts 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  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. sort: [required],
  11. email: [required],
  12. phone: [
  13. {
  14. min: 11,
  15. max: 11,
  16. trigger: 'blur',
  17. message: '请输入正确的手机号码'
  18. }
  19. ]
  20. })
  21. // CrudSchema
  22. const crudSchemas = reactive<VxeCrudSchema>({
  23. primaryKey: 'id',
  24. primaryType: null,
  25. action: true,
  26. columns: [
  27. {
  28. title: '上级部门',
  29. field: 'parentId',
  30. isTable: false
  31. },
  32. {
  33. title: '部门名称',
  34. field: 'name',
  35. isSearch: true,
  36. table: {
  37. treeNode: true,
  38. align: 'left'
  39. }
  40. },
  41. {
  42. title: '负责人',
  43. field: 'leaderUserId',
  44. table: {
  45. slots: {
  46. default: 'leaderUserId_default'
  47. }
  48. }
  49. },
  50. {
  51. title: '联系电话',
  52. field: 'phone'
  53. },
  54. {
  55. title: '邮箱',
  56. field: 'email',
  57. isTable: false
  58. },
  59. {
  60. title: '显示排序',
  61. field: 'sort'
  62. },
  63. {
  64. title: t('common.status'),
  65. field: 'status',
  66. dictType: DICT_TYPE.COMMON_STATUS,
  67. dictClass: 'number',
  68. isSearch: true
  69. },
  70. {
  71. title: t('common.createTime'),
  72. field: 'createTime',
  73. formatter: 'formatDate',
  74. isForm: false
  75. }
  76. ]
  77. })
  78. export const { allSchemas } = useVxeCrudSchemas(crudSchemas)