qa-prevention-gwj-vue/src/views/safetyenvironmental/archive/components/accept.vue

674 lines
23 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<template>
<div>
<div class="app-container">
<div class="level-title">
<h1>隐患信息</h1>
</div>
<div class="mb-20">
<table class="table-ui">
<tr>
<td class="tbg">隐患来源</td>
<template v-if="pd.SOURCE=='1'">
<td>隐患快报</td>
</template>
<template v-else-if="pd.SOURCE=='2'">
<td>清单排查</td>
</template>
<template v-else-if="pd.SOURCE=='3'">
<td>清单排查</td>
</template>
<template v-else-if="pd.SOURCE=='4'">
<td>安全环保检查(监管端)</td>
</template>
<template v-else-if="pd.SOURCE=='5'">
<td>安全环保检查(企业端)</td>
</template>
</tr>
<tr>
<td class="tbg">隐患描述</td>
<td>{{ pd.HIDDENDESCR }}</td>
</tr>
<tr v-if="pd.SOURCE=='2'">
<td class="tbg">风险点(单元)</td>
<td>{{ pd.RISK_UNIT }}</td>
</tr>
<tr v-if="pd.SOURCE=='2'">
<td class="tbg">辨识部位</td>
<td>{{ pd.IDENTIFICATION }}</td>
</tr>
<tr v-if="pd.SOURCE=='2'">
<td class="tbg">存在风险</td>
<td class="tbg">存在风险</td>
<td>{{ pd.RISK_DESCR }}</td>
</tr>
<tr v-if="pd.SOURCE=='2'">
<td class="tbg">风险分级</td>
<td>{{ pd.LEVEL }}</td>
</tr>
<tr v-if="pd.SOURCE=='2'">
<td class="tbg">检查内容</td>
<td>{{ pd.CHECK_CONTENT }}</td>
</tr>
<tr>
<td class="tbg">隐患级别</td>
<td>{{ pd.HIDDENLEVELNAME }}</td>
</tr>
<tr>
<td class="tbg">隐患类型</td>
<td>{{ pd.HIDDENTYPENAME }}</td>
</tr>
<tr>
<td class="tbg">隐患状态</td>
<td>
<template v-if="pd.STATE=='1'">
未整改
</template>
<template v-else-if="pd.STATE=='2'">
已整改
</template>
<template v-else-if="pd.STATE=='3'">
已验收
</template>
<template v-else-if="pd.STATE=='4'">
已验收
</template>
<template v-else-if="pd.STATE=='8'">
特殊处置审核
</template>
</td>
</tr>
<tr>
<td class="tbg">隐患部位</td>
<td>{{ pd.hregionName?pd.hregionName:pd.HIDDENPART }}</td>
</tr>
<tr>
<td class="tbg">隐患上报位置</td>
<td>经度:{{ pd.LONGITUDE }} , 纬度:{{ pd.LATITUDE }}</td>
</tr>
<tr>
<td class="tbg">隐患位置描述</td>
<td>{{ pd.POSITIONDESC }}</td>
</tr>
<tr>
<td class="tbg">隐患图片</td>
<td class="img-select">
<viewer :images="hImgs">
<img v-for="item in hImgs" :src="config.fileUrl + item.FILEPATH" :key="item.IMGFILES_ID" width="100" height="100">
</viewer>
</td>
</tr>
<tr v-for="item in hiddenFindPeople" :key="item.USER_ID">
<td class="tbg">隐患发现人 </td>
<td>{{ item.NAME }}</td>
</tr>
<tr>
<td class="tbg">隐患发现时间</td>
<td>{{ pd.CREATTIME }}</td>
</tr>
<tr>
<td class="tbg">整改类型</td>
<td>
<template v-if="pd.RECTIFICATIONTYPE=='1'">
立即整改
</template>
<template v-else-if="pd.RECTIFICATIONTYPE=='2'">
限期整改
</template>
</td>
</tr>
<tr>
<td class="tbg">整改负责人</td>
<td >{{ pd.oldUserName }}</td>
</tr>
<tr v-if="pd.RECTIFICATIONTYPE=='2'">
<td class="tbg">整改完成期限</td>
<td>{{ pd.oldRectificationDeadline }}</td>
</tr>
<tr>
<td class="tbg">是否是相关方</td>
<td>{{ pd.ISRELEVANT ==='1'?'是':'否' }}</td>
</tr>
<tr v-if="playerOptions.sources[0].src">
<td class="tbg">隐患视频</td>
<td>
<span style="color: #4395ff;cursor: pointer" @click="dialogVideoVisible = true">隐患视频</span>
</td>
</tr>
</table>
<div v-for="(item,index) in hiddenExamineList" :key="index">
<div class="level-line" />
<div class="level-title">
<h1 v-if="item.TYPE === 4">确认信息</h1>
<h1 v-else-if="item.TYPE === 2">延期信息</h1>
<h1 v-else-if="item.TYPE === 1">特殊处理审核信息</h1>
</div>
<table v-if="item.TYPE === 4" class="table-ui">
<tr>
<td class="tbg">隐患级别</td>
<td >{{ item.editLevelName }}</td>
</tr>
<tr>
<td class="tbg">整改负责人</td>
<td >{{ item.editUserName }}</td>
</tr>
<tr>
<td class="tbg">整改完成期限</td>
<td >{{ item.spare3 }}</td>
</tr>
<tr>
<td class="tbg">隐患确认人</td>
<td>{{ pd.conUserName }}</td>
</tr>
<tr >
<td class="tbg">隐患确认时间</td>
<td>{{ pd.CONFIRM_TIME }}</td>
</tr>
</table>
<table v-else-if="item.TYPE === 2" class="table-ui">
<tr>
<td class="tbg">申请延期日期</td>
<td >{{ item.DELAY_TIME }}</td>
</tr>
<tr>
<td class="tbg">审核人</td>
<td>{{ pd.conUserName }}</td>
</tr>
<tr>
<td class="tbg">处置方案</td>
<td >{{ item.DISPOSAL_PLAN }}</td>
</tr>
<tr v-if="item.DISPOSAL_FILE">
<td class="tbg">方案附件</td>
<td><a style="color: #1e9fff" @click="goViewPdf(item.DISPOSAL_FILE)">[预览]</a> </td>
</tr>
<tr>
<td class="tbg">延期审核状态</td>
<template v-if="item.STATE===-1">
<td>待审核</td>
</template>
<template v-else-if="item.STATE===1">
<td>通过</td>
</template>
<template v-else-if="item.STATE===2">
<td>未通过</td>
</template>
</tr>
<tr v-if="item.STATE===1">
<td class="tbg">审核时间</td>
<td>{{ item.OPERATTIME }}</td>
</tr>
</table>
<table v-else-if="item.TYPE === 1" class="table-ui">
<tr>
<td class="tbg">无法整改原因</td>
<td >{{ item.EXAMINE }}</td>
</tr>
<tr>
<td class="tbg">特殊处置审核状态</td>
<template v-if="item.STATE===-1">
<td>待审核</td>
</template>
<template v-else-if="item.STATE===2">
<td>通过</td>
</template>
<template v-else-if="item.STATE===1">
<td>未通过</td>
</template>
</tr>
<tr v-if="item.STATE===2">
<td class="tbg">处置方案</td>
<td>{{ item.DISPOSAL_PLAN }}</td>
</tr>
<tr v-if="item.STATE===2 && item.DISPOSAL_FILE">
<td class="tbg">处置方案附件</td>
<td><a style="color: #1e9fff" @click="goViewPdf(item.DISPOSAL_FILE)">[预览]</a></td>
</tr>
<tr v-if="item.STATE!==-1">
<td class="tbg">审核时间</td>
<td>{{ item.OPERATTIME }}</td>
</tr>
<tr v-if="item.STATE!==-1">
<td class="tbg">审核人</td>
<td>{{ pd.conUserName }}</td>
</tr>
<tr v-if="item.TYPE ==='2'">
<td class="tbg">是否更换整改负责人</td>
<td v-if="item.spare1==='1'">是</td>
<td v-if="item.spare1==='0'">否</td>
</tr>
<tr v-if="item.spare1==='1'">
<td class="tbg">整改负责人</td>
<td >{{ item.NEWRECTIFICATIONOR }}</td>
</tr>
</table>
</div>
<div v-show="pd.STATE>=2 && pd.STATE !=8">
<div class="level-line" />
<div class="level-title">
<h1>整改信息</h1>
</div>
<table class="table-ui">
<tr>
<td class="tbg">整改描述</td>
<td>{{ pd.RECTIFYDESCR }}</td>
</tr>
<tr>
<td class="tbg">整改部门</td>
<td>{{ pd.RECTIFICATIONDEPTNAME }}</td>
</tr>
<tr>
<td class="tbg">整改人</td>
<td>{{ pd.RECTIFICATIONORNAME }}</td>
</tr>
<tr>
<td class="tbg">整改时间</td>
<td>{{ pd.RECTIFICATIONTIME }}</td>
</tr>
<tr>
<td class="tbg">投入资金</td>
<td>{{ pd.INVESTMENT_FUNDS }}元</td>
</tr>
<tr>
<td class="tbg">整改后图片</td>
<td class="img-select">
<viewer :images="rImgs">
<img v-for="item in rImgs" :src="config.fileUrl + item.FILEPATH" :key="item.IMGFILES_ID" width="100" height="100">
</viewer>
</td>
</tr>
<tr>
<td class="tbg">整改方案</td>
<td v-if="pd.HAVESCHEME==0">无</td>
<td v-else-if="pd.HAVESCHEME==1">有</td>
<td v-else/>
</tr>
</table>
<div class="level-line" />
</div>
<div v-show="hs.HIDDENSCHEME_ID && pd.HAVESCHEME==1">
<div class="level-title">
<h1>整改方案</h1>
</div>
<table class="table-ui">
<tr>
<td class="tbg">排查日期</td>
<td>{{ hs.SCREENINGDATE }}</td>
</tr>
<tr>
<td class="tbg">隐患清单</td>
<td>{{ hs.LISTNAME }}</td>
</tr>
<tr>
<td class="tbg">治理标准要求</td>
<td>{{ hs.GOVERNSTANDARDS }}</td>
</tr>
<tr>
<td class="tbg">治理方法</td>
<td>{{ hs.GOVERNMETHOD }}</td>
</tr>
<tr >
<td class="tbg">经费和物资的落实</td>
<td>{{ hs.EXPENDITURE }}</td>
</tr>
<tr >
<td class="tbg">负责治理人员</td>
<td>{{ hs.PRINCIPAL }}</td>
</tr>
<tr >
<td class="tbg">工时安排</td>
<td>{{ hs.PROGRAMMING }}</td>
</tr>
<tr >
<td class="tbg">时限要求</td>
<td>{{ hs.TIMELIMITFOR }}</td>
</tr>
<tr >
<td class="tbg">工作要求</td>
<td>{{ hs.JOBREQUIREMENT }}</td>
</tr>
<tr >
<td class="tbg">其他事项</td>
<td>{{ hs.OTHERBUSINESS }}</td>
</tr>
<tr>
<td class="tbg">方案图片</td>
<td class="img-select">
<viewer :images="sImgs">
<img v-for="item in sImgs" :src="config.fileUrl + item.FILEPATH" :key="item.IMGFILES_ID" width="100" height="100">
</viewer>
</td>
</tr>
</table>
<div class="level-line" />
</div>
<div v-show="pd.STATE == 4">
<div class="level-line" />
<div class="level-title">
<h1>验收信息</h1>
</div>
<template >
<table v-for="(data) in checkList" :key="data.value" class="table-ui">
<tr>
<td class="tbg">验收描述</td>
<td>{{ data.CHECKDESCR }}</td>
</tr>
<tr>
<td class="tbg">是否合格</td>
<td>
<template v-if="data.STATUS=='1'">
</template>
<template v-else-if="data.STATUS=='0'">
</template>
</td>
</tr>
<tr>
<td class="tbg">验收部门</td>
<td>{{ data.CHECKDEPTNAME }}</td>
</tr>
<tr>
<td class="tbg">验收人</td>
<td>{{ data.CHECKORNAME }}</td>
</tr>
<tr>
<td class="tbg">验收时间</td>
<td>{{ data.CHECK_TIME }}</td>
</tr>
<tr>
<td class="tbg">验收图片</td>
<td class="img-select">
<viewer :images="data.cImgs">
<img v-for="item in data.cImgs" :src="config.fileUrl + item.FILEPATH" :key="item.IMGFILES_ID" width="100" height="100">
</viewer>
</td>
</tr>
</table>
</template>
</div>
<div class="mt-20">
<div class="level-title">
<h1>安全环保检查验收</h1>
</div>
<div>
<el-form ref="form" :rules="formRule" :model="form" label-width="90px">
<el-form-item label="是否合格" prop="FINAL_CHECK">
<el-radio-group ref="FINAL_CHECK" v-model="form.FINAL_CHECK">
<el-radio label="1" value="1" >是</el-radio>
<el-radio label="2" value="2" >否</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item prop="FINAL_CHECKDESCR" label="验收意见" >
<el-input ref="FINAL_CHECKDESCR" v-model="form.FINAL_CHECKDESCR" placeholder="验收意见"/>
</el-form-item>
<el-form-item prop="FINAL_CHECKTIME" label="验收时间" >
<el-date-picker ref="FINAL_CHECKTIME" v-model="form.FINAL_CHECKTIME" type="date" value-format="yyyy-MM-dd" placeholder="选择日期" />
</el-form-item>
<el-form-item label="验收图片" >
<el-upload
ref="upload"
:on-preview="handlePictureCardPreview"
:before-upload="beforeFileUpload"
:auto-upload="false"
class="avatar-uploader"
action="#"
accept=".jpg,.jpeg,.png"
list-type="picture-card">
<i class="el-icon-plus" />
</el-upload>
<el-dialog :visible.sync="dialogVisible">
<img :src="check_imgList" width="100%" alt="">
</el-dialog>
</el-form-item>
</el-form>
</div>
</div>
</div>
</div>
<div class="ui-height" />
<div class="ui-foot">
<el-button type="primary" @click="save">保 存</el-button>
<el-button plain type="info" @click="back">返 回</el-button>
</div>
<el-dialog :visible.sync="dialogVideoVisible" title="隐患视频">
<div>
<video-player
ref="videoPlayer"
:playsinline="true"
:options="playerOptions"
style="width: 100%;"
class="video-player vjs-custom-skin"/>
</div>
<span slot="footer" class="dialog-footer">
<el-button @click="dialogVideoVisible = false">关 闭</el-button>
</span>
</el-dialog>
<el-dialog :visible.sync="dialogViewPdf" title="文档" width="600px">
<div>
<iframe :src="pdfUrl" width="500px" height="500px" frameborder="1" />
</div>
</el-dialog>
</div>
</template>
<script>
import Pagination from '@/components/Pagination'
import waves from '@/directive/waves'
import { requestFN } from '@/utils/request'
import { upload } from '@/utils/upload'
import 'video.js/dist/video-js.css'
import { videoPlayer } from 'vue-video-player'
export default {
components: { Pagination, videoPlayer },
directives: { waves },
data() {
return {
config: config,
HIDDEN_ID: '', // 主键ID
pd: {}, // 存放字段参数 Wesdddrrrf 呃呃呃呃,
hs: {},
checkList: [],
check: [],
msg: 'add',
check_files: [],
check_imgList: [],
FINAL_CHECK: '1',
rImgs: [],
hImgs: [],
cImgs: [],
sImgs: [],
form: {
FINAL_CHECK: '1',
FINAL_CHECKTIME: '',
FINAL_CHECKDESCR: ''
},
formRule: {
FINAL_CHECKTIME: [{ required: true, message: '请输入验收时间', trigger: 'blur' }],
FINAL_CHECKDESCR: [{ required: true, message: '请输入验收描述', trigger: 'blur' }],
check_imgList: [{ required: true, message: '请上传验收照片', trigger: 'blur' }]
},
dialogVisible: false,
playerOptions: {
playbackRates: [0.5, 1.0, 1.5, 2.0], // 可选的播放速度
autoplay: false, // 如果为true,浏览器准备好时开始回放。
muted: false, // 默认情况下将会消除任何音频。
loop: false, // 是否视频一结束就重新开始。
preload: 'auto', // 建议浏览器在<video>加载元素后是否应该开始下载视频数据。auto浏览器选择最佳行为,立即开始加载视频(如果浏览器支持)
language: 'zh-CN',
aspectRatio: '16:9', // 将播放器置于流畅模式,并在计算播放器的动态大小时使用该值。值应该代表一个比例 - 用冒号分隔的两个数字(例如"16:9"或"4:3"
fluid: true, // 当true时Video.js player将拥有流体大小。换句话说它将按比例缩放以适应其容器。
sources: [{
type: 'video/mp4', // 类型
src: '' // url地址
}],
poster: '', // 封面地址
notSupportedMessage: '此视频暂无法播放,请稍后再试', // 允许覆盖Video.js无法播放媒体源时显示的默认信息。
controlBar: {
timeDivider: true, // 当前时间和持续时间的分隔符
durationDisplay: true, // 显示持续时间
remainingTimeDisplay: false, // 是否显示剩余时间功能
fullscreenToggle: true // 是否显示全屏按钮
}
},
dialogVideoVisible: false,
// pdf预览
pdfUrl: '',
pageNum: 1,
pageTotalNum: 1, // 总页数
dialogViewPdf: false,
hiddenFindPeople: [],
hiddenExamineList: []
}
},
created() {
if (this.$parent.HIDDEN_ID) {
this.HIDDEN_ID = this.$parent.HIDDEN_ID
this.getData()
}
},
methods: {
getData() {
requestFN(
'/hidden/goEdit',
{
HIDDEN_ID: this.HIDDEN_ID,
tm: new Date().getTime()
}
).then((data) => {
if (data.result == 'success') {
this.pd = data.pd // 参数map
this.hs = Object.assign(this.hs, data.hs) // 参数map
this.checkList = data.checkList
this.hImgs = data.hImgs
this.rImgs = data.rImgs
this.cImgs = data.cImgs
this.sImgs = data.sImgs
this.hiddenFindPeople = data.hiddenFindPeople
if (data.hiddenVideo.length > 0) {
this.playerOptions.sources[0].src = config.fileUrl + data.hiddenVideo[0].FILEPATH
}
this.hiddenExamineList = data.hiddenExa
data.hiddenExa.forEach(item => {
if (item.TYPE === 4) {
this.pd.oldUserName = item.oldUserName
this.pd.oldDeptName = item.oldDeptName
this.pd.oldLevelName = item.oldLevelName
this.pd.oldRectificationDeadline = item.spare3
}
})
}
}).catch((e) => {
this.listLoading = false
})
},
goViewPdf(filePath) {
this.pageNum = 1
this.pdfUrl = this.config.fileUrl + filePath
// this.pdfUrl = 'http://192.168.50.60:8082/file/' + filePath
console.info(this.pdfUrl)
this.dialogViewPdf = true
},
// 返回列表
back() {
this.$parent.activeName = 'HiddenList'
},
handlePictureCardPreview(file) {
this.check_imgList = file.url
this.dialogVisible = true
},
beforeFileUpload(file) {
const types = ['image/jpeg', 'image/jpg', 'image/png']
const isImage = types.includes(file.type)
if (!isImage) {
this.$message.error('上传图片只能是 JPG、JPEG、PNG 格式!')
} else {
this.check_imgList.push(file)
}
},
save() {
var _this = this
this.$refs.form.validate(valid => {
if (valid) {
requestFN(
'/safetyenvironmental/V2/finalcheck',
{
HIDDEN_ID: this.HIDDEN_ID,
FINAL_CHECKDESCR: this.form.FINAL_CHECKDESCR,
FINAL_CHECKTIME: this.form.FINAL_CHECKTIME,
FINAL_CHECK: this.form.FINAL_CHECK,
INSPECTION_ID: this.pd.FOREIGN_ID,
tm: new Date().getTime()
}
).then((data) => {
if (data.result == 'success') {
this.saveCheckImg(_this.HIDDEN_ID)
this.$parent.activeName = 'HiddenList'
}
}).catch((e) => {
this.listLoading = false
})
} else {
return false
}
})
},
saveCheckImg(imgKeyId) {
this.$refs.upload.submit()
var _this = this
var todata = new FormData()
for (var i = 0; i < _this.check_imgList.length; i++) {
if (_this.check_imgList[i]) {
todata.append('FFILE', _this.check_imgList[i])
}
}
if (!todata.get('FFILE')) {
return
}
todata.append('FOREIGN_KEY', imgKeyId)
todata.append('TYPE', 50)
upload(
'/imgfiles/add',
todata
).then((data) => {
if (data.result == 'success') {
this.$message({
message: '保存成功',
type: 'success'
})
}
}).catch((e) => {
this.listLoading = false
})
}
}
}
</script>
<style lang="sass" scoped>
.form-flex
display: flex
align-items: center
margin-bottom: 18px
.form-item
width: 300px
.el-form-item--small.el-form-item
margin-bottom: 0
.table-ui
.tbg
width: 150px
.img-flex
display: flex
.img-ui
width: 240px
height: 240px
margin-right: 20px
& img
width: 100%
height: 100%
</style>