popupForm.vue 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. <template>
  2. <!-- 对话框表单 -->
  3. <el-dialog
  4. custom-class="ba-operate-dialog"
  5. :close-on-click-modal="false"
  6. :model-value="baTable.form.operate ? true : false"
  7. @close="baTable.toggleForm"
  8. >
  9. <template #header>
  10. <div class="title" v-drag="['.ba-operate-dialog', '.el-dialog__header']" v-zoom="'.ba-operate-dialog'">
  11. {{ baTable.form.operate ? baTable.form.operate=='edit'?'编辑' : '添加':'无标题'}}
  12. </div>
  13. </template>
  14. <el-scrollbar v-loading="baTable.form.loading" class="ba-table-form-scrollbar">
  15. <div
  16. class="ba-operate-form"
  17. :class="'ba-' + baTable.form.operate + '-form'"
  18. :style="'width: calc(100% - ' + baTable.form.labelWidth! / 2 + 'px)'"
  19. >
  20. <el-form
  21. v-if="!baTable.form.loading"
  22. ref="formRef"
  23. :model="baTable.form.items"
  24. label-position="right"
  25. :label-width="baTable.form.labelWidth + 'px'"
  26. :rules="rules"
  27. >
  28. <FormItem
  29. label="规则名称"
  30. type="string"
  31. v-model="baTable.form.items!.name"
  32. prop="name"
  33. placeholder="规则名称有助于后续识别被删数据"
  34. />
  35. <FormItem
  36. label="控制器"
  37. type="select"
  38. v-model="baTable.form.items!.controller"
  39. prop="controller"
  40. :data="{ content: formData.controllerList }"
  41. placeholder="数据回收机制将监控此控制器下的删除操作"
  42. />
  43. <FormItem
  44. label="实体类"
  45. type="select"
  46. v-model="baTable.form.items!.controllerAs"
  47. prop="controllerAs"
  48. :data="{content: formData.entitiesList}"
  49. placeholder="数据回收机制通过实体类进行还原操作"
  50. />
  51. <FormItem
  52. label="对应数据表"
  53. type="select"
  54. v-model="baTable.form.items!.dataTable"
  55. prop="dataTable"
  56. :data="{ content: formData.tableList }"
  57. :input-attr="{ onChange: onTableChange }"
  58. />
  59. <FormItem
  60. label="数据表主键"
  61. type="string"
  62. v-model="baTable.form.items!.primaryKey"
  63. prop="primaryKey"
  64. placeholder="数据回收机制通过数据表主键识别数据"
  65. />
  66. <FormItem
  67. label="状态"
  68. type="radio"
  69. v-model="baTable.form.items!.status"
  70. prop="status"
  71. :data="{ content: { '0': '禁用', '1': '启用' } }"
  72. />
  73. </el-form>
  74. </div>
  75. </el-scrollbar>
  76. <template #footer>
  77. <div :style="'width: calc(100% - ' + baTable.form.labelWidth! / 1.8 + 'px)'">
  78. <el-button @click="baTable.toggleForm('')">取消</el-button>
  79. <el-button v-blur :loading="baTable.form.submitLoading" @click="baTable.onSubmit(formRef)" type="primary">
  80. {{ baTable.form.operateIds && baTable.form.operateIds.length > 1 ? '保存并编辑下一项' : '保存' }}
  81. </el-button>
  82. </div>
  83. </template>
  84. </el-dialog>
  85. </template>
  86. <script setup lang="ts">
  87. import { reactive, ref, inject } from 'vue'
  88. import type baTableClass from '/@/utils/baTable'
  89. import FormItem from '/@/components/formItem/index.vue'
  90. import type { ElForm, FormItemRule } from 'element-plus'
  91. import { buildValidatorData } from '/@/utils/validate'
  92. import { getTablePk } from '/@/api/common'
  93. interface Props {
  94. formData: {
  95. tableList?: anyObj
  96. controllerList?: anyObj
  97. entitiesList?:anyObj
  98. }
  99. }
  100. const props = withDefaults(defineProps<Props>(), {
  101. formData: () => {
  102. return {}
  103. },
  104. })
  105. const formRef = ref<InstanceType<typeof ElForm>>()
  106. const baTable = inject('baTable') as baTableClass
  107. const rules: Partial<Record<string, FormItemRule[]>> = reactive({
  108. name: [buildValidatorData('required', '请输入规则名称')],
  109. controllerAs: [buildValidatorData('required','请选择控制器')],
  110. controller: [buildValidatorData('required', '', 'change', '请选择实体类')],
  111. dataTable: [buildValidatorData('required', '', 'change', '请选择数据表')],
  112. primaryKey: [buildValidatorData('required','请输入数据表主键', 'change')],
  113. })
  114. const onTableChange = (val: string) => {
  115. if (!val) return
  116. getTablePk(val).then((res) => {
  117. baTable.form.items!.primaryKey = res.data.pk
  118. baTable.form.defaultItems!.primaryKey = res.data.pk
  119. })
  120. }
  121. </script>
  122. <style scoped lang="scss">
  123. .ba-el-radio {
  124. margin-bottom: 10px;
  125. }
  126. </style>