<template>
|
<GlobalWindow
|
:title="title"
|
width="100%"
|
:visible.sync="visible"
|
:confirm-working="isWorking"
|
@confirm="confirm"
|
>
|
<div class="desc">
|
<div class="desc_item">
|
<div class="desc_item_label">
|
<div class="desc_item_label_left">
|
<span>投保企业:{{ apply.companyName }}</span>
|
<span v-if="model.status === 0">保单状态:<span :class="'change-status'+model.status" >待签署</span></span>
|
<span v-if="model.status === 1">保单状态:<span :class="'change-status'+model.status" >待审核</span></span>
|
<span v-if="model.status === 2">保单状态:<span :class="'change-status'+model.status" >已生效</span></span>
|
<span v-if="model.status === 7">保单状态:<span :class="'change-status'+model.status" >待出单</span></span>
|
<span v-if="model.status === 9">保单状态:<span :class="'change-status'+model.status" >批改申请中</span></span>
|
<span v-if="model.status === 3 || model.status === 4">保单状态:<span :class="'change-status'+model.status" >退回申请</span></span>
|
<span v-if="model.status === 5 || model.status === 8">保单状态:<span :class="'change-status'+model.status" >已退回</span></span>
|
<span v-if=" model.status === 6">保单状态:<span :class="'change-status'+model.status" >已关闭</span></span>
|
<span>提交时间:{{ model.createDate }}</span>
|
</div>
|
<div class="desc_item_label_right">
|
<template v-if="userInfo.type === 1">
|
<el-button type="primary" v-if="[5,8].includes(model.status)" @click="$refs.editFactoryChange.open('更换派遣单位申请', {id: dataId, applyChangId: modelId})">再次投保</el-button>
|
<el-button type="primary" @click="$refs.ApplyChangeDetails.open('更换派遣单位详情',apply,model,0)">导出详单</el-button>
|
<el-button type="primary" v-if="model.status == 0" :disabled="loading" :loading="loading" @click="getSignLink(0)">签署申请单</el-button>
|
<el-button v-if="[0, 1, 3, 7].includes(model.status) && model.solutionType == 0" type="danger" @click="$refs.add_subtract_return.open('申请退回', { id: modelId })">申请退回</el-button>
|
<el-button v-if="[1,2,4,7,9].includes(model.status)" type="primary" @click="viewApplyFile">查看申请单</el-button>
|
<el-button v-if="model.status == 2" type="primary" @click="viewPidan">查看批单</el-button>
|
<el-button v-if="[5,8].includes(model.status)" type="primary" @click="closeOrder">关闭订单</el-button>
|
</template>
|
<template v-if="userInfo.type === 2">
|
<el-button type="primary" @click="$refs.ApplyChangeDetails.open('更换派遣单位详单',apply,model,0)">导出详单</el-button>
|
<el-button v-if="[1,2,4,7,9].includes(model.status)" type="primary" @click="viewApplyFile">查看申请单</el-button>
|
<el-button v-if="[2].includes(model.status)" type="primary" @click="viewPidan">查看批单</el-button>
|
<el-button v-if=" model.solutionType == 1 && [1].includes(model.status)" type="primary" @click="$refs.ApplyChangeDetails.open('投保审核',apply,model,1)">批改审核</el-button>
|
<el-button v-if=" model.solutionType == 1 && [0,1].includes(model.status)" type="danger" @click="$refs.OperaApplyChangeCheckWindow.open('退回申请',model,1)">退回申请</el-button>
|
<el-button v-if=" model.solutionType == 1 && [7].includes(model.status)" type="danger" @click="closeOrder">关闭订单</el-button>
|
<el-button v-if=" model.solutionType == 0 && [1].includes(model.status)" type="primary" @click="$refs.OperaApplyChangeCheckWindow.open('上传批单',model,3)">上传批单</el-button>
|
<el-button v-if="model.solutionType == 0 &&[3,4].includes(model.status)" type="primary" @click="$refs.OperaApplyChangeCheckWindow.open('驳回退回申请',model,5)">驳回退回申请</el-button>
|
<el-button v-if="model.solutionType == 0 &&[0,1,3,4].includes(model.status)" type="danger" @click="$refs.OperaApplyChangeCheckWindow.open('退回投保',model,1)">退回投保</el-button>
|
<el-button v-if="model.solutionType == 0 &&[2].includes(model.status)" type="danger" @click="$refs.OperaApplyChangeCheckWindow.open('修改批单',model,4)">修改批单</el-button>
|
</template>
|
<template v-if="userInfo.type === 0">
|
<el-button type="primary" @click="$refs.ApplyChangeDetails.open('更换派遣单位详单',apply,model,0)">导出详单</el-button>
|
<el-button v-if="[1,2,4,7,9].includes(model.status)" type="primary" @click="viewApplyFile">查看申请单</el-button>
|
<el-button v-if="[2].includes(model.status)" type="primary" @click="viewPidan">查看批单</el-button>
|
<el-button v-if=" model.solutionType == 0 && [1].includes(model.status)" type="primary" @click="$refs.OperaApplyChangeCheckWindow.open('上传批单',model,3)">上传批单</el-button>
|
<el-button v-if="model.solutionType == 0 &&[3,4].includes(model.status)" type="primary" @click="$refs.OperaApplyChangeCheckWindow.open('驳回退回申请',model,5)">驳回退回申请</el-button>
|
<el-button v-if="model.solutionType == 0 &&[0,1,3,4].includes(model.status)" type="danger" @click="$refs.OperaApplyChangeCheckWindow.open('退回投保',model,1)">退回投保</el-button>
|
<el-button v-if="model.solutionType == 0 &&[2].includes(model.status)" type="danger" @click="$refs.OperaApplyChangeCheckWindow.open('修改批单',model,4)">修改批单</el-button>
|
</template>
|
</div>
|
</div>
|
<div class="desc_item_from">
|
<el-table
|
:data="tableData"
|
border
|
style="width: 100%">
|
<el-table-column
|
prop="validCode"
|
align="center"
|
label="批单号">
|
</el-table-column>
|
<el-table-column
|
prop="applyCode"
|
align="center"
|
label="关联保单号">
|
<template slot-scope="{row}">
|
<el-button type="text" @click="$refs.insuranceApplyDetails.open('投保详情', { id: row.applyId })">{{row.applyCode}}</el-button>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="solutionsName"
|
label="保险方案"
|
align="center"
|
width="180">
|
</el-table-column>
|
<el-table-column
|
prop="startTime"
|
align="center"
|
label="保险生效起期">
|
</el-table-column>
|
<el-table-column
|
prop="endTime"
|
align="center"
|
label="保险生效止期">
|
</el-table-column>
|
<el-table-column
|
prop="applyStartTime"
|
align="center"
|
label="批单生效起期">
|
</el-table-column>
|
<el-table-column
|
prop="changeNum"
|
align="center"
|
label="更换派遣单位人数">
|
</el-table-column>
|
</el-table>
|
</div>
|
<div class="desc_item_from">
|
<el-table
|
:data="list"
|
border
|
style="width: 100%">
|
<el-table-column label="序号">
|
<template slot-scope="scope">
|
<span>{{scope.$index + 1}}</span>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="memberName"
|
label="员工姓名">
|
</el-table-column>
|
<el-table-column
|
label="性别">
|
<template slot-scope="{row}">
|
<span v-if="row.sex === 0">男</span>
|
<span v-if="row.sex === 1">女</span>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="memberIdcardNo"
|
label="身份证号">
|
</el-table-column>
|
<el-table-column
|
prop="oldDuName"
|
label="原派遣单位">
|
</el-table-column>
|
<el-table-column
|
prop="oldWorkTypeName"
|
label="原所属工种">
|
</el-table-column>
|
<el-table-column
|
prop="startTime"
|
label="保险生效起期">
|
</el-table-column>
|
<el-table-column
|
prop="duName"
|
label="更换后派遣单位">
|
</el-table-column>
|
<el-table-column
|
prop="workTypeName"
|
label="更换后所属工种">
|
</el-table-column>
|
<el-table-column
|
prop="endTime"
|
label="保险生效止期">
|
</el-table-column>
|
<el-table-column
|
prop="remark"
|
label="备注">
|
</el-table-column>
|
</el-table>
|
<div class="desc_item_from_page">
|
<el-pagination
|
@current-change="handleCurrentChange"
|
:current-page="currentPage"
|
:page-size="10"
|
layout="total, prev, pager, next, jumper"
|
:total="total">
|
</el-pagination>
|
</div>
|
</div>
|
<div class="desc_item_review">
|
<div class="desc_item_review_label">操作记录</div>
|
<el-timeline :reverse="reverse">
|
<el-timeline-item
|
v-for="(activity, index) in activities"
|
:key="index">
|
<div style="display: flex; flex-direction: column;">
|
<span style="font-size: 16px; font-weight: 400; color: black;">
|
{{activity.title}}
|
<span style="font-size: 16px; font-weight: 400; color: black; margin-left: 10px;" >
|
{{activity.content}}
|
</span>
|
</span>
|
<span style="margin-top: 5px; font-size: 12px; font-weight: 400; color: #999999;">
|
操作员-{{activity.creatorName}}({{activity.creatorType==1? activity.companyName: (activity.creatorType==2? activity.companyName: "平台端")}}){{activity.createDate}}
|
</span>
|
</div>
|
</el-timeline-item>
|
</el-timeline>
|
</div>
|
</div>
|
</div>
|
<el-dialog
|
:title="signTitle"
|
:visible.sync="visiblePhone"
|
width="500px"
|
:modal="false"
|
:show-close="false"
|
:close-on-click-modal="false"
|
center>
|
<el-form :model="form" ref="form" :rules="rules">
|
<el-form-item label="手机号" prop="phone">
|
<el-input v-model="form.phone" placeholder="请输入" disabled v-trim/>
|
</el-form-item>
|
<el-form-item label="验证码" prop="code">
|
<div style="width: 100%; display: flex; align-items: center;">
|
<el-input v-model="form.code" placeholder="请输入" v-trim/>
|
<el-button type="primary" style="margin-left: 15px;" @click="send" v-if="num === 0">发送验证码</el-button>
|
<el-button type="primary" style="margin-left: 15px;" v-else>{{num}}s</el-button>
|
</div>
|
</el-form-item>
|
</el-form>
|
<span slot="footer" class="dialog-footer">
|
<el-button type="primary" @click="goSignDo()">确 定</el-button>
|
<el-button @click="visiblePhone=false">取 消</el-button>
|
</span>
|
</el-dialog>
|
<ApplyChangeUnitDetails ref="ApplyChangeDetails" @success="successEvent" />
|
<OperaApplyChangeUnitCheckWindow ref="OperaApplyChangeCheckWindow" @success="successEvent" />
|
<!-- 企业申请退回 -->
|
<applyReturn ref="applyReturn" @success="successEvent" />
|
<add_subtract_return ref="add_subtract_return" @success="successEvent" />
|
<!-- 新增投保 -->
|
<OperaInsuranceApply ref="OperaInsuranceApply" @success="successEvent" />
|
<!-- 更换派遣单位申请 -->
|
<additionSubtractionApplication ref="additionSubtractionApplication" @success="successEvent" />
|
<!-- 更换派遣单位申请 -->
|
<factoryChange ref="factoryChange" @success="successEvent" />
|
<editFactoryChange ref="editFactoryChange" @success="successEvent" />
|
<!-- 投保详情 -->
|
<insuranceApplyDetails ref="insuranceApplyDetails" @success="successEvent" />
|
<OperaPdfViewerWindow ref="OperaPdfViewerWindow" />
|
<template v-slot:footer>
|
<el-button @click="visible=false">返回</el-button>
|
</template>
|
</GlobalWindow>
|
</template>
|
|
<script>
|
import BaseOpera from '@/components/base/BaseOpera'
|
import GlobalWindow from '@/components/common/GlobalWindow'
|
import ApplyChangeUnitDetails from '@/components/business/ApplyChangeUnitDetails'
|
import OperaApplyChangeUnitCheckWindow from '@/components/business/OperaApplyChangeUnitCheckWindow'
|
import additionSubtractionApplication from '@/components/enterprise/additionSubtractionApplication'
|
import factoryChange from '@/components/enterprise/factoryChange'
|
import editFactoryChange from '@/components/enterprise/editFactoryChange'
|
import applyReturn from '@/components/enterprise/applyReturn'
|
import add_subtract_return from '@/components/enterprise/add_subtract_return'
|
// import insuranceApplyDetails from '@/components/business/OperaInsuranceApplyWindow'
|
import OperaPdfViewerWindow from '@/components/business/OperaPdfViewerWindow'
|
import {
|
getDetail,
|
getChangeDetail,
|
applyChagneDetailPage,
|
getChangeUnitSignLink
|
} from '@/api/business/insuranceApply'
|
import { applyChangeOpt, getChangeMemberListOnlineSignLink } from '@/api/business/applyChange'
|
import OperaInsuranceApply from '@/components/enterprise/OperaInsuranceApplyAddWindow'
|
import { mapState } from 'vuex'
|
import { sendSms } from '@/api/business/smsEmail'
|
|
export default {
|
name: 'OperaApplyChangeUnitDetailWindow',
|
extends: BaseOpera,
|
components: {
|
GlobalWindow,
|
OperaPdfViewerWindow,
|
ApplyChangeUnitDetails,
|
OperaApplyChangeUnitCheckWindow,
|
applyReturn,
|
OperaInsuranceApply,
|
additionSubtractionApplication,
|
factoryChange,
|
add_subtract_return,
|
editFactoryChange,
|
insuranceApplyDetails: () => import('@/components/business/OperaInsuranceApplyWindow')
|
},
|
data () {
|
return {
|
// 表单数据
|
dataId: null,
|
modelId: null,
|
apply: {},
|
num: 0,
|
timer: null,
|
signTitle: '手机号验证',
|
model: {},
|
visiblePhone: false,
|
form: {
|
businessId: null,
|
phone: this.$store.state.userInfo.company ? this.$store.state.userInfo.company.phone:null,
|
id: null,
|
editDate: '',
|
code: null
|
},
|
// 验证规则
|
rules: {
|
},
|
formInline: {
|
applyStatus: '',
|
duId: '',
|
workTypeId: '',
|
memberName: '',
|
types: ''
|
},
|
reverse: false,
|
radio: 0,
|
activities: [],
|
tableData: [],
|
list: [],
|
activeName: '0',
|
total: 0,
|
currentPage: 1,
|
loading: false
|
}
|
},
|
created () {
|
this.config({
|
api: '/business/insuranceApply',
|
'field.id': 'id'
|
})
|
},
|
computed: {
|
...mapState(['userInfo'])
|
},
|
methods: {
|
open (title, target) {
|
this.visible = true
|
this.title = title
|
this.dataId = target.applyId
|
this.modelId = target.id
|
this.form.businessId = target.id
|
this.num=0
|
this.timer=null
|
this.getDetail()
|
this.getList()
|
},
|
send () {
|
sendSms({
|
phone: this.form.phone
|
}).then(res => {
|
this.num = 60
|
this.setTime()
|
})
|
},
|
setTime () {
|
this.timer = setInterval(() => {
|
if (this.num === 0) {
|
clearInterval(this.timer)
|
this.timer = null
|
return
|
}
|
this.num = this.num - 1
|
}, 1000)
|
},
|
getSignLink (flag) {
|
this.signTitle = '签署申请单'
|
this.form.type = flag
|
this.loading = true
|
getChangeMemberListOnlineSignLink(this.form).then(res => {
|
this.loading = false
|
window.open(res)
|
}).catch(err => {
|
this.loading = false
|
this.$tip.apiFailed(err)
|
})
|
// this.visiblePhone = true
|
// this.$nextTick(() => {
|
// this.$refs.form.resetFields()
|
// })
|
},
|
goSignDo () {
|
this.$refs.form.validate((valid) => {
|
if (!valid) {
|
return
|
}
|
this.isWorking = true
|
getChangeMemberListOnlineSignLink(this.form).then(res => {
|
setTimeout(() => {
|
this.visiblePhone = false
|
window.open(res)
|
}, 500)
|
}).catch(err => {
|
this.$tip.apiFailed(err)
|
})
|
})
|
},
|
closeOrder () {
|
this.$confirm('确认关闭此订单吗?', '提示', {
|
confirmButtonText: '确定',
|
cancelButtonText: '取消',
|
type: 'warning'
|
}).then(() => {
|
applyChangeOpt({
|
optType: 6,
|
applyId: this.model.id
|
}).then(res => {
|
this.getDetail()
|
}).catch(e => {
|
this.$message.error(e)
|
})
|
}).catch(() => {
|
|
})
|
},
|
resetting () {
|
this.search()
|
},
|
search () {
|
this.currentPage = 1
|
this.getList()
|
},
|
getList () {
|
applyChagneDetailPage({
|
capacity: 10,
|
page: this.currentPage,
|
model: {
|
applyChangeId: this.modelId,
|
types: [2]
|
}
|
}).then(res => {
|
this.list = res.records
|
this.total = res.total
|
})
|
},
|
handleClick (e) {
|
this.activeName = e.index
|
this.resetting()
|
},
|
goSign () {
|
getChangeUnitSignLink({ id: this.modelId }).then(res => {
|
setTimeout(() => {
|
window.open(res)
|
}, 500)
|
}).catch(err => {
|
this.$tip.apiFailed(err)
|
})
|
},
|
viewApplyFile(){
|
if(this.model.applyUnitFile && this.model.applyUnitFile.fileurlFull){
|
this.$refs.OperaPdfViewerWindow.open('查看申请单',this.model.applyUnitFile.fileurlFull)
|
// window.open(this.model.applyFile.fileurlFull)
|
}
|
},
|
viewPidan(){
|
if(this.model.pidanFile && this.model.pidanFile.fileurlFull){
|
this.$refs.OperaPdfViewerWindow.open('查看批单',this.model.pidanFile.fileurlFull)
|
// window.open(this.model.pidanFile.fileurlFull)
|
}
|
},
|
handleSizeChange (val) {
|
console.log(val)
|
},
|
handleCurrentChange (val) {
|
console.log(val)
|
this.currentPage = val
|
this.getList()
|
},
|
onSubmit () {
|
|
},
|
getDetail () {
|
getDetail(this.dataId).then(res => {
|
this.apply = res
|
console.log(this.tableData)
|
}).catch(err => {
|
})
|
getChangeDetail(this.modelId).then(res => {
|
this.model = res
|
this.tableData = new Array()
|
this.tableData.push(res)
|
console.log(this.tableData)
|
this.activities = res.applyLogList
|
}).catch(err => {
|
})
|
},
|
successEvent () {
|
// this.visible=false
|
this.getDetail()
|
this.$emit('success')
|
}
|
}
|
}
|
</script>
|
<style>
|
|
</style>
|
<style lang="scss" scoped>
|
.form {
|
width: 100%;
|
display: flex;
|
align-items: center;
|
flex-direction: column;
|
.form_span {
|
width: 100%;
|
display: flex;
|
align-items: start;
|
flex-direction: column;
|
margin-bottom: 20px;
|
span {
|
font-size: 14px;
|
&:nth-child(1) {
|
color: black;
|
margin-bottom: 5px;
|
}
|
&:nth-child(2) {
|
color: #8c939d;
|
}
|
}
|
}
|
.form_item {
|
width: 100%;
|
display: flex;
|
align-items: center;
|
margin-bottom: 20px;
|
&:last-child {
|
margin: 0 !important;
|
}
|
.form_item_label {
|
flex-shrink: 0;
|
width: 170px;
|
color: black;
|
font-size: 14px;
|
span {
|
color: red;
|
font-size: 14px;
|
}
|
}
|
.form_item_val {
|
flex: 1;
|
/*height: 40px;*/
|
margin-left: 20px;
|
textarea {
|
width: 100%;
|
height: 70px;
|
border: 1px solid #cbcbcb;
|
padding: 10px;
|
outline: none;
|
box-sizing: border-box;
|
}
|
input {
|
width: 100%;
|
height: 40px;
|
outline: none;
|
border-radius: 5px;
|
border: 1px solid #cbcbcb;
|
padding: 0 20px;
|
box-sizing: border-box;
|
}
|
}
|
}
|
}
|
.desc {
|
width: 100%;
|
.desc_item {
|
width: 100%;
|
display: flex;
|
flex-direction: column;
|
.desc_item_label {
|
width: 100%;
|
display: flex;
|
align-items: center;
|
justify-content: space-between;
|
margin-bottom: 10px;
|
span {
|
font-size: 14px;
|
color: black;
|
margin-right: 30px;
|
}
|
}
|
.desc_item_from {
|
width: 100%;
|
margin-bottom: 10px;
|
.desc_item_from_page {
|
width: 100%;
|
display: flex;
|
align-items: center;
|
justify-content: end;
|
margin-top: 10px;
|
}
|
}
|
.desc_item_cate {
|
width: 100%;
|
margin-bottom: 10px;
|
}
|
.desc_item_search {
|
width: 100%;
|
margin-bottom: 20px;
|
}
|
.desc_item_review {
|
width: 100%;
|
.desc_item_review_label {
|
font-size: 20px;
|
color: black;
|
font-weight: bold;
|
margin-bottom: 15px;
|
}
|
}
|
}
|
}
|
</style>
|