fashion.vue 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. <template>
  2. <CommonListPage
  3. :title="'闽南时尚'"
  4. :dropDownNames="[]"
  5. :showSearch="true"
  6. :pageSize="8"
  7. :load="loadData"
  8. :loadDetail="loadDetail"
  9. :tagsData="tagsData"
  10. :defaultSelectTag="tagsData[0].id"
  11. />
  12. </template>
  13. <script setup lang="ts">
  14. import { ref } from 'vue';
  15. import { GetContentListParams } from '@/api/CommonContent';
  16. import CustomContent from '@/api/introduction/CustomContent';
  17. let _selectedTag = 0;
  18. async function loadDetail(id: number, item: any) {
  19. return await CustomContent.getContentDetail(
  20. id,
  21. tagsData.value.find((item) => item.id == _selectedTag)?.modelId || 0
  22. );
  23. }
  24. async function loadData(
  25. page: number,
  26. pageSize: number,
  27. selectedTag: number,
  28. searchText: string,
  29. dropDownValues: number[],
  30. ) {
  31. _selectedTag = selectedTag;
  32. const res = await CustomContent.getContentList(new GetContentListParams()
  33. .setModelId(tagsData.value.find((item) => item.id == selectedTag)?.modelId || 0)
  34. .setMainBodyColumnId(selectedTag < 0 ?
  35. tagsData.value.find((item) => item.id == selectedTag)?.mainBodyColumnId || 0
  36. : selectedTag)
  37. .setKeywords(searchText)
  38. , page, pageSize);
  39. return {
  40. page: page,
  41. total: res.total,
  42. data: res.list.map((item, index) => {
  43. return {
  44. id: item.id,
  45. title: item.title,
  46. desc: item.desc,
  47. image: item.thumbnail || item.image,
  48. addItems: [],
  49. };
  50. }),
  51. }
  52. }
  53. //子分类
  54. const tagsData = ref([
  55. { modelId: 16, id: 291, name: '闽南时尚' },
  56. { modelId: 16, id: 191, name: '闽南语经典歌曲' },
  57. { modelId: 16, id: 190, name: '南音' },
  58. { modelId: 16, id: 189, name: '闽南童谣' },
  59. { modelId: 5, mainBodyColumnId: [ 257,235,237,210 ], id: -100, name: '常用闽南语' },
  60. { modelId: 5, mainBodyColumnId: 313, id: -101, name: '闽南语原声' },
  61. ]);
  62. </script>
  63. <style>
  64. </style>