config.data.ts 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. import { reactive } from 'vue'
  2. import { useI18n } from '@/hooks/web/useI18n'
  3. import { required } from '@/utils/formRules'
  4. import { CrudSchema, useCrudSchemas } from '@/hooks/web/useCrudSchemas'
  5. import { DICT_TYPE } from '@/utils/dict'
  6. const { t } = useI18n() // 国际化
  7. // 表单校验
  8. export const rules = reactive({
  9. category: [required],
  10. name: [required],
  11. key: [required],
  12. value: [required]
  13. })
  14. // CrudSchema
  15. const crudSchemas = reactive<CrudSchema[]>([
  16. {
  17. label: t('common.index'),
  18. field: 'id',
  19. type: 'index',
  20. form: {
  21. show: false
  22. },
  23. detail: {
  24. show: false
  25. }
  26. },
  27. {
  28. label: '参数分类',
  29. field: 'category'
  30. },
  31. {
  32. label: '参数名称',
  33. field: 'name',
  34. search: {
  35. show: true
  36. }
  37. },
  38. {
  39. label: '参数键名',
  40. field: 'key',
  41. search: {
  42. show: true
  43. }
  44. },
  45. {
  46. label: '参数键值',
  47. field: 'value'
  48. },
  49. {
  50. label: '系统内置',
  51. field: 'type',
  52. dictType: DICT_TYPE.INFRA_CONFIG_TYPE,
  53. dictData: 'number',
  54. search: {
  55. show: true
  56. }
  57. },
  58. {
  59. label: '是否可见',
  60. field: 'visible',
  61. form: {
  62. component: 'RadioButton',
  63. componentProps: {
  64. options: [
  65. { label: '是', value: true },
  66. { label: '否', value: false }
  67. ]
  68. }
  69. }
  70. },
  71. {
  72. label: t('form.remark'),
  73. field: 'remark',
  74. form: {
  75. component: 'Input',
  76. componentProps: {
  77. type: 'textarea',
  78. rows: 4
  79. },
  80. colProps: {
  81. span: 24
  82. }
  83. },
  84. table: {
  85. show: false
  86. }
  87. },
  88. {
  89. label: t('common.createTime'),
  90. field: 'createTime',
  91. form: {
  92. show: false
  93. },
  94. search: {
  95. show: true,
  96. component: 'DatePicker',
  97. componentProps: {
  98. type: 'datetimerange',
  99. valueFormat: 'YYYY-MM-DD HH:mm:ss',
  100. defaultTime: [new Date(2000, 1, 1, 0, 0, 0), new Date(2000, 2, 1, 23, 59, 59)]
  101. }
  102. }
  103. },
  104. {
  105. label: t('table.action'),
  106. field: 'action',
  107. width: '240px',
  108. form: {
  109. show: false
  110. },
  111. detail: {
  112. show: false
  113. }
  114. }
  115. ])
  116. export const { allSchemas } = useCrudSchemas(crudSchemas)