|
@@ -9,7 +9,7 @@
|
|
|
</div>
|
|
|
<div class="report-detail-page" @click="closeAttention" v-if="info" :style="{paddingBottom:$store.state.hzyb.audioData.url&&'80px'}">
|
|
|
<!-- 晨报、周报章节 -->
|
|
|
- <div class="chapter-list-wrap" v-if="['晨报','周报'].includes(info.report_info.classify_name_first)">
|
|
|
+ <div class="chapter-list-wrap" v-if="info.report_info.has_chapter">
|
|
|
<div class="top-box" :style="'background-image:url(' + info.report_info.banner_url + ')'">
|
|
|
<div class="title">{{info.report_info.classify_name_first}}</div>
|
|
|
<div class="sub-title">{{info.report_info.title}}</div>
|
|
@@ -67,37 +67,66 @@
|
|
|
<!-- 报告详情 -->
|
|
|
<div :class="['main-box',!info.auth_ok&&'main-box-noauth']" v-else>
|
|
|
<!-- <div class="title">【第{{info.report_info.stage}}期|{{info.report_info.classify_name_second}}】{{info.report_info.title}}</div> -->
|
|
|
- <div class="title">{{title}}</div>
|
|
|
- <div class="flex time">
|
|
|
- <span>FICC团队</span>
|
|
|
- <span>{{formatTime(info.report_info.publish_time)}}</span>
|
|
|
- </div>
|
|
|
- <!-- 音频模块 -->
|
|
|
- <AudioBox :audioData="audioData" v-if="info.report_info.video_url&&info.report_info.video_play_seconds>0"></AudioBox>
|
|
|
- <div class="flex tips">
|
|
|
- <div style="flex:1">
|
|
|
- <div v-if="info.road_video_id">点击<span style="color: #e3b377;" @click="goVideoPage">查看视频</span></div>
|
|
|
- <div class="abstract" v-if="info.report_info.abstract">摘要:{{info.report_info.abstract}}</div>
|
|
|
- <div>
|
|
|
- <span>注:请务必阅读</span>
|
|
|
- <span style="color:#E3B377;margin-left:20px" @click="showDisclaimers=true">免责声明</span>
|
|
|
- <span
|
|
|
- v-if="info.report_info.video_url&&info.report_info.video_play_seconds>0"
|
|
|
- style="float:right;background:#E3B377;color:#fff;border-radius:30px;padding:0 10px;font-size:0.9em" @click="handlePlayAudioBG"
|
|
|
- >背景播放</span>
|
|
|
+ <div :style="{backgroundColor:info.report_info.canvas_color||''}">
|
|
|
+ <!-- 无版头板尾显示标题 -->
|
|
|
+ <template v-if="(!info.report_info.head_img) && (!info.report_info.end_img)">
|
|
|
+ <div class="title">{{title}}</div>
|
|
|
+ <div class="flex time">
|
|
|
+ <span>FICC团队</span>
|
|
|
+ <span>{{formatTime(info.report_info.publish_time)}}</span>
|
|
|
+ </div>
|
|
|
+ </template>
|
|
|
+
|
|
|
+ <!-- 拼接版头 -->
|
|
|
+ <div class="html-head-img-box" v-if="info.auth_ok&&info.report_info.head_img">
|
|
|
+ <img :src="info.report_info.head_img" alt="" style="display:block;width:100%">
|
|
|
+ <div class="head-layout-item" v-for="item in headImgStyle" :key="item.value"
|
|
|
+ :style="{fontFamily:item.family,fontSize:(item.size*2)+'px',fontWeight:item.weight,textAlign:item.align,color:item.color,
|
|
|
+ width:item.width,height:item.height,left:item.left,top:item.top
|
|
|
+ }">
|
|
|
+ {{ layoutBaseInfo[item.value] }}
|
|
|
</div>
|
|
|
</div>
|
|
|
- </div>
|
|
|
- <div id="report-rich-content" class="rich-content" style="position: relative;" ref="richConBox">
|
|
|
- <div v-if="info.auth_ok">
|
|
|
- <ul>
|
|
|
- <li v-for="item in realContent" :key="item" v-html="item"></li>
|
|
|
- </ul>
|
|
|
+
|
|
|
+
|
|
|
+ <!-- 音频模块 -->
|
|
|
+ <AudioBox :audioData="audioData" v-if="info.report_info.video_url&&info.report_info.video_play_seconds>0"></AudioBox>
|
|
|
+ <div class="flex tips">
|
|
|
+ <div style="flex:1">
|
|
|
+ <div v-if="info.road_video_id">点击<span style="color: #e3b377;" @click="goVideoPage">查看视频</span></div>
|
|
|
+ <div class="abstract" v-if="info.report_info.abstract">摘要:{{info.report_info.abstract}}</div>
|
|
|
+ <div>
|
|
|
+ <span>注:请务必阅读</span>
|
|
|
+ <span style="color:#E3B377;margin-left:20px" @click="showDisclaimers=true">免责声明</span>
|
|
|
+ <span
|
|
|
+ v-if="info.report_info.video_url&&info.report_info.video_play_seconds>0"
|
|
|
+ style="float:right;background:#E3B377;color:#fff;border-radius:30px;padding:0 10px;font-size:0.9em" @click="handlePlayAudioBG"
|
|
|
+ >背景播放</span>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
</div>
|
|
|
- <div v-html="info.report_info.content_sub" v-else></div>
|
|
|
- <!-- 隐藏的水印 -->
|
|
|
- <div class="hide-watermark-box" v-if="userInfo">
|
|
|
- <div v-for="item in 20" :key="item">{{userInfo.mobile}}</div>
|
|
|
+ <div id="report-rich-content" class="rich-content" style="position: relative;" ref="richConBox">
|
|
|
+ <div v-if="info.auth_ok">
|
|
|
+ <ul>
|
|
|
+ <li v-for="item in realContent" :key="item" v-html="item"></li>
|
|
|
+ </ul>
|
|
|
+ </div>
|
|
|
+ <div v-html="info.report_info.content_sub" v-else></div>
|
|
|
+ <!-- 隐藏的水印 -->
|
|
|
+ <div class="hide-watermark-box" v-if="userInfo">
|
|
|
+ <div v-for="item in 20" :key="item">{{userInfo.mobile}}</div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+
|
|
|
+ <!-- 拼接版尾 -->
|
|
|
+ <div class="html-end-img-box" v-if="info.auth_ok&&info.report_info.end_img">
|
|
|
+ <img :src="info.report_info.end_img" alt="" style="display:block;width:100%">
|
|
|
+ <div class="head-layout-item" v-for="item in endImgStyle" :key="item.value"
|
|
|
+ :style="{fontFamily:item.family,fontSize:(item.size*2)+'px',fontWeight:item.weight,textAlign:item.align,color:item.color,
|
|
|
+ width:item.width,height:item.height,left:item.left,top:item.top
|
|
|
+ }">
|
|
|
+ {{ layoutBaseInfo[item.value] }}
|
|
|
+ </div>
|
|
|
</div>
|
|
|
</div>
|
|
|
|
|
@@ -141,7 +170,7 @@
|
|
|
</div>
|
|
|
|
|
|
<!-- 留言点赞模块 -->
|
|
|
- <div id="messgaeBoardCont" v-if="info.auth_ok && !['晨报','周报'].includes(info.report_info.classify_name_first)">
|
|
|
+ <div id="messgaeBoardCont" v-if="info.auth_ok && !info.report_info.has_chapter">
|
|
|
<LeaveMessage
|
|
|
:info="info"
|
|
|
@like_change="giveOrCancelLike"
|
|
@@ -253,7 +282,15 @@ export default {
|
|
|
|
|
|
showAttention:false,//是否显示配置播放清单提示
|
|
|
isReportPublishCancel:false,//报告取消发布
|
|
|
- bannerDataList:[]
|
|
|
+ bannerDataList:[],
|
|
|
+
|
|
|
+ headImgStyle:null,//版头style
|
|
|
+ endImgStyle:null,//版尾style
|
|
|
+ layoutBaseInfo:{
|
|
|
+ 研报标题:'',
|
|
|
+ 研报作者:'',
|
|
|
+ 创建时间:''
|
|
|
+ }
|
|
|
}
|
|
|
},
|
|
|
beforeCreate(){
|
|
@@ -402,6 +439,13 @@ export default {
|
|
|
const res=await apiReportDetail({report_id:Number(this.reportId)})
|
|
|
if(res.code===200){
|
|
|
this.info=res.data
|
|
|
+
|
|
|
+ this.headImgStyle=res.data.report_info.head_style?JSON.parse(res.data.report_info.head_style):[]
|
|
|
+ this.endImgStyle=res.data.report_info.end_style?JSON.parse(res.data.report_info.end_style):[]
|
|
|
+ this.layoutBaseInfo['研报标题']=res.data.report_info.title
|
|
|
+ this.layoutBaseInfo['研报作者']=res.data.report_info.author
|
|
|
+ // 已发布已通过的报告才显示发布时间
|
|
|
+ this.layoutBaseInfo['创建时间']=moment(res.data.report_info.publish_time).format('YYYY.MM.DD HH:mm')
|
|
|
this.audioData={
|
|
|
auth_ok:res.data.auth_ok,
|
|
|
video_name:res.data.report_info.video_name,
|
|
@@ -440,7 +484,7 @@ export default {
|
|
|
}
|
|
|
|
|
|
// 处理报告标题数据
|
|
|
- if(!['晨报','周报'].includes(res.data.report_info.classify_name_first)){
|
|
|
+ if(!this.info.report_info.has_chapter){
|
|
|
//【第{{info.report_info.stage}}期|{{info.report_info.classify_name_second}}】{{info.report_info.title}}
|
|
|
const time=moment(res.data.report_info.publish_time).format('MMDD')
|
|
|
if(res.data.report_info.classify_name_second==res.data.report_info.title){
|
|
@@ -463,7 +507,7 @@ export default {
|
|
|
}else{
|
|
|
shareTitle=res.data.report_info.title
|
|
|
imgText=`<div style="font-size:78px">${moment(res.data.report_info.publish_time).format('YYYY/MM/DD')}</div><div style="font-size:78px">第${res.data.report_info.stage}期 | ${res.data.report_info.classify_name_second}</div>`
|
|
|
- if(['晨报','周报'].includes(res.data.report_info.classify_name_first)){
|
|
|
+ if(this.info.report_info.has_chapter){
|
|
|
imgText=`<div style="font-size:78px">${moment(res.data.report_info.publish_time).format('YYYY/MM/DD')}</div><div style="font-size:78px">第${res.data.report_info.stage}期 | ${res.data.report_info.classify_name_first} </div>`
|
|
|
}
|
|
|
}
|
|
@@ -524,6 +568,19 @@ export default {
|
|
|
target.style.background = "url(" + data + ") repeat";
|
|
|
},
|
|
|
|
|
|
+ // 智能布局内容排版全部变成1个1行的顺排
|
|
|
+ formatSmartStyle() {
|
|
|
+ this.$nextTick(() =>{
|
|
|
+ $('.report-drag-item-wrap_child-wrap').css({
|
|
|
+ 'flex-wrap': 'wrap',
|
|
|
+ });
|
|
|
+ $('.report-drag-item-wrap_child-wrap').children().css({
|
|
|
+ 'flex': 'none',
|
|
|
+ 'width': '100%'
|
|
|
+ });
|
|
|
+ })
|
|
|
+ },
|
|
|
+
|
|
|
/*内容分割*/
|
|
|
splitContentHandle(content) {
|
|
|
content=addTokenToIframe(content,this.reportId,0)
|
|
@@ -531,11 +588,13 @@ export default {
|
|
|
this.totalContent = arr.map(_ => _+'</p>');
|
|
|
this.realContent = this.totalContent.slice(0,this.pageSize)
|
|
|
this.total_page = parseInt(this.totalContent.length / this.pageSize) + 1;
|
|
|
+ this.formatSmartStyle()
|
|
|
},
|
|
|
|
|
|
/* 加载下一页内容 */
|
|
|
loadContent() {
|
|
|
this.realContent = this.realContent.concat(this.totalContent.slice(this.page_no*this.pageSize, (this.page_no + 1)*this.pageSize))
|
|
|
+ this.formatSmartStyle()
|
|
|
},
|
|
|
|
|
|
loadMoreHandle: _.throttle(function() {
|
|
@@ -1114,4 +1173,14 @@ export default {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+.html-head-img-box,.html-end-img-box{
|
|
|
+ margin-bottom: 10px;
|
|
|
+ position: relative;
|
|
|
+ overflow: hidden;
|
|
|
+ .head-layout-item{
|
|
|
+ position: absolute;
|
|
|
+ overflow: hidden;
|
|
|
+ box-sizing: border-box
|
|
|
+ }
|
|
|
+}
|
|
|
</style>
|