chapterDetail.vue 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466
  1. <template>
  2. <view class="chapter-detail-page" v-if="info">
  3. <view class="main-box">
  4. <view class="title">【第{{info.report_chapter_item.stage}}期 | {{info.report_chapter_item.classify_name_first}} | {{info.report_chapter_item.type_name}}】{{info.report_chapter_item.title}}</view>
  5. <view class="flex time">
  6. <text>FICC团队</text>
  7. <text>{{formatTime(info.report_chapter_item.publish_time)}}</text>
  8. </view>
  9. <view class="flex audio-wrap">
  10. <image style="opacity:0.3" src="./static/audio-pause.png" mode="aspectFill" v-if="!info.auth_ok"/>
  11. <image src="./static/audio-pause.png" mode="aspectFill" v-else/>
  12. <view>
  13. <view>{{info.report_chapter_item.video_name}}</view>
  14. <view style="color: #999999">{{info.report_chapter_item.video_play_seconds|formatVoiceTime}}</view>
  15. </view>
  16. </view>
  17. <view class="tips">
  18. <text>注:请务必阅读</text>
  19. <text style="color: #e3b377; margin-left: 20rpx" @click="showDisclaimers = true">免责声明</text>
  20. </view>
  21. <view class="rich-content">
  22. <mp-html :content="info.report_chapter_item.content" v-if="info.auth_ok" />
  23. <mp-html :content="info.report_chapter_item.content_sub" v-else />
  24. </view>
  25. <!-- 无权限 -->
  26. <view class="no-auth-wrap" v-if="!info.auth_ok">
  27. <view class="apply-box" v-if="info.permission_check.type=='apply'">
  28. <view>您暂无权限查看报告,若想查看请申请开通</view>
  29. <view class="btn" @click="handleGoApply">立即申请</view>
  30. </view>
  31. <view class="apply-box" v-else>
  32. <view>您暂无权限查看报告 </view>
  33. <view>若想查看请联系对口销售:{{info.permission_check.name}}</view>
  34. <view class="btn" @click="handleContact">立即联系</view>
  35. </view>
  36. </view>
  37. <!-- 指标数据模块 -->
  38. <view class="ticker-wrap" v-if="tickerInfo">
  39. <view class="top-title">{{tickerInfo.ticker_title.report_chapter_type_name}}数据表</view>
  40. <view class="table-box">
  41. <view class="table-row table-head">
  42. <view class="table-item" v-for="item in tickerHead" :key="item.key">{{item.label}}</view>
  43. </view>
  44. <view class="table-row table-body" v-for="(tr,index) in tickerInfo.list" :key="tr.base_column_name">
  45. <view :class="['table-item',index%2==0?'grey':'',tr[td.key]<0?'minus':'']" v-for="td in tickerHead" :key="td.key">{{tr[td.key]}}</view>
  46. </view>
  47. </view>
  48. <view v-if="tickerInfo.ticker_title.report_chapter_type_id ===26" style="text-align:center;font-weight:bold">注:与新加坡TSR20相关数据均取展示日期前一交易日数据</view>
  49. <view></view>
  50. </view>
  51. </view>
  52. <!-- 章节详情底部快速切换 -->
  53. <view class="chapter-list-wrap" v-if="formPage!='home'">
  54. <view class="top-text">更多</view>
  55. <van-row gutter="10">
  56. <van-col span="6" v-for="item in info.report_chapter_menu_list" :key="item.report_chapter_id">
  57. <view :class="['item',item.report_chapter_id==chapterId&&'active']" @click="handleChapterChange(item)">
  58. <image :src="item.report_chapter_type_thumb" mode="aspectFill"/>
  59. <text>{{item.report_chapter_type_name}}</text>
  60. </view>
  61. </van-col>
  62. </van-row>
  63. </view>
  64. <!-- 返回顶部 -->
  65. <image @click="handleBackTop" class="back-top-img" src="./static/back-top.png" mode="aspectFill" />
  66. <!-- 免责声明 -->
  67. <van-popup :show="showDisclaimers" @close="showDisclaimers = false" round closeable>
  68. <view class="disclaimers-box">
  69. <view style="text-align: center; font-size: 16px; font-weight: bold; margin-bottom: 20rpx">免责声明</view>
  70. <view style="margin-bottom: 10rpx">1、本报告仅供弘则弥道(上海)投资咨询有限公司正式签约的机构客户使用,不会仅因接收人/接受机构收到本报告而将其视为客户。</view>
  71. <view style="margin-bottom: 10rpx"
  72. >2、本报告根据国际和行业通行的准则,以合法渠道获得这些信息,尽可能保证可靠、准确和完整,但并不保证报告所述信息的准确性和完整性,也不保证本报告所包含的信息或建议在本报告发出后不会发生任何变更。本报告中所提供的信息仅供参考。</view
  73. >
  74. <view style="margin-bottom: 10rpx"
  75. >3、报告中的内容不对投资者做出的最终操作建议做任何的担保,也没有任何形式的分享投资收益或者分担投资损失的书面或口头承诺。不作为客户在投资、法律、会计或税务等方面的最终操作建议,也不作为道义的、责任的和法律的依据或者凭证,无论是否已经明示或者暗示。</view
  76. >
  77. <view style="margin-bottom: 10rpx">4、在任何情况下,本公司不对客户/接受人/接受机构因使用报告中内容所引致的一切损失负责任,客户/接受人/接受机构需自行承担全部风险。</view>
  78. </view>
  79. </van-popup>
  80. <!-- 申请提示弹窗 -->
  81. <van-popup :show="pupData.show" @close="pupData.show=false" :close-on-click-overlay="false">
  82. <view class="global-pup">
  83. <view class="content">
  84. <rich-text :nodes="pupData.content"></rich-text>
  85. </view>
  86. <view class="flex bot">
  87. <view @click="pupData.show=false">知道了</view>
  88. </view>
  89. </view>
  90. </van-popup>
  91. </view>
  92. </template>
  93. <script>
  94. const moment=require('@/utils/moment-with-locales.min')
  95. moment.locale('zh-cn');
  96. import {apiChapterDetail,apiChapterTickerValue} from '@/api/report'
  97. export default {
  98. data() {
  99. return {
  100. showDisclaimers: false, //显示免责声明
  101. html: "<h1>Hello World!</h1>",
  102. chapterId:0,
  103. formPage:'',//如果是从首页(home)来的则隐藏底部切换
  104. info:null,
  105. tickerInfo:null,
  106. tickerHead:[],
  107. pupData:{
  108. show:false,
  109. content:'',//弹窗html字符串
  110. }
  111. };
  112. },
  113. onLoad(options) {
  114. this.chapterId=options.chapterId
  115. this.formPage=options.formPage||''
  116. this.getDetail()
  117. },
  118. methods: {
  119. async getDetail(){
  120. const res=await apiChapterDetail({report_chapter_id:Number(this.chapterId)})
  121. if(res.code===200){
  122. this.info=res.data
  123. uni.setNavigationBarTitle({ title: res.data.report_chapter_item.classify_name_first })
  124. if(res.data.report_chapter_item.classify_name_first==='晨报'){
  125. this.getTickerValue()
  126. }
  127. }
  128. },
  129. //获取晨报中指标数据
  130. async getTickerValue(){
  131. const res=await apiChapterTickerValue({report_chapter_id:Number(this.chapterId)})
  132. if(res.code===200){
  133. if(!res.data.list) return
  134. this.tickerInfo=res.data
  135. if(res.data.ticker_title.report_chapter_type_id===17){
  136. this.tickerHead=[
  137. {
  138. label:res.data.ticker_title.ticker_title,
  139. key:'base_column_name'
  140. },
  141. {
  142. label:'公布日期',
  143. key:'date'
  144. },
  145. {
  146. label:'最新值',
  147. key:'ticker_value'
  148. },
  149. {
  150. label:'上期值',
  151. key:'last_value'
  152. }
  153. ]
  154. }else{
  155. this.tickerHead=[
  156. {
  157. label:res.data.ticker_title.ticker_title,
  158. key:'base_column_name'
  159. },
  160. {
  161. label:res.data.list[0].date,
  162. key:'ticker_value'
  163. },
  164. {
  165. label:'当日涨跌',
  166. key:'dd_value'
  167. },
  168. {
  169. label:'一周涨跌',
  170. key:'ww_value'
  171. },
  172. {
  173. label:'一月涨跌',
  174. key:'mm_value'
  175. }
  176. ]
  177. }
  178. }
  179. },
  180. handleBackTop() {
  181. uni.pageScrollTo({ scrollTop: 0 });
  182. },
  183. formatTime(time){
  184. return moment(time).format('YYYY-MM-DD HH:mm:ss')
  185. },
  186. handleChapterChange(item){
  187. this.chapterId=item.report_chapter_id
  188. this.info=null
  189. this.getDetail()
  190. this.handleBackTop()
  191. },
  192. // 联系销售
  193. handleContact(){
  194. uni.makePhoneCall({
  195. phoneNumber: this.info.permission_check.mobile
  196. });
  197. },
  198. //点击申请
  199. async handleGoApply(){
  200. if(this.info.permission_check.type=='apply'){
  201. if(this.info.permission_check.customer_info.has_apply){// 已经申请过
  202. this.pupData.show=true
  203. this.pupData.content=`<p>您已提交过申请,请耐心等待</p>`
  204. }else{
  205. if(!this.info.permission_check.customer_info.status||this.info.permission_check.customer_info.status!='流失'){
  206. uni.redirectTo({
  207. url:"/pages-applyPermission/applyPermission?source=4&from_page=报告详情"
  208. })
  209. }else{//主动调一次申请权限接口
  210. const res=await apiApplyPermission({
  211. company_name:this.info.permission_check.customer_info.company_name,
  212. real_name:this.info.permission_check.customer_info.name,
  213. source:4,
  214. from_page:'报告详情'
  215. })
  216. if(res.code===200){
  217. this.pupData.show=true
  218. this.pupData.content=`<p>申请已提交</p><p>请等待销售人员与您联系</p>`
  219. }
  220. }
  221. }
  222. }
  223. },
  224. },
  225. };
  226. </script>
  227. <style>
  228. page{
  229. padding-bottom: 0;
  230. }
  231. </style>
  232. <style lang="scss" scoped>
  233. .chapter-detail-page {
  234. .main-box{
  235. padding: 34rpx;
  236. }
  237. .title{
  238. font-size: 36rpx;
  239. font-weight: bold;
  240. margin-bottom: 30rpx;
  241. }
  242. .time{
  243. justify-content: space-between;
  244. font-size: 28rpx;
  245. }
  246. .audio-wrap{
  247. height: 160rpx;
  248. background: #FAF7EE;
  249. border-radius: 16rpx;
  250. margin-top: 20rpx;
  251. padding: 10rpx 31rpx;
  252. margin-bottom: 31rpx;
  253. align-items: center;
  254. image{
  255. width: 110rpx;
  256. height: 110rpx;
  257. display: block;
  258. margin-right: 16rpx;
  259. }
  260. }
  261. .tips{
  262. font-size: 34rpx;
  263. margin-bottom: 51rpx;
  264. &::before{
  265. content: '';
  266. width: 10rpx;
  267. height: 50rpx;
  268. display: inline-block;
  269. background-color: #E3B377;
  270. margin-right: 20rpx;
  271. position: relative;
  272. top: 10rpx;
  273. }
  274. }
  275. .disclaimers-box{
  276. width: 94vw;
  277. padding: 32rpx;
  278. }
  279. .rich-content{
  280. line-height: 1.7;
  281. font-size: 32rpx;
  282. }
  283. .no-auth-wrap{
  284. min-height: 200rpx;
  285. background: linear-gradient(360deg, #FFFFFF 60%, rgba(255, 255, 255, 0) 88%);
  286. position: relative;
  287. top: -150rpx;
  288. text-align: center;
  289. font-size: 32rpx;
  290. color: #E3B377;
  291. .apply-box{
  292. padding-top: 250rpx;
  293. }
  294. .btn{
  295. width: 100%;
  296. margin-left: auto;
  297. margin-right: auto;
  298. line-height: 80rpx;
  299. background-color: #E6B77D;
  300. border-radius: 4rpx;
  301. color: #fff;
  302. margin-top: 100rpx;
  303. }
  304. }
  305. .back-top-img{
  306. position: fixed;
  307. z-index: 99;
  308. width: 76rpx;
  309. height: 76rpx;
  310. right: 34rpx;
  311. bottom: 100rpx;
  312. }
  313. .chapter-list-wrap {
  314. background-color: #f5f6fa;
  315. padding: 34rpx;
  316. min-height: 300px;
  317. .top-text {
  318. text-align: center;
  319. color: #666666;
  320. margin-bottom: 30rpx;
  321. &::before {
  322. content: "";
  323. width: 90rpx;
  324. height: 1px;
  325. background-color: #999;
  326. display: inline-block;
  327. vertical-align: middle;
  328. margin-right: 10rpx;
  329. }
  330. &::after {
  331. content: "";
  332. width: 90rpx;
  333. height: 1px;
  334. background-color: #999;
  335. display: inline-block;
  336. vertical-align: middle;
  337. margin-left: 10rpx;
  338. }
  339. }
  340. .item {
  341. background-color: #fff;
  342. height: 160rpx;
  343. margin-bottom: 20rpx;
  344. text-align: center;
  345. color: #C0CFDA;
  346. font-size: 24rpx;
  347. padding-top: 20rpx;
  348. border-radius: 8rpx;
  349. overflow: hidden;
  350. image{
  351. width: 88rpx;
  352. height: 88rpx;
  353. display: block;
  354. margin-left: auto;
  355. margin-right: auto;
  356. }
  357. }
  358. .active{
  359. border: 1px solid #E3B377;
  360. position: relative;
  361. &::before{
  362. content: '';
  363. display: block;
  364. position: absolute;
  365. left: 0;
  366. top: 0;
  367. width: 0;
  368. height: 0;
  369. border-top: 46rpx solid #E3B377;
  370. border-right: 46rpx solid transparent;
  371. }
  372. }
  373. }
  374. .ticker-wrap{
  375. margin-top: 30rpx;
  376. .top-title{
  377. text-align: center;
  378. font-size: 36rpx;
  379. font-weight: bold;
  380. vertical-align: middle;
  381. &::before,&::after{
  382. content: '';
  383. display: inline-block;
  384. width: 100rpx;
  385. height: 4rpx;
  386. background-color:rgb(204, 204, 204);
  387. vertical-align: middle;
  388. margin: 0 20rpx;
  389. }
  390. }
  391. .table-box{
  392. margin: 20rpx 0;
  393. &::-webkit-scrollbar{
  394. width: 0;
  395. }
  396. overflow: auto hidden;
  397. .table-row{
  398. display: flex;
  399. width: 100%;
  400. }
  401. .table-item{
  402. padding: 10rpx;
  403. min-width: 200rpx;
  404. max-width: 280rpx;
  405. display: flex;
  406. align-items: center;
  407. justify-content: center;
  408. }
  409. .table-head{
  410. color: #fff;
  411. background-color: rgb(58, 76, 115);
  412. .table-item{
  413. &:first-child{
  414. position: sticky;
  415. left: 0;
  416. z-index: 5;
  417. border-right-color: rgb(58, 76, 115);
  418. }
  419. background-color: rgb(58, 76, 115);
  420. }
  421. }
  422. .table-body{
  423. .table-item{
  424. background-color: #fff;
  425. &:first-child{
  426. position: sticky;
  427. left: 0;
  428. z-index: 5;
  429. }
  430. }
  431. .grey{
  432. background-color: #ddd;
  433. }
  434. .minus{
  435. color: #006600;
  436. }
  437. }
  438. }
  439. }
  440. }
  441. </style>