sensitiveWord.data.ts 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  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. tags: [required]
  11. })
  12. // CrudSchema
  13. const crudSchemas = reactive<VxeCrudSchema>({
  14. primaryKey: 'id',
  15. primaryType: 'seq',
  16. primaryTitle: '敏感词编号',
  17. action: true,
  18. columns: [
  19. {
  20. title: '敏感词',
  21. field: 'name',
  22. isSearch: true
  23. },
  24. {
  25. title: '标签',
  26. field: 'tag',
  27. isTable: false,
  28. isForm: false,
  29. isDetail: false,
  30. isSearch: true
  31. },
  32. {
  33. title: '标签',
  34. field: 'tags',
  35. table: {
  36. slots: {
  37. default: 'tags_default'
  38. }
  39. }
  40. },
  41. {
  42. title: t('common.status'),
  43. field: 'status',
  44. dictType: DICT_TYPE.COMMON_STATUS,
  45. dictClass: 'number',
  46. isSearch: true
  47. },
  48. {
  49. title: '描述',
  50. field: 'description',
  51. form: {
  52. component: 'Input',
  53. componentProps: {
  54. type: 'textarea',
  55. rows: 4
  56. },
  57. colProps: {
  58. span: 24
  59. }
  60. }
  61. },
  62. {
  63. title: t('common.createTime'),
  64. field: 'createTime',
  65. formatter: 'formatDate',
  66. isForm: false,
  67. search: {
  68. show: true,
  69. itemRender: {
  70. name: 'XDataTimePicker'
  71. }
  72. }
  73. }
  74. ]
  75. })
  76. export const { allSchemas } = useVxeCrudSchemas(crudSchemas)