detection-business/pages/xiaoxi/details.vue
2025-08-08 14:27:37 +08:00

409 lines
7.4 KiB
Vue

<template>
<view class="content">
<view class="c-top">
<view class="" @click="getback()">
<uni-icons type="left" size="18"></uni-icons>
</view>
<view class="c-title">{{ flag ? obj.newsTitle : obj.title }}</view>
<view class=""></view>
</view>
<!-- html -->
<view class="c-content" v-if="flag">
<view class="cont-gongs">{{ obj.publishUnit }}</view>
<u-parse :content="obj.newsContent" :tagStyle="style"></u-parse>
<view class="videobox" v-if="videoList != null && videoList !== ''">
<video :src="baseUrl+ videoList" controls></video>
</view>
<view class="cont-time">{{ getDate(createTime) || new Date() }}</view>
</view>
<view class="c-content" v-else>
<u-parse style="font-size: 18px;text-indent: 2rem" :content="obj.content" :tagStyle="style"></u-parse>
<view class="cont-time">{{ getDate(obj.createTime) || new Date() }}</view>
</view>
<uni-popup ref="alertDialog" type="dialog">
<uni-popup-dialog :type="msgType" cancelText="关闭" confirmText="同意" title="通知" content="您确认删除吗"
@confirm="dialogConfirm()"
@close="dialogClose"></uni-popup-dialog>
</uni-popup>
</view>
</template>
<script>
import config from '@/config'
import request from '../../utils/request';
import {formatDate} from "../../utils/utils";
export default {
data() {
return {
id: '',
obj: {},
style: {
image: 'width: 100%;'
},
inputvalue: '',
createTime: '',
pinglun: false,
dianzan: false,
shoucang: false,
baseUrl: config.baseImageUrl,
pinglunlist: [],
arrlist: [],
user: {},
videoList: null,
type: 'center',
msgType: 'success',
messageText: '这是一条成功提示',
flag: true
}
},
onLoad(option) {
this.id = option.id
if (option.index) {
this.flag = false
this.getWarnDetail()
} else {
this.getlistindex()
}
},
onShow() {
this.user = uni.getStorageSync('userinfo')
},
methods: {
getWarnDetail(){
request({
url: '/warnMsg/warnMsg/' + this.id,
method: 'get'
}).then(res => {
this.obj = res.data
})
},
getDate(value) {
return formatDate(value)
},
//dianzan
async getdianzan() {
let data = {
newsId: this.id,
type: 'like',
}
let res = await request({
url: '/appInspection/news/likeOrCollect',
method: 'post',
params: data
})
this.getlistindex()
},
async getdelete(id) {
let data = {
commentId: id,
}
let res = await request({
url: '/appInspection/news/delNewsComment',
method: 'post',
params: data
})
this.getlistindex()
},
//评论
getpinglun() {
this.pinglun = !this.pinglun
},
getback() {
uni.navigateBack({
delta: 1,
})
},
async getnew() {
let data = {
newsId: this.id,
}
let res = await request({
url: '/appInspection/news/getDetail',
method: 'get',
params: data
})
},
async getlistindex() {
let res = await request({
url: '/appInspection/news/getDetail?newsId=' + this.id,
method: 'get',
})
this.obj = res.data
this.videoList = res.data.videoUrl
if (res.data.isLike == '1') {
this.dianzan = true
} else {
this.dianzan = false
}
if (res.data.isCollect == '1') {
this.shoucang = true
} else {
this.shoucang = false
}
this.createTime = this.obj.createTime
let resx = await request({
url: '/appInspection/news/getCommentList?newsId=' + this.id,
})
this.pinglunlist = resx.rows
let ress = await request({
url: '/appInspection/news/addReadNum?newsId=' + this.id + '&objectId=' + uni.getStorageSync('partnerId'),
method: 'post',
})
},
async getfasong() {
let data = {
newsId: this.id,
context: this.inputvalue,
}
let res = await request({
url: '/appInspection/news/addInspectionNewsComment',
method: 'post',
data: data
})
this.inputvalue = ''
this.getlistindex()
},
dialogToggle(id) {
this.deleteid = id
this.$refs.alertDialog.open()
},
dialogClose() {
},
dialogConfirm() {
this.getdelete(this.deleteid)
},
}
}
</script>
<style scoped lang="scss">
.content {
width: 100%;
height: calc(100vh);
// background-color: #F6F6F6;
box-sizing: border-box;
// padding-top: 45px;
}
.cont-title {
width: 100%;
text-align: center;
font-size: 24px;
font-weight: bold;
color: #333333;
margin-bottom: 5px;
}
.cont-gongs {
text-align: right;
font-size: 14px;
font-weight: 400;
color: #666666;
margin-bottom: 25px;
}
.videobox {
width: 100%;
margin: 0 auto;
}
.cont-time {
font-size: 16px;
font-weight: 400;
color: #666666;
margin-bottom: 25px;
float: right;
}
.top-icon {
margin-bottom: 45px;
}
.c-top {
width: 100%;
height: 88px;
box-sizing: border-box;
padding: 15px;
padding-top: 44px;
display: flex;
justify-content: space-between;
align-items: center;
background-color: white;
}
.c-title {
font-size: 18px;
font-weight: bold
}
.c-content {
width: 100%;
background-color: white;
box-sizing: border-box;
padding: 15px;
}
.pinglist {
width: 100%;
background-color: white;
margin-top: 15px;
box-sizing: border-box;
padding: 15px;
border-radius: 16px 16px 0px 0px;
}
.pinginput {
width: 100%;
height: 50px;
background-color: white;
display: flex;
position: fixed;
bottom: 0px;
z-index: 99;
box-sizing: border-box;
padding: 15px;
display: flex;
align-items: center;
justify-content: space-between;
}
.left-input {
width: 50%;
height: 35px;
border-radius: 50px;
background: #E7E7E7;
display: flex;
align-items: center;
justify-content: space-between;
padding: 0 20px;
font-size: 16px;
}
.t-right {
width: 60px;
border-left: 1px solid #a6a6a6;
font-size: 16px;
color: #a6a6a6;
box-sizing: border-box;
padding-left: 5px;
}
.list-top {
}
.gang {
width: 8%;
height: 4px;
background: #0D2E8D;
}
.view-box {
border-bottom: 1px solid #D8D8D8;
display: flex;
justify-content: space-between;
margin-top: 10px;
box-sizing: border-box;
padding-bottom: 9px;
}
.touxiang {
width: 40px;
height: 40px;
background: #D8D8D8;
border-radius: 50%;
overflow: hidden;
image {
width: 100%;
height: 100%;
}
}
.vb-right {
width: 85%;
}
.vb-nr {
}
.vb-bottom {
width: 100%;
display: flex;
justify-content: space-between;
align-items: center;
margin-top: 5px;
}
.vb-title {
font-size: 16px;
font-weight: 400;
color: #666666;
}
.right-xuan {
display: flex;
}
.sc-botm {
display: flex;
align-items: center;
margin-right: 5px;
}
.icon-sc {
width: 20px;
height: 20px;
margin-right: 5px;
image {
width: 100%;
height: 100%;
}
}
.s-botm {
display: flex;
align-items: center;
margin-right: 5px;
color: crimson;
}
.icon-s {
width: 18px;
height: 18px;
margin-right: 5px;
image {
width: 100%;
height: 100%;
}
}
.font-s {
font-size: 15px;
line-height: 16px;
}
.zuo-hui {
font-size: 15px;
font-weight: 400;
color: #B7B7B7;
}
</style>