dept.data.ts 1.6 KB

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