<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 === 1">保单状态:<span :class="'change-status'+model.status" >待签署</span></span>
|
<span v-if="model.status === 0">保单状态:<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 === 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 === 7 || 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" @click="$refs.ApplyChangeDetails.open('加减保详单',apply,model)">导出详单</el-button>
|
<el-button v-if="[5, 8].includes(model.status)" type="primary" @click="$refs.reinsurance.open('加减保申请', {id: dataId, applyChangId: modelId})">再次投保</el-button>
|
<el-button type="primary" v-if="model.status == 0" @click="goSign">签署申请单</el-button>
|
<el-button v-if="[0, 1, 3, 7].includes(model.status)" type="primary" @click="$refs.add_subtract_return.open('申请退回', { id: modelId })">申请退回</el-button>
|
<el-button v-if="model.status == 5" 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-else>
|
<el-button type="primary" @click="$refs.ApplyChangeDetails.open('加减保详单',apply,model)">导出详单</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
|
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="addNum"
|
align="center"
|
label="加保人数">
|
</el-table-column>
|
<el-table-column
|
prop="delNum"
|
align="center"
|
label="减保人数">
|
</el-table-column>
|
<el-table-column
|
prop="fee"
|
align="center"
|
label="费用变更(元)">
|
</el-table-column>
|
</el-table>
|
</div>
|
<div class="desc_item_cate">
|
<el-tabs v-model="activeName" @tab-click="handleClick">
|
<el-tab-pane label="加保记录" name="0"></el-tab-pane>
|
<el-tab-pane label="减保记录" name="1"></el-tab-pane>
|
</el-tabs>
|
</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="duName"
|
label="派遣单位">
|
</el-table-column>
|
<el-table-column
|
prop="workTypeName"
|
label="所属工种">
|
</el-table-column>
|
<el-table-column
|
prop="startTime"
|
label="保险生效起期">
|
</el-table-column>
|
<el-table-column
|
prop="endTime"
|
label="保险生效止期">
|
</el-table-column>
|
<el-table-column
|
prop="fee"
|
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>
|
<ApplyChangeDetails ref="ApplyChangeDetails" @success="successEvent" />
|
<OperaApplyChangeCheckWindow ref="OperaApplyChangeCheckWindow" @success="successEvent" />
|
<!-- 企业申请退回 -->
|
<!-- <applyReturn ref="applyReturn" @success="successEvent" />-->
|
<add_subtract_return ref="add_subtract_return" @success="successEvent" />
|
<!-- 新增投保 -->
|
<OperaInsuranceApply ref="OperaInsuranceApply" @success="successEvent" />
|
<!-- 加减保申请 -->
|
<reinsurance ref="reinsurance" @success="successEvent" />
|
<!-- 换厂申请 -->
|
<factoryChange ref="factoryChange" @success="successEvent" />
|
<!-- 投保详情 -->
|
<insuranceApplyDetails ref="insuranceApplyDetails" @success="successEvent" />
|
<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 ApplyChangeDetails from '@/components/business/ApplyChangeDetails'
|
import OperaApplyChangeCheckWindow from '@/components/business/OperaApplyChangeCheckWindow'
|
import reinsurance from '@/components/enterprise/reinsurance'
|
import factoryChange from '@/components/enterprise/factoryChange'
|
import add_subtract_return from '@/components/enterprise/add_subtract_return'
|
// import insuranceApplyDetails from '@/components/business/OperaInsuranceApplyWindow'
|
import {
|
getDetail,
|
getChangeDetail,
|
applyChagneDetailPage,
|
getJiajianBaoSignLink
|
} from '@/api/business/insuranceApply'
|
import { applyChangeOpt } from '@/api/business/applyChange'
|
import OperaInsuranceApply from '@/components/enterprise/OperaInsuranceApplyWindow'
|
import { mapState } from 'vuex'
|
|
export default {
|
name: 'OperaApplyChangeDetailWindow1',
|
extends: BaseOpera,
|
components: {
|
GlobalWindow,
|
ApplyChangeDetails,
|
OperaApplyChangeCheckWindow,
|
add_subtract_return,
|
OperaInsuranceApply,
|
reinsurance,
|
factoryChange,
|
insuranceApplyDetails: () => import ('@/components/business/OperaInsuranceApplyWindow')
|
},
|
data () {
|
return {
|
// 表单数据
|
dataId:null,
|
modelId:null,
|
apply:{},
|
model: {},
|
form: {
|
id: null,
|
editDate: ''
|
},
|
// 验证规则
|
rules: {
|
},
|
formInline: {
|
applyStatus: '',
|
duId: '',
|
workTypeId: '',
|
memberName: '',
|
types: ''
|
},
|
reverse: false,
|
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()
|
},
|
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(() => {
|
|
});
|
},
|
search() {
|
this.currentPage = 1
|
this.getList()
|
},
|
getList() {
|
applyChagneDetailPage({
|
capacity: 10,
|
page: this.currentPage,
|
model: {
|
applyChangeId: this.modelId,
|
types:[ this.activeName]
|
}
|
}).then(res => {
|
this.list = res.records
|
this.total = res.total
|
})
|
},
|
handleClick(e) {
|
this.activeName = e.index
|
this.resetting()
|
},
|
goSign(){
|
getJiajianBaoSignLink({id:this.modelId}).then(res => {
|
setTimeout(() => {
|
window.open(res)
|
}, 500);
|
}).catch(err => {
|
this.$tip.apiFailed(err)
|
})
|
},
|
viewApplyFile(){
|
if(this.model.applyFile && this.model.applyFile.fileurlFull){
|
window.open(this.model.applyFile.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;
|
.desc_item_label_left {
|
flex-shrink: 0;
|
}
|
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>
|