introduction.vue 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. <template>
  2. <view class="home-container page-home-introduction d-flex flex-col bg-base" style="min-height:100vh">
  3. <StatusBarSpace />
  4. <NavBar leftButton="back" :iconProps="{ color: 'white' }" :innerStyle="{ zIndex: 1000 }" backgroundColor="transparent" />
  5. <image
  6. class="w-100 position-absolute"
  7. src="https://mncdn.wenlvti.net/app_static/minnan/images/home/BackgroundBanner2.jpg"
  8. mode="widthFix"
  9. />
  10. <view class="content d-flex flex-col wing-l">
  11. <!-- 标题 -->
  12. <view class="font-songti color-title-text d-flex flex-col align-center justify-center p-3">
  13. <text class="size-lll">闽南文化生态保护区<text class="size-ll">(厦门市)</text></text>
  14. <text class="size-base mt-2">世界闽南文化交流中心</text>
  15. </view>
  16. <!-- 分栏 -->
  17. <view class="shadow-l radius-l bg-base p-3">
  18. <SimplePageContentLoader :loader="introdData">
  19. <Parse :content="introdData.content.value" :tag-style="commonParserStyle" />
  20. </SimplePageContentLoader>
  21. <!--保护区建设历程-->
  22. <view
  23. class="mt-4 d-flex flex-row justify-center align-center p-25 radius-base border-all-primary color-primary"
  24. @click="navTo('./history')"
  25. >
  26. <text class="iconfont icon-task-history-4 size-lll mr-2"></text>
  27. <text>保护区建设历程</text>
  28. </view>
  29. </view>
  30. <view class="d-flex flex-col mt-3">
  31. <view
  32. v-for="item in listLoader.list.value"
  33. :key="item.id"
  34. >
  35. <Box2LineImageRightShadow
  36. classNames="ml-2 mb-3"
  37. titleColor="title-text"
  38. :image="item.image"
  39. :title="item.title"
  40. :desc="item.desc"
  41. @click="goDetail(item.id)"
  42. />
  43. </view>
  44. </view>
  45. <SimplePageListLoader :loader="listLoader" />
  46. </view>
  47. </view>
  48. <tabbar :current="0"></tabbar>
  49. </template>
  50. <script setup lang="ts">
  51. import { useSimpleDataLoader } from '@/common/composeabe/SimpleDataLoader';
  52. import CommonContent, { GetColumListParams, GetContentListParams } from '@/api/CommonContent';
  53. import SimplePageListLoader from '@/common/components/SimplePageListLoader.vue';
  54. import Box2LineImageRightShadow from '@/pages/parts/Box2LineImageRightShadow.vue';
  55. import NewsIndexContent from '@/api/news/NewsIndexContent';
  56. import Tabbar from '@/common/components/tabs/tabbar.vue';
  57. import commonParserStyle from '@/common/style/commonParserStyle';
  58. import SimplePageContentLoader from '@/common/components/SimplePageContentLoader.vue';
  59. import { useSimplePageListLoader } from '@/common/composeabe/SimplePageListLoader';
  60. import { DataDateUtils } from '@imengyu/js-request-transform';
  61. import { navTo } from '@/components/utils/PageAction';
  62. import { onMounted } from 'vue';
  63. import Parse from '@/components/display/parse/Parse.vue';
  64. import NavBar from '@/components/nav/NavBar.vue';
  65. import StatusBarSpace from '@/components/layout/space/StatusBarSpace.vue';
  66. const introdData = useSimpleDataLoader(async () => {
  67. return (await NewsIndexContent.getColumList(new GetColumListParams()
  68. .setModelId(17)
  69. .setMainBodyColumnId(234)
  70. )).list[0]?.overview || '无内容!请添加内容!!';
  71. }, true);
  72. const listLoader = useSimplePageListLoader<{
  73. id: number,
  74. image: string,
  75. title: string,
  76. desc: string,
  77. date: string,
  78. }, {
  79. modelId: number|undefined,
  80. mainBodyColumnId: number|undefined,
  81. }>(8, async (page, pageSize, params) => {
  82. const res = await CommonContent.getContentList(new GetContentListParams().setSelfValues({
  83. modelId: 17,
  84. mainBodyColumnId: '255,256,283,284',
  85. }), page, pageSize);
  86. return { list: res.list.map((item) => {
  87. return {
  88. id: item.id,
  89. image: item.thumbnail || item.image,
  90. title: item.title,
  91. desc: '重点保护区域',
  92. date: DataDateUtils.formatDate(item.publishAt, 'YYYY-MM-dd'),
  93. }
  94. }), total: res.total }
  95. });
  96. function goDetail(id: number) {
  97. navTo('/pages/article/details', { id });
  98. }
  99. onMounted(() => {
  100. listLoader.loadData();
  101. })
  102. </script>
  103. <style lang="scss">
  104. .page-home-introduction {
  105. .content {
  106. margin-top: 15vh;
  107. }
  108. }
  109. </style>