261 lines
10 KiB
Vue
261 lines
10 KiB
Vue
<template>
|
||
<view class="modultInfo">
|
||
<headers :showBack="true" :themeType="'white'">
|
||
<view class="headerName">
|
||
{{type==1?'合同':type==2?'体检':type==3?'保险':type==4?'安全教育':''}}
|
||
</view>
|
||
</headers>
|
||
<view class="content">
|
||
<view class="info_wrap" v-if="type==1">
|
||
<!-- <view class="title">
|
||
<text class="state1" v-if="info.length==0">未签订</text>
|
||
<text class="state2" v-else>已签订</text>
|
||
</view> -->
|
||
<view class="detailInfo" v-for="(item,index) in info" :key="index">
|
||
<view>合同编号:{{item.contractNumber}}</view>
|
||
<view>合同类型:{{item.contractType==1?'纸质合同':item.contractType==2?'电子合同':''}}</view>
|
||
<view>合同期限:{{item.laborContractType==1?'固定期限合同':item.laborContractType==2?'以完成一定工作为期限的合同':''}}
|
||
</view>
|
||
<view>生效日期:{{item.contractBeginDate}}</view>
|
||
<view>失效日期:{{item.contractEndDate}}</view>
|
||
<view>工资核定方式:{{
|
||
item.wagesVerificationType == 1
|
||
? "按天"
|
||
: item.wagesVerificationType == 2
|
||
? "按小时"
|
||
: item.wagesVerificationType == 3
|
||
? "按月"
|
||
: item.wagesVerificationType == 4
|
||
? "按件"
|
||
: ""
|
||
}}</view>
|
||
<view>合同附件:
|
||
<text v-for="(val, valIndex) in item.fileList" @click="handlePreview(val.url)" :key="valIndex"
|
||
style="cursor: pointer;margin-right:10rpx">{{val.name}}</text>
|
||
|
||
</view>
|
||
</view>
|
||
<view class="no_data" v-if="info.length == 0">
|
||
<image src="/static/noData.png"></image>
|
||
<view>暂无数据</view>
|
||
</view>
|
||
</view>
|
||
<view class="info_wrap" v-if="type==2">
|
||
<!-- <view class="title">
|
||
<text class="state1" v-if="info.length==0">未体检</text>
|
||
<text class="state2" v-else>已体检</text>
|
||
</view> -->
|
||
<view class="detailInfo" v-for="(item,index) in info" :key="index">
|
||
<view>身高:{{item.personHeight}}cm</view>
|
||
<view>体重:{{item.personWeight}}kg</view>
|
||
<view>体检日期:{{item.physicalsTime}}</view>
|
||
<view>体检状态:{{item.state==1?'未体检':item.state==2?'体检合格':item.state==1?'体检不合格':''}}</view>
|
||
<view>结论:{{item.conclusion}}</view>
|
||
</view>
|
||
<view class="no_data" v-if="info.length == 0">
|
||
<image src="/static/noData.png"></image>
|
||
<view>暂无数据</view>
|
||
</view>
|
||
</view>
|
||
<view class="info_wrap" v-if="type==3">
|
||
<!-- <view class="title">
|
||
<text class="state1" v-if="info.length==0">未购买</text>
|
||
<text class="state2" v-else>已购买</text>
|
||
</view> -->
|
||
<view class="detailInfo" v-for="(item,index) in info" :key="index">
|
||
<view>保险购买日期:{{item.insuranceTime}}</view>
|
||
<view>保险到期日期:{{item.expireTime}}</view>
|
||
<view>保险状态:{{item.state==1?'未购买':item.state==2?'已购买':''}}</view>
|
||
<view>险种:{{item.insuranceType}}</view>
|
||
<view>城乡居民医疗保险:{{item.medicalInsurance==1?'否':item.medicalInsurance==2?'是':''}}</view>
|
||
<view>城乡居民养老保险:{{item.endowmentInsurance==1?'否':item.endowmentInsurance==2?'是':''}}</view>
|
||
</view>
|
||
<view class="no_data" v-if="info.length == 0">
|
||
<image src="/static/noData.png"></image>
|
||
<view>暂无数据</view>
|
||
</view>
|
||
</view>
|
||
<view class="info_wrap" v-if="type==4">
|
||
<!-- <view class="title">
|
||
<text class="state1" v-if="info.length==0">未培训</text>
|
||
<text class="state2" v-else>已培训</text>
|
||
</view> -->
|
||
<view class="detailInfo" v-for="(item,index) in info" :key="index">
|
||
<!-- <view>培训类型: {{
|
||
item.eduType == 1
|
||
? "入场三级教育"
|
||
: item.eduType == 2
|
||
? "定期安全教育"
|
||
: item.eduType == 3
|
||
? "安全技术交底"
|
||
: item.eduType == 4
|
||
? "VR安全教育"
|
||
: ""
|
||
}}</view> -->
|
||
<view>考试时间:{{item.startExamTime}}</view>
|
||
<view>考试科目:{{item.subjectName}}</view>
|
||
<view>考试分数:{{item.score}}</view>
|
||
<view>是否合格:{{item.isPass == 1 ? "是":item.isPass == 0? "否":''}}</view>
|
||
</view>
|
||
<view class="no_data" v-if="info.length == 0">
|
||
<image src="/static/noData.png"></image>
|
||
<view>暂无数据</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</template>
|
||
|
||
<script>
|
||
export default {
|
||
data() {
|
||
return {
|
||
type: 1,
|
||
info: null,
|
||
workerId: "",
|
||
idCard: "",
|
||
}
|
||
},
|
||
onLoad(option) {
|
||
this.type = Number(option.type);
|
||
this.workerId = option.workerId;
|
||
this.idCard = option.idCard;
|
||
this.info = uni.getStorageSync('moduleInfo');
|
||
this.getFileInfo();
|
||
if (this.type == 4) { // 安全教育考试数据特殊处理
|
||
this.getDangerItemRecord();
|
||
}
|
||
},
|
||
methods: {
|
||
// 获取考试数据
|
||
getExamDataList() {
|
||
this.sendRequest({
|
||
url: 'xmgl/workerInfo/getTrainRecordsByWorkerId',
|
||
method: 'post',
|
||
data: {
|
||
projectSn: JSON.parse(uni.getStorageSync('projectDetail')).projectSn,
|
||
workerId: this.workerId,
|
||
},
|
||
success: res => {
|
||
if (res.code == 200) {
|
||
this.info = res.result;
|
||
}
|
||
}
|
||
})
|
||
},
|
||
getDangerItemRecord() {
|
||
this.sendRequest({
|
||
url: 'exam/trainRecord/page',
|
||
method: 'post',
|
||
data: {
|
||
projectSn: JSON.parse(uni.getStorageSync('projectDetail')).projectSn,
|
||
// workerId: this.workerId,
|
||
idCard: this.idCard,
|
||
isReEducation: 0,
|
||
pageNo: 1,
|
||
pageSize: -1
|
||
},
|
||
success: res => {
|
||
if (res.code == 200) {
|
||
this.info = res.result.records;
|
||
}
|
||
}
|
||
})
|
||
},
|
||
|
||
//获取附件信息
|
||
getFileInfo() {
|
||
let data = JSON.parse(JSON.stringify(this.info))
|
||
if (this.type == 1) {
|
||
//获取合同照片
|
||
if (data.length > 0 && data[0].imageUrl) {
|
||
let arr = data[0].imageUrl.split(",");
|
||
let fileList = [];
|
||
arr.forEach((item) => {
|
||
let valArr = item.split("*");
|
||
fileList.push({
|
||
name: valArr[0],
|
||
url: valArr[1]
|
||
});
|
||
});
|
||
data[0].fileList = fileList;
|
||
} else {
|
||
if (data.length > 0) {
|
||
data[0].fileList = [];
|
||
}
|
||
}
|
||
}
|
||
this.info = data;
|
||
},
|
||
//预览文件
|
||
handlePreview(url) {
|
||
let type = url.split('.')[1];
|
||
if (type == 'doc' || type == 'xls' || type == 'ppt' || type == 'pdf' || type == 'docx' || type == 'xlsx' ||
|
||
type ==
|
||
'pptx') {
|
||
uni.openDocument({
|
||
filePath: this.url_config + 'image/' + url,
|
||
})
|
||
} else {
|
||
let fileList = [];
|
||
fileList = [this.url_config + 'image/' + url];
|
||
uni.previewImage({
|
||
current: 0,
|
||
urls: fileList
|
||
})
|
||
}
|
||
|
||
},
|
||
}
|
||
}
|
||
</script>
|
||
|
||
<style lang="scss" scoped>
|
||
.info_wrap {
|
||
text-align: center;
|
||
padding-bottom: 2rpx;
|
||
}
|
||
|
||
.detailInfo {
|
||
text-align: left;
|
||
padding: 20rpx 30rpx;
|
||
box-sizing: border-box;
|
||
margin: 20rpx 0 40rpx;
|
||
box-shadow: 0 0px 20rpx rgba(220, 220, 220, 0.8);
|
||
font-size: 30rpx;
|
||
line-height: 44rpx;
|
||
}
|
||
|
||
.no_data {
|
||
position: fixed;
|
||
top: 35%;
|
||
// transform: translateY(-50%);
|
||
left: 50%;
|
||
transform: translateX(-50%);
|
||
padding-top: 60rpx;
|
||
text-align: center;
|
||
color: rgba(0, 0, 0, 0.5);
|
||
font-size: 28rpx;
|
||
|
||
uni-image {
|
||
width: 162rpx;
|
||
height: 130rpx;
|
||
display: block;
|
||
margin: 0 auto;
|
||
margin-bottom: 40rpx;
|
||
}
|
||
}
|
||
|
||
.info_wrap .title {
|
||
font-size: 30rpx;
|
||
margin-top: 16rpx;
|
||
}
|
||
|
||
.title .state1 {
|
||
color: red;
|
||
}
|
||
|
||
.title .state2 {
|
||
color: #4181FE;
|
||
}
|
||
</style> |