| | |
| | | <template> |
| | | <GlobalWindow :title="title" width="900px" :visible.sync="visible" :confirm-working="isWorking" @confirm="confirm"> |
| | | <GlobalWindow :title="title" width="800px" :visible.sync="visible" :confirm-working="isWorking" @confirm="confirm"> |
| | | <el-form :model="form" ref="form" :rules="rules"> |
| | | <div class="list"> |
| | | <div class="title">基础信息</div> |
| | | <el-form-item label="客户" prop="name"> |
| | | <el-form-item label="客户名称" prop="name"> |
| | | <div class="df"> |
| | | <el-input v-model="form.name" placeholder="请输入客户" v-trim /> |
| | | <el-checkbox v-model="form.type" class="ml10" true-label="0" false-label="1">个人</el-checkbox> |
| | | <el-checkbox v-model="form.type" class="ml10" :true-label="0" :false-label="1">个人</el-checkbox> |
| | | </div> |
| | | </el-form-item> |
| | | <el-form-item label="行业分类" prop="industryId"> |
| | | <el-select v-model="form.industryId" clearable filterable> |
| | | <el-option v-for="item in cateList" :value="item.id" :label="item.name" /> |
| | | <div key="21" class="df_center mt10"><el-button type="primary" plain class="w200" |
| | | @click="openTrade">添加</el-button> |
| | | </div> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="客户编号" prop="code"> |
| | | <el-input v-model="form.code" placeholder="请输入" v-trim /> |
| | | </el-form-item> |
| | | <div class="title">默认联系人</div> |
| | | <el-form-item label="姓名" prop="member.name"> |
| | | <el-input v-model="form.member.name" placeholder="请输入" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="手机号" prop="member.phone"> |
| | | <el-input v-model="form.member.phone" placeholder="请输入手机号" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="身份"> |
| | | <el-select v-model="form.member.highCheckor" filterable> |
| | | <el-option :value="0" label="老板/超级管理员" /> |
| | | <el-option :value="1" label="人事/管理员" /> |
| | | <el-option :value="2" label="员工/普通员工" /> |
| | | <template v-if="!form.id"> |
| | | <div class="title">默认联系人</div> |
| | | <el-form-item label="姓名" prop="member.name"> |
| | | <el-input v-model="form.member.name" placeholder="请输入" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="手机号" prop="member.phone"> |
| | | <el-input v-model="form.member.phone" placeholder="请输入手机号" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="身份"> |
| | | <el-select v-model="form.member.highCheckor" filterable> |
| | | <el-option :value="0" label="老板/超级管理员" /> |
| | | <el-option :value="1" label="人事/管理员" /> |
| | | <el-option :value="2" label="员工/普通员工" /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="证件类型"> |
| | | <el-select v-model="form.member.idcardType" filterable> |
| | | <el-option :value="0" label="身份证" /> |
| | | <el-option :value="1" label="港澳证件" /> |
| | | <el-option :value="2" label="护照" /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="证件号码" prop="member.idcardNo"> |
| | | <el-input v-model="form.member.idcardNo" placeholder="请输入" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="邮箱" prop="member.email" :rules="[ |
| | | { required: false, type: 'email', message: '请输入正确的邮箱格式'} |
| | | ]"> |
| | | <el-input v-model="form.member.email" placeholder="请输入邮箱" v-trim /> |
| | | </el-form-item> |
| | | </template> |
| | | <el-form-item v-else label="默认联系人" prop="memberId"> |
| | | <el-select v-model="form.memberId" clearable filterable> |
| | | <el-option v-for="item in clientList" :value="item.id" :label="item.name" /> |
| | | <div key="11" class="df_center mt10"><el-button type="primary" plain class="w200" |
| | | @click="openClient">添加</el-button> |
| | | </div> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="证件类型"> |
| | | <el-select v-model="form.member.idcardType" filterable> |
| | | <el-option :value="0" label="身份证" /> |
| | | <el-option :value="1" label="港澳证件" /> |
| | | <el-option :value="2" label="护照" /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="证件号码" prop="member.idcardNo"> |
| | | <el-input v-model="form.member.idcardNo" placeholder="请输入" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="邮箱" prop="email"> |
| | | <el-input v-model="form.member.email" placeholder="请输入邮箱" v-trim /> |
| | | </el-form-item> |
| | | |
| | | <div class="title">账户信息</div> |
| | | <el-form-item label="开户银行" prop="accountBank"> |
| | | <el-input v-model="form.accountBank" placeholder="请输入开户银行" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="账号" prop="accountNo"> |
| | | <el-input v-model="form.accountNo" placeholder="请输入账号" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="电话" prop="accountPhone"> |
| | | <el-input v-model="form.accountPhone" placeholder="请输入账户电话" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="统一信用代码" prop="creditCard"> |
| | | <el-input v-model="form.creditCard" placeholder="请输入统一信用代码" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="默认发票类型" prop="fpType"> |
| | | <el-select v-model="form.fpType" clearable filterable> |
| | | <el-option :value="0" label="增值税普通发票" /> |
| | | <el-option :value="1" label="增值税专用发票" /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="注册地址" prop="accountAddr"> |
| | | <el-input v-model="form.accountAddr" placeholder="请输入账号注册地址" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="营业期限"> |
| | | <div class="df"> |
| | | <el-date-picker type="date" v-model="form.validity" value-format="yyyy-MM-dd" placeholder="请选择" /> |
| | | <el-checkbox v-model="form.selLangTime" @change="changeValid" class="ml10">长期</el-checkbox> |
| | | </div> |
| | | </el-form-item> |
| | | <template v-if="form.type == 1"> |
| | | <div class="title">账户信息</div> |
| | | <el-form-item label="开户银行" prop="accountBank"> |
| | | <el-input v-model="form.accountBank" placeholder="请输入开户银行" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="账号" prop="accountNo"> |
| | | <el-input v-model="form.accountNo" placeholder="请输入账号" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="电话" prop="accountPhone"> |
| | | <el-input v-model="form.accountPhone" placeholder="请输入账户电话" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="统一信用代码" prop="creditCard"> |
| | | <el-input v-model="form.creditCard" placeholder="请输入统一信用代码" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="默认发票类型" prop="fpType"> |
| | | <el-select v-model="form.fpType" clearable filterable> |
| | | <el-option :value="0" label="增值税普通发票" /> |
| | | <el-option :value="1" label="增值税专用发票" /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="注册地址" prop="accountAddr"> |
| | | <el-input v-model="form.accountAddr" placeholder="请输入账号注册地址" v-trim /> |
| | | </el-form-item> |
| | | <el-form-item label="营业期限"> |
| | | <div class="df"> |
| | | <el-date-picker type="date" v-model="form.validity" value-format="yyyy-MM-dd" placeholder="请选择" /> |
| | | <el-checkbox v-model="form.selLangTime" @change="changeValid" class="ml10">长期</el-checkbox> |
| | | </div> |
| | | </el-form-item> |
| | | </template> |
| | | |
| | | </div> |
| | | </el-form> |
| | | <!-- --> |
| | | <OperaCategoryWindow ref="OperaCategoryWindowRef" @success="initData" /> |
| | | <StaffEdit ref="StaffEditRef" @success="getClient" /> |
| | | </GlobalWindow> |
| | | </template> |
| | | |
| | |
| | | import { fetchCateList } from '@/api/business/category' |
| | | import { rules } from './config' |
| | | import { detailById } from '@/api/client/ywCustomer' |
| | | import { fetchList } from '@/api/client/staff' |
| | | import OperaCategoryWindow from './OperaCategoryWindow.vue' |
| | | import StaffEdit from './staffEdit.vue' |
| | | export default { |
| | | name: 'OperaYwCustomerWindow', |
| | | extends: BaseOpera, |
| | | components: { GlobalWindow }, |
| | | components: { GlobalWindow, OperaCategoryWindow, StaffEdit }, |
| | | data() { |
| | | return { |
| | | // 表单数据 |
| | |
| | | isdeleted: '', |
| | | remark: '', |
| | | industryId: '', |
| | | type: '1', |
| | | type: 1, |
| | | name: '', |
| | | phone: '', |
| | | idcardNo: '', |
| | |
| | | code: '', |
| | | status: '', |
| | | memberName: '', |
| | | |
| | | |
| | | lastLoginDate: '', |
| | | loginNum: '', |
| | | userId: '', |
| | | |
| | | memberId: '', |
| | | |
| | | accountBank: '', |
| | | accountNo: '', |
| | | accountPhone: '', |
| | |
| | | accountAddr: '', |
| | | // identityType: '0', |
| | | email: '', |
| | | memberId: '', |
| | | member: { |
| | | name: "", |
| | | phone: "", |
| | |
| | | email: '', |
| | | } |
| | | }, |
| | | title: '新增客户', |
| | | isShowTrade: false, |
| | | |
| | | clientList: [], |
| | | cateList: [], |
| | | // 验证规则 |
| | | rules |
| | |
| | | }) |
| | | }, |
| | | methods: { |
| | | openTrade() { |
| | | this.$refs.OperaCategoryWindowRef.open('新增行业') |
| | | }, |
| | | openClient() { |
| | | this.$refs.StaffEditRef.open('新建人员') |
| | | setTimeout(() => { |
| | | this.$refs.StaffEditRef.form.customerId = this.form.id |
| | | console.log('--', this.$refs.StaffEditRef.form); |
| | | |
| | | // this.$update |
| | | }, 1200) |
| | | this.$refs.StaffEditRef.customerId = this.form.id |
| | | }, |
| | | initData() { |
| | | fetchCateList({ type: 6 }).then(res => { |
| | | this.cateList = res |
| | | }) |
| | | }, |
| | | open (title, target) { |
| | | open(title, target) { |
| | | this.title = title |
| | | this.visible = true |
| | | this.initData() |
| | |
| | | if (target == null) { |
| | | this.$nextTick(() => { |
| | | this.$refs.form.resetFields() |
| | | this.form.validity = '' |
| | | this.form.id = '' |
| | | this.form.member = { |
| | | name: "", |
| | | phone: "", |
| | | highCheckor: 0, |
| | | idcardType: 0, |
| | | idcardNo: '', |
| | | email: '', |
| | | } |
| | | }) |
| | | this.form.type = 1 |
| | | return |
| | | } |
| | | // 编辑 |
| | | this.$nextTick(() => { |
| | | if(title == '编辑客户'){ |
| | | if (title == '编辑客户') { |
| | | this.getClient(target.id) |
| | | detailById(target.id).then(res => { |
| | | this.form = res |
| | | }) |
| | | } |
| | | }) |
| | | }, |
| | | getClient(customerId) { |
| | | fetchList({ |
| | | capacity: 9999, |
| | | page: 1, |
| | | model: {customerId} |
| | | }).then(res => { |
| | | this.clientList = res.records |
| | | }) |
| | | }, |
| | | changeValid(e) { |
| | |
| | | } |
| | | } |
| | | } |
| | | </style> |
| | | </style> |