activity.vue 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. <template>
  2. <!-- 文化传承 - 非遗活动 -->
  3. <CommonListPage
  4. :title="'非遗活动'"
  5. :dropDownNames="[]"
  6. :showSearch="true"
  7. :pageSize="8"
  8. :load="loadData"
  9. :loadDetail="loadDetail"
  10. :tagsData="tagsData"
  11. :defaultSelectTag="tagsData[0].id"
  12. />
  13. </template>
  14. <script setup lang="ts">
  15. import { ref } from 'vue';
  16. import { GetContentListParams } from '@/api/CommonContent';
  17. import CustomContent from '@/api/introduction/CustomContent';
  18. let _selectedTag = 0;
  19. async function loadDetail(id: number, item: any) {
  20. return await CustomContent.getContentDetail(
  21. id,
  22. tagsData.value.find((item) => item.id == _selectedTag)?.modelId || 0
  23. );
  24. }
  25. async function loadData(
  26. page: number,
  27. pageSize: number,
  28. selectedTag: number,
  29. searchText: string,
  30. dropDownValues: number[],
  31. ) {
  32. _selectedTag = selectedTag;
  33. const res = await CustomContent.getContentList(new GetContentListParams()
  34. .setModelId(tagsData.value.find((item) => item.id == selectedTag)?.modelId || 0)
  35. .setMainBodyColumnId(selectedTag > 0 ? selectedTag : 0)
  36. .setKeywords(searchText)
  37. , page, pageSize);
  38. return {
  39. page: page,
  40. total: res.total,
  41. data: res.list.map((item, index) => {
  42. return {
  43. id: item.id,
  44. title: item.title,
  45. desc: item.desc,
  46. image: item.image,
  47. addItems: [],
  48. };
  49. }),
  50. }
  51. }
  52. //子分类
  53. const tagsData = ref([
  54. { modelId: 18, id: 290, name: '全部' },
  55. { modelId: 16, id: 187, name: '讲古' },
  56. { modelId: 5, id: -1, name: '方言' },
  57. { modelId: 4, id: -2, name: '民俗习俗' },
  58. ]);
  59. </script>
  60. <style>
  61. </style>