| | |
| | | </el-select> |
| | | </div> |
| | | </el-form-item> |
| | | <el-form-item label="保险费用" prop="price"> |
| | | <el-form-item label="方案费用" prop="price"> |
| | | <div style="display: flex; align-items: center;"> |
| | | <el-input v-model="form.price" style="flex: 1;" placeholder="请输入" v-trim/> |
| | | <span style="margin: 0 30px;">元/人</span> |
| | | <el-select v-model="form.timeUnit" style="flex: 1;" placeholder="请选择"> |
| | | <el-select v-model="form.timeUnit" style="flex: 1;" placeholder="请选择周期单位" @change="changeTimeUnit"> |
| | | <el-option label="天" :value="0"></el-option> |
| | | <!-- <el-option label="半月" :value="1"></el-option>--> |
| | | <el-option label="月" :value="2"></el-option> |
| | | <el-option label="年" :value="3"></el-option> |
| | | <el-option label="月" :value="2"></el-option> |
| | | <el-option label="季度" :value="3"></el-option> |
| | | <el-option label="半年" :value="4"></el-option> |
| | | <el-option label="年" :value="5"></el-option> |
| | | </el-select> |
| | | </div> |
| | | </el-form-item> |
| | | <el-form-item label="投保周期" prop="insureCycle"> |
| | | <el-form-item label="批改计费规则" prop="insureCycleUnit"> |
| | | <div style="display: flex; align-items: center;"> |
| | | <el-input v-model="form.insureCycle" style="flex: 1;" placeholder="请输入" v-trim/> |
| | | <span style="margin: 0 30px;"></span> |
| | | <el-select v-model="form.insureCycleUnit" style="flex: 1;" placeholder="请选择"> |
| | | <el-option label="天" :value="0"></el-option> |
| | | <!-- <el-option label="半月" :value="1"></el-option>--> |
| | | <el-option label="月" :value="2"></el-option> |
| | | <el-option label="年" :value="3"></el-option> |
| | | <el-option label="天" :value="0"></el-option> |
| | | <el-option v-if="form.timeUnit>=1" label="半月" :value="1"></el-option> |
| | | <el-option v-if="form.timeUnit>=2" label="月" :value="2"></el-option> |
| | | <el-option v-if="form.timeUnit>=3" label="季度" :value="3"></el-option> |
| | | <el-option v-if="form.timeUnit>=4" label="半年" :value="4"></el-option> |
| | | <el-option v-if="form.timeUnit>=5" label="年" :value="5"></el-option> |
| | | </el-select> |
| | | </div> |
| | | </el-form-item> |
| | |
| | | <el-radio :label="1">次月生效</el-radio> |
| | | </el-radio-group> |
| | | </div> |
| | | <el-input style="margin-left: 20px;" type="number" v-model="form.validTypeNum" placeholder="请输入延迟天数" v-if="form.validType === 0"></el-input> |
| | | <el-input style="margin-left: 20px;" type="number" v-model="form.validTypeNum" placeholder="请输入延迟天数" v-if="form.validType === 0"></el-input> |
| | | </div> |
| | | </el-form-item> |
| | | <el-form-item label="批改支持" > |
| | | <div style="width: 100%; display: flex; align-items: center;"> |
| | | <el-checkbox :true-label="1" :false-label="0" v-model="form.canAdd">加保</el-checkbox> |
| | | <el-checkbox :true-label="1" :false-label="0" v-model="form.canReduce">减保</el-checkbox> |
| | | <el-checkbox :true-label="1" :false-label="0" v-model="form.canChangeUnit">更换派遣单位</el-checkbox> |
| | | </div> |
| | | </el-form-item> |
| | | <el-form-item label="批减只支持替换(减保批改仅支持替换人员,即减保人员不少于加保人员数量)" prop="delOnlyReplace" v-if="form.insureCycleUnit===0 || (form.insureCycleUnit===form.timeUnit)"> |
| | | <div style="width: 100%; display: flex; align-items: center;"> |
| | | <el-radio-group v-model="form.delOnlyReplace"> |
| | | <el-radio :label="1">是</el-radio> |
| | | <el-radio :label="0">否</el-radio> |
| | | </el-radio-group> |
| | | </div> |
| | | </el-form-item> |
| | | <el-form-item label="批增生效(天数)" prop="addValidDays" v-if="form.delOnlyReplace != 1"> |
| | | <div style="width: 100%; display: flex; align-items: center;"> |
| | | <el-input style="margin-left: 0px;" type="number" v-model="form.addValidDays" placeholder="请输入批增生效时间(天数)" ></el-input> |
| | | </div> |
| | | </el-form-item> |
| | | <el-form-item label="批减生效(天数)" prop="delValidDays"> |
| | | <div style="width: 100%; display: flex; align-items: center;"> |
| | | <el-input style="margin-left: 0px;" type="number" v-model="form.delValidDays" placeholder="请输入批减生效时间(天数)" ></el-input> |
| | | </div> |
| | | </el-form-item> |
| | | <el-form-item label="投保类型" prop="type"> |
| | | <el-radio-group v-model="form.type"> |
| | | <el-radio :label="0">直保</el-radio> |
| | | <el-radio-group v-model="form.type" :disabled="form.id!=null"> |
| | | <el-radio :label="0" >直保</el-radio> |
| | | <el-radio :label="1">委托投保</el-radio> |
| | | </el-radio-group> |
| | | </el-form-item> |
| | | <el-form-item label="委托商户" prop="shopId" v-if="form.type =='1'" :rules="form.type===1?[{required:true,message:'请选择商户'}]:[{required:false}]"> |
| | | <el-select v-model="form.shopId" placeholder="请选择委托商户"> |
| | | <el-option |
| | | v-for="item in shops" |
| | | :key="item.id" |
| | | :label="item.name" |
| | | :value="item.id"> |
| | | </el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="上传方案确认书:" prop="fanganFile" v-if="form.type =='1'" :rules="form.type===1?[{required:true,message:'请上传方案确认书'}]:[{required:false}]"> |
| | | <UploadFile @remove="deleFile" :uploadData="{ folder: 'apply',fileType:'.pdf' }" :fileList="form.fileList1" @uploadSuccess="editFanganFile" /> |
| | | </el-form-item> |
| | | <el-form-item label="接收文件邮箱" prop="email"> |
| | | <el-input v-model="form.email" placeholder="请输入" v-trim/> |
| | | </el-form-item> |
| | |
| | | </el-table-column> |
| | | </el-table> |
| | | <el-form-item label="特别约定" prop="specialAgreement"> |
| | | <el-input type="textarea" v-model="form.specialAgreement" placeholder="请输入特别约定" v-trim/> |
| | | <RichEditor :richData="form.specialAgreement" :styleEditor="'border: 1px solid #ccc;display: inline-block;'" @getWangedditor="getWangedditor" :readonly="false"/> |
| | | </el-form-item> |
| | | <el-form-item label="特别说明" prop="specialInfo"> |
| | | <el-input type="textarea" v-model="form.specialInfo" placeholder="请输入特别说明" v-trim/> |
| | | <RichEditor :richData="form.specialInfo" :styleEditor="'border: 1px solid #ccc;display: inline-block;'" @getWangedditor="getWangedditor1" :readonly="false"/> |
| | | </el-form-item> |
| | | <el-form-item label="其他说明" prop="ortherInfo"> |
| | | <el-input type="textarea" v-model="form.ortherInfo" placeholder="请输入其他说明" v-trim/> |
| | | <el-form-item label="其他说明" prop="ortherInfo"> |
| | | <RichEditor :richData="form.ortherInfo" :styleEditor="'border: 1px solid #ccc;display: inline-block;'" @getWangedditor="getWangedditor2" :readonly="false"/> |
| | | </el-form-item> |
| | | </el-form> |
| | | </GlobalWindow> |
| | | </template> |
| | | |
| | | <script> |
| | | import BaseOpera from '@/components/base/BaseOpera' |
| | | import GlobalWindow from '@/components/common/GlobalWindow' |
| | | import { all } from '@/api/business/insurance' |
| | | import { all as allWorktype } from '@/api/business/worktype' |
| | | import { solutionsId } from '@/api/business/solutions' |
| | | export default { |
| | | name: 'OperaSolutionsWindow', |
| | | extends: BaseOpera, |
| | | components: { GlobalWindow }, |
| | | data () { |
| | | var validType = (rule, value, callback) => { |
| | | if (this.form.validType === 0 && !value) { |
| | | return callback(new Error('延迟天数不能为空')); |
| | | } else if (this.form.validType === 0 && !/^[0-9]*[1-9][0-9]*$/.test(value)) { |
| | | return callback(new Error('延迟天数只能为正整数')); |
| | | } |
| | | callback(); |
| | | } |
| | | return { |
| | | // 表单数据 |
| | | form: { |
| | | id: null, |
| | | name: '', |
| | | companyName: '', |
| | | insuranceId: '', |
| | | validType: 0, |
| | | type: 0, |
| | | minAge: '', |
| | | maxAge: '', |
| | | price: '', |
| | | timeUnit: '', |
| | | insureCycle: '', |
| | | insureCycleUnit: '', |
| | | email: '', |
| | | specialAgreement: '', |
| | | specialInfo: '', |
| | | ortherInfo: '', |
| | | signKeyword: '', |
| | | validTypeNum: '', |
| | | worktypeIdList: [{ worktypeId: '' }] |
| | | }, |
| | | // 验证规则 |
| | | rules: { |
| | | name: [ |
| | | { required: true, message: '请输入方案名称' } |
| | | ], |
| | | insuranceId: [ |
| | | { required: true, message: '请选择保险公司' } |
| | | ], |
| | | companyName: [ |
| | | { required: true, message: '请输入承保公司' } |
| | | ], |
| | | minAge: [ |
| | | { required: true, message: '请选择投保年龄' } |
| | | ], |
| | | price: [ |
| | | { required: true, message: '请输入保险费用' } |
| | | ], |
| | | insureCycle: [ |
| | | { required: true, message: '请输入投保周期' } |
| | | ], |
| | | validTypeNum: [ |
| | | { required: true, validator: validType } |
| | | ], |
| | | type: [ |
| | | { required: true, message: '请选择投保类型' } |
| | | ], |
| | | // signKeyword: [ |
| | | // { required: false, message: '请输入投保单签章关键字' } |
| | | // ] |
| | | }, |
| | | company: [], |
| | | typeWork: [] |
| | | } |
| | | }, |
| | | created () { |
| | | this.config({ |
| | | api: '/business/solutions', |
| | | 'field.id': 'id' |
| | | }) |
| | | }, |
| | | methods: { |
| | | // 切换公司 |
| | | getAllWorktype1() { |
| | | this.form.worktypeIdList = [{ worktypeId: '' }] |
| | | this.getAllWorktype() |
| | | }, |
| | | // 确认新建/修改 |
| | | confirm () { |
| | | let data = JSON.parse(JSON.stringify(this.form)) |
| | | data.worktypeIdList = data.worktypeIdList.map(item => item.worktypeId) |
| | | this.$refs.form.validate((valid) => { |
| | | if (!valid) { |
| | | return |
| | | } |
| | | // 调用新建接口 |
| | | this.isWorking = true |
| | | if (data.id == null || data.id === '') { |
| | | this.api.create(data) |
| | | .then(() => { |
| | | this.visible = false |
| | | this.$tip.apiSuccess('新建成功') |
| | | this.$emit('success') |
| | | }) |
| | | .catch(e => { |
| | | this.$tip.apiFailed(e) |
| | | }) |
| | | .finally(() => { |
| | | this.isWorking = false |
| | | }) |
| | | } else { |
| | | this.api.updateById(data) |
| | | .then(() => { |
| | | this.visible = false |
| | | this.$tip.apiSuccess('修改成功') |
| | | this.$emit('success') |
| | | }) |
| | | .catch(e => { |
| | | this.$tip.apiFailed(e) |
| | | }) |
| | | .finally(() => { |
| | | this.isWorking = false |
| | | }) |
| | | } |
| | | }) |
| | | }, |
| | | open (title, target) { |
| | | this.title = title |
| | | this.form.maxAge = '' |
| | | this.form.timeUnit = '' |
| | | this.form.insureCycleUnit = '' |
| | | this.form.validTypeNum = '' |
| | | this.visible = true |
| | | this.form.worktypeIdList = [{ worktypeId: '' }] |
| | | this.allCompany() |
| | | // 新建 |
| | | if (target == null) { |
| | | this.$nextTick(() => { |
| | | this.$refs.form.resetFields() |
| | | this.form[this.configData['field.id']] = null |
| | | }) |
| | | return |
| | | } |
| | | // 编辑 |
| | | this.$nextTick(() => { |
| | | solutionsId(target.id) |
| | | .then(res => { |
| | | for (const key in this.form) { |
| | | this.form[key] = res[key] |
| | | } |
| | | this.form.worktypeIdList = res.worktypeList.map(item => { |
| | | return { |
| | | worktypeId: item.worktypeId |
| | | } |
| | | }) |
| | | this.getAllWorktype() |
| | | }) |
| | | }) |
| | | }, |
| | | // 查询保险公司下全部工种 |
| | | getAllWorktype() { |
| | | allWorktype({ |
| | | insuranceId: this.form.insuranceId |
| | | }).then(res => { |
| | | this.typeWork = res |
| | | }) |
| | | }, |
| | | // 查询全部保险公司 |
| | | allCompany() { |
| | | all({ dataType: 2, status: 0 }) |
| | | .then(res => { |
| | | console.log(res) |
| | | this.company = res |
| | | }) |
| | | }, |
| | | add() { |
| | | this.form.worktypeIdList.push({ worktypeId: '' }) |
| | | }, |
| | | dele(index) { |
| | | if (this.form.worktypeIdList.length === 1) { |
| | | this.$message.warning('至少要保留一项') |
| | | return |
| | | } |
| | | this.form.worktypeIdList.splice(index, 1) |
| | | } |
| | | } |
| | | import BaseOpera from '@/components/base/BaseOpera' |
| | | import GlobalWindow from '@/components/common/GlobalWindow' |
| | | import { all } from '@/api/business/insurance' |
| | | import { all as allWorktype } from '@/api/business/worktype' |
| | | import { solutionsId } from '@/api/business/solutions' |
| | | import { pageAll as shopList } from '@/api/business/company' |
| | | import UploadFile from '@/components/common/UploadFile' |
| | | import { checkMobile, numRule } from '@/utils/form' |
| | | import RichEditor from '@/components/common/RichEditor' |
| | | export default { |
| | | name: 'OperaSolutionsWindow', |
| | | extends: BaseOpera, |
| | | components: { GlobalWindow, UploadFile, RichEditor }, |
| | | data () { |
| | | var validType = (rule, value, callback) => { |
| | | if (this.form.validType === 0 && !value) { |
| | | return callback(new Error('延迟天数不能为空')) |
| | | } else if (this.form.validType === 0 && !/^[0-9]*[1-9][0-9]*$/.test(value)) { |
| | | return callback(new Error('延迟天数只能为正整数')) |
| | | } |
| | | callback() |
| | | } |
| | | return { |
| | | // 表单数据 |
| | | form: { |
| | | id: null, |
| | | name: '', |
| | | companyName: '', |
| | | insuranceId: '', |
| | | validType: 0, |
| | | type: 0, |
| | | minAge: '', |
| | | maxAge: '', |
| | | price: '', |
| | | timeUnit: '', |
| | | shopId: null, |
| | | insureCycle: '', |
| | | insureCycleUnit: '', |
| | | email: '', |
| | | specialAgreement: '', |
| | | specialInfo: '', |
| | | ortherInfo: '', |
| | | signKeyword: '', |
| | | validTypeNum: '', |
| | | canReduce: 0, |
| | | canChangeUnit: 0, |
| | | addValidDays: 0, |
| | | delValidDays: 0, |
| | | delOnlyReplace: 0, |
| | | canAdd: 0, |
| | | fileList1: [], |
| | | fanganFile: null, |
| | | worktypeIdList: [{ worktypeId: '' }] |
| | | }, |
| | | // 验证规则 |
| | | rules: { |
| | | name: [ |
| | | { required: true, message: '请输入方案名称' } |
| | | ], |
| | | delOnlyReplace: [ |
| | | { required: true, message: '请选择' } |
| | | ], |
| | | addValidDays: [ |
| | | { validator: numRule } |
| | | ], |
| | | delValidDays: [ |
| | | { validator: numRule } |
| | | ], |
| | | insuranceId: [ |
| | | { required: true, message: '请选择保险公司' } |
| | | ], |
| | | companyName: [ |
| | | { required: true, message: '请输入承保公司' } |
| | | ], |
| | | minAge: [ |
| | | { required: true, message: '请选择投保年龄' } |
| | | ], |
| | | price: [ |
| | | { required: true, message: '请输入方案费用' } |
| | | ], |
| | | insureCycleUnit: [ |
| | | { required: true, message: '请输入批改计费单位' } |
| | | ], |
| | | validTypeNum: [ |
| | | { required: true, validator: validType } |
| | | ], |
| | | type: [ |
| | | { required: true, message: '请选择投保类型' } |
| | | ] |
| | | // signKeyword: [ |
| | | // { required: false, message: '请输入投保单签章关键字' } |
| | | // ] |
| | | }, |
| | | shops: [], |
| | | company: [], |
| | | typeWork: [] |
| | | } |
| | | }, |
| | | created () { |
| | | this.config({ |
| | | api: '/business/solutions', |
| | | 'field.id': 'id' |
| | | }) |
| | | }, |
| | | methods: { |
| | | getWangedditor(val){ |
| | | this.form.specialAgreement = val; |
| | | }, |
| | | getWangedditor1(val){ |
| | | this.form.specialInfo = val; |
| | | }, |
| | | getWangedditor2(val){ |
| | | this.form.ortherInfo = val; |
| | | }, |
| | | |
| | | handNumberInput (value) { |
| | | const regex = /^[-+]?\d*$/ |
| | | if (!regex.test(value)) { |
| | | // 如果输入的不是整数,则设置为上一个有效的整数值 |
| | | this.form.addValidDays = value.replace(/[^0-9]/g, '') |
| | | this.form.addValidDays = value.replace(/[^0-9]/g, '') |
| | | this.form.delValidDays = value.replace(/[^0-9]/g, '') |
| | | } |
| | | }, |
| | | changeTimeUnit () { |
| | | if (this.form.timeUnit < this.form.insureCycleUnit) { |
| | | this.form.insureCycleUnit = null |
| | | } |
| | | }, |
| | | editFanganFile (data) { |
| | | this.form.fanganFile = data |
| | | }, |
| | | // 切换公司 |
| | | getAllWorktype1 () { |
| | | this.form.worktypeIdList = [{ worktypeId: '' }] |
| | | this.getAllWorktype() |
| | | }, |
| | | // 确认新建/修改 |
| | | confirm () { |
| | | const data = JSON.parse(JSON.stringify(this.form)) |
| | | data.worktypeIdList = data.worktypeIdList.map(item => item.worktypeId) |
| | | this.$refs.form.validate((valid) => { |
| | | if (!valid) { |
| | | return |
| | | } |
| | | if (data.type === 1 && (!data.fanganFile || !data.fanganFile.fileurl)) { |
| | | this.$message.error('请上传方案确认书!') |
| | | return |
| | | } |
| | | // 调用新建接口 |
| | | this.isWorking = true |
| | | if (data.id == null || data.id === '') { |
| | | this.api.create(data) |
| | | .then(() => { |
| | | this.visible = false |
| | | this.$tip.apiSuccess('新建成功') |
| | | this.$emit('success') |
| | | }) |
| | | .catch(e => { |
| | | this.$tip.apiFailed(e) |
| | | }) |
| | | .finally(() => { |
| | | this.isWorking = false |
| | | }) |
| | | } else { |
| | | this.api.updateById(data) |
| | | .then(() => { |
| | | this.visible = false |
| | | this.$tip.apiSuccess('修改成功') |
| | | this.$emit('success') |
| | | }) |
| | | .catch(e => { |
| | | this.$tip.apiFailed(e) |
| | | }) |
| | | .finally(() => { |
| | | this.isWorking = false |
| | | }) |
| | | } |
| | | }) |
| | | }, |
| | | deleFile () { |
| | | this.form.fanganFile = {} |
| | | }, |
| | | open (title, target) { |
| | | this.title = title |
| | | this.visible = true |
| | | this.form.maxAge = '' |
| | | this.form.timeUnit = '' |
| | | this.form.insureCycleUnit = '' |
| | | this.form.validTypeNum = '' |
| | | this.form.fanganFile = null |
| | | this.form.canReduce = 0 |
| | | this.form.canChangeUnit = 0 |
| | | this.form.addValidDays = 0 |
| | | this.form.delOnlyReplace = 0 |
| | | this.form.delValidDays = 0 |
| | | this.form.canAdd = 0 |
| | | this.form.fileList1 = [] |
| | | this.form.worktypeIdList = [{ worktypeId: '' }] |
| | | // this.$refs['$upload'].clearFiles()//初始化导入组件 |
| | | this.allCompany() |
| | | this.allShops() |
| | | // 新建 |
| | | if (target == null) { |
| | | this.$nextTick(() => { |
| | | this.$refs.form.resetFields() |
| | | this.form.maxAge = '' |
| | | this.form.timeUnit = '' |
| | | this.form.insureCycleUnit = '' |
| | | this.form.validTypeNum = '' |
| | | this.form.fanganFile = null |
| | | this.form.fileList1 = [] |
| | | this.form.worktypeIdList = [{ worktypeId: '' }] |
| | | this.form[this.configData['field.id']] = null |
| | | }) |
| | | return |
| | | } |
| | | // 编辑 |
| | | this.$nextTick(() => { |
| | | solutionsId(target.id) |
| | | .then(res => { |
| | | for (const key in this.form) { |
| | | this.form[key] = res[key] |
| | | } |
| | | if (this.form.fanganFile && this.form.fanganFile.fileurl) { |
| | | this.form.fileList1 = [{ url: this.form.fanganFile.fileurlFull, name: this.form.fanganFile.name }] |
| | | } |
| | | console.log(this.form.fileList1) |
| | | this.form.worktypeIdList = res.worktypeList.map(item => { |
| | | return { |
| | | worktypeId: item.worktypeId |
| | | } |
| | | }) |
| | | this.getAllWorktype() |
| | | }) |
| | | }) |
| | | }, |
| | | // 查询保险公司下全部工种 |
| | | getAllWorktype () { |
| | | allWorktype({ |
| | | insuranceId: this.form.insuranceId |
| | | }).then(res => { |
| | | this.typeWork = res |
| | | }) |
| | | }, |
| | | |
| | | // 查询全部保险公司 |
| | | allCompany () { |
| | | all({ dataType: 2, status: 0 }) |
| | | .then(res => { |
| | | console.log(res) |
| | | this.company = res |
| | | }) |
| | | }, |
| | | allShops () { |
| | | shopList({ type: 1, status: 0 }) |
| | | .then(res => { |
| | | console.log(res) |
| | | this.shops = res |
| | | }) |
| | | }, |
| | | add () { |
| | | this.form.worktypeIdList.push({ worktypeId: '' }) |
| | | }, |
| | | dele (index) { |
| | | if (this.form.worktypeIdList.length === 1) { |
| | | this.$message.warning('至少要保留一项') |
| | | return |
| | | } |
| | | this.form.worktypeIdList.splice(index, 1) |
| | | } |
| | | } |
| | | } |
| | | </script> |