role.data.ts 1.7 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. // 国际化
  7. const { t } = useI18n()
  8. // 表单校验
  9. export const rules = reactive({
  10. name: [required],
  11. code: [required],
  12. sort: [required]
  13. })
  14. // CrudSchema
  15. const crudSchemas = reactive<VxeCrudSchema>({
  16. primaryKey: 'id',
  17. primaryTitle: '角色编号',
  18. primaryType: 'seq',
  19. action: true,
  20. actionWidth: '400px',
  21. columns: [
  22. {
  23. title: '角色名称',
  24. field: 'name',
  25. isSearch: true
  26. },
  27. {
  28. title: '角色类型',
  29. field: 'type',
  30. dictType: DICT_TYPE.SYSTEM_ROLE_TYPE,
  31. dictClass: 'number',
  32. isForm: false
  33. },
  34. {
  35. title: '角色标识',
  36. field: 'code',
  37. isSearch: true
  38. },
  39. {
  40. title: '显示顺序',
  41. field: 'sort'
  42. },
  43. {
  44. title: t('form.remark'),
  45. field: 'remark',
  46. isTable: false,
  47. form: {
  48. component: 'Input',
  49. componentProps: {
  50. type: 'textarea',
  51. rows: 4
  52. },
  53. colProps: {
  54. span: 24
  55. }
  56. }
  57. },
  58. {
  59. title: t('common.status'),
  60. field: 'status',
  61. dictType: DICT_TYPE.COMMON_STATUS,
  62. dictClass: 'number',
  63. isSearch: true
  64. },
  65. {
  66. title: t('common.createTime'),
  67. field: 'createTime',
  68. formatter: 'formatDate',
  69. isForm: false,
  70. search: {
  71. show: true,
  72. itemRender: {
  73. name: 'XDataTimePicker'
  74. }
  75. }
  76. }
  77. ]
  78. })
  79. export const { allSchemas } = useVxeCrudSchemas(crudSchemas)