classifyDia.vue 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. <template>
  2. <div class="predict-classify-dialog">
  3. <el-dialog
  4. :visible.sync="isOpenDialog"
  5. :close-on-click-modal="false"
  6. :modal-append-to-body='false'
  7. :title="title"
  8. @close="cancelHandle"
  9. custom-class="dialog"
  10. center
  11. width="560px"
  12. v-dialogDrag>
  13. <div class="dialog-main">
  14. <el-form
  15. ref="diaForm"
  16. label-position="left"
  17. hide-required-asterisk
  18. label-width="80px"
  19. :model="formData"
  20. :rules="formRules">
  21. <!-- 添加一级目录的子分类/编辑二级目录时显示 -->
  22. <template v-if="(title=='添加'&&formData.Level >= 1)||(title=='编辑'&&formData.Level >= 2)">
  23. <el-form-item label="一级目录" prop="level_1_Name">
  24. <span>{{formData.level_1_Name}}</span>
  25. </el-form-item>
  26. </template>
  27. <!-- 添加二级目录的子分类/编辑三级目录时显示 -->
  28. <template v-if="(title=='添加'&&formData.Level === 2)||(title=='编辑'&&formData.Level === 3)">
  29. <el-form-item label="二级目录" prop="level_2_Name">
  30. <span>{{formData.level_2_Name}}</span>
  31. </el-form-item>
  32. </template>
  33. <el-form-item label="目录名称" prop="classify_name">
  34. <el-input
  35. v-model="formData.classify_name"
  36. style="width: 80%"
  37. placeholder="必填项"></el-input>
  38. </el-form-item>
  39. </el-form>
  40. </div>
  41. <div class="dia-bot">
  42. <el-button type="primary" style="margin-right:20px" @click="saveHandle">保存</el-button>
  43. <el-button type="primary" plain @click="cancelHandle">取消</el-button>
  44. </div>
  45. </el-dialog>
  46. </div>
  47. </template>
  48. <script>
  49. import * as preDictEdbInterface from '@/api/modules/predictEdbApi.js';
  50. export default {
  51. props: {
  52. isOpenDialog: {
  53. type: Boolean,
  54. },
  55. //标题
  56. title: {
  57. type: String,
  58. default: '添加'
  59. },
  60. form: {
  61. type: Object,
  62. }
  63. },
  64. watch: {
  65. 'isOpenDialog': {
  66. handler(newval) {
  67. if(newval) {
  68. this.formData = {...this.form};
  69. }
  70. }
  71. }
  72. },
  73. data () {
  74. return {
  75. formData: {},
  76. formRules: {
  77. classify_name:[
  78. { required: true, message: '目录名称不能为空', trigger: 'blur' },
  79. ]
  80. },
  81. };
  82. },
  83. methods: {
  84. async saveHandle() {
  85. await this.$refs.diaForm.validate()
  86. const { classify_name,classify_id,Level,ParentId} = this.formData;
  87. const { Ret,Msg } = this.title==='添加'
  88. ? await preDictEdbInterface.classifyAdd({ ClassifyName:classify_name,ParentId,Level})
  89. : await preDictEdbInterface.classifyEdit({ ClassifyName:classify_name, ClassifyId:classify_id })
  90. if( Ret !== 200) return
  91. this.$message.success(Msg);
  92. this.cancelHandle();
  93. this.$emit('successCallback')
  94. },
  95. /* 取消 */
  96. cancelHandle() {
  97. this.formData = {}
  98. this.$refs.diaForm.resetFields();
  99. this.$emit('update:isOpenDialog',false)
  100. },
  101. },
  102. created() {},
  103. mounted() {},
  104. }
  105. </script>
  106. <style lang='scss'>
  107. .predict-classify-dialog {
  108. .dialog-main {
  109. padding-left: 50px;
  110. }
  111. .el-cascader .el-input {
  112. width: 100%;
  113. }
  114. .dia-bot {
  115. margin: 52px 0 30px;
  116. display: flex;
  117. justify-content: center;
  118. }
  119. }
  120. </style>