| <template> | 
|   <GlobalWindow | 
|     :title="title" | 
|     :visible.sync="visible" | 
|     :confirm-working="isWorking" | 
|     @confirm="confirm" | 
|   > | 
|     <el-form :model="form" ref="form" label-suffix=":" :rules="rules"> | 
|       <el-form-item :label="form.cateType==0? '分类编码' : '不良项编码'" prop="code"> | 
|         <el-input v-model="form.code" :disabled="form.id" placeholder="可填写,忽略将自动生成" v-trim/> | 
|       </el-form-item> | 
|       <el-form-item :label="form.cateType==0? '分类名称' : '不良项'" prop="name"> | 
|         <el-input v-model="form.name" placeholder="请输入分类名称" v-trim/> | 
|       </el-form-item> | 
|        | 
|     </el-form> | 
|   </GlobalWindow> | 
| </template> | 
|   | 
| <script> | 
| import BaseOpera from '@/components/base/BaseOpera' | 
| import GlobalWindow from '@/components/common/GlobalWindow' | 
| import { getListByType } from '@/api/ext/categoryExt' | 
| import { validateSpecialKey } from '@/assets/js/validate' | 
| export default { | 
|   name: 'OperaCategoryExtWindow', | 
|   extends: BaseOpera, | 
|   components: { GlobalWindow }, | 
|   data () { | 
|     return { | 
|       // 表单数据 | 
|       form: { | 
|         id: null, | 
|         cateType: 0, | 
|         code: '', | 
|         name: '', | 
|         type: 0 | 
|       }, | 
|       parent: [], | 
|       // isShow: false, | 
|       // 验证规则 | 
|       rules: { | 
|         code: [ | 
|           // { required: true, message: '请输入分类编码', trigger: 'blur' }, | 
|           // { max: 10, message: '输入字数不超过10', trigger: 'change' }, | 
|           { validator: validateSpecialKey, trigger: 'blur' } | 
|         ], | 
|         name: [ | 
|           { max: 10, message: '输入字数不超过10', trigger: 'change' }, | 
|           { required: true, message: '请输入分类名称', trigger: 'blur' } | 
|         ] | 
|       } | 
|     } | 
|   }, | 
|   computed: { | 
|     isShow: { | 
|       get () { | 
|         return this.form.type !== '0' | 
|       } | 
|     } | 
|   }, | 
|   methods: { | 
|     open (title, target, cateType) { | 
|       this.title = title | 
|       this.visible = true | 
|       // 新建 | 
|       if (target == null) { | 
|          | 
|         this.$nextTick(() => { | 
|           this.$refs.form.resetFields() | 
|           this.form[this.configData['field.id']] = null | 
|           this.form.cateType = cateType | 
|         }) | 
|         return | 
|       } | 
|       // 编辑 | 
|       this.$nextTick(() => { | 
|         for (const key in this.form) { | 
|           this.form[key] = target[key] | 
|         } | 
|         this.form.cateType = cateType | 
|         // this.form.cateType = parseInt(this.form.cateType) | 
|         // this.getParent() | 
|       }) | 
|     }, | 
|     changeModel (item) { | 
|       this.getParent() | 
|     }, | 
|     getParent () { | 
|       if (!this.isShow) { | 
|         return | 
|       } | 
|       const qurey = '?cateType=' + this.form.cateType + '&' + 'type=' + (this.form.type - 1) | 
|       getListByType( | 
|         qurey | 
|       ).then(res => { | 
|         // console.log(res) | 
|         this.parent = res | 
|       }).catch(err => { | 
|         console.log(err) | 
|       }) | 
|     } | 
|   }, | 
|   created () { | 
|     this.config({ | 
|       api: '/ext/categoryExt', | 
|       'field.id': 'id' | 
|     }) | 
|   } | 
| } | 
| </script> |