Index.vue 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. <template>
  2. <app-view class="home-main">
  3. <template #header>
  4. <app-navbar :title="globalStore.appName" :show-back-button="false" />
  5. </template>
  6. <Banner :data-list="topBanners" />
  7. <PullRefresh class="home-main__container" v-model="refreshing" @refresh="onRefresh">
  8. <app-block>
  9. <Cell title="通知公告" value="更多" :to="{ name: 'notice-list' }" icon="volume" is-link />
  10. </app-block>
  11. <app-block class="home-main__iconbar bg">
  12. <ul>
  13. <li @click="routerTo('presale-list')">
  14. <Iconfont label-direction="bottom" icon="icon-yushoujingpai">预售竞拍</Iconfont>
  15. </li>
  16. <li @click="routerTo('forward-list')">
  17. <Iconfont label-direction="bottom" icon="icon-dingjinzhuanrang">中远期挂牌</Iconfont>
  18. </li>
  19. <!-- <li @click="switchTab(1)">
  20. <Iconfont label-direction="bottom" icon="icon-zhongqian">预售中签</Iconfont>
  21. </li> -->
  22. <!-- <li @click="switchTab(2)">
  23. <Iconfont label-direction="bottom" icon="icon-dingjinzhuanrang">定金转让</Iconfont>
  24. </li> -->
  25. <li @click="routerTo('swap-list')">
  26. <Iconfont label-direction="bottom" icon="icon-diaoqimaoyi">掉期贸易</Iconfont>
  27. </li>
  28. </ul>
  29. <ul>
  30. <!-- <li @click="switchTab(3)">
  31. <Iconfont label-direction="bottom" icon="icon-a-zu771">订单挂牌</Iconfont>
  32. </li> -->
  33. <li @click="routerTo('pricing-list')">
  34. <Iconfont label-direction="bottom" icon="icon-guapaidianjia">挂牌点价</Iconfont>
  35. </li>
  36. <li @click="routerTo('spot-list')">
  37. <Iconfont label-direction="bottom" icon="icon-xianhuomaoyi">现货贸易</Iconfont>
  38. </li>
  39. <li @click="routerTo('market-list')">
  40. <Iconfont label-direction="bottom" icon="icon-cankaohangqing">参考行情</Iconfont>
  41. </li>
  42. </ul>
  43. </app-block>
  44. <app-block class="home-main__news">
  45. <CellGroup class="article">
  46. <Cell class="home-main__titlebar" value="更多" :to="{ name: 'news-list' }" is-link>
  47. <template #title>
  48. <img src="../../../assets/icons/fire.png" />
  49. <span>市场资讯</span>
  50. </template>
  51. </Cell>
  52. <template v-for="(item, index) in newsList" :key="index">
  53. <Cell class="article-item" :title="item.title" :value="formatDate(item.publishdate, 'MM/DD')"
  54. :to="{ name: 'news-detail', query: { id: item.id } }" />
  55. </template>
  56. </CellGroup>
  57. </app-block>
  58. </PullRefresh>
  59. </app-view>
  60. </template>
  61. <script lang="ts" setup>
  62. import { shallowRef } from "vue";
  63. import { Cell, CellGroup, PullRefresh } from "vant";
  64. import { formatDate } from "@/filters";
  65. import { useNavigation } from '../../../router/navigation';
  66. import { queryImageConfigs } from "@/services/api/common";
  67. import { queryNewTitles } from "@/services/api/news";
  68. import { useLoginStore, useGlobalStore } from '@/stores'
  69. import Banner from '../../../components/base/banner/index.vue'
  70. import Iconfont from '../../../components/base/iconfont/index.vue'
  71. const globalStore = useGlobalStore()
  72. const loginStore = useLoginStore();
  73. const { routerTo, setGlobalUrlParams } = useNavigation();
  74. const refreshing = shallowRef(false); // 是否处于加载中状态
  75. const topBanners = shallowRef<string[]>([]); // 轮播图列表
  76. const newsList = shallowRef<Model.NewTitlesRsp[]>([]); // 资讯列表
  77. // 跳转导航页面
  78. const switchTab = (tabIndex: number) => {
  79. if (loginStore.token) {
  80. setGlobalUrlParams({ tabIndex })
  81. switch (tabIndex) {
  82. case 1:
  83. routerTo('home-ballot', true)
  84. break
  85. case 2:
  86. routerTo('home-transfer', true)
  87. break
  88. case 3:
  89. routerTo('home-goods', true)
  90. break
  91. }
  92. } else {
  93. routerTo('user-login')
  94. }
  95. }
  96. // 下拉刷新
  97. const onRefresh = () => {
  98. if (!topBanners.value.length) {
  99. queryImageConfigs({
  100. data: {
  101. imageType: 1,
  102. }
  103. }).then((res) => {
  104. topBanners.value = res.data.map((e) => e.imagepath)
  105. })
  106. }
  107. // 市场资讯
  108. queryNewTitles({
  109. data: {
  110. page: 1,
  111. pagesize: 10,
  112. }
  113. }).then((res) => {
  114. newsList.value = res.data
  115. }).finally(() => {
  116. refreshing.value = false
  117. })
  118. }
  119. onRefresh()
  120. </script>
  121. <style lang="less">
  122. @import "./index.less";
  123. </style>