content.vue 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. <template>
  2. <div class="main-background main-background main-background-type2">
  3. <div class="nav-placeholder"></div>
  4. <section class="main-section">
  5. <div class="content">
  6. <SimplePageContentLoader :loader="newsLoader">
  7. <div class="d-flex flex-column details">
  8. <div class="nav-back-title">
  9. <img :src="BackArrow" @click="back" />
  10. <h2>{{ newsLoader.content.value?.title }}</h2>
  11. </div>
  12. <SimpleRichHtml
  13. class="news-content mt-3"
  14. :contents="[
  15. newsLoader.content.value?.intro ?? '',
  16. newsLoader.content.value?.value ?? '',
  17. newsLoader.content.value?.content ?? '',
  18. ]"
  19. />
  20. <ContentNode />
  21. </div>
  22. </SimplePageContentLoader>
  23. </div>
  24. </section>
  25. </div>
  26. </template>
  27. <script setup lang="ts">
  28. import { watch } from 'vue';
  29. import { useRoute, useRouter } from 'vue-router';
  30. import { useSimpleDataLoader } from '@/composeable/SimpleDataLoader';
  31. import { useLoadQuerys } from '@/composeable/PageQuerys';
  32. import BackArrow from '@/assets/images/BackArrow.png';
  33. import CommonContent, { GetContentDetailItem } from '@/api/CommonContent';
  34. import SimplePageContentLoader from '@/components/content/SimplePageContentLoader.vue';
  35. import SimpleRichHtml from '@/components/display/SimpleRichHtml.vue';
  36. import ContentNode from '@/components/content/ContentNode.vue';
  37. const router = useRouter();
  38. const route = useRoute();
  39. function back() {
  40. router.back();
  41. }
  42. watch(() => route.query.id, (newVal) => {
  43. newsLoader.loadData(undefined);
  44. });
  45. const newsLoader = useSimpleDataLoader<GetContentDetailItem, { id: number, modelId: number }>(async (p) => {
  46. if (!p)
  47. throw new Error('参数错误');
  48. return (await CommonContent.getContentDetail<GetContentDetailItem>(p.id, p.modelId ? p.modelId : undefined));
  49. }, false)
  50. useLoadQuerys({
  51. id: 0,
  52. modelId: 0,
  53. }, async (p) => {
  54. if (p.id <= 0) {
  55. router.push({ path: '404' });
  56. return;
  57. }
  58. newsLoader.loadData(p);
  59. })
  60. </script>
  61. <style>
  62. </style>