menu.data.ts 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. import { reactive } from 'vue'
  2. import { useI18n } from '@/hooks/web/useI18n'
  3. import { DICT_TYPE } from '@/utils/dict'
  4. import { required } from '@/utils/formRules'
  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. path: [required],
  12. status: [required]
  13. })
  14. // CrudSchema
  15. const crudSchemas = reactive<VxeCrudSchema>({
  16. primaryKey: 'id',
  17. primaryType: null,
  18. action: true,
  19. columns: [
  20. {
  21. title: '上级菜单',
  22. field: 'parentId',
  23. isTable: false
  24. },
  25. {
  26. title: '菜单名称',
  27. field: 'name',
  28. isSearch: true,
  29. table: {
  30. treeNode: true,
  31. align: 'left',
  32. width: '200px',
  33. slots: {
  34. default: 'name_default'
  35. }
  36. }
  37. },
  38. {
  39. title: '菜单类型',
  40. field: 'type',
  41. dictType: DICT_TYPE.SYSTEM_MENU_TYPE
  42. },
  43. {
  44. title: '路由地址',
  45. field: 'path'
  46. },
  47. {
  48. title: '组件路径',
  49. field: 'component'
  50. },
  51. {
  52. title: '权限标识',
  53. field: 'permission'
  54. },
  55. {
  56. title: '排序',
  57. field: 'sort'
  58. },
  59. {
  60. title: t('common.status'),
  61. field: 'status',
  62. dictType: DICT_TYPE.COMMON_STATUS,
  63. dictClass: 'number',
  64. isSearch: true
  65. },
  66. {
  67. title: t('common.createTime'),
  68. field: 'createTime',
  69. formatter: 'formatDate'
  70. }
  71. ]
  72. })
  73. export const { allSchemas } = useVxeCrudSchemas(crudSchemas)