| ¶Ô±ÈÐÂÎļþ |
| | |
| | | <template> |
| | | <GlobalWindow |
| | | :title="title" |
| | | width="60%" |
| | | :visible.sync="visible" |
| | | :confirm-working="isWorking" |
| | | @confirm="confirm" |
| | | > |
| | | <el-form :model="form" ref="form" :rules="rules"> |
| | | <el-form-item label="å§å" prop="name"> |
| | | <el-input v-model="form.name" placeholder="请è¾å
¥å§å" v-trim/> |
| | | </el-form-item> |
| | | <el-form-item label="æå±ç»ç»" prop="companyId"> |
| | | <el-cascader |
| | | v-model="form.company" |
| | | :options="department" |
| | | @change="handleChangeCompany" |
| | | :show-all-levels="false" |
| | | clearable |
| | | :props="departprops" |
| | | ></el-cascader> |
| | | </el-form-item> |
| | | <el-form-item label="ææºå·" prop="phone"> |
| | | <el-input v-model="form.phone" placeholder="请è¾å
¥ææºå·" v-trim/> |
| | | <div style="color: #F56C6C;font-size: 12px">ï¼æ³¨ï¼åå·¥ææºå·å°ä½ä¸ºå¹³å°ç»å½è´¦å·ï¼åå§å¯ç 为系ç»é»è®¤å¯ç é
置项ï¼</div> |
| | | </el-form-item> |
| | | <el-form-item label="身份è¯å·" prop="idcardNo" v-if="form.id ==null"> |
| | | <el-input v-model="form.idcardNo" placeholder="请è¾å
¥èº«ä»½è¯å·" v-trim/> |
| | | </el-form-item> |
| | | <el-form-item label="ä¿®æ¹èº«ä»½è¯å·" prop="idcardNoNew" v-if="form.id !=null"> |
| | | <el-input v-model="form.idcardNoNew" placeholder="å¯ä¿®æ¹èº«ä»½è¯å·" v-trim/> |
| | | <div style="font-size: 12px" v-if="form.id !=null"> |
| | | ï¼æ³¨ï¼å½å身份è¯å·ä¸º<span style="color: #F56C6C">ã{{form.idcardDecode}}ã</span>ï¼å¦éä¿®æ¹ï¼è¯·å¨è¾å
¥æ å¡«åæ°ç身份è¯å·!ï¼ |
| | | </div> |
| | | </el-form-item> |
| | | <el-form-item label="å·¥å·" prop="code"> |
| | | <el-input v-model="form.code" placeholder="请è¾å
¥å工工å·" v-trim/> |
| | | </el-form-item> |
| | | <el-form-item label="人è¸ç
§ç" prop="faceImgFull" > |
| | | <UploadAvatarImage |
| | | :file="{ 'imgurlfull': form.faceImgFull, 'imgurl': form.faceImg }" |
| | | :uploadData="uploadData" |
| | | @uploadSuccess="uploadAvatarSuccess" |
| | | @uploadEnd="isUploading = false" |
| | | @uploadBegin="isUploading = true" |
| | | /> |
| | | </el-form-item> |
| | | </el-form> |
| | | </GlobalWindow> |
| | | </template> |
| | | |
| | | <script> |
| | | import BaseOpera from '@/components/base/BaseOpera' |
| | | import GlobalWindow from '@/components/common/GlobalWindow' |
| | | import UploadAvatarImage from '@/components/common/UploadAvatarImage' |
| | | import {checkMobile, validIdCardNo, validIdCardNoNew} from '@/utils/form' |
| | | export default { |
| | | name: 'OperaCompanyWindow', |
| | | extends: BaseOpera, |
| | | components: { GlobalWindow, UploadAvatarImage }, |
| | | data () { |
| | | return { |
| | | uploadData: { |
| | | folder: 'member' |
| | | }, |
| | | departprops: { |
| | | label: 'name', |
| | | value: 'id', |
| | | checkStrictly: true |
| | | }, |
| | | department: [], |
| | | // è¡¨åæ°æ® |
| | | form: { |
| | | id: null, |
| | | name: '', |
| | | type: '', |
| | | company: [], |
| | | code: '', |
| | | idcardNo: '', |
| | | idcardNoNew: '', |
| | | linkName: '', |
| | | idcardDecode: '', |
| | | companyId: null, |
| | | idcardType: 0, |
| | | phone: '', |
| | | faceImg: '', |
| | | faceImgFull: '' |
| | | }, |
| | | // éªè¯è§å |
| | | rules: { |
| | | name: [{ required: true, message: '请è¾å
¥åå·¥å§å', trigger: 'blur' }], |
| | | phone: [{ required: true, validator: checkMobile, trigger: 'blur' }], |
| | | companyId: [{ required: true, message: 'è¯·éæ©æå±ç»ç»' }], |
| | | idcardNo: [{ required: true, validator: validIdCardNo, message: '请è¾å
¥èº«ä»½è¯å·', trigger: 'blur' }], |
| | | idcardNoNew: [{ required: false, validator: validIdCardNoNew, trigger: 'blur' }] |
| | | } |
| | | } |
| | | }, |
| | | created () { |
| | | this.config({ |
| | | api: '/business/member.js', |
| | | 'field.id': 'id' |
| | | }) |
| | | }, |
| | | methods: { |
| | | handleChangeCompany (value) { |
| | | if (this.form.company && this.form.company.length > 1) { |
| | | this.form.companyId = this.form.company[this.form.company.length - 1] |
| | | } |
| | | }, |
| | | /** |
| | | * æå¼çªå£ |
| | | * @title çªå£æ é¢ |
| | | * @target ç¼è¾ç对象 |
| | | */ |
| | | open (title, target, depart) { |
| | | this.title = title |
| | | this.department = depart |
| | | this.visible = true |
| | | // æ°å»º |
| | | if (target == null) { |
| | | this.$nextTick(() => { |
| | | this.$refs.form.resetFields() |
| | | this.form[this.configData['field.id']] = null |
| | | this.form.company = [] |
| | | }) |
| | | return |
| | | } |
| | | // ç¼è¾ |
| | | var that = this |
| | | this.$nextTick(() => { |
| | | for (const key in this.form) { |
| | | this.form[key] = target[key] |
| | | this.form.idcardNo = '' |
| | | } |
| | | this.form.company =[] |
| | | if (target.companyId && target.companyPath) { |
| | | var array = target.companyPath.split('/') |
| | | array.forEach(item => { |
| | | if (item && item != null && item != '') { |
| | | that.form.company.push(parseInt(item)) |
| | | } |
| | | }) |
| | | } |
| | | console.log(that.form.company) |
| | | }) |
| | | }, |
| | | // ä¸ä¼ å¾ç |
| | | uploadAvatarSuccess (file) { |
| | | this.form.faceImg = file.imgurl |
| | | this.form.faceImgFull = file.imgurlfull |
| | | } |
| | | } |
| | | } |
| | | </script> |