<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>
|
<span v-if="model.status === 1">保单状态:已签章</span>
|
<span v-if="model.status === 2">保单状态:已生效</span>
|
<span v-if="model.status === 3 || model.status === 4">保单状态:退回申请</span>
|
<span v-if="model.status ===5 || model.status === 8">保单状态:已退回</span>
|
<span v-if="model.status ===7">保单状态:已关闭</span>
|
<span>提交时间:{{ model.createDate }}</span>
|
</div>
|
<div class="desc_item_label_right">
|
<template v-if="userInfo.type === 1">
|
<el-button v-if="[0, 2, 3, 10].includes(model.status)" type="danger" @click="$refs.applyReturn.open('申请退回', {id: dataId})">申请退回</el-button>
|
<el-button v-if="model.status == 4" type="primary" @click="$refs.OperaInsuranceApply.open('投保申请', {id: dataId})">再次投保</el-button>
|
<el-button type="primary" @click="$refs.InsuranceDetails.open('投保详情单',model,0)">签署申请单</el-button>
|
<el-button v-if="[2, 3, 5, 7, 8].includes(model.status)" type="primary" @click="viewToubaodan">申请退回</el-button>
|
<el-button v-if="model.status == 5" type="primary" @click="viewBaoxiandan">查看申请单</el-button>
|
<el-button v-if="model.status == 5" type="primary" @click="viewBaoxiandan">查看批单</el-button>
|
<el-button v-if="model.status == 2" type="primary" @click="goSign">关闭订单</el-button>
|
</template>
|
<template v-else>
|
<el-button type="primary" @click="$refs.ApplyChangeDetails.open('换厂申请详单',apply,model)">导出详单</el-button>
|
<el-button type="primary" v-if="model.status == 0" @click="goSign">签署申请单</el-button>
|
<el-button v-if="[1,2,4].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="[1].includes(model.status)" type="primary" @click="$refs.OperaApplyChangeCheckWindow.open('上传批单',model,3)">上传批单</el-button>
|
<el-button v-if="[3,4].includes(model.status)" type="primary" @click="$refs.OperaApplyChangeCheckWindow.open('驳回退回申请',model,5)">驳回退回申请</el-button>
|
<el-button v-if="[0,1,3,4].includes(model.status)" type="danger" @click="$refs.OperaApplyChangeCheckWindow.open('退回投保',model,1)">退回投保</el-button>
|
<el-button v-if="[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="关联保单号">
|
</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-else>女</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>
|
<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.createDate}}
|
</span>
|
</div>
|
</el-timeline-item>
|
</el-timeline>
|
</div>
|
</div>
|
</div>
|
<ApplyChangeUnitDetails ref="ApplyChangeDetails" @success="successEvent" />
|
<OperaApplyChangeUnitCheckWindow ref="OperaApplyChangeCheckWindow" @success="successEvent" />
|
<!-- 企业申请退回 -->
|
<applyReturn ref="applyReturn" @success="successEvent" />
|
<!-- 新增投保 -->
|
<OperaInsuranceApply ref="OperaInsuranceApply" @success="successEvent" />
|
<!-- 加减保申请 -->
|
<additionSubtractionApplication ref="additionSubtractionApplication" @success="successEvent" />
|
<!-- 换厂申请 -->
|
<factoryChange ref="factoryChange" @success="successEvent" />
|
</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 applyReturn from '@/components/enterprise/applyReturn'
|
import {
|
getDetail,
|
getChangeDetail,
|
applyChagneDetailPage,
|
getChangeUnitSignLink
|
} from '@/api/business/insuranceApply'
|
import OperaInsuranceApply from '@/components/enterprise/OperaInsuranceApplyWindow'
|
import { mapState } from 'vuex'
|
|
export default {
|
name: 'OperaApplyChangeDetailWindow',
|
extends: BaseOpera,
|
components: {
|
GlobalWindow,
|
ApplyChangeUnitDetails,
|
OperaApplyChangeUnitCheckWindow,
|
applyReturn,
|
OperaInsuranceApply,
|
additionSubtractionApplication,
|
factoryChange
|
},
|
data () {
|
return {
|
// 表单数据
|
dataId:null,
|
modelId:null,
|
apply:{},
|
model: {},
|
form: {
|
id: null,
|
editDate: ''
|
},
|
// 验证规则
|
rules: {
|
},
|
formInline: {
|
applyStatus: '',
|
duId: '',
|
workTypeId: '',
|
memberName: '',
|
types: ''
|
},
|
reverse: true,
|
radio: 0,
|
activities: [],
|
tableData: [],
|
list: [],
|
activeName: '0',
|
total: 0,
|
currentPage: 1
|
}
|
},
|
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.getDetail()
|
this.getList()
|
},
|
resetting() {
|
this.search()
|
},
|
search() {
|
this.currentPage = 1
|
this.getList()
|
},
|
getList() {
|
applyChagneDetailPage({
|
capacity: 10,
|
page: this.currentPage,
|
model: {
|
applyChangId: 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){
|
window.open(this.model.applyUnitFile.fileurlFull)
|
}
|
},
|
viewPidan(){
|
if(this.model.pidanFile && this.model.pidanFile.fileurlFull){
|
window.open(this.model.pidanFile.fileurlFull)
|
}
|
},
|
handleSizeChange(val){
|
console.log(val)
|
},
|
handleCurrentChange(val){
|
console.log(val)
|
this.page = 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>
|